[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index] [Xen-devel] [PATCH 3/5] libxl/PCI: make "rdm=" parsing comply with documentation
Documentation says "<RDM_RESERVATION_STRING> is a comma separated list of <KEY=VALUE> settings, from the following list". There's no mention of a specific order, yet so far the parsing logic did accept only strategy, then policy (and neither of the two omitted). Make "state" move - back to STATE_TYPE when finding a comma after having parsed the <VALUE> part of a setting, - to STATE_TERMINAL otherwise. Signed-off-by: Jan Beulich <jbeulich@xxxxxxxx> --- a/tools/libxl/libxlu_pci.c +++ b/tools/libxl/libxlu_pci.c @@ -194,9 +194,12 @@ int xlu_rdm_parse(XLU_Config *cfg, libxl switch(state) { case STATE_TYPE: if (*ptr == '=') { - state = STATE_RDM_STRATEGY; *ptr = '\0'; - if (strcmp(tok, "strategy")) { + if (!strcmp(tok, "strategy")) { + state = STATE_RDM_STRATEGY; + } else if (!strcmp(tok, "policy")) { + state = STATE_RESERVE_POLICY; + } else { XLU__PCI_ERR(cfg, "Unknown RDM state option: %s", tok); goto parse_error; } @@ -205,7 +208,7 @@ int xlu_rdm_parse(XLU_Config *cfg, libxl break; case STATE_RDM_STRATEGY: if (*ptr == '\0' || *ptr == ',') { - state = STATE_RESERVE_POLICY; + state = *ptr == ',' ? STATE_TYPE : STATE_TERMINAL; *ptr = '\0'; if (!strcmp(tok, "host")) { rdm->strategy = LIBXL_RDM_RESERVE_STRATEGY_HOST; @@ -217,19 +220,8 @@ int xlu_rdm_parse(XLU_Config *cfg, libxl } break; case STATE_RESERVE_POLICY: - if (*ptr == '=') { - state = STATE_OPTIONS_V; - *ptr = '\0'; - if (strcmp(tok, "policy")) { - XLU__PCI_ERR(cfg, "Unknown RDM property value: %s", tok); - goto parse_error; - } - tok = ptr + 1; - } - break; - case STATE_OPTIONS_V: if (*ptr == ',' || *ptr == '\0') { - state = STATE_TERMINAL; + state = *ptr == ',' ? STATE_TYPE : STATE_TERMINAL; *ptr = '\0'; if (!strcmp(tok, "strict")) { rdm->policy = LIBXL_RDM_RESERVE_POLICY_STRICT; _______________________________________________ Xen-devel mailing list Xen-devel@xxxxxxxxxxxxxxxxxxxx https://lists.xenproject.org/mailman/listinfo/xen-devel
|
Lists.xenproject.org is hosted with RackSpace, monitoring our |