9ae3a8
From 05205ba1d42e1381c4b0ecee32dd34535a68dace Mon Sep 17 00:00:00 2001
9ae3a8
From: Bandan Das <bsd@redhat.com>
9ae3a8
Date: Tue, 15 Oct 2013 17:10:58 +0200
9ae3a8
Subject: [PATCH 21/25] hda-codec: refactor common definitions into a header file
9ae3a8
9ae3a8
RH-Author: Bandan Das <bsd@redhat.com>
9ae3a8
Message-id: <1381857067-9399-2-git-send-email-bsd@redhat.com>
9ae3a8
Patchwork-id: 54949
9ae3a8
O-Subject: [PATCH RHEL-7 qemu-kvm v3 1/5] hda-codec: refactor common definitions into a header file
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
Move common defines and structs to a header file.
9ae3a8
The next commit will include it twice, once for a device with a
9ae3a8
mixer, and once for device without a mixer.
9ae3a8
9ae3a8
Signed-off-by: Bandan Das <bsd@redhat.com>
9ae3a8
Signed-off-by: Gerd Hoffmann <kraxel@redhat.com>
9ae3a8
(cherry picked from commit 7953793c033343dbea97836645edbe4e61754b11)
9ae3a8
---
9ae3a8
 hw/audio/hda-codec-common.h | 449 ++++++++++++++++++++++++++++++++++++++++++++
9ae3a8
 hw/audio/hda-codec.c        | 424 +----------------------------------------
9ae3a8
 2 files changed, 450 insertions(+), 423 deletions(-)
9ae3a8
 create mode 100644 hw/audio/hda-codec-common.h
9ae3a8
9ae3a8
Signed-off-by: Miroslav Rezanina <mrezanin@redhat.com>
9ae3a8
---
9ae3a8
 hw/audio/hda-codec-common.h |  449 +++++++++++++++++++++++++++++++++++++++++++
9ae3a8
 hw/audio/hda-codec.c        |  424 +----------------------------------------
9ae3a8
 2 files changed, 450 insertions(+), 423 deletions(-)
9ae3a8
 create mode 100644 hw/audio/hda-codec-common.h
9ae3a8
9ae3a8
diff --git a/hw/audio/hda-codec-common.h b/hw/audio/hda-codec-common.h
9ae3a8
new file mode 100644
9ae3a8
index 0000000..2f7e95f
9ae3a8
--- /dev/null
9ae3a8
+++ b/hw/audio/hda-codec-common.h
9ae3a8
@@ -0,0 +1,449 @@
9ae3a8
+/*
9ae3a8
+ * Common code to disable/enable mixer emulation at run time
9ae3a8
+ *
9ae3a8
+ * Copyright (C) 2013 Red Hat, Inc.
9ae3a8
+ *
9ae3a8
+ * Written by Bandan Das <bsd@redhat.com>
9ae3a8
+ * with important bits picked up from hda-codec.c
9ae3a8
+ *
9ae3a8
+ * This program is free software; you can redistribute it and/or
9ae3a8
+ * modify it under the terms of the GNU General Public License as
9ae3a8
+ * published by the Free Software Foundation; either version 2 or
9ae3a8
+ * (at your option) version 3 of the License.
9ae3a8
+ *
9ae3a8
+ * This program is distributed in the hope that it will be useful,
9ae3a8
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
9ae3a8
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
9ae3a8
+ * GNU General Public License for more details.
9ae3a8
+ *
9ae3a8
+ * You should have received a copy of the GNU General Public License
9ae3a8
+ * along with this program; if not, see <http://www.gnu.org/licenses/>.
9ae3a8
+ */
9ae3a8
+
9ae3a8
+/*
9ae3a8
+ * HDA codec descriptions
9ae3a8
+ */
9ae3a8
+
9ae3a8
+#ifdef CONFIG_MIXEMU
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
+#define QEMU_HDA_AMP_CAPS                                               \
9ae3a8
+    (AC_AMPCAP_MUTE |                                                   \
9ae3a8
+     (QEMU_HDA_AMP_STEPS << AC_AMPCAP_OFFSET_SHIFT)    |                \
9ae3a8
+     (QEMU_HDA_AMP_STEPS << AC_AMPCAP_NUM_STEPS_SHIFT) |                \
9ae3a8
+     (3                  << AC_AMPCAP_STEP_SIZE_SHIFT))
9ae3a8
+#else
9ae3a8
+#define QEMU_HDA_ID_OUTPUT  ((QEMU_HDA_ID_VENDOR << 16) | 0x11)
9ae3a8
+#define QEMU_HDA_ID_DUPLEX  ((QEMU_HDA_ID_VENDOR << 16) | 0x21)
9ae3a8
+#define QEMU_HDA_ID_MICRO   ((QEMU_HDA_ID_VENDOR << 16) | 0x31)
9ae3a8
+#define QEMU_HDA_AMP_CAPS   QEMU_HDA_AMP_NONE
9ae3a8
+#endif
9ae3a8
+
9ae3a8
+
9ae3a8
+/* common: audio output widget */
9ae3a8
+static const desc_param common_params_audio_dac[] = {
9ae3a8
+    {
9ae3a8
+        .id  = AC_PAR_AUDIO_WIDGET_CAP,
9ae3a8
+        .val = ((AC_WID_AUD_OUT << AC_WCAP_TYPE_SHIFT) |
9ae3a8
+                AC_WCAP_FORMAT_OVRD |
9ae3a8
+                AC_WCAP_AMP_OVRD |
9ae3a8
+                AC_WCAP_OUT_AMP |
9ae3a8
+                AC_WCAP_STEREO),
9ae3a8
+    },{
9ae3a8
+        .id  = AC_PAR_PCM,
9ae3a8
+        .val = QEMU_HDA_PCM_FORMATS,
9ae3a8
+    },{
9ae3a8
+        .id  = AC_PAR_STREAM,
9ae3a8
+        .val = AC_SUPFMT_PCM,
9ae3a8
+    },{
9ae3a8
+        .id  = AC_PAR_AMP_IN_CAP,
9ae3a8
+        .val = QEMU_HDA_AMP_NONE,
9ae3a8
+    },{
9ae3a8
+        .id  = AC_PAR_AMP_OUT_CAP,
9ae3a8
+        .val = QEMU_HDA_AMP_CAPS,
9ae3a8
+    },
9ae3a8
+};
9ae3a8
+
9ae3a8
+/* common: audio input widget */
9ae3a8
+static const desc_param common_params_audio_adc[] = {
9ae3a8
+    {
9ae3a8
+        .id  = AC_PAR_AUDIO_WIDGET_CAP,
9ae3a8
+        .val = ((AC_WID_AUD_IN << AC_WCAP_TYPE_SHIFT) |
9ae3a8
+                AC_WCAP_CONN_LIST |
9ae3a8
+                AC_WCAP_FORMAT_OVRD |
9ae3a8
+                AC_WCAP_AMP_OVRD |
9ae3a8
+                AC_WCAP_IN_AMP |
9ae3a8
+                AC_WCAP_STEREO),
9ae3a8
+    },{
9ae3a8
+        .id  = AC_PAR_CONNLIST_LEN,
9ae3a8
+        .val = 1,
9ae3a8
+    },{
9ae3a8
+        .id  = AC_PAR_PCM,
9ae3a8
+        .val = QEMU_HDA_PCM_FORMATS,
9ae3a8
+    },{
9ae3a8
+        .id  = AC_PAR_STREAM,
9ae3a8
+        .val = AC_SUPFMT_PCM,
9ae3a8
+    },{
9ae3a8
+        .id  = AC_PAR_AMP_IN_CAP,
9ae3a8
+        .val = QEMU_HDA_AMP_CAPS,
9ae3a8
+    },{
9ae3a8
+        .id  = AC_PAR_AMP_OUT_CAP,
9ae3a8
+        .val = QEMU_HDA_AMP_NONE,
9ae3a8
+    },
9ae3a8
+};
9ae3a8
+
9ae3a8
+/* common: pin widget (line-out) */
9ae3a8
+static const desc_param common_params_audio_lineout[] = {
9ae3a8
+    {
9ae3a8
+        .id  = AC_PAR_AUDIO_WIDGET_CAP,
9ae3a8
+        .val = ((AC_WID_PIN << AC_WCAP_TYPE_SHIFT) |
9ae3a8
+                AC_WCAP_CONN_LIST |
9ae3a8
+                AC_WCAP_STEREO),
9ae3a8
+    },{
9ae3a8
+        .id  = AC_PAR_PIN_CAP,
9ae3a8
+        .val = AC_PINCAP_OUT,
9ae3a8
+    },{
9ae3a8
+        .id  = AC_PAR_CONNLIST_LEN,
9ae3a8
+        .val = 1,
9ae3a8
+    },{
9ae3a8
+        .id  = AC_PAR_AMP_IN_CAP,
9ae3a8
+        .val = QEMU_HDA_AMP_NONE,
9ae3a8
+    },{
9ae3a8
+        .id  = AC_PAR_AMP_OUT_CAP,
9ae3a8
+        .val = QEMU_HDA_AMP_NONE,
9ae3a8
+    },
9ae3a8
+};
9ae3a8
+
9ae3a8
+/* common: pin widget (line-in) */
9ae3a8
+static const desc_param common_params_audio_linein[] = {
9ae3a8
+    {
9ae3a8
+        .id  = AC_PAR_AUDIO_WIDGET_CAP,
9ae3a8
+        .val = ((AC_WID_PIN << AC_WCAP_TYPE_SHIFT) |
9ae3a8
+                AC_WCAP_STEREO),
9ae3a8
+    },{
9ae3a8
+        .id  = AC_PAR_PIN_CAP,
9ae3a8
+        .val = AC_PINCAP_IN,
9ae3a8
+    },{
9ae3a8
+        .id  = AC_PAR_AMP_IN_CAP,
9ae3a8
+        .val = QEMU_HDA_AMP_NONE,
9ae3a8
+    },{
9ae3a8
+        .id  = AC_PAR_AMP_OUT_CAP,
9ae3a8
+        .val = QEMU_HDA_AMP_NONE,
9ae3a8
+    },
9ae3a8
+};
9ae3a8
+
9ae3a8
+/* output: root node */
9ae3a8
+static const desc_param output_params_root[] = {
9ae3a8
+    {
9ae3a8
+        .id  = AC_PAR_VENDOR_ID,
9ae3a8
+        .val = QEMU_HDA_ID_OUTPUT,
9ae3a8
+    },{
9ae3a8
+        .id  = AC_PAR_SUBSYSTEM_ID,
9ae3a8
+        .val = QEMU_HDA_ID_OUTPUT,
9ae3a8
+    },{
9ae3a8
+        .id  = AC_PAR_REV_ID,
9ae3a8
+        .val = 0x00100101,
9ae3a8
+    },{
9ae3a8
+        .id  = AC_PAR_NODE_COUNT,
9ae3a8
+        .val = 0x00010001,
9ae3a8
+    },
9ae3a8
+};
9ae3a8
+
9ae3a8
+/* output: audio function */
9ae3a8
+static const desc_param output_params_audio_func[] = {
9ae3a8
+    {
9ae3a8
+        .id  = AC_PAR_FUNCTION_TYPE,
9ae3a8
+        .val = AC_GRP_AUDIO_FUNCTION,
9ae3a8
+    },{
9ae3a8
+        .id  = AC_PAR_SUBSYSTEM_ID,
9ae3a8
+        .val = QEMU_HDA_ID_OUTPUT,
9ae3a8
+    },{
9ae3a8
+        .id  = AC_PAR_NODE_COUNT,
9ae3a8
+        .val = 0x00020002,
9ae3a8
+    },{
9ae3a8
+        .id  = AC_PAR_PCM,
9ae3a8
+        .val = QEMU_HDA_PCM_FORMATS,
9ae3a8
+    },{
9ae3a8
+        .id  = AC_PAR_STREAM,
9ae3a8
+        .val = AC_SUPFMT_PCM,
9ae3a8
+    },{
9ae3a8
+        .id  = AC_PAR_AMP_IN_CAP,
9ae3a8
+        .val = QEMU_HDA_AMP_NONE,
9ae3a8
+    },{
9ae3a8
+        .id  = AC_PAR_AMP_OUT_CAP,
9ae3a8
+        .val = QEMU_HDA_AMP_NONE,
9ae3a8
+    },{
9ae3a8
+        .id  = AC_PAR_GPIO_CAP,
9ae3a8
+        .val = 0,
9ae3a8
+    },{
9ae3a8
+        .id  = AC_PAR_AUDIO_FG_CAP,
9ae3a8
+        .val = 0x00000808,
9ae3a8
+    },{
9ae3a8
+        .id  = AC_PAR_POWER_STATE,
9ae3a8
+        .val = 0,
9ae3a8
+    },
9ae3a8
+};
9ae3a8
+
9ae3a8
+/* output: nodes */
9ae3a8
+static const desc_node output_nodes[] = {
9ae3a8
+    {
9ae3a8
+        .nid     = AC_NODE_ROOT,
9ae3a8
+        .name    = "root",
9ae3a8
+        .params  = output_params_root,
9ae3a8
+        .nparams = ARRAY_SIZE(output_params_root),
9ae3a8
+    },{
9ae3a8
+        .nid     = 1,
9ae3a8
+        .name    = "func",
9ae3a8
+        .params  = output_params_audio_func,
9ae3a8
+        .nparams = ARRAY_SIZE(output_params_audio_func),
9ae3a8
+    },{
9ae3a8
+        .nid     = 2,
9ae3a8
+        .name    = "dac",
9ae3a8
+        .params  = common_params_audio_dac,
9ae3a8
+        .nparams = ARRAY_SIZE(common_params_audio_dac),
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
+        .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
+                    (AC_JACK_COLOR_GREEN  << AC_DEFCFG_COLOR_SHIFT)     |
9ae3a8
+                    0x10),
9ae3a8
+        .pinctl  = AC_PINCTL_OUT_EN,
9ae3a8
+        .conn    = (uint32_t[]) { 2 },
9ae3a8
+    }
9ae3a8
+};
9ae3a8
+
9ae3a8
+/* output: codec */
9ae3a8
+static const desc_codec output = {
9ae3a8
+    .name   = "output",
9ae3a8
+    .iid    = QEMU_HDA_ID_OUTPUT,
9ae3a8
+    .nodes  = output_nodes,
9ae3a8
+    .nnodes = ARRAY_SIZE(output_nodes),
9ae3a8
+};
9ae3a8
+
9ae3a8
+/* duplex: root node */
9ae3a8
+static const desc_param duplex_params_root[] = {
9ae3a8
+    {
9ae3a8
+        .id  = AC_PAR_VENDOR_ID,
9ae3a8
+        .val = QEMU_HDA_ID_DUPLEX,
9ae3a8
+    },{
9ae3a8
+        .id  = AC_PAR_SUBSYSTEM_ID,
9ae3a8
+        .val = QEMU_HDA_ID_DUPLEX,
9ae3a8
+    },{
9ae3a8
+        .id  = AC_PAR_REV_ID,
9ae3a8
+        .val = 0x00100101,
9ae3a8
+    },{
9ae3a8
+        .id  = AC_PAR_NODE_COUNT,
9ae3a8
+        .val = 0x00010001,
9ae3a8
+    },
9ae3a8
+};
9ae3a8
+
9ae3a8
+/* duplex: audio function */
9ae3a8
+static const desc_param duplex_params_audio_func[] = {
9ae3a8
+    {
9ae3a8
+        .id  = AC_PAR_FUNCTION_TYPE,
9ae3a8
+        .val = AC_GRP_AUDIO_FUNCTION,
9ae3a8
+    },{
9ae3a8
+        .id  = AC_PAR_SUBSYSTEM_ID,
9ae3a8
+        .val = QEMU_HDA_ID_DUPLEX,
9ae3a8
+    },{
9ae3a8
+        .id  = AC_PAR_NODE_COUNT,
9ae3a8
+        .val = 0x00020004,
9ae3a8
+    },{
9ae3a8
+        .id  = AC_PAR_PCM,
9ae3a8
+        .val = QEMU_HDA_PCM_FORMATS,
9ae3a8
+    },{
9ae3a8
+        .id  = AC_PAR_STREAM,
9ae3a8
+        .val = AC_SUPFMT_PCM,
9ae3a8
+    },{
9ae3a8
+        .id  = AC_PAR_AMP_IN_CAP,
9ae3a8
+        .val = QEMU_HDA_AMP_NONE,
9ae3a8
+    },{
9ae3a8
+        .id  = AC_PAR_AMP_OUT_CAP,
9ae3a8
+        .val = QEMU_HDA_AMP_NONE,
9ae3a8
+    },{
9ae3a8
+        .id  = AC_PAR_GPIO_CAP,
9ae3a8
+        .val = 0,
9ae3a8
+    },{
9ae3a8
+        .id  = AC_PAR_AUDIO_FG_CAP,
9ae3a8
+        .val = 0x00000808,
9ae3a8
+    },{
9ae3a8
+        .id  = AC_PAR_POWER_STATE,
9ae3a8
+        .val = 0,
9ae3a8
+    },
9ae3a8
+};
9ae3a8
+
9ae3a8
+/* duplex: nodes */
9ae3a8
+static const desc_node duplex_nodes[] = {
9ae3a8
+    {
9ae3a8
+        .nid     = AC_NODE_ROOT,
9ae3a8
+        .name    = "root",
9ae3a8
+        .params  = duplex_params_root,
9ae3a8
+        .nparams = ARRAY_SIZE(duplex_params_root),
9ae3a8
+    },{
9ae3a8
+        .nid     = 1,
9ae3a8
+        .name    = "func",
9ae3a8
+        .params  = duplex_params_audio_func,
9ae3a8
+        .nparams = ARRAY_SIZE(duplex_params_audio_func),
9ae3a8
+    },{
9ae3a8
+        .nid     = 2,
9ae3a8
+        .name    = "dac",
9ae3a8
+        .params  = common_params_audio_dac,
9ae3a8
+        .nparams = ARRAY_SIZE(common_params_audio_dac),
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
+        .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
+                    (AC_JACK_COLOR_GREEN  << AC_DEFCFG_COLOR_SHIFT)     |
9ae3a8
+                    0x10),
9ae3a8
+        .pinctl  = AC_PINCTL_OUT_EN,
9ae3a8
+        .conn    = (uint32_t[]) { 2 },
9ae3a8
+    },{
9ae3a8
+        .nid     = 4,
9ae3a8
+        .name    = "adc",
9ae3a8
+        .params  = common_params_audio_adc,
9ae3a8
+        .nparams = ARRAY_SIZE(common_params_audio_adc),
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
+        .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
+                    (AC_JACK_COLOR_RED    << AC_DEFCFG_COLOR_SHIFT)     |
9ae3a8
+                    0x20),
9ae3a8
+        .pinctl  = AC_PINCTL_IN_EN,
9ae3a8
+    }
9ae3a8
+};
9ae3a8
+
9ae3a8
+/* duplex: codec */
9ae3a8
+static const desc_codec duplex = {
9ae3a8
+    .name   = "duplex",
9ae3a8
+    .iid    = QEMU_HDA_ID_DUPLEX,
9ae3a8
+    .nodes  = duplex_nodes,
9ae3a8
+    .nnodes = ARRAY_SIZE(duplex_nodes),
9ae3a8
+};
9ae3a8
+
9ae3a8
+/* micro: root node */
9ae3a8
+static const desc_param micro_params_root[] = {
9ae3a8
+    {
9ae3a8
+        .id  = AC_PAR_VENDOR_ID,
9ae3a8
+        .val = QEMU_HDA_ID_MICRO,
9ae3a8
+    },{
9ae3a8
+        .id  = AC_PAR_SUBSYSTEM_ID,
9ae3a8
+        .val = QEMU_HDA_ID_MICRO,
9ae3a8
+    },{
9ae3a8
+        .id  = AC_PAR_REV_ID,
9ae3a8
+        .val = 0x00100101,
9ae3a8
+    },{
9ae3a8
+        .id  = AC_PAR_NODE_COUNT,
9ae3a8
+        .val = 0x00010001,
9ae3a8
+    },
9ae3a8
+};
9ae3a8
+
9ae3a8
+/* micro: audio function */
9ae3a8
+static const desc_param micro_params_audio_func[] = {
9ae3a8
+    {
9ae3a8
+        .id  = AC_PAR_FUNCTION_TYPE,
9ae3a8
+        .val = AC_GRP_AUDIO_FUNCTION,
9ae3a8
+    },{
9ae3a8
+        .id  = AC_PAR_SUBSYSTEM_ID,
9ae3a8
+        .val = QEMU_HDA_ID_MICRO,
9ae3a8
+    },{
9ae3a8
+        .id  = AC_PAR_NODE_COUNT,
9ae3a8
+        .val = 0x00020004,
9ae3a8
+    },{
9ae3a8
+        .id  = AC_PAR_PCM,
9ae3a8
+        .val = QEMU_HDA_PCM_FORMATS,
9ae3a8
+    },{
9ae3a8
+        .id  = AC_PAR_STREAM,
9ae3a8
+        .val = AC_SUPFMT_PCM,
9ae3a8
+    },{
9ae3a8
+        .id  = AC_PAR_AMP_IN_CAP,
9ae3a8
+        .val = QEMU_HDA_AMP_NONE,
9ae3a8
+    },{
9ae3a8
+        .id  = AC_PAR_AMP_OUT_CAP,
9ae3a8
+        .val = QEMU_HDA_AMP_NONE,
9ae3a8
+    },{
9ae3a8
+        .id  = AC_PAR_GPIO_CAP,
9ae3a8
+        .val = 0,
9ae3a8
+    },{
9ae3a8
+        .id  = AC_PAR_AUDIO_FG_CAP,
9ae3a8
+        .val = 0x00000808,
9ae3a8
+    },{
9ae3a8
+        .id  = AC_PAR_POWER_STATE,
9ae3a8
+        .val = 0,
9ae3a8
+    },
9ae3a8
+};
9ae3a8
+
9ae3a8
+/* micro: nodes */
9ae3a8
+static const desc_node micro_nodes[] = {
9ae3a8
+    {
9ae3a8
+        .nid     = AC_NODE_ROOT,
9ae3a8
+        .name    = "root",
9ae3a8
+        .params  = micro_params_root,
9ae3a8
+        .nparams = ARRAY_SIZE(micro_params_root),
9ae3a8
+    },{
9ae3a8
+        .nid     = 1,
9ae3a8
+        .name    = "func",
9ae3a8
+        .params  = micro_params_audio_func,
9ae3a8
+        .nparams = ARRAY_SIZE(micro_params_audio_func),
9ae3a8
+    },{
9ae3a8
+        .nid     = 2,
9ae3a8
+        .name    = "dac",
9ae3a8
+        .params  = common_params_audio_dac,
9ae3a8
+        .nparams = ARRAY_SIZE(common_params_audio_dac),
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
+        .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
+                    (AC_JACK_COLOR_GREEN  << AC_DEFCFG_COLOR_SHIFT)     |
9ae3a8
+                    0x10),
9ae3a8
+        .pinctl  = AC_PINCTL_OUT_EN,
9ae3a8
+        .conn    = (uint32_t[]) { 2 },
9ae3a8
+    },{
9ae3a8
+        .nid     = 4,
9ae3a8
+        .name    = "adc",
9ae3a8
+        .params  = common_params_audio_adc,
9ae3a8
+        .nparams = ARRAY_SIZE(common_params_audio_adc),
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
+        .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
+                    (AC_JACK_COLOR_RED    << AC_DEFCFG_COLOR_SHIFT)     |
9ae3a8
+                    0x20),
9ae3a8
+        .pinctl  = AC_PINCTL_IN_EN,
9ae3a8
+    }
9ae3a8
+};
9ae3a8
+
9ae3a8
+/* micro: codec */
9ae3a8
+static const desc_codec micro = {
9ae3a8
+    .name   = "micro",
9ae3a8
+    .iid    = QEMU_HDA_ID_MICRO,
9ae3a8
+    .nodes  = micro_nodes,
9ae3a8
+    .nnodes = ARRAY_SIZE(micro_nodes),
9ae3a8
+};
9ae3a8
diff --git a/hw/audio/hda-codec.c b/hw/audio/hda-codec.c
9ae3a8
index 362d8c0..cb498fc 100644
9ae3a8
--- a/hw/audio/hda-codec.c
9ae3a8
+++ b/hw/audio/hda-codec.c
9ae3a8
@@ -118,429 +118,7 @@ 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 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
-# define QEMU_HDA_AMP_CAPS                                              \
9ae3a8
-    (AC_AMPCAP_MUTE |                                                   \
9ae3a8
-     (QEMU_HDA_AMP_STEPS << AC_AMPCAP_OFFSET_SHIFT)    |                \
9ae3a8
-     (QEMU_HDA_AMP_STEPS << AC_AMPCAP_NUM_STEPS_SHIFT) |                \
9ae3a8
-     (3                  << AC_AMPCAP_STEP_SIZE_SHIFT))
9ae3a8
-#else
9ae3a8
-# define QEMU_HDA_ID_OUTPUT  ((QEMU_HDA_ID_VENDOR << 16) | 0x11)
9ae3a8
-# define QEMU_HDA_ID_DUPLEX  ((QEMU_HDA_ID_VENDOR << 16) | 0x21)
9ae3a8
-# define QEMU_HDA_ID_MICRO   ((QEMU_HDA_ID_VENDOR << 16) | 0x31)
9ae3a8
-# define QEMU_HDA_AMP_CAPS   QEMU_HDA_AMP_NONE
9ae3a8
-#endif
9ae3a8
-
9ae3a8
-/* common: audio output widget */
9ae3a8
-static const desc_param common_params_audio_dac[] = {
9ae3a8
-    {
9ae3a8
-        .id  = AC_PAR_AUDIO_WIDGET_CAP,
9ae3a8
-        .val = ((AC_WID_AUD_OUT << AC_WCAP_TYPE_SHIFT) |
9ae3a8
-                AC_WCAP_FORMAT_OVRD |
9ae3a8
-                AC_WCAP_AMP_OVRD |
9ae3a8
-                AC_WCAP_OUT_AMP |
9ae3a8
-                AC_WCAP_STEREO),
9ae3a8
-    },{
9ae3a8
-        .id  = AC_PAR_PCM,
9ae3a8
-        .val = QEMU_HDA_PCM_FORMATS,
9ae3a8
-    },{
9ae3a8
-        .id  = AC_PAR_STREAM,
9ae3a8
-        .val = AC_SUPFMT_PCM,
9ae3a8
-    },{
9ae3a8
-        .id  = AC_PAR_AMP_IN_CAP,
9ae3a8
-        .val = QEMU_HDA_AMP_NONE,
9ae3a8
-    },{
9ae3a8
-        .id  = AC_PAR_AMP_OUT_CAP,
9ae3a8
-        .val = QEMU_HDA_AMP_CAPS,
9ae3a8
-    },
9ae3a8
-};
9ae3a8
-
9ae3a8
-/* common: audio input widget */
9ae3a8
-static const desc_param common_params_audio_adc[] = {
9ae3a8
-    {
9ae3a8
-        .id  = AC_PAR_AUDIO_WIDGET_CAP,
9ae3a8
-        .val = ((AC_WID_AUD_IN << AC_WCAP_TYPE_SHIFT) |
9ae3a8
-                AC_WCAP_CONN_LIST |
9ae3a8
-                AC_WCAP_FORMAT_OVRD |
9ae3a8
-                AC_WCAP_AMP_OVRD |
9ae3a8
-                AC_WCAP_IN_AMP |
9ae3a8
-                AC_WCAP_STEREO),
9ae3a8
-    },{
9ae3a8
-        .id  = AC_PAR_CONNLIST_LEN,
9ae3a8
-        .val = 1,
9ae3a8
-    },{
9ae3a8
-        .id  = AC_PAR_PCM,
9ae3a8
-        .val = QEMU_HDA_PCM_FORMATS,
9ae3a8
-    },{
9ae3a8
-        .id  = AC_PAR_STREAM,
9ae3a8
-        .val = AC_SUPFMT_PCM,
9ae3a8
-    },{
9ae3a8
-        .id  = AC_PAR_AMP_IN_CAP,
9ae3a8
-        .val = QEMU_HDA_AMP_CAPS,
9ae3a8
-    },{
9ae3a8
-        .id  = AC_PAR_AMP_OUT_CAP,
9ae3a8
-        .val = QEMU_HDA_AMP_NONE,
9ae3a8
-    },
9ae3a8
-};
9ae3a8
-
9ae3a8
-/* common: pin widget (line-out) */
9ae3a8
-static const desc_param common_params_audio_lineout[] = {
9ae3a8
-    {
9ae3a8
-        .id  = AC_PAR_AUDIO_WIDGET_CAP,
9ae3a8
-        .val = ((AC_WID_PIN << AC_WCAP_TYPE_SHIFT) |
9ae3a8
-                AC_WCAP_CONN_LIST |
9ae3a8
-                AC_WCAP_STEREO),
9ae3a8
-    },{
9ae3a8
-        .id  = AC_PAR_PIN_CAP,
9ae3a8
-        .val = AC_PINCAP_OUT,
9ae3a8
-    },{
9ae3a8
-        .id  = AC_PAR_CONNLIST_LEN,
9ae3a8
-        .val = 1,
9ae3a8
-    },{
9ae3a8
-        .id  = AC_PAR_AMP_IN_CAP,
9ae3a8
-        .val = QEMU_HDA_AMP_NONE,
9ae3a8
-    },{
9ae3a8
-        .id  = AC_PAR_AMP_OUT_CAP,
9ae3a8
-        .val = QEMU_HDA_AMP_NONE,
9ae3a8
-    },
9ae3a8
-};
9ae3a8
-
9ae3a8
-/* common: pin widget (line-in) */
9ae3a8
-static const desc_param common_params_audio_linein[] = {
9ae3a8
-    {
9ae3a8
-        .id  = AC_PAR_AUDIO_WIDGET_CAP,
9ae3a8
-        .val = ((AC_WID_PIN << AC_WCAP_TYPE_SHIFT) |
9ae3a8
-                AC_WCAP_STEREO),
9ae3a8
-    },{
9ae3a8
-        .id  = AC_PAR_PIN_CAP,
9ae3a8
-        .val = AC_PINCAP_IN,
9ae3a8
-    },{
9ae3a8
-        .id  = AC_PAR_AMP_IN_CAP,
9ae3a8
-        .val = QEMU_HDA_AMP_NONE,
9ae3a8
-    },{
9ae3a8
-        .id  = AC_PAR_AMP_OUT_CAP,
9ae3a8
-        .val = QEMU_HDA_AMP_NONE,
9ae3a8
-    },
9ae3a8
-};
9ae3a8
-
9ae3a8
-/* output: root node */
9ae3a8
-static const desc_param output_params_root[] = {
9ae3a8
-    {
9ae3a8
-        .id  = AC_PAR_VENDOR_ID,
9ae3a8
-        .val = QEMU_HDA_ID_OUTPUT,
9ae3a8
-    },{
9ae3a8
-        .id  = AC_PAR_SUBSYSTEM_ID,
9ae3a8
-        .val = QEMU_HDA_ID_OUTPUT,
9ae3a8
-    },{
9ae3a8
-        .id  = AC_PAR_REV_ID,
9ae3a8
-        .val = 0x00100101,
9ae3a8
-    },{
9ae3a8
-        .id  = AC_PAR_NODE_COUNT,
9ae3a8
-        .val = 0x00010001,
9ae3a8
-    },
9ae3a8
-};
9ae3a8
-
9ae3a8
-/* output: audio function */
9ae3a8
-static const desc_param output_params_audio_func[] = {
9ae3a8
-    {
9ae3a8
-        .id  = AC_PAR_FUNCTION_TYPE,
9ae3a8
-        .val = AC_GRP_AUDIO_FUNCTION,
9ae3a8
-    },{
9ae3a8
-        .id  = AC_PAR_SUBSYSTEM_ID,
9ae3a8
-        .val = QEMU_HDA_ID_OUTPUT,
9ae3a8
-    },{
9ae3a8
-        .id  = AC_PAR_NODE_COUNT,
9ae3a8
-        .val = 0x00020002,
9ae3a8
-    },{
9ae3a8
-        .id  = AC_PAR_PCM,
9ae3a8
-        .val = QEMU_HDA_PCM_FORMATS,
9ae3a8
-    },{
9ae3a8
-        .id  = AC_PAR_STREAM,
9ae3a8
-        .val = AC_SUPFMT_PCM,
9ae3a8
-    },{
9ae3a8
-        .id  = AC_PAR_AMP_IN_CAP,
9ae3a8
-        .val = QEMU_HDA_AMP_NONE,
9ae3a8
-    },{
9ae3a8
-        .id  = AC_PAR_AMP_OUT_CAP,
9ae3a8
-        .val = QEMU_HDA_AMP_NONE,
9ae3a8
-    },{
9ae3a8
-        .id  = AC_PAR_GPIO_CAP,
9ae3a8
-        .val = 0,
9ae3a8
-    },{
9ae3a8
-        .id  = AC_PAR_AUDIO_FG_CAP,
9ae3a8
-        .val = 0x00000808,
9ae3a8
-    },{
9ae3a8
-        .id  = AC_PAR_POWER_STATE,
9ae3a8
-        .val = 0,
9ae3a8
-    },
9ae3a8
-};
9ae3a8
-
9ae3a8
-/* output: nodes */
9ae3a8
-static const desc_node output_nodes[] = {
9ae3a8
-    {
9ae3a8
-        .nid     = AC_NODE_ROOT,
9ae3a8
-        .name    = "root",
9ae3a8
-        .params  = output_params_root,
9ae3a8
-        .nparams = ARRAY_SIZE(output_params_root),
9ae3a8
-    },{
9ae3a8
-        .nid     = 1,
9ae3a8
-        .name    = "func",
9ae3a8
-        .params  = output_params_audio_func,
9ae3a8
-        .nparams = ARRAY_SIZE(output_params_audio_func),
9ae3a8
-    },{
9ae3a8
-        .nid     = 2,
9ae3a8
-        .name    = "dac",
9ae3a8
-        .params  = common_params_audio_dac,
9ae3a8
-        .nparams = ARRAY_SIZE(common_params_audio_dac),
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
-        .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
-                    (AC_JACK_COLOR_GREEN  << AC_DEFCFG_COLOR_SHIFT)     |
9ae3a8
-                    0x10),
9ae3a8
-        .pinctl  = AC_PINCTL_OUT_EN,
9ae3a8
-        .conn    = (uint32_t[]) { 2 },
9ae3a8
-    }
9ae3a8
-};
9ae3a8
-
9ae3a8
-/* output: codec */
9ae3a8
-static const desc_codec output = {
9ae3a8
-    .name   = "output",
9ae3a8
-    .iid    = QEMU_HDA_ID_OUTPUT,
9ae3a8
-    .nodes  = output_nodes,
9ae3a8
-    .nnodes = ARRAY_SIZE(output_nodes),
9ae3a8
-};
9ae3a8
-
9ae3a8
-/* duplex: root node */
9ae3a8
-static const desc_param duplex_params_root[] = {
9ae3a8
-    {
9ae3a8
-        .id  = AC_PAR_VENDOR_ID,
9ae3a8
-        .val = QEMU_HDA_ID_DUPLEX,
9ae3a8
-    },{
9ae3a8
-        .id  = AC_PAR_SUBSYSTEM_ID,
9ae3a8
-        .val = QEMU_HDA_ID_DUPLEX,
9ae3a8
-    },{
9ae3a8
-        .id  = AC_PAR_REV_ID,
9ae3a8
-        .val = 0x00100101,
9ae3a8
-    },{
9ae3a8
-        .id  = AC_PAR_NODE_COUNT,
9ae3a8
-        .val = 0x00010001,
9ae3a8
-    },
9ae3a8
-};
9ae3a8
-
9ae3a8
-/* duplex: audio function */
9ae3a8
-static const desc_param duplex_params_audio_func[] = {
9ae3a8
-    {
9ae3a8
-        .id  = AC_PAR_FUNCTION_TYPE,
9ae3a8
-        .val = AC_GRP_AUDIO_FUNCTION,
9ae3a8
-    },{
9ae3a8
-        .id  = AC_PAR_SUBSYSTEM_ID,
9ae3a8
-        .val = QEMU_HDA_ID_DUPLEX,
9ae3a8
-    },{
9ae3a8
-        .id  = AC_PAR_NODE_COUNT,
9ae3a8
-        .val = 0x00020004,
9ae3a8
-    },{
9ae3a8
-        .id  = AC_PAR_PCM,
9ae3a8
-        .val = QEMU_HDA_PCM_FORMATS,
9ae3a8
-    },{
9ae3a8
-        .id  = AC_PAR_STREAM,
9ae3a8
-        .val = AC_SUPFMT_PCM,
9ae3a8
-    },{
9ae3a8
-        .id  = AC_PAR_AMP_IN_CAP,
9ae3a8
-        .val = QEMU_HDA_AMP_NONE,
9ae3a8
-    },{
9ae3a8
-        .id  = AC_PAR_AMP_OUT_CAP,
9ae3a8
-        .val = QEMU_HDA_AMP_NONE,
9ae3a8
-    },{
9ae3a8
-        .id  = AC_PAR_GPIO_CAP,
9ae3a8
-        .val = 0,
9ae3a8
-    },{
9ae3a8
-        .id  = AC_PAR_AUDIO_FG_CAP,
9ae3a8
-        .val = 0x00000808,
9ae3a8
-    },{
9ae3a8
-        .id  = AC_PAR_POWER_STATE,
9ae3a8
-        .val = 0,
9ae3a8
-    },
9ae3a8
-};
9ae3a8
-
9ae3a8
-/* duplex: nodes */
9ae3a8
-static const desc_node duplex_nodes[] = {
9ae3a8
-    {
9ae3a8
-        .nid     = AC_NODE_ROOT,
9ae3a8
-        .name    = "root",
9ae3a8
-        .params  = duplex_params_root,
9ae3a8
-        .nparams = ARRAY_SIZE(duplex_params_root),
9ae3a8
-    },{
9ae3a8
-        .nid     = 1,
9ae3a8
-        .name    = "func",
9ae3a8
-        .params  = duplex_params_audio_func,
9ae3a8
-        .nparams = ARRAY_SIZE(duplex_params_audio_func),
9ae3a8
-    },{
9ae3a8
-        .nid     = 2,
9ae3a8
-        .name    = "dac",
9ae3a8
-        .params  = common_params_audio_dac,
9ae3a8
-        .nparams = ARRAY_SIZE(common_params_audio_dac),
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
-        .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
-                    (AC_JACK_COLOR_GREEN  << AC_DEFCFG_COLOR_SHIFT)     |
9ae3a8
-                    0x10),
9ae3a8
-        .pinctl  = AC_PINCTL_OUT_EN,
9ae3a8
-        .conn    = (uint32_t[]) { 2 },
9ae3a8
-    },{
9ae3a8
-        .nid     = 4,
9ae3a8
-        .name    = "adc",
9ae3a8
-        .params  = common_params_audio_adc,
9ae3a8
-        .nparams = ARRAY_SIZE(common_params_audio_adc),
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
-        .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
-                    (AC_JACK_COLOR_RED    << AC_DEFCFG_COLOR_SHIFT)     |
9ae3a8
-                    0x20),
9ae3a8
-        .pinctl  = AC_PINCTL_IN_EN,
9ae3a8
-    }
9ae3a8
-};
9ae3a8
-
9ae3a8
-/* duplex: codec */
9ae3a8
-static const desc_codec duplex = {
9ae3a8
-    .name   = "duplex",
9ae3a8
-    .iid    = QEMU_HDA_ID_DUPLEX,
9ae3a8
-    .nodes  = duplex_nodes,
9ae3a8
-    .nnodes = ARRAY_SIZE(duplex_nodes),
9ae3a8
-};
9ae3a8
-
9ae3a8
-/* micro: root node */
9ae3a8
-static const desc_param micro_params_root[] = {
9ae3a8
-    {
9ae3a8
-        .id  = AC_PAR_VENDOR_ID,
9ae3a8
-        .val = QEMU_HDA_ID_MICRO,
9ae3a8
-    },{
9ae3a8
-        .id  = AC_PAR_SUBSYSTEM_ID,
9ae3a8
-        .val = QEMU_HDA_ID_MICRO,
9ae3a8
-    },{
9ae3a8
-        .id  = AC_PAR_REV_ID,
9ae3a8
-        .val = 0x00100101,
9ae3a8
-    },{
9ae3a8
-        .id  = AC_PAR_NODE_COUNT,
9ae3a8
-        .val = 0x00010001,
9ae3a8
-    },
9ae3a8
-};
9ae3a8
-
9ae3a8
-/* micro: audio function */
9ae3a8
-static const desc_param micro_params_audio_func[] = {
9ae3a8
-    {
9ae3a8
-        .id  = AC_PAR_FUNCTION_TYPE,
9ae3a8
-        .val = AC_GRP_AUDIO_FUNCTION,
9ae3a8
-    },{
9ae3a8
-        .id  = AC_PAR_SUBSYSTEM_ID,
9ae3a8
-        .val = QEMU_HDA_ID_MICRO,
9ae3a8
-    },{
9ae3a8
-        .id  = AC_PAR_NODE_COUNT,
9ae3a8
-        .val = 0x00020004,
9ae3a8
-    },{
9ae3a8
-        .id  = AC_PAR_PCM,
9ae3a8
-        .val = QEMU_HDA_PCM_FORMATS,
9ae3a8
-    },{
9ae3a8
-        .id  = AC_PAR_STREAM,
9ae3a8
-        .val = AC_SUPFMT_PCM,
9ae3a8
-    },{
9ae3a8
-        .id  = AC_PAR_AMP_IN_CAP,
9ae3a8
-        .val = QEMU_HDA_AMP_NONE,
9ae3a8
-    },{
9ae3a8
-        .id  = AC_PAR_AMP_OUT_CAP,
9ae3a8
-        .val = QEMU_HDA_AMP_NONE,
9ae3a8
-    },{
9ae3a8
-        .id  = AC_PAR_GPIO_CAP,
9ae3a8
-        .val = 0,
9ae3a8
-    },{
9ae3a8
-        .id  = AC_PAR_AUDIO_FG_CAP,
9ae3a8
-        .val = 0x00000808,
9ae3a8
-    },{
9ae3a8
-        .id  = AC_PAR_POWER_STATE,
9ae3a8
-        .val = 0,
9ae3a8
-    },
9ae3a8
-};
9ae3a8
-
9ae3a8
-/* micro: nodes */
9ae3a8
-static const desc_node micro_nodes[] = {
9ae3a8
-    {
9ae3a8
-        .nid     = AC_NODE_ROOT,
9ae3a8
-        .name    = "root",
9ae3a8
-        .params  = micro_params_root,
9ae3a8
-        .nparams = ARRAY_SIZE(micro_params_root),
9ae3a8
-    },{
9ae3a8
-        .nid     = 1,
9ae3a8
-        .name    = "func",
9ae3a8
-        .params  = micro_params_audio_func,
9ae3a8
-        .nparams = ARRAY_SIZE(micro_params_audio_func),
9ae3a8
-    },{
9ae3a8
-        .nid     = 2,
9ae3a8
-        .name    = "dac",
9ae3a8
-        .params  = common_params_audio_dac,
9ae3a8
-        .nparams = ARRAY_SIZE(common_params_audio_dac),
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
-        .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
-                    (AC_JACK_COLOR_GREEN  << AC_DEFCFG_COLOR_SHIFT)     |
9ae3a8
-                    0x10),
9ae3a8
-        .pinctl  = AC_PINCTL_OUT_EN,
9ae3a8
-        .conn    = (uint32_t[]) { 2 },
9ae3a8
-    },{
9ae3a8
-        .nid     = 4,
9ae3a8
-        .name    = "adc",
9ae3a8
-        .params  = common_params_audio_adc,
9ae3a8
-        .nparams = ARRAY_SIZE(common_params_audio_adc),
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
-        .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
-                    (AC_JACK_COLOR_RED    << AC_DEFCFG_COLOR_SHIFT)     |
9ae3a8
-                    0x20),
9ae3a8
-        .pinctl  = AC_PINCTL_IN_EN,
9ae3a8
-    }
9ae3a8
-};
9ae3a8
-
9ae3a8
-/* micro: codec */
9ae3a8
-static const desc_codec micro = {
9ae3a8
-    .name   = "micro",
9ae3a8
-    .iid    = QEMU_HDA_ID_MICRO,
9ae3a8
-    .nodes  = micro_nodes,
9ae3a8
-    .nnodes = ARRAY_SIZE(micro_nodes),
9ae3a8
-};
9ae3a8
-
9ae3a8
+#include "hda-codec-common.h"
9ae3a8
 /* -------------------------------------------------------------------------- */
9ae3a8
 
9ae3a8
 static const char *fmt2name[] = {
9ae3a8
-- 
9ae3a8
1.7.1
9ae3a8