]> git.ipfire.org Git - thirdparty/libvirt.git/commitdiff
qemu: Generate acpi-generic-initiator command from acpi nodeset
authorAndrea Righi <arighi@nvidia.com>
Sat, 6 Sep 2025 13:09:00 +0000 (15:09 +0200)
committerDaniel P. Berrangé <berrange@redhat.com>
Mon, 8 Sep 2025 18:12:35 +0000 (19:12 +0100)
Reviewed-by: Daniel P. Berrangé <berrange@redhat.com>
Signed-off-by: Andrea Righi <arighi@nvidia.com>
src/qemu/qemu_command.c

index 3f9b5839859667e978490a2f22c13a9f3711d935..031f09b7a5c87be9a9ecb3cd4900c35d2add0c36 100644 (file)
@@ -5222,6 +5222,43 @@ qemuBuildHostdevSCSICommandLine(virCommand *cmd,
 }
 
 
+static int
+qemuBuildAcpiNodesetProps(virCommand *cmd,
+                          virDomainDeviceInfo *info)
+{
+    static unsigned int giIndex;
+    int node = -1;
+
+    if (!info->acpiNodeset)
+        return 0;
+
+    while ((node = virBitmapNextSetBit(info->acpiNodeset, node)) > -1) {
+        g_autoptr(virJSONValue) props = NULL;
+        g_autofree char *id = g_strdup_printf("gi%u", giIndex++);
+
+        if (virJSONValueObjectAdd(&props,
+                                  "s:qom-type", "acpi-generic-initiator",
+                                  "s:id", id,
+                                  "s:pci-dev", info->alias,
+                                  "i:node", node,
+                                  NULL) < 0) {
+            virReportError(VIR_ERR_INTERNAL_ERROR, "%s",
+                           _("Failed to build acpi-generic-initiator properties"));
+
+            return -1;
+        }
+
+        if (qemuBuildObjectCommandlineFromJSON(cmd, props) < 0) {
+            virReportError(VIR_ERR_INTERNAL_ERROR, "%s",
+                           _("Failed to build QEMU command line for acpi-generic-initiator"));
+            return -1;
+        }
+    }
+
+    return 0;
+}
+
+
 static int
 qemuBuildHostdevCommandLine(virCommand *cmd,
                             const virDomainDef *def,
@@ -5264,6 +5301,10 @@ qemuBuildHostdevCommandLine(virCommand *cmd,
 
             if (qemuBuildDeviceCommandlineFromJSON(cmd, devprops, def, qemuCaps) < 0)
                 return -1;
+
+            if (qemuBuildAcpiNodesetProps(cmd, hostdev->info) < 0)
+                return -1;
+
             break;
 
         /* SCSI */