Re: [PATCH] ASoC: amd: acp: soc-acpi: add is_device_rt712_vb() helper

From: Mario Limonciello

Date: Mon Jan 12 2026 - 09:12:22 EST


On 1/11/26 11:52 PM, Mukunda,Vijendar wrote:
On 11/01/26 04:17, Mario Limonciello wrote:


On 1/10/2026 12:44 AM, Vijendar Mukunda wrote:
Add a filter to skip the RT172 VB configuration if a SmartMic Function
is not found in the SDCA descriptors.

If the ACPI information is incorrect this can only be quirked further
with DMI information.

Signed-off-by: Vijendar Mukunda <Vijendar.Mukunda@xxxxxxx>

Thanks for the comments below, no remaining concerns by me.

Reviewed-by: Mario Limonciello (AMD) <superm1@xxxxxxxxxx>

---
  sound/soc/amd/acp/Kconfig                    |  6 +++
  sound/soc/amd/acp/Makefile                   |  2 +
  sound/soc/amd/acp/amd-acp70-acpi-match.c     | 50 ++++++++++++++++++++
  sound/soc/amd/acp/soc-acpi-amd-sdca-quirks.c | 42 ++++++++++++++++
  sound/soc/amd/acp/soc-acpi-amd-sdca-quirks.h | 14 ++++++
  5 files changed, 114 insertions(+)
  create mode 100644 sound/soc/amd/acp/soc-acpi-amd-sdca-quirks.c
  create mode 100644 sound/soc/amd/acp/soc-acpi-amd-sdca-quirks.h

diff --git a/sound/soc/amd/acp/Kconfig b/sound/soc/amd/acp/Kconfig
index c2a60bc80ee6..ed2fa055f7f6 100644
--- a/sound/soc/amd/acp/Kconfig
+++ b/sound/soc/amd/acp/Kconfig
@@ -15,8 +15,14 @@ config SND_SOC_AMD_ACP_COMMON
    config SND_SOC_ACPI_AMD_MATCH
      tristate
+    select SND_SOC_ACPI_AMD_SDCA_QUIRKS
      select SND_SOC_ACPI if ACPI
  +config SND_SOC_ACPI_AMD_SDCA_QUIRKS
+    tristate
+    depends on ACPI
+    depends on SND_SOC_SDCA

Does this need a description?
Not required. This Config is not directly populated where user can go and select.

+
  if SND_SOC_AMD_ACP_COMMON
    config SND_SOC_AMD_ACP_PDM
diff --git a/sound/soc/amd/acp/Makefile b/sound/soc/amd/acp/Makefile
index 08220b9a3802..81d23aded348 100644
--- a/sound/soc/amd/acp/Makefile
+++ b/sound/soc/amd/acp/Makefile
@@ -27,6 +27,7 @@ snd-soc-acpi-amd-match-y := amd-acp63-acpi-match.o
amd-acp70-acpi-match.o
  snd-acp-sdw-mach-y     := acp-sdw-mach-common.o
  snd-acp-sdw-sof-mach-y += acp-sdw-sof-mach.o
  snd-acp-sdw-legacy-mach-y += acp-sdw-legacy-mach.o
+snd-soc-acpi-amd-sdca-quirks-y += soc-acpi-amd-sdca-quirks.o
    obj-$(CONFIG_SND_SOC_AMD_ACP_PCM) += snd-acp-pcm.o
  obj-$(CONFIG_SND_SOC_AMD_ACP_I2S) += snd-acp-i2s.o
@@ -40,6 +41,7 @@ obj-$(CONFIG_SND_AMD_ASOC_REMBRANDT) += snd-acp-rembrandt.o
  obj-$(CONFIG_SND_AMD_ASOC_ACP63) += snd-acp63.o
  obj-$(CONFIG_SND_AMD_ASOC_ACP70) += snd-acp70.o
  +obj-$(CONFIG_SND_SOC_ACPI_AMD_SDCA_QUIRKS) += snd-soc-acpi-amd-sdca-quirks.o
  obj-$(CONFIG_SND_AMD_SOUNDWIRE_ACPI) += snd-amd-sdw-acpi.o
  obj-$(CONFIG_SND_SOC_AMD_MACH_COMMON) += snd-acp-mach.o
  obj-$(CONFIG_SND_SOC_AMD_LEGACY_MACH) += snd-acp-legacy-mach.o
diff --git a/sound/soc/amd/acp/amd-acp70-acpi-match.c
b/sound/soc/amd/acp/amd-acp70-acpi-match.c
index 871b4f054a84..fa39f18578ca 100644
--- a/sound/soc/amd/acp/amd-acp70-acpi-match.c
+++ b/sound/soc/amd/acp/amd-acp70-acpi-match.c
@@ -7,6 +7,7 @@
   */
    #include <sound/soc-acpi.h>
+#include "soc-acpi-amd-sdca-quirks.h"
  #include "../mach-config.h"
    static const struct snd_soc_acpi_endpoint single_endpoint = {
@@ -44,6 +45,39 @@ static const struct snd_soc_acpi_endpoint spk_3_endpoint = {
      .group_id = 1
  };
  +static const struct snd_soc_acpi_endpoint jack_amp_g1_dmic_endpoints[] = {
+    /* Jack Endpoint */
+    {
+        .num = 0,
+        .aggregated = 0,
+        .group_position = 0,
+        .group_id = 0,
+    },
+    /* Amp Endpoint, work as spk_l_endpoint */
+    {
+        .num = 1,
+        .aggregated = 1,
+        .group_position = 0,
+        .group_id = 1,
+    },
+    /* DMIC Endpoint */
+    {
+        .num = 2,
+        .aggregated = 0,
+        .group_position = 0,
+        .group_id = 0,
+    },
+};
+
+static const struct snd_soc_acpi_adr_device rt712_vb_1_group1_adr[] = {
+    {
+        .adr = 0x000130025D071201ull,
+        .num_endpoints = ARRAY_SIZE(jack_amp_g1_dmic_endpoints),
+        .endpoints = jack_amp_g1_dmic_endpoints,
+        .name_prefix = "rt712"
+    }
+};
+
  static const struct snd_soc_acpi_adr_device rt711_rt1316_group_adr[] = {
      {
          .adr = 0x000030025D071101ull,
@@ -254,6 +288,15 @@ static const struct snd_soc_acpi_link_adr
acp70_cs35l56x4_l1[] = {
      {}
  };
  +static const struct snd_soc_acpi_link_adr acp70_alc712_vb_l1[] = {
+    {
+        .mask = BIT(1),
+        .num_adr = ARRAY_SIZE(rt712_vb_1_group1_adr),
+        .adr_d = rt712_vb_1_group1_adr,
+    },
+    {}
+};
+
  static const struct snd_soc_acpi_link_adr acp70_rt722_only[] = {
      {
          .mask = BIT(0),
@@ -308,6 +351,12 @@ struct snd_soc_acpi_mach
snd_soc_acpi_amd_acp70_sdw_machines[] = {
          .links = acp70_cs35l56x4_l1,
          .drv_name = "amd_sdw",
      },
+    {
+        .link_mask = BIT(1),
+        .links = acp70_alc712_vb_l1,
+        .machine_check = snd_soc_acpi_amd_sdca_is_device_rt712_vb,
+        .drv_name = "amd_sdw",
+    },
      {},
  };
  EXPORT_SYMBOL(snd_soc_acpi_amd_acp70_sdw_machines);
@@ -327,3 +376,4 @@ EXPORT_SYMBOL(snd_soc_acpi_amd_acp70_sof_sdw_machines);
  MODULE_DESCRIPTION("AMD ACP7.0 & ACP7.1 tables and support for ACPI
enumeration");
  MODULE_LICENSE("GPL");
  MODULE_AUTHOR("Vijendar.Mukunda@xxxxxxx");
+MODULE_IMPORT_NS("SND_SOC_ACPI_AMD_SDCA_QUIRKS");
diff --git a/sound/soc/amd/acp/soc-acpi-amd-sdca-quirks.c
b/sound/soc/amd/acp/soc-acpi-amd-sdca-quirks.c
new file mode 100644
index 000000000000..63bf9e3c0ae1
--- /dev/null
+++ b/sound/soc/amd/acp/soc-acpi-amd-sdca-quirks.c
@@ -0,0 +1,42 @@
+// SPDX-License-Identifier: GPL-2.0-only
+/*
+ * soc-acpi-amd-sdca-quirks.c - tables and support for SDCA quirks
+ *
+ * Copyright(c) 2025 Advanced Micro Devices, Inc. All rights reserved.

2026 now
 This patch was implemented and posted as a PR in SOF GitHub last month.
That's why the year was mentioned as 2025.

+ *
+ */
+
+#include <linux/soundwire/sdw_amd.h>
+#include <sound/sdca.h>
+#include <sound/soc-acpi.h>
+#include "soc-acpi-amd-sdca-quirks.h"
+
+/*
+ * Pretend machine quirk. The argument type is not the traditional
+ * 'struct snd_soc_acpi_mach' pointer but instead the sdw_amd_ctx
+ * which contains the peripheral information required for the
+ * SoundWire/SDCA filter on the SMART_MIC setup and interface
+ * revision. When the return value is false, the entry in the
+ * 'snd_soc_acpi_mach' table needs to be skipped.
+ */
+bool snd_soc_acpi_amd_sdca_is_device_rt712_vb(void *arg)
+{
+    struct sdw_amd_ctx *ctx = arg;
+    int i;
+
+    if (!ctx)
+        return false;
+
+    for (i = 0; i < ctx->peripherals->num_peripherals; i++) {
+        if (sdca_device_quirk_match(ctx->peripherals->array[i],
+                        SDCA_QUIRKS_RT712_VB))
+            return true;
+    }
+
+    return false;
+}
+EXPORT_SYMBOL_NS(snd_soc_acpi_amd_sdca_is_device_rt712_vb,
"SND_SOC_ACPI_AMD_SDCA_QUIRKS");
+
+MODULE_DESCRIPTION("ASoC ACPI AMD SDCA quirks");
+MODULE_LICENSE("GPL");
+MODULE_IMPORT_NS("SND_SOC_SDCA");
diff --git a/sound/soc/amd/acp/soc-acpi-amd-sdca-quirks.h
b/sound/soc/amd/acp/soc-acpi-amd-sdca-quirks.h
new file mode 100644
index 000000000000..7e345a236da1
--- /dev/null
+++ b/sound/soc/amd/acp/soc-acpi-amd-sdca-quirks.h
@@ -0,0 +1,14 @@
+/* SPDX-License-Identifier: GPL-2.0-only */
+/*
+ * soc-acpi-amd-sdca-quirks.h - tables and support for SDCA quirks
+ *
+ * Copyright(c) 2025 Advanced Micro Devices, Inc. All rights reserved.

2026


+ *
+ */
+
+#ifndef _SND_SOC_ACPI_AMD_SDCA_QUIRKS
+#define _SND_SOC_ACPI_AMD_SDCA_QUIRKS
+
+bool snd_soc_acpi_amd_sdca_is_device_rt712_vb(void *arg);
+
+#endif