9ae3a8
From 76e63c2bd20deda91bf99de161deb85b5229bf7e Mon Sep 17 00:00:00 2001
9ae3a8
From: Bandan Das <bsd@redhat.com>
9ae3a8
Date: Tue, 15 Oct 2013 17:10:59 +0200
9ae3a8
Subject: [PATCH 22/25] hda-codec: make mixemu selectable at runtime
9ae3a8
9ae3a8
RH-Author: Bandan Das <bsd@redhat.com>
9ae3a8
Message-id: <1381857067-9399-3-git-send-email-bsd@redhat.com>
9ae3a8
Patchwork-id: 54950
9ae3a8
O-Subject: [PATCH RHEL-7 qemu-kvm v3 2/5] hda-codec: make mixemu selectable at runtime
9ae3a8
Bugzilla: 954195
9ae3a8
RH-Acked-by: Paolo Bonzini <pbonzini@redhat.com>
9ae3a8
RH-Acked-by: Gerd Hoffmann <kraxel@redhat.com>
9ae3a8
RH-Acked-by: Markus Armbruster <armbru@redhat.com>
9ae3a8
9ae3a8
Define PARAM so that we have two versions of the "desc_codec
9ae3a8
and family" structs. Add a property called "mixer" whose default
9ae3a8
value depends on whether CONFIG_MIXEMU is defined or not which
9ae3a8
will help us call the appropriate instance init functions.
9ae3a8
9ae3a8
Signed-off-by: Bandan Das <bsd@redhat.com>
9ae3a8
Signed-off-by: Gerd Hoffmann <kraxel@redhat.com>
9ae3a8
(cherry picked from commit 2690e61e8e313461428334586ed9dbf56531dae9)
9ae3a8
---
9ae3a8
 hw/audio/hda-codec-common.h | 117 +++++++++++++++++++++++---------------------
9ae3a8
 hw/audio/hda-codec.c        |  64 ++++++++++++++++++++++--
9ae3a8
 2 files changed, 122 insertions(+), 59 deletions(-)
9ae3a8
9ae3a8
Signed-off-by: Miroslav Rezanina <mrezanin@redhat.com>
9ae3a8
---
9ae3a8
 hw/audio/hda-codec-common.h |  117 +++++++++++++++++++++++--------------------
9ae3a8
 hw/audio/hda-codec.c        |   64 ++++++++++++++++++++++--
9ae3a8
 2 files changed, 122 insertions(+), 59 deletions(-)
9ae3a8
9ae3a8
diff --git a/hw/audio/hda-codec-common.h b/hw/audio/hda-codec-common.h
9ae3a8
index 2f7e95f..b4fdb51 100644
9ae3a8
--- a/hw/audio/hda-codec-common.h
9ae3a8
+++ b/hw/audio/hda-codec-common.h
9ae3a8
@@ -24,7 +24,7 @@
9ae3a8
  * HDA codec descriptions
9ae3a8
  */
9ae3a8
 
9ae3a8
-#ifdef CONFIG_MIXEMU
9ae3a8
+#ifdef HDA_MIXER
9ae3a8
 #define QEMU_HDA_ID_OUTPUT  ((QEMU_HDA_ID_VENDOR << 16) | 0x12)
9ae3a8
 #define QEMU_HDA_ID_DUPLEX  ((QEMU_HDA_ID_VENDOR << 16) | 0x22)
9ae3a8
 #define QEMU_HDA_ID_MICRO   ((QEMU_HDA_ID_VENDOR << 16) | 0x32)
9ae3a8
@@ -42,7 +42,7 @@
9ae3a8
 
9ae3a8
 
9ae3a8
 /* common: audio output widget */
9ae3a8
-static const desc_param common_params_audio_dac[] = {
9ae3a8
+static const desc_param glue(common_params_audio_dac_, PARAM)[] = {
9ae3a8
     {
9ae3a8
         .id  = AC_PAR_AUDIO_WIDGET_CAP,
9ae3a8
         .val = ((AC_WID_AUD_OUT << AC_WCAP_TYPE_SHIFT) |
9ae3a8
@@ -66,7 +66,7 @@ static const desc_param common_params_audio_dac[] = {
9ae3a8
 };
9ae3a8
 
9ae3a8
 /* common: audio input widget */
9ae3a8
-static const desc_param common_params_audio_adc[] = {
9ae3a8
+static const desc_param glue(common_params_audio_adc_, PARAM)[] = {
9ae3a8
     {
9ae3a8
         .id  = AC_PAR_AUDIO_WIDGET_CAP,
9ae3a8
         .val = ((AC_WID_AUD_IN << AC_WCAP_TYPE_SHIFT) |
9ae3a8
@@ -94,7 +94,7 @@ static const desc_param common_params_audio_adc[] = {
9ae3a8
 };
9ae3a8
 
9ae3a8
 /* common: pin widget (line-out) */
9ae3a8
-static const desc_param common_params_audio_lineout[] = {
9ae3a8
+static const desc_param glue(common_params_audio_lineout_, PARAM)[] = {
9ae3a8
     {
9ae3a8
         .id  = AC_PAR_AUDIO_WIDGET_CAP,
9ae3a8
         .val = ((AC_WID_PIN << AC_WCAP_TYPE_SHIFT) |
9ae3a8
@@ -116,7 +116,7 @@ static const desc_param common_params_audio_lineout[] = {
9ae3a8
 };
9ae3a8
 
9ae3a8
 /* common: pin widget (line-in) */
9ae3a8
-static const desc_param common_params_audio_linein[] = {
9ae3a8
+static const desc_param glue(common_params_audio_linein_, PARAM)[] = {
9ae3a8
     {
9ae3a8
         .id  = AC_PAR_AUDIO_WIDGET_CAP,
9ae3a8
         .val = ((AC_WID_PIN << AC_WCAP_TYPE_SHIFT) |
9ae3a8
@@ -134,7 +134,7 @@ static const desc_param common_params_audio_linein[] = {
9ae3a8
 };
9ae3a8
 
9ae3a8
 /* output: root node */
9ae3a8
-static const desc_param output_params_root[] = {
9ae3a8
+static const desc_param glue(output_params_root_, PARAM)[] = {
9ae3a8
     {
9ae3a8
         .id  = AC_PAR_VENDOR_ID,
9ae3a8
         .val = QEMU_HDA_ID_OUTPUT,
9ae3a8
@@ -151,7 +151,7 @@ static const desc_param output_params_root[] = {
9ae3a8
 };
9ae3a8
 
9ae3a8
 /* output: audio function */
9ae3a8
-static const desc_param output_params_audio_func[] = {
9ae3a8
+static const desc_param glue(output_params_audio_func_, PARAM)[] = {
9ae3a8
     {
9ae3a8
         .id  = AC_PAR_FUNCTION_TYPE,
9ae3a8
         .val = AC_GRP_AUDIO_FUNCTION,
9ae3a8
@@ -186,28 +186,28 @@ static const desc_param output_params_audio_func[] = {
9ae3a8
 };
9ae3a8
 
9ae3a8
 /* output: nodes */
9ae3a8
-static const desc_node output_nodes[] = {
9ae3a8
+static const desc_node glue(output_nodes_, PARAM)[] = {
9ae3a8
     {
9ae3a8
         .nid     = AC_NODE_ROOT,
9ae3a8
         .name    = "root",
9ae3a8
-        .params  = output_params_root,
9ae3a8
-        .nparams = ARRAY_SIZE(output_params_root),
9ae3a8
+        .params  = glue(output_params_root_, PARAM),
9ae3a8
+        .nparams = ARRAY_SIZE(glue(output_params_root_, PARAM)),
9ae3a8
     },{
9ae3a8
         .nid     = 1,
9ae3a8
         .name    = "func",
9ae3a8
-        .params  = output_params_audio_func,
9ae3a8
-        .nparams = ARRAY_SIZE(output_params_audio_func),
9ae3a8
+        .params  = glue(output_params_audio_func_, PARAM),
9ae3a8
+        .nparams = ARRAY_SIZE(glue(output_params_audio_func_, PARAM)),
9ae3a8
     },{
9ae3a8
         .nid     = 2,
9ae3a8
         .name    = "dac",
9ae3a8
-        .params  = common_params_audio_dac,
9ae3a8
-        .nparams = ARRAY_SIZE(common_params_audio_dac),
9ae3a8
+        .params  = glue(common_params_audio_dac_, PARAM),
9ae3a8
+        .nparams = ARRAY_SIZE(glue(common_params_audio_dac_, PARAM)),
9ae3a8
         .stindex = 0,
9ae3a8
     },{
9ae3a8
         .nid     = 3,
9ae3a8
         .name    = "out",
9ae3a8
-        .params  = common_params_audio_lineout,
9ae3a8
-        .nparams = ARRAY_SIZE(common_params_audio_lineout),
9ae3a8
+        .params  = glue(common_params_audio_lineout_, PARAM),
9ae3a8
+        .nparams = ARRAY_SIZE(glue(common_params_audio_lineout_, PARAM)),
9ae3a8
         .config  = ((AC_JACK_PORT_COMPLEX << AC_DEFCFG_PORT_CONN_SHIFT) |
9ae3a8
                     (AC_JACK_LINE_OUT     << AC_DEFCFG_DEVICE_SHIFT)    |
9ae3a8
                     (AC_JACK_CONN_UNKNOWN << AC_DEFCFG_CONN_TYPE_SHIFT) |
9ae3a8
@@ -219,15 +219,15 @@ static const desc_node output_nodes[] = {
9ae3a8
 };
9ae3a8
 
9ae3a8
 /* output: codec */
9ae3a8
-static const desc_codec output = {
9ae3a8
+static const desc_codec glue(output_, PARAM) = {
9ae3a8
     .name   = "output",
9ae3a8
     .iid    = QEMU_HDA_ID_OUTPUT,
9ae3a8
-    .nodes  = output_nodes,
9ae3a8
-    .nnodes = ARRAY_SIZE(output_nodes),
9ae3a8
+    .nodes  = glue(output_nodes_, PARAM),
9ae3a8
+    .nnodes = ARRAY_SIZE(glue(output_nodes_, PARAM)),
9ae3a8
 };
9ae3a8
 
9ae3a8
 /* duplex: root node */
9ae3a8
-static const desc_param duplex_params_root[] = {
9ae3a8
+static const desc_param glue(duplex_params_root_, PARAM)[] = {
9ae3a8
     {
9ae3a8
         .id  = AC_PAR_VENDOR_ID,
9ae3a8
         .val = QEMU_HDA_ID_DUPLEX,
9ae3a8
@@ -244,7 +244,7 @@ static const desc_param duplex_params_root[] = {
9ae3a8
 };
9ae3a8
 
9ae3a8
 /* duplex: audio function */
9ae3a8
-static const desc_param duplex_params_audio_func[] = {
9ae3a8
+static const desc_param glue(duplex_params_audio_func_, PARAM)[] = {
9ae3a8
     {
9ae3a8
         .id  = AC_PAR_FUNCTION_TYPE,
9ae3a8
         .val = AC_GRP_AUDIO_FUNCTION,
9ae3a8
@@ -279,28 +279,28 @@ static const desc_param duplex_params_audio_func[] = {
9ae3a8
 };
9ae3a8
 
9ae3a8
 /* duplex: nodes */
9ae3a8
-static const desc_node duplex_nodes[] = {
9ae3a8
+static const desc_node glue(duplex_nodes_, PARAM)[] = {
9ae3a8
     {
9ae3a8
         .nid     = AC_NODE_ROOT,
9ae3a8
         .name    = "root",
9ae3a8
-        .params  = duplex_params_root,
9ae3a8
-        .nparams = ARRAY_SIZE(duplex_params_root),
9ae3a8
+        .params  = glue(duplex_params_root_, PARAM),
9ae3a8
+        .nparams = ARRAY_SIZE(glue(duplex_params_root_, PARAM)),
9ae3a8
     },{
9ae3a8
         .nid     = 1,
9ae3a8
         .name    = "func",
9ae3a8
-        .params  = duplex_params_audio_func,
9ae3a8
-        .nparams = ARRAY_SIZE(duplex_params_audio_func),
9ae3a8
+        .params  = glue(duplex_params_audio_func_, PARAM),
9ae3a8
+        .nparams = ARRAY_SIZE(glue(duplex_params_audio_func_, PARAM)),
9ae3a8
     },{
9ae3a8
         .nid     = 2,
9ae3a8
         .name    = "dac",
9ae3a8
-        .params  = common_params_audio_dac,
9ae3a8
-        .nparams = ARRAY_SIZE(common_params_audio_dac),
9ae3a8
+        .params  = glue(common_params_audio_dac_, PARAM),
9ae3a8
+        .nparams = ARRAY_SIZE(glue(common_params_audio_dac_, PARAM)),
9ae3a8
         .stindex = 0,
9ae3a8
     },{
9ae3a8
         .nid     = 3,
9ae3a8
         .name    = "out",
9ae3a8
-        .params  = common_params_audio_lineout,
9ae3a8
-        .nparams = ARRAY_SIZE(common_params_audio_lineout),
9ae3a8
+        .params  = glue(common_params_audio_lineout_, PARAM),
9ae3a8
+        .nparams = ARRAY_SIZE(glue(common_params_audio_lineout_, PARAM)),
9ae3a8
         .config  = ((AC_JACK_PORT_COMPLEX << AC_DEFCFG_PORT_CONN_SHIFT) |
9ae3a8
                     (AC_JACK_LINE_OUT     << AC_DEFCFG_DEVICE_SHIFT)    |
9ae3a8
                     (AC_JACK_CONN_UNKNOWN << AC_DEFCFG_CONN_TYPE_SHIFT) |
9ae3a8
@@ -311,15 +311,15 @@ static const desc_node duplex_nodes[] = {
9ae3a8
     },{
9ae3a8
         .nid     = 4,
9ae3a8
         .name    = "adc",
9ae3a8
-        .params  = common_params_audio_adc,
9ae3a8
-        .nparams = ARRAY_SIZE(common_params_audio_adc),
9ae3a8
+        .params  = glue(common_params_audio_adc_, PARAM),
9ae3a8
+        .nparams = ARRAY_SIZE(glue(common_params_audio_adc_, PARAM)),
9ae3a8
         .stindex = 1,
9ae3a8
         .conn    = (uint32_t[]) { 5 },
9ae3a8
     },{
9ae3a8
         .nid     = 5,
9ae3a8
         .name    = "in",
9ae3a8
-        .params  = common_params_audio_linein,
9ae3a8
-        .nparams = ARRAY_SIZE(common_params_audio_linein),
9ae3a8
+        .params  = glue(common_params_audio_linein_, PARAM),
9ae3a8
+        .nparams = ARRAY_SIZE(glue(common_params_audio_linein_, PARAM)),
9ae3a8
         .config  = ((AC_JACK_PORT_COMPLEX << AC_DEFCFG_PORT_CONN_SHIFT) |
9ae3a8
                     (AC_JACK_LINE_IN      << AC_DEFCFG_DEVICE_SHIFT)    |
9ae3a8
                     (AC_JACK_CONN_UNKNOWN << AC_DEFCFG_CONN_TYPE_SHIFT) |
9ae3a8
@@ -330,15 +330,15 @@ static const desc_node duplex_nodes[] = {
9ae3a8
 };
9ae3a8
 
9ae3a8
 /* duplex: codec */
9ae3a8
-static const desc_codec duplex = {
9ae3a8
+static const desc_codec glue(duplex_, PARAM) = {
9ae3a8
     .name   = "duplex",
9ae3a8
     .iid    = QEMU_HDA_ID_DUPLEX,
9ae3a8
-    .nodes  = duplex_nodes,
9ae3a8
-    .nnodes = ARRAY_SIZE(duplex_nodes),
9ae3a8
+    .nodes  = glue(duplex_nodes_, PARAM),
9ae3a8
+    .nnodes = ARRAY_SIZE(glue(duplex_nodes_, PARAM)),
9ae3a8
 };
9ae3a8
 
9ae3a8
 /* micro: root node */
9ae3a8
-static const desc_param micro_params_root[] = {
9ae3a8
+static const desc_param glue(micro_params_root_, PARAM)[] = {
9ae3a8
     {
9ae3a8
         .id  = AC_PAR_VENDOR_ID,
9ae3a8
         .val = QEMU_HDA_ID_MICRO,
9ae3a8
@@ -355,7 +355,7 @@ static const desc_param micro_params_root[] = {
9ae3a8
 };
9ae3a8
 
9ae3a8
 /* micro: audio function */
9ae3a8
-static const desc_param micro_params_audio_func[] = {
9ae3a8
+static const desc_param glue(micro_params_audio_func_, PARAM)[] = {
9ae3a8
     {
9ae3a8
         .id  = AC_PAR_FUNCTION_TYPE,
9ae3a8
         .val = AC_GRP_AUDIO_FUNCTION,
9ae3a8
@@ -390,28 +390,28 @@ static const desc_param micro_params_audio_func[] = {
9ae3a8
 };
9ae3a8
 
9ae3a8
 /* micro: nodes */
9ae3a8
-static const desc_node micro_nodes[] = {
9ae3a8
+static const desc_node glue(micro_nodes_, PARAM)[] = {
9ae3a8
     {
9ae3a8
         .nid     = AC_NODE_ROOT,
9ae3a8
         .name    = "root",
9ae3a8
-        .params  = micro_params_root,
9ae3a8
-        .nparams = ARRAY_SIZE(micro_params_root),
9ae3a8
+        .params  = glue(micro_params_root_, PARAM),
9ae3a8
+        .nparams = ARRAY_SIZE(glue(micro_params_root_, PARAM)),
9ae3a8
     },{
9ae3a8
         .nid     = 1,
9ae3a8
         .name    = "func",
9ae3a8
-        .params  = micro_params_audio_func,
9ae3a8
-        .nparams = ARRAY_SIZE(micro_params_audio_func),
9ae3a8
+        .params  = glue(micro_params_audio_func_, PARAM),
9ae3a8
+        .nparams = ARRAY_SIZE(glue(micro_params_audio_func_, PARAM)),
9ae3a8
     },{
9ae3a8
         .nid     = 2,
9ae3a8
         .name    = "dac",
9ae3a8
-        .params  = common_params_audio_dac,
9ae3a8
-        .nparams = ARRAY_SIZE(common_params_audio_dac),
9ae3a8
+        .params  = glue(common_params_audio_dac_, PARAM),
9ae3a8
+        .nparams = ARRAY_SIZE(glue(common_params_audio_dac_, PARAM)),
9ae3a8
         .stindex = 0,
9ae3a8
     },{
9ae3a8
         .nid     = 3,
9ae3a8
         .name    = "out",
9ae3a8
-        .params  = common_params_audio_lineout,
9ae3a8
-        .nparams = ARRAY_SIZE(common_params_audio_lineout),
9ae3a8
+        .params  = glue(common_params_audio_lineout_, PARAM),
9ae3a8
+        .nparams = ARRAY_SIZE(glue(common_params_audio_lineout_, PARAM)),
9ae3a8
         .config  = ((AC_JACK_PORT_COMPLEX << AC_DEFCFG_PORT_CONN_SHIFT) |
9ae3a8
                     (AC_JACK_SPEAKER      << AC_DEFCFG_DEVICE_SHIFT)    |
9ae3a8
                     (AC_JACK_CONN_UNKNOWN << AC_DEFCFG_CONN_TYPE_SHIFT) |
9ae3a8
@@ -422,15 +422,15 @@ static const desc_node micro_nodes[] = {
9ae3a8
     },{
9ae3a8
         .nid     = 4,
9ae3a8
         .name    = "adc",
9ae3a8
-        .params  = common_params_audio_adc,
9ae3a8
-        .nparams = ARRAY_SIZE(common_params_audio_adc),
9ae3a8
+        .params  = glue(common_params_audio_adc_, PARAM),
9ae3a8
+        .nparams = ARRAY_SIZE(glue(common_params_audio_adc_, PARAM)),
9ae3a8
         .stindex = 1,
9ae3a8
         .conn    = (uint32_t[]) { 5 },
9ae3a8
     },{
9ae3a8
         .nid     = 5,
9ae3a8
         .name    = "in",
9ae3a8
-        .params  = common_params_audio_linein,
9ae3a8
-        .nparams = ARRAY_SIZE(common_params_audio_linein),
9ae3a8
+        .params  = glue(common_params_audio_linein_, PARAM),
9ae3a8
+        .nparams = ARRAY_SIZE(glue(common_params_audio_linein_, PARAM)),
9ae3a8
         .config  = ((AC_JACK_PORT_COMPLEX << AC_DEFCFG_PORT_CONN_SHIFT) |
9ae3a8
                     (AC_JACK_MIC_IN       << AC_DEFCFG_DEVICE_SHIFT)    |
9ae3a8
                     (AC_JACK_CONN_UNKNOWN << AC_DEFCFG_CONN_TYPE_SHIFT) |
9ae3a8
@@ -441,9 +441,16 @@ static const desc_node micro_nodes[] = {
9ae3a8
 };
9ae3a8
 
9ae3a8
 /* micro: codec */
9ae3a8
-static const desc_codec micro = {
9ae3a8
+static const desc_codec glue(micro_, PARAM) = {
9ae3a8
     .name   = "micro",
9ae3a8
     .iid    = QEMU_HDA_ID_MICRO,
9ae3a8
-    .nodes  = micro_nodes,
9ae3a8
-    .nnodes = ARRAY_SIZE(micro_nodes),
9ae3a8
+    .nodes  = glue(micro_nodes_, PARAM),
9ae3a8
+    .nnodes = ARRAY_SIZE(glue(micro_nodes_, PARAM)),
9ae3a8
 };
9ae3a8
+
9ae3a8
+#undef PARAM
9ae3a8
+#undef HDA_MIXER
9ae3a8
+#undef QEMU_HDA_ID_OUTPUT
9ae3a8
+#undef QEMU_HDA_ID_DUPLEX
9ae3a8
+#undef QEMU_HDA_ID_MICRO
9ae3a8
+#undef QEMU_HDA_AMP_CAPS
9ae3a8
diff --git a/hw/audio/hda-codec.c b/hw/audio/hda-codec.c
9ae3a8
index cb498fc..3217d90 100644
9ae3a8
--- a/hw/audio/hda-codec.c
9ae3a8
+++ b/hw/audio/hda-codec.c
9ae3a8
@@ -118,7 +118,15 @@ static void hda_codec_parse_fmt(uint32_t format, struct audsettings *as)
9ae3a8
 #define QEMU_HDA_AMP_NONE    (0)
9ae3a8
 #define QEMU_HDA_AMP_STEPS   0x4a
9ae3a8
 
9ae3a8
+#ifdef CONFIG_MIXEMU
9ae3a8
+#define   PARAM mixemu
9ae3a8
+#define   HDA_MIXER
9ae3a8
 #include "hda-codec-common.h"
9ae3a8
+#endif
9ae3a8
+
9ae3a8
+#define   PARAM nomixemu
9ae3a8
+#include  "hda-codec-common.h"
9ae3a8
+
9ae3a8
 /* -------------------------------------------------------------------------- */
9ae3a8
 
9ae3a8
 static const char *fmt2name[] = {
9ae3a8
@@ -163,6 +171,7 @@ struct HDAAudioState {
9ae3a8
 
9ae3a8
     /* properties */
9ae3a8
     uint32_t debug;
9ae3a8
+    bool     mixer;
9ae3a8
 };
9ae3a8
 
9ae3a8
 static void hda_audio_input_cb(void *opaque, int avail)
9ae3a8
@@ -584,23 +593,70 @@ static const VMStateDescription vmstate_hda_audio = {
9ae3a8
 };
9ae3a8
 
9ae3a8
 static Property hda_audio_properties[] = {
9ae3a8
-    DEFINE_PROP_UINT32("debug", HDAAudioState, debug, 0),
9ae3a8
+    DEFINE_PROP_UINT32("debug", HDAAudioState, debug,   0),
9ae3a8
+#ifdef CONFIG_MIXEMU
9ae3a8
+    DEFINE_PROP_BOOL("mixer", HDAAudioState, mixer,  true),
9ae3a8
+#else
9ae3a8
+    DEFINE_PROP_BOOL("mixer", HDAAudioState, mixer, false),
9ae3a8
+#endif
9ae3a8
     DEFINE_PROP_END_OF_LIST(),
9ae3a8
 };
9ae3a8
 
9ae3a8
 static int hda_audio_init_output(HDACodecDevice *hda)
9ae3a8
 {
9ae3a8
-    return hda_audio_init(hda, &output);
9ae3a8
+    HDAAudioState *a = DO_UPCAST(HDAAudioState, hda, hda);
9ae3a8
+
9ae3a8
+    if (!a->mixer) {
9ae3a8
+        return hda_audio_init(hda, &output_nomixemu);
9ae3a8
+    } else {
9ae3a8
+
9ae3a8
+#ifdef CONFIG_MIXEMU
9ae3a8
+        return hda_audio_init(hda, &output_mixemu);
9ae3a8
+#else
9ae3a8
+        fprintf(stderr, "ERROR: "
9ae3a8
+                "hda-codec : Mixer emulation has not been compiled in!\n");
9ae3a8
+        return -1;
9ae3a8
+#endif
9ae3a8
+
9ae3a8
+    }
9ae3a8
 }
9ae3a8
 
9ae3a8
 static int hda_audio_init_duplex(HDACodecDevice *hda)
9ae3a8
 {
9ae3a8
-    return hda_audio_init(hda, &duplex);
9ae3a8
+    HDAAudioState *a = DO_UPCAST(HDAAudioState, hda, hda);
9ae3a8
+
9ae3a8
+    if (!a->mixer) {
9ae3a8
+        return hda_audio_init(hda, &duplex_nomixemu);
9ae3a8
+    } else {
9ae3a8
+
9ae3a8
+#ifdef CONFIG_MIXEMU
9ae3a8
+        return hda_audio_init(hda, &duplex_mixemu);
9ae3a8
+#else
9ae3a8
+        fprintf(stderr, "ERROR: "
9ae3a8
+                "hda-codec : Mixer emulation has not been compiled in!\n");
9ae3a8
+        return -1;
9ae3a8
+#endif
9ae3a8
+
9ae3a8
+    }
9ae3a8
 }
9ae3a8
 
9ae3a8
 static int hda_audio_init_micro(HDACodecDevice *hda)
9ae3a8
 {
9ae3a8
-    return hda_audio_init(hda, µ);
9ae3a8
+    HDAAudioState *a = DO_UPCAST(HDAAudioState, hda, hda);
9ae3a8
+
9ae3a8
+    if (!a->mixer) {
9ae3a8
+        return hda_audio_init(hda, &micro_nomixemu);
9ae3a8
+    } else {
9ae3a8
+
9ae3a8
+#ifdef CONFIG_MIXEMU
9ae3a8
+        return hda_audio_init(hda, &micro_mixemu);
9ae3a8
+#else
9ae3a8
+        fprintf(stderr, "ERROR: "
9ae3a8
+                "hda-codec : Mixer emulation has not been compiled in!\n");
9ae3a8
+        return -1;
9ae3a8
+#endif
9ae3a8
+
9ae3a8
+    }
9ae3a8
 }
9ae3a8
 
9ae3a8
 static void hda_audio_output_class_init(ObjectClass *klass, void *data)
9ae3a8
-- 
9ae3a8
1.7.1
9ae3a8