[libvirt] [PATCH 11/16] qemu: Implement the device parse callback and use it for interfaces

Laine Stump laine at laine.org
Fri Mar 1 19:25:05 UTC 2013


On 03/01/2013 02:13 PM, Laine Stump wrote:
> On 02/20/2013 12:06 PM, Peter Krempa wrote:
>> This patch implements the callback that is used to fill the qemu default
>> network card into the XML if none is provided in the definition.
>> ---
>>  src/qemu/qemu_conf.c   |  1 +
>>  src/qemu/qemu_domain.c | 23 +++++++++++++++++++++++
>>  src/qemu/qemu_domain.h |  1 +
>>  3 files changed, 25 insertions(+)
>>
>> diff --git a/src/qemu/qemu_conf.c b/src/qemu/qemu_conf.c
>> index a2a05d4..cc6a738 100644
>> --- a/src/qemu/qemu_conf.c
>> +++ b/src/qemu/qemu_conf.c
>> @@ -556,6 +556,7 @@ virCapsPtr virQEMUDriverCreateCapabilities(virQEMUDriverPtr driver)
>>
>>      qemuDomainSetPrivateDataHooks(caps);
>>      qemuDomainSetNamespaceHooks(caps);
>> +    qemuDomainSetDefHooks(caps);
>>
>>      if (virGetHostUUID(caps->host.host_uuid)) {
>>          virReportError(VIR_ERR_INTERNAL_ERROR,
>> diff --git a/src/qemu/qemu_domain.c b/src/qemu/qemu_domain.c
>> index 482f64a..7c8768b 100644
>> --- a/src/qemu/qemu_domain.c
>> +++ b/src/qemu/qemu_domain.c
>> @@ -633,6 +633,24 @@ qemuDomainDefNamespaceFormatXML(virBufferPtr buf,
>>      return 0;
>>  }
>>
>> +
>> +static int
>> +qemuDomainDeviceDefCallback(void *device)
>> +{
>> +    virDomainDeviceDefPtr dev = device;
>> +
>> +    if (dev->type == VIR_DOMAIN_DEVICE_NET) {
>> +        if (!dev->data.net->model) {
>> +            if (!(dev->data.net->model = strdup("rtl8139"))) {
>> +                virReportOOMError();
>> +                return -1;

Also, if the net->type is hostdev, then model should not be set at all
(although it is harmlessly ignored, it could be confusing).

>> +            }
>> +        }
>> +    }
>> +    return 0;
>> +}
> This is a good example of why the domain pointer and caps pointer are
> needed in the callback. The default netdev model cuold very well change
> depending on which hypervisor is used, the version/capabilities of the
> hypervisor, and the machinetype.
>
>> +
>> +
>>  static const char *
>>  qemuDomainDefNamespaceHref(void)
>>  {
>> @@ -659,6 +677,11 @@ void qemuDomainSetNamespaceHooks(virCapsPtr caps)
>>      caps->ns.href = qemuDomainDefNamespaceHref;
>>  }
>>
>> +void qemuDomainSetDefHooks(virCapsPtr caps)
>> +{
>> +    caps->virDriverDeviceDefCallback = qemuDomainDeviceDefCallback;
>> +}
>> +
>>  static void
>>  qemuDomainObjSaveJob(virQEMUDriverPtr driver, virDomainObjPtr obj)
>>  {
>> diff --git a/src/qemu/qemu_domain.h b/src/qemu/qemu_domain.h
>> index 905b099..210cffd 100644
>> --- a/src/qemu/qemu_domain.h
>> +++ b/src/qemu/qemu_domain.h
>> @@ -180,6 +180,7 @@ void qemuDomainEventQueue(virQEMUDriverPtr driver,
>>
>>  void qemuDomainSetPrivateDataHooks(virCapsPtr caps);
>>  void qemuDomainSetNamespaceHooks(virCapsPtr caps);
>> +void qemuDomainSetDefHooks(virCapsPtr caps);
>>
>>  int qemuDomainObjBeginJob(virQEMUDriverPtr driver,
>>                            virDomainObjPtr obj,
> --
> libvir-list mailing list
> libvir-list at redhat.com
> https://www.redhat.com/mailman/listinfo/libvir-list
>




More information about the libvir-list mailing list