]> git.proxmox.com Git - mirror_qemu.git/commitdiff
vl: recognize audiodev groups in configuration files
authorPaolo Bonzini <pbonzini@redhat.com>
Thu, 21 Sep 2023 12:04:39 +0000 (14:04 +0200)
committerPaolo Bonzini <pbonzini@redhat.com>
Fri, 22 Sep 2023 15:35:11 +0000 (17:35 +0200)
This is necessary for the q35 configuration tests to pass,
once audiodev becomes mandatory.

Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
docs/config/q35-emulated.cfg
docs/config/q35-virtio-graphical.cfg
softmmu/vl.c

index c8806e6d362b85b456e9716f798a7bca934012ef..b4bd7e858a91d2cc3cca09f8e5d3c595e0687008 100644 (file)
   driver = "hda-duplex"
   bus = "ich9-hda-audio.0"
   cad = "0"
+  audiodev = "audiodev0"
+
+[audiodev "audiodev0"]
+  driver = "none"                      # CHANGE ME
index 148b5d2c5e4ea90ef04908b992b20a0ab2a83215..820860aefe0d14627af34908d95736e2047d63e6 100644 (file)
   driver = "hda-duplex"
   bus = "sound.0"
   cad = "0"
+  audiodev = "audiodev0"
+
+[audiodev "audiodev0"]
+  driver = "none"                      # CHANGE ME
index 3db4fd2680842cdd1a79fa215ab334b7e2d151fd..db04f98c36fbf214dceca6b09d50025a846b6565 100644 (file)
@@ -2125,6 +2125,7 @@ static int global_init_func(void *opaque, QemuOpts *opts, Error **errp)
 static bool is_qemuopts_group(const char *group)
 {
     if (g_str_equal(group, "object") ||
+        g_str_equal(group, "audiodev") ||
         g_str_equal(group, "machine") ||
         g_str_equal(group, "smp-opts") ||
         g_str_equal(group, "boot-opts")) {
@@ -2140,6 +2141,15 @@ static void qemu_record_config_group(const char *group, QDict *dict,
         Visitor *v = qobject_input_visitor_new_keyval(QOBJECT(dict));
         object_option_add_visitor(v);
         visit_free(v);
+
+    } else if (g_str_equal(group, "audiodev")) {
+        Audiodev *dev = NULL;
+        Visitor *v = qobject_input_visitor_new_keyval(QOBJECT(dict));
+        if (visit_type_Audiodev(v, NULL, &dev, errp)) {
+            audio_define(dev);
+        }
+        visit_free(v);
+
     } else if (g_str_equal(group, "machine")) {
         /*
          * Cannot merge string-valued and type-safe dictionaries, so JSON