xenFormatNet: correct `type=netfront' to 'type=vif' to match libxl

According to current xl.cfg docs and xl codes, it uses type=vif
instead of type=netfront.

Currently after domxml-to-native, libvirt xml model=netfront will be
converted to xl type=netfront. This has no problem before, xen codes
for a long time just check type=ioemu, if not, set type to _VIF.

Since libxl uses parse_nic_config to avoid duplicate codes, it
compares 'type=vif' and 'type=ioemu' for valid parameters, others
are considered as invalid, thus we have problem with type=netfront
in xl config file.
 #xl create sles12gm-hvm.orig
 Parsing config from sles12gm-hvm.orig
 Invalid parameter `type'.

Correct the conversion in libvirt, so that it matchs libxl codes
and also xl.cfg.

Signed-off-by: Chunyan Liu <cyliu@suse.com>
This commit is contained in:
Chunyan Liu 2016-05-17 17:34:45 +08:00 committed by Jim Fehlig
parent f1066d0d46
commit 03f8bba26e
4 changed files with 40 additions and 16 deletions

View File

@ -807,7 +807,7 @@ xenParseCharDev(virConfPtr conf, virDomainDefPtr def)
static int static int
xenParseVif(virConfPtr conf, virDomainDefPtr def) xenParseVif(virConfPtr conf, virDomainDefPtr def, const char *vif_typename)
{ {
char *script = NULL; char *script = NULL;
virDomainNetDefPtr net = NULL; virDomainNetDefPtr net = NULL;
@ -946,7 +946,7 @@ xenParseVif(virConfPtr conf, virDomainDefPtr def)
VIR_STRDUP(net->model, model) < 0) VIR_STRDUP(net->model, model) < 0)
goto cleanup; goto cleanup;
if (!model[0] && type[0] && STREQ(type, "netfront") && if (!model[0] && type[0] && STREQ(type, vif_typename) &&
VIR_STRDUP(net->model, "netfront") < 0) VIR_STRDUP(net->model, "netfront") < 0)
goto cleanup; goto cleanup;
@ -1050,7 +1050,8 @@ xenParseGeneralMeta(virConfPtr conf, virDomainDefPtr def, virCapsPtr caps)
int int
xenParseConfigCommon(virConfPtr conf, xenParseConfigCommon(virConfPtr conf,
virDomainDefPtr def, virDomainDefPtr def,
virCapsPtr caps) virCapsPtr caps,
const char *nativeFormat)
{ {
if (xenParseGeneralMeta(conf, def, caps) < 0) if (xenParseGeneralMeta(conf, def, caps) < 0)
return -1; return -1;
@ -1070,8 +1071,17 @@ xenParseConfigCommon(virConfPtr conf,
if (xenConfigCopyStringOpt(conf, "device_model", &def->emulator) < 0) if (xenConfigCopyStringOpt(conf, "device_model", &def->emulator) < 0)
return -1; return -1;
if (xenParseVif(conf, def) < 0) if (STREQ(nativeFormat, XEN_CONFIG_FORMAT_XL)) {
if (xenParseVif(conf, def, "vif") < 0)
return -1; return -1;
} else if (STREQ(nativeFormat, XEN_CONFIG_FORMAT_XM)) {
if (xenParseVif(conf, def, "netfront") < 0)
return -1;
} else {
virReportError(VIR_ERR_INVALID_ARG,
_("unsupported config type %s"), nativeFormat);
return -1;
}
if (xenParsePCI(conf, def) < 0) if (xenParsePCI(conf, def) < 0)
return -1; return -1;
@ -1131,7 +1141,8 @@ static int
xenFormatNet(virConnectPtr conn, xenFormatNet(virConnectPtr conn,
virConfValuePtr list, virConfValuePtr list,
virDomainNetDefPtr net, virDomainNetDefPtr net,
int hvm) int hvm,
const char *vif_typename)
{ {
virBuffer buf = VIR_BUFFER_INITIALIZER; virBuffer buf = VIR_BUFFER_INITIALIZER;
virConfValuePtr val, tmp; virConfValuePtr val, tmp;
@ -1203,7 +1214,7 @@ xenFormatNet(virConnectPtr conn,
virBufferAsprintf(&buf, ",model=%s", net->model); virBufferAsprintf(&buf, ",model=%s", net->model);
} else { } else {
if (net->model != NULL && STREQ(net->model, "netfront")) { if (net->model != NULL && STREQ(net->model, "netfront")) {
virBufferAddLit(&buf, ",type=netfront"); virBufferAsprintf(&buf, ",type=%s", vif_typename);
} else { } else {
if (net->model != NULL) if (net->model != NULL)
virBufferAsprintf(&buf, ",model=%s", net->model); virBufferAsprintf(&buf, ",model=%s", net->model);
@ -1753,7 +1764,8 @@ xenFormatSound(virConfPtr conf, virDomainDefPtr def)
static int static int
xenFormatVif(virConfPtr conf, xenFormatVif(virConfPtr conf,
virConnectPtr conn, virConnectPtr conn,
virDomainDefPtr def) virDomainDefPtr def,
const char *vif_typename)
{ {
virConfValuePtr netVal = NULL; virConfValuePtr netVal = NULL;
size_t i; size_t i;
@ -1766,7 +1778,7 @@ xenFormatVif(virConfPtr conf,
for (i = 0; i < def->nnets; i++) { for (i = 0; i < def->nnets; i++) {
if (xenFormatNet(conn, netVal, def->nets[i], if (xenFormatNet(conn, netVal, def->nets[i],
hvm) < 0) hvm, vif_typename) < 0)
goto cleanup; goto cleanup;
} }
@ -1792,7 +1804,8 @@ xenFormatVif(virConfPtr conf,
int int
xenFormatConfigCommon(virConfPtr conf, xenFormatConfigCommon(virConfPtr conf,
virDomainDefPtr def, virDomainDefPtr def,
virConnectPtr conn) virConnectPtr conn,
const char *nativeFormat)
{ {
if (xenFormatGeneralMeta(conf, def) < 0) if (xenFormatGeneralMeta(conf, def) < 0)
return -1; return -1;
@ -1818,8 +1831,17 @@ xenFormatConfigCommon(virConfPtr conf,
if (xenFormatVfb(conf, def) < 0) if (xenFormatVfb(conf, def) < 0)
return -1; return -1;
if (xenFormatVif(conf, conn, def) < 0) if (STREQ(nativeFormat, XEN_CONFIG_FORMAT_XL)) {
if (xenFormatVif(conf, conn, def, "vif") < 0)
return -1; return -1;
} else if (STREQ(nativeFormat, XEN_CONFIG_FORMAT_XM)) {
if (xenFormatVif(conf, conn, def, "netfront") < 0)
return -1;
} else {
virReportError(VIR_ERR_INVALID_ARG,
_("unsupported config type %s"), nativeFormat);
return -1;
}
if (xenFormatPCI(conf, def) < 0) if (xenFormatPCI(conf, def) < 0)
return -1; return -1;

View File

@ -58,11 +58,13 @@ int xenConfigCopyStringOpt(virConfPtr conf,
int xenParseConfigCommon(virConfPtr conf, int xenParseConfigCommon(virConfPtr conf,
virDomainDefPtr def, virDomainDefPtr def,
virCapsPtr caps); virCapsPtr caps,
const char *nativeFormat);
int xenFormatConfigCommon(virConfPtr conf, int xenFormatConfigCommon(virConfPtr conf,
virDomainDefPtr def, virDomainDefPtr def,
virConnectPtr conn); virConnectPtr conn,
const char *nativeFormat);
int xenDomainDefAddImplicitInputDevice(virDomainDefPtr def); int xenDomainDefAddImplicitInputDevice(virDomainDefPtr def);

View File

@ -498,7 +498,7 @@ xenParseXL(virConfPtr conf,
def->virtType = VIR_DOMAIN_VIRT_XEN; def->virtType = VIR_DOMAIN_VIRT_XEN;
def->id = -1; def->id = -1;
if (xenParseConfigCommon(conf, def, caps) < 0) if (xenParseConfigCommon(conf, def, caps, XEN_CONFIG_FORMAT_XL) < 0)
goto cleanup; goto cleanup;
if (xenParseXLOS(conf, def, caps) < 0) if (xenParseXLOS(conf, def, caps) < 0)
@ -993,7 +993,7 @@ xenFormatXL(virDomainDefPtr def, virConnectPtr conn)
if (!(conf = virConfNew())) if (!(conf = virConfNew()))
goto cleanup; goto cleanup;
if (xenFormatConfigCommon(conf, def, conn) < 0) if (xenFormatConfigCommon(conf, def, conn, XEN_CONFIG_FORMAT_XL) < 0)
goto cleanup; goto cleanup;
if (xenFormatXLOS(conf, def) < 0) if (xenFormatXLOS(conf, def) < 0)

View File

@ -443,7 +443,7 @@ xenParseXM(virConfPtr conf,
def->virtType = VIR_DOMAIN_VIRT_XEN; def->virtType = VIR_DOMAIN_VIRT_XEN;
def->id = -1; def->id = -1;
if (xenParseConfigCommon(conf, def, caps) < 0) if (xenParseConfigCommon(conf, def, caps, XEN_CONFIG_FORMAT_XM) < 0)
goto cleanup; goto cleanup;
if (xenParseXMOS(conf, def) < 0) if (xenParseXMOS(conf, def) < 0)
@ -586,7 +586,7 @@ xenFormatXM(virConnectPtr conn,
if (!(conf = virConfNew())) if (!(conf = virConfNew()))
goto cleanup; goto cleanup;
if (xenFormatConfigCommon(conf, def, conn) < 0) if (xenFormatConfigCommon(conf, def, conn, XEN_CONFIG_FORMAT_XM) < 0)
goto cleanup; goto cleanup;
if (xenFormatXMOS(conf, def) < 0) if (xenFormatXMOS(conf, def) < 0)