qemu: Partially convert to net model enum

This converts the qemu driver to the net model enum, for all
the model values that we have hardcoded for various checks,
which adds e1000e, virtio-transitional, virtio-non-transitional,
usb-net, spapr-vlan, lan9118, smc91c111

Because the qemu driver has historically also allowed the raw
model string onto the qemu command line, this isn't a full
conversion. Unwinding that will require more thought. However
for all new driver code we should be adding explicit enum
values for any model name we have special handling for.

Remove the now unused virDomainNetStreqModelString

Acked-by: Michal Privoznik <mprivozn@redhat.com>
Signed-off-by: Cole Robinson <crobinso@redhat.com>
This commit is contained in:
Cole Robinson 2019-01-18 09:59:02 -05:00
parent c0cf17c280
commit 41b002f934
6 changed files with 38 additions and 41 deletions

View File

@ -513,6 +513,13 @@ VIR_ENUM_IMPL(virDomainNetModel,
"rtl8139", "rtl8139",
"virtio", "virtio",
"e1000", "e1000",
"e1000e",
"virtio-transitional",
"virtio-non-transitional",
"usb-net",
"spapr-vlan",
"lan9118",
"scm91c111",
); );
VIR_ENUM_IMPL(virDomainNetBackend, VIR_ENUM_IMPL(virDomainNetBackend,
@ -29515,15 +29522,6 @@ virDomainNetSetModelString(virDomainNetDefPtr net,
return 0; return 0;
} }
int
virDomainNetStreqModelString(const virDomainNetDef *net,
const char *model)
{
if (net->model)
return net->model == virDomainNetModelTypeFromString(model);
return STREQ_NULLABLE(net->modelstr, model);
}
int int
virDomainNetStrcaseeqModelString(const virDomainNetDef *net, virDomainNetStrcaseeqModelString(const virDomainNetDef *net,
const char *model) const char *model)
@ -29536,9 +29534,9 @@ virDomainNetStrcaseeqModelString(const virDomainNetDef *net,
bool bool
virDomainNetIsVirtioModel(const virDomainNetDef *net) virDomainNetIsVirtioModel(const virDomainNetDef *net)
{ {
return (virDomainNetStreqModelString(net, "virtio") || return (net->model == VIR_DOMAIN_NET_MODEL_VIRTIO ||
virDomainNetStreqModelString(net, "virtio-transitional") || net->model == VIR_DOMAIN_NET_MODEL_VIRTIO_TRANSITIONAL ||
virDomainNetStreqModelString(net, "virtio-non-transitional")); net->model == VIR_DOMAIN_NET_MODEL_VIRTIO_NON_TRANSITIONAL);
} }

View File

@ -846,6 +846,13 @@ typedef enum {
VIR_DOMAIN_NET_MODEL_RTL8139, VIR_DOMAIN_NET_MODEL_RTL8139,
VIR_DOMAIN_NET_MODEL_VIRTIO, VIR_DOMAIN_NET_MODEL_VIRTIO,
VIR_DOMAIN_NET_MODEL_E1000, VIR_DOMAIN_NET_MODEL_E1000,
VIR_DOMAIN_NET_MODEL_E1000E,
VIR_DOMAIN_NET_MODEL_VIRTIO_TRANSITIONAL,
VIR_DOMAIN_NET_MODEL_VIRTIO_NON_TRANSITIONAL,
VIR_DOMAIN_NET_MODEL_USB_NET,
VIR_DOMAIN_NET_MODEL_SPAPR_VLAN,
VIR_DOMAIN_NET_MODEL_LAN9118,
VIR_DOMAIN_NET_MODEL_SMC91C111,
VIR_DOMAIN_NET_MODEL_LAST VIR_DOMAIN_NET_MODEL_LAST
} virDomainNetModelType; } virDomainNetModelType;
@ -3126,8 +3133,6 @@ bool virDomainNetGetActualTrustGuestRxFilters(virDomainNetDefPtr iface);
const char *virDomainNetGetModelString(const virDomainNetDef *net); const char *virDomainNetGetModelString(const virDomainNetDef *net);
int virDomainNetSetModelString(virDomainNetDefPtr et, int virDomainNetSetModelString(virDomainNetDefPtr et,
const char *model); const char *model);
int virDomainNetStreqModelString(const virDomainNetDef *net,
const char *model);
int virDomainNetStrcaseeqModelString(const virDomainNetDef *net, int virDomainNetStrcaseeqModelString(const virDomainNetDef *net,
const char *model); const char *model);
bool virDomainNetIsVirtioModel(const virDomainNetDef *net); bool virDomainNetIsVirtioModel(const virDomainNetDef *net);

View File

@ -488,7 +488,6 @@ virDomainNetResolveActualType;
virDomainNetSetDeviceImpl; virDomainNetSetDeviceImpl;
virDomainNetSetModelString; virDomainNetSetModelString;
virDomainNetStrcaseeqModelString; virDomainNetStrcaseeqModelString;
virDomainNetStreqModelString;
virDomainNetTypeFromString; virDomainNetTypeFromString;
virDomainNetTypeSharesHostView; virDomainNetTypeSharesHostView;
virDomainNetTypeToString; virDomainNetTypeToString;

View File

@ -489,10 +489,8 @@ qemuBuildVirtioDevStr(virBufferPtr buf,
break; break;
case VIR_DOMAIN_DEVICE_NET: case VIR_DOMAIN_DEVICE_NET:
has_tmodel = virDomainNetStreqModelString(device.data.net, has_tmodel = device.data.net->model == VIR_DOMAIN_NET_MODEL_VIRTIO_TRANSITIONAL;
"virtio-transitional"); has_ntmodel = device.data.net->model == VIR_DOMAIN_NET_MODEL_VIRTIO_NON_TRANSITIONAL;
has_ntmodel = virDomainNetStreqModelString(device.data.net,
"virtio-non-transitional");
break; break;
case VIR_DOMAIN_DEVICE_HOSTDEV: case VIR_DOMAIN_DEVICE_HOSTDEV:

View File

@ -6224,49 +6224,49 @@ qemuDomainDeviceDefValidate(const virDomainDeviceDef *dev,
* is NULL this function may return NULL if the default model depends on the * is NULL this function may return NULL if the default model depends on the
* capabilities. * capabilities.
*/ */
static const char * static int
qemuDomainDefaultNetModel(const virDomainDef *def, qemuDomainDefaultNetModel(const virDomainDef *def,
virQEMUCapsPtr qemuCaps) virQEMUCapsPtr qemuCaps)
{ {
if (ARCH_IS_S390(def->os.arch)) if (ARCH_IS_S390(def->os.arch))
return "virtio"; return VIR_DOMAIN_NET_MODEL_VIRTIO;
if (def->os.arch == VIR_ARCH_ARMV6L || if (def->os.arch == VIR_ARCH_ARMV6L ||
def->os.arch == VIR_ARCH_ARMV7L || def->os.arch == VIR_ARCH_ARMV7L ||
def->os.arch == VIR_ARCH_AARCH64) { def->os.arch == VIR_ARCH_AARCH64) {
if (STREQ(def->os.machine, "versatilepb")) if (STREQ(def->os.machine, "versatilepb"))
return "smc91c111"; return VIR_DOMAIN_NET_MODEL_SMC91C111;
if (qemuDomainIsARMVirt(def)) if (qemuDomainIsARMVirt(def))
return "virtio"; return VIR_DOMAIN_NET_MODEL_VIRTIO;
/* Incomplete. vexpress (and a few others) use this, but not all /* Incomplete. vexpress (and a few others) use this, but not all
* arm boards */ * arm boards */
return "lan9118"; return VIR_DOMAIN_NET_MODEL_LAN9118;
} }
/* virtio is a sensible default for RISC-V virt guests */ /* virtio is a sensible default for RISC-V virt guests */
if (qemuDomainIsRISCVVirt(def)) if (qemuDomainIsRISCVVirt(def))
return "virtio"; return VIR_DOMAIN_NET_MODEL_VIRTIO;
/* In all other cases the model depends on the capabilities. If they were /* In all other cases the model depends on the capabilities. If they were
* not provided don't report any default. */ * not provided don't report any default. */
if (!qemuCaps) if (!qemuCaps)
return NULL; return VIR_DOMAIN_NET_MODEL_UNKNOWN;
/* Try several network devices in turn; each of these devices is /* Try several network devices in turn; each of these devices is
* less likely be supported out-of-the-box by the guest operating * less likely be supported out-of-the-box by the guest operating
* system than the previous one */ * system than the previous one */
if (virQEMUCapsGet(qemuCaps, QEMU_CAPS_DEVICE_RTL8139)) if (virQEMUCapsGet(qemuCaps, QEMU_CAPS_DEVICE_RTL8139))
return "rtl8139"; return VIR_DOMAIN_NET_MODEL_RTL8139;
else if (virQEMUCapsGet(qemuCaps, QEMU_CAPS_DEVICE_E1000)) else if (virQEMUCapsGet(qemuCaps, QEMU_CAPS_DEVICE_E1000))
return "e1000"; return VIR_DOMAIN_NET_MODEL_E1000;
else if (virQEMUCapsGet(qemuCaps, QEMU_CAPS_DEVICE_VIRTIO_NET)) else if (virQEMUCapsGet(qemuCaps, QEMU_CAPS_DEVICE_VIRTIO_NET))
return "virtio"; return VIR_DOMAIN_NET_MODEL_VIRTIO;
/* We've had no luck detecting support for any network device, /* We've had no luck detecting support for any network device,
* but we have to return something: might as well be rtl8139 */ * but we have to return something: might as well be rtl8139 */
return "rtl8139"; return VIR_DOMAIN_NET_MODEL_RTL8139;
} }
@ -6722,11 +6722,8 @@ qemuDomainDeviceNetDefPostParse(virDomainNetDefPtr net,
virQEMUCapsPtr qemuCaps) virQEMUCapsPtr qemuCaps)
{ {
if (net->type != VIR_DOMAIN_NET_TYPE_HOSTDEV && if (net->type != VIR_DOMAIN_NET_TYPE_HOSTDEV &&
!virDomainNetGetModelString(net)) { !virDomainNetGetModelString(net))
if (virDomainNetSetModelString(net, net->model = qemuDomainDefaultNetModel(def, qemuCaps);
qemuDomainDefaultNetModel(def, qemuCaps)) < 0)
return -1;
}
return 0; return 0;
} }

View File

@ -230,7 +230,7 @@ qemuDomainAssignSpaprVIOAddresses(virDomainDefPtr def)
for (i = 0; i < def->nnets; i++) { for (i = 0; i < def->nnets; i++) {
virDomainNetDefPtr net = def->nets[i]; virDomainNetDefPtr net = def->nets[i];
if (virDomainNetStreqModelString(net, "spapr-vlan")) if (net->model == VIR_DOMAIN_NET_MODEL_SPAPR_VLAN)
net->info.type = VIR_DOMAIN_DEVICE_ADDRESS_TYPE_SPAPRVIO; net->info.type = VIR_DOMAIN_DEVICE_ADDRESS_TYPE_SPAPRVIO;
if (qemuDomainAssignSpaprVIOAddress(def, &net->info, VIO_ADDR_NET) < 0) if (qemuDomainAssignSpaprVIOAddress(def, &net->info, VIO_ADDR_NET) < 0)
@ -699,18 +699,18 @@ qemuDomainDeviceCalculatePCIConnectFlags(virDomainDeviceDefPtr dev,
* addresses for other hostdev devices. * addresses for other hostdev devices.
*/ */
if (net->type == VIR_DOMAIN_NET_TYPE_HOSTDEV || if (net->type == VIR_DOMAIN_NET_TYPE_HOSTDEV ||
virDomainNetStreqModelString(net, "usb-net")) { net->model == VIR_DOMAIN_NET_MODEL_USB_NET) {
return 0; return 0;
} }
if (virDomainNetStreqModelString(net, "virtio") || if (net->model == VIR_DOMAIN_NET_MODEL_VIRTIO ||
virDomainNetStreqModelString(net, "virtio-non-transitional")) net->model == VIR_DOMAIN_NET_MODEL_VIRTIO_NON_TRANSITIONAL)
return virtioFlags; return virtioFlags;
if (virDomainNetStreqModelString(net, "virtio-transitional")) if (net->model == VIR_DOMAIN_NET_MODEL_VIRTIO_TRANSITIONAL)
return pciFlags; return pciFlags;
if (virDomainNetStreqModelString(net, "e1000e")) if (net->model == VIR_DOMAIN_NET_MODEL_E1000E)
return pcieFlags; return pcieFlags;
return pciFlags; return pciFlags;