]> git.ipfire.org Git - thirdparty/libvirt.git/commitdiff
Introduce generic virDomainDeviceInfo iterator function
authorDaniel P. Berrange <berrange@redhat.com>
Wed, 27 Jan 2010 15:10:34 +0000 (15:10 +0000)
committerDaniel P. Berrange <berrange@redhat.com>
Tue, 2 Feb 2010 16:31:47 +0000 (16:31 +0000)
The virDomainDeviceInfoIterate() function will provide a
convenient way to iterate over all devices in a domain.

* src/conf/domain_conf.c, src/conf/domain_conf.h,
  src/libvirt_private.syms: Add virDomainDeviceInfoIterate()
  function.

src/conf/domain_conf.c
src/conf/domain_conf.h
src/libvirt_private.syms

index e548d1dbcc0b7f7b680ec3fb0c17db765ce9ee85..691fc84e7da899b151ed1fc34cb33ec882ac2807 100644 (file)
@@ -824,59 +824,82 @@ void virDomainDeviceInfoClear(virDomainDeviceInfoPtr info)
 }
 
 
-static void virDomainDeviceInfoClearField(virDomainDeviceInfoPtr info, int alias, int pciaddr)
+static int virDomainDeviceInfoClearAlias(virDomainDefPtr def ATTRIBUTE_UNUSED,
+                                         virDomainDeviceInfoPtr info,
+                                         void *opaque ATTRIBUTE_UNUSED)
 {
-    if (alias)
-        VIR_FREE(info->alias);
-    if (pciaddr &&
-        info->type == VIR_DOMAIN_DEVICE_ADDRESS_TYPE_PCI) {
+    VIR_FREE(info->alias);
+    return 0;
+}
+
+static int virDomainDeviceInfoClearPCIAddress(virDomainDefPtr def ATTRIBUTE_UNUSED,
+                                              virDomainDeviceInfoPtr info,
+                                              void *opaque ATTRIBUTE_UNUSED)
+{
+    if (info->type == VIR_DOMAIN_DEVICE_ADDRESS_TYPE_PCI) {
         memset(&info->addr, 0, sizeof(info->addr));
         info->type = VIR_DOMAIN_DEVICE_ADDRESS_TYPE_NONE;
     }
+    return 0;
 }
 
-
-static void virDomainDefClearDeviceInfo(virDomainDefPtr def, int alias, int pciaddr)
+int virDomainDeviceInfoIterate(virDomainDefPtr def,
+                               virDomainDeviceInfoCallback cb,
+                               void *opaque)
 {
     int i;
 
     for (i = 0; i < def->ndisks ; i++)
-        virDomainDeviceInfoClearField(&def->disks[i]->info, alias, pciaddr);
+        if (cb(def, &def->disks[i]->info, opaque) < 0)
+            return -1;
     for (i = 0; i < def->nnets ; i++)
-        virDomainDeviceInfoClearField(&def->nets[i]->info, alias, pciaddr);
+        if (cb(def, &def->nets[i]->info, opaque) < 0)
+            return -1;
     for (i = 0; i < def->nsounds ; i++)
-        virDomainDeviceInfoClearField(&def->sounds[i]->info, alias, pciaddr);
+        if (cb(def, &def->sounds[i]->info, opaque) < 0)
+            return -1;
     for (i = 0; i < def->nhostdevs ; i++)
-        virDomainDeviceInfoClearField(&def->hostdevs[i]->info, alias, pciaddr);
+        if (cb(def, &def->hostdevs[i]->info, opaque) < 0)
+            return -1;
     for (i = 0; i < def->nvideos ; i++)
-        virDomainDeviceInfoClearField(&def->videos[i]->info, alias, pciaddr);
+        if (cb(def, &def->videos[i]->info, opaque) < 0)
+            return -1;
     for (i = 0; i < def->ncontrollers ; i++)
-        virDomainDeviceInfoClearField(&def->controllers[i]->info, alias, pciaddr);
+        if (cb(def, &def->controllers[i]->info, opaque) < 0)
+            return -1;
     for (i = 0; i < def->nserials ; i++)
-        virDomainDeviceInfoClearField(&def->serials[i]->info, alias, pciaddr);
+        if (cb(def, &def->serials[i]->info, opaque) < 0)
+            return -1;
     for (i = 0; i < def->nparallels ; i++)
-        virDomainDeviceInfoClearField(&def->parallels[i]->info, alias, pciaddr);
+        if (cb(def, &def->parallels[i]->info, opaque) < 0)
+            return -1;
     for (i = 0; i < def->nchannels ; i++)
-        virDomainDeviceInfoClearField(&def->channels[i]->info, alias, pciaddr);
+        if (cb(def, &def->channels[i]->info, opaque) < 0)
+            return -1;
     for (i = 0; i < def->ninputs ; i++)
-        virDomainDeviceInfoClearField(&def->inputs[i]->info, alias, pciaddr);
+        if (cb(def, &def->inputs[i]->info, opaque) < 0)
+            return -1;
     for (i = 0; i < def->nfss ; i++)
-        virDomainDeviceInfoClearField(&def->fss[i]->info, alias, pciaddr);
+        if (cb(def, &def->fss[i]->info, opaque) < 0)
+            return -1;
     if (def->watchdog)
-        virDomainDeviceInfoClearField(&def->watchdog->info, alias, pciaddr);
+        if (cb(def, &def->watchdog->info, opaque) < 0)
+            return -1;
     if (def->console)
-        virDomainDeviceInfoClearField(&def->console->info, alias, pciaddr);
+        if (cb(def, &def->console->info, opaque) < 0)
+            return -1;
+    return 0;
 }
 
 
 void virDomainDefClearPCIAddresses(virDomainDefPtr def)
 {
-    virDomainDefClearDeviceInfo(def, 0, 1);
+    virDomainDeviceInfoIterate(def, virDomainDeviceInfoClearPCIAddress, NULL);
 }
 
 void virDomainDefClearDeviceAliases(virDomainDefPtr def)
 {
-    virDomainDefClearDeviceInfo(def, 1, 0);
+    virDomainDeviceInfoIterate(def, virDomainDeviceInfoClearAlias, NULL);
 }
 
 
index 7be090d444e0ad67adabf4d18606692f8fc6f10c..be0dc926bb8f2b655eb641bac041e0183c579f1d 100644 (file)
@@ -742,6 +742,14 @@ void virDomainDeviceInfoClear(virDomainDeviceInfoPtr info);
 void virDomainDefClearPCIAddresses(virDomainDefPtr def);
 void virDomainDefClearDeviceAliases(virDomainDefPtr def);
 
+typedef int (*virDomainDeviceInfoCallback)(virDomainDefPtr def,
+                                           virDomainDeviceInfoPtr dev,
+                                           void *opaque);
+
+int virDomainDeviceInfoIterate(virDomainDefPtr def,
+                               virDomainDeviceInfoCallback cb,
+                               void *opaque);
+
 void virDomainDefFree(virDomainDefPtr vm);
 void virDomainObjRef(virDomainObjPtr vm);
 /* Returns 1 if the object was freed, 0 if more refs exist */
index d56fb7d27c04873574bf627f47beccf4bfbdc86f..e5e8860a6a3121705e0903d08b08ffefbba3869a 100644 (file)
@@ -187,6 +187,7 @@ virDomainDeviceAddressTypeToString;
 virDomainDefAddDiskControllers;
 virDomainDefClearPCIAddresses;
 virDomainDefClearDeviceAliases;
+virDomainDeviceInfoIterate;
 
 
 # domain_event.h