From: Connor McAdams <conmanx...@gmail.com>

[ Upstream commit ed93f9750c6c2ed371347d0aac3dcd31cb9cf256 ]

Add AE-7 quirk data for setting of microphone. The AE-7 has no front
panel connector, so only rear-mic/line-in have new commands.

Signed-off-by: Connor McAdams <conmanx...@gmail.com>
Link: https://lore.kernel.org/r/20200825201040.30339-19-conmanx...@gmail.com
Signed-off-by: Takashi Iwai <ti...@suse.de>
Signed-off-by: Sasha Levin <sas...@kernel.org>
---
 sound/pci/hda/patch_ca0132.c | 22 +++++++++++++++++++++-
 1 file changed, 21 insertions(+), 1 deletion(-)

diff --git a/sound/pci/hda/patch_ca0132.c b/sound/pci/hda/patch_ca0132.c
index b7dbf2e7f77af..c68669911de0a 100644
--- a/sound/pci/hda/patch_ca0132.c
+++ b/sound/pci/hda/patch_ca0132.c
@@ -4675,6 +4675,15 @@ static int ca0132_alt_select_in(struct hda_codec *codec)
                        ca0113_mmio_command_set(codec, 0x30, 0x28, 0x00);
                        tmp = FLOAT_THREE;
                        break;
+               case QUIRK_AE7:
+                       ca0113_mmio_command_set(codec, 0x30, 0x28, 0x00);
+                       tmp = FLOAT_THREE;
+                       chipio_set_conn_rate(codec, MEM_CONNID_MICIN2,
+                                       SR_96_000);
+                       chipio_set_conn_rate(codec, MEM_CONNID_MICOUT2,
+                                       SR_96_000);
+                       dspio_set_uint_param(codec, 0x80, 0x01, FLOAT_ZERO);
+                       break;
                default:
                        tmp = FLOAT_ONE;
                        break;
@@ -4720,6 +4729,14 @@ static int ca0132_alt_select_in(struct hda_codec *codec)
                case QUIRK_AE5:
                        ca0113_mmio_command_set(codec, 0x30, 0x28, 0x00);
                        break;
+               case QUIRK_AE7:
+                       ca0113_mmio_command_set(codec, 0x30, 0x28, 0x3f);
+                       chipio_set_conn_rate(codec, MEM_CONNID_MICIN2,
+                                       SR_96_000);
+                       chipio_set_conn_rate(codec, MEM_CONNID_MICOUT2,
+                                       SR_96_000);
+                       dspio_set_uint_param(codec, 0x80, 0x01, FLOAT_ZERO);
+                       break;
                default:
                        break;
                }
@@ -4729,7 +4746,10 @@ static int ca0132_alt_select_in(struct hda_codec *codec)
                if (ca0132_quirk(spec) == QUIRK_R3DI)
                        chipio_set_conn_rate(codec, 0x0F, SR_96_000);
 
-               tmp = FLOAT_ZERO;
+               if (ca0132_quirk(spec) == QUIRK_AE7)
+                       tmp = FLOAT_THREE;
+               else
+                       tmp = FLOAT_ZERO;
                dspio_set_uint_param(codec, 0x80, 0x00, tmp);
 
                switch (ca0132_quirk(spec)) {
-- 
2.25.1

Reply via email to