Commit 744866d2 authored by Pierre-Louis Bossart's avatar Pierre-Louis Bossart Committed by Mark Brown

ASoC: Intel: sof_sdw: remove FOUR_SPEAKER quirks

This patch removes a confusion between speakers and amplifiers.

The existing code keeps track of the number of amplifiers and reports
it in the 'cfg-amp' component string.

The number of speakers is defined with quirks, but those quirks are
not consistently added: in the MeteorLake case, none of the supported
platforms used such a quirk, and UCM does not use the values reported
anyways. The notion of 'FOUR_SPEAKERS' is also obsolete now with some
platforms having more than four speakers.

Let's just remove all this and only report the number of amplifiers.
Signed-off-by: default avatarPierre-Louis Bossart <pierre-louis.bossart@linux.intel.com>
Reviewed-by: default avatarBard Liao <yung-chuan.liao@linux.intel.com>
Link: https://lore.kernel.org/r/20240411220347.131267-6-pierre-louis.bossart@linux.intel.comSigned-off-by: default avatarMark Brown <broonie@kernel.org>
parent b10cb955
...@@ -27,7 +27,7 @@ static void log_quirks(struct device *dev) ...@@ -27,7 +27,7 @@ static void log_quirks(struct device *dev)
dev_dbg(dev, "quirk realtek,jack-detect-source %ld\n", dev_dbg(dev, "quirk realtek,jack-detect-source %ld\n",
SOF_JACK_JDSRC(sof_sdw_quirk)); SOF_JACK_JDSRC(sof_sdw_quirk));
if (sof_sdw_quirk & SOF_SDW_FOUR_SPK) if (sof_sdw_quirk & SOF_SDW_FOUR_SPK)
dev_dbg(dev, "quirk SOF_SDW_FOUR_SPK enabled\n"); dev_err(dev, "quirk SOF_SDW_FOUR_SPK enabled but no longer supported\n");
if (sof_sdw_quirk & SOF_SDW_TGL_HDMI) if (sof_sdw_quirk & SOF_SDW_TGL_HDMI)
dev_dbg(dev, "quirk SOF_SDW_TGL_HDMI enabled\n"); dev_dbg(dev, "quirk SOF_SDW_TGL_HDMI enabled\n");
if (sof_sdw_quirk & SOF_SDW_PCH_DMIC) if (sof_sdw_quirk & SOF_SDW_PCH_DMIC)
...@@ -80,8 +80,7 @@ static const struct dmi_system_id sof_sdw_quirk_table[] = { ...@@ -80,8 +80,7 @@ static const struct dmi_system_id sof_sdw_quirk_table[] = {
DMI_MATCH(DMI_SYS_VENDOR, "Dell Inc"), DMI_MATCH(DMI_SYS_VENDOR, "Dell Inc"),
DMI_EXACT_MATCH(DMI_PRODUCT_SKU, "098F"), DMI_EXACT_MATCH(DMI_PRODUCT_SKU, "098F"),
}, },
.driver_data = (void *)(RT711_JD2 | .driver_data = (void *)(RT711_JD2),
SOF_SDW_FOUR_SPK),
}, },
{ {
.callback = sof_sdw_quirk_cb, .callback = sof_sdw_quirk_cb,
...@@ -89,8 +88,7 @@ static const struct dmi_system_id sof_sdw_quirk_table[] = { ...@@ -89,8 +88,7 @@ static const struct dmi_system_id sof_sdw_quirk_table[] = {
DMI_MATCH(DMI_SYS_VENDOR, "Dell Inc"), DMI_MATCH(DMI_SYS_VENDOR, "Dell Inc"),
DMI_EXACT_MATCH(DMI_PRODUCT_SKU, "0990"), DMI_EXACT_MATCH(DMI_PRODUCT_SKU, "0990"),
}, },
.driver_data = (void *)(RT711_JD2 | .driver_data = (void *)(RT711_JD2),
SOF_SDW_FOUR_SPK),
}, },
/* IceLake devices */ /* IceLake devices */
{ {
...@@ -141,8 +139,7 @@ static const struct dmi_system_id sof_sdw_quirk_table[] = { ...@@ -141,8 +139,7 @@ static const struct dmi_system_id sof_sdw_quirk_table[] = {
DMI_EXACT_MATCH(DMI_PRODUCT_SKU, "0A5D") DMI_EXACT_MATCH(DMI_PRODUCT_SKU, "0A5D")
}, },
.driver_data = (void *)(SOF_SDW_TGL_HDMI | .driver_data = (void *)(SOF_SDW_TGL_HDMI |
RT711_JD2 | RT711_JD2),
SOF_SDW_FOUR_SPK),
}, },
{ {
.callback = sof_sdw_quirk_cb, .callback = sof_sdw_quirk_cb,
...@@ -151,8 +148,7 @@ static const struct dmi_system_id sof_sdw_quirk_table[] = { ...@@ -151,8 +148,7 @@ static const struct dmi_system_id sof_sdw_quirk_table[] = {
DMI_EXACT_MATCH(DMI_PRODUCT_SKU, "0A5E") DMI_EXACT_MATCH(DMI_PRODUCT_SKU, "0A5E")
}, },
.driver_data = (void *)(SOF_SDW_TGL_HDMI | .driver_data = (void *)(SOF_SDW_TGL_HDMI |
RT711_JD2 | RT711_JD2),
SOF_SDW_FOUR_SPK),
}, },
{ {
.callback = sof_sdw_quirk_cb, .callback = sof_sdw_quirk_cb,
...@@ -162,7 +158,6 @@ static const struct dmi_system_id sof_sdw_quirk_table[] = { ...@@ -162,7 +158,6 @@ static const struct dmi_system_id sof_sdw_quirk_table[] = {
}, },
.driver_data = (void *)(SOF_SDW_TGL_HDMI | .driver_data = (void *)(SOF_SDW_TGL_HDMI |
SOF_SDW_PCH_DMIC | SOF_SDW_PCH_DMIC |
SOF_SDW_FOUR_SPK |
SOF_BT_OFFLOAD_SSP(2) | SOF_BT_OFFLOAD_SSP(2) |
SOF_SSP_BT_OFFLOAD_PRESENT), SOF_SSP_BT_OFFLOAD_PRESENT),
}, },
...@@ -173,8 +168,7 @@ static const struct dmi_system_id sof_sdw_quirk_table[] = { ...@@ -173,8 +168,7 @@ static const struct dmi_system_id sof_sdw_quirk_table[] = {
DMI_MATCH(DMI_PRODUCT_NAME, "Ripto"), DMI_MATCH(DMI_PRODUCT_NAME, "Ripto"),
}, },
.driver_data = (void *)(SOF_SDW_TGL_HDMI | .driver_data = (void *)(SOF_SDW_TGL_HDMI |
SOF_SDW_PCH_DMIC | SOF_SDW_PCH_DMIC),
SOF_SDW_FOUR_SPK),
}, },
{ {
/* /*
...@@ -258,8 +252,7 @@ static const struct dmi_system_id sof_sdw_quirk_table[] = { ...@@ -258,8 +252,7 @@ static const struct dmi_system_id sof_sdw_quirk_table[] = {
DMI_EXACT_MATCH(DMI_PRODUCT_SKU, "0A32") DMI_EXACT_MATCH(DMI_PRODUCT_SKU, "0A32")
}, },
.driver_data = (void *)(SOF_SDW_TGL_HDMI | .driver_data = (void *)(SOF_SDW_TGL_HDMI |
RT711_JD2 | RT711_JD2),
SOF_SDW_FOUR_SPK),
}, },
{ {
.callback = sof_sdw_quirk_cb, .callback = sof_sdw_quirk_cb,
...@@ -290,7 +283,6 @@ static const struct dmi_system_id sof_sdw_quirk_table[] = { ...@@ -290,7 +283,6 @@ static const struct dmi_system_id sof_sdw_quirk_table[] = {
}, },
.driver_data = (void *)(SOF_SDW_TGL_HDMI | .driver_data = (void *)(SOF_SDW_TGL_HDMI |
SOF_SDW_PCH_DMIC | SOF_SDW_PCH_DMIC |
SOF_SDW_FOUR_SPK |
SOF_BT_OFFLOAD_SSP(2) | SOF_BT_OFFLOAD_SSP(2) |
SOF_SSP_BT_OFFLOAD_PRESENT), SOF_SSP_BT_OFFLOAD_PRESENT),
}, },
...@@ -301,8 +293,7 @@ static const struct dmi_system_id sof_sdw_quirk_table[] = { ...@@ -301,8 +293,7 @@ static const struct dmi_system_id sof_sdw_quirk_table[] = {
DMI_EXACT_MATCH(DMI_PRODUCT_SKU, "0AF0") DMI_EXACT_MATCH(DMI_PRODUCT_SKU, "0AF0")
}, },
.driver_data = (void *)(SOF_SDW_TGL_HDMI | .driver_data = (void *)(SOF_SDW_TGL_HDMI |
RT711_JD2 | RT711_JD2),
SOF_SDW_FOUR_SPK),
}, },
{ {
.callback = sof_sdw_quirk_cb, .callback = sof_sdw_quirk_cb,
...@@ -311,8 +302,7 @@ static const struct dmi_system_id sof_sdw_quirk_table[] = { ...@@ -311,8 +302,7 @@ static const struct dmi_system_id sof_sdw_quirk_table[] = {
DMI_EXACT_MATCH(DMI_PRODUCT_SKU, "0AF3"), DMI_EXACT_MATCH(DMI_PRODUCT_SKU, "0AF3"),
}, },
/* No Jack */ /* No Jack */
.driver_data = (void *)(SOF_SDW_TGL_HDMI | .driver_data = (void *)(SOF_SDW_TGL_HDMI),
SOF_SDW_FOUR_SPK),
}, },
{ {
.callback = sof_sdw_quirk_cb, .callback = sof_sdw_quirk_cb,
...@@ -321,8 +311,7 @@ static const struct dmi_system_id sof_sdw_quirk_table[] = { ...@@ -321,8 +311,7 @@ static const struct dmi_system_id sof_sdw_quirk_table[] = {
DMI_EXACT_MATCH(DMI_PRODUCT_SKU, "0AFE") DMI_EXACT_MATCH(DMI_PRODUCT_SKU, "0AFE")
}, },
.driver_data = (void *)(SOF_SDW_TGL_HDMI | .driver_data = (void *)(SOF_SDW_TGL_HDMI |
RT711_JD2 | RT711_JD2),
SOF_SDW_FOUR_SPK),
}, },
{ {
.callback = sof_sdw_quirk_cb, .callback = sof_sdw_quirk_cb,
...@@ -331,8 +320,7 @@ static const struct dmi_system_id sof_sdw_quirk_table[] = { ...@@ -331,8 +320,7 @@ static const struct dmi_system_id sof_sdw_quirk_table[] = {
DMI_EXACT_MATCH(DMI_PRODUCT_SKU, "0AFF") DMI_EXACT_MATCH(DMI_PRODUCT_SKU, "0AFF")
}, },
.driver_data = (void *)(SOF_SDW_TGL_HDMI | .driver_data = (void *)(SOF_SDW_TGL_HDMI |
RT711_JD2 | RT711_JD2),
SOF_SDW_FOUR_SPK),
}, },
{ {
.callback = sof_sdw_quirk_cb, .callback = sof_sdw_quirk_cb,
...@@ -341,8 +329,7 @@ static const struct dmi_system_id sof_sdw_quirk_table[] = { ...@@ -341,8 +329,7 @@ static const struct dmi_system_id sof_sdw_quirk_table[] = {
DMI_EXACT_MATCH(DMI_PRODUCT_SKU, "0B00") DMI_EXACT_MATCH(DMI_PRODUCT_SKU, "0B00")
}, },
.driver_data = (void *)(SOF_SDW_TGL_HDMI | .driver_data = (void *)(SOF_SDW_TGL_HDMI |
RT711_JD2 | RT711_JD2),
SOF_SDW_FOUR_SPK),
}, },
{ {
.callback = sof_sdw_quirk_cb, .callback = sof_sdw_quirk_cb,
...@@ -351,8 +338,7 @@ static const struct dmi_system_id sof_sdw_quirk_table[] = { ...@@ -351,8 +338,7 @@ static const struct dmi_system_id sof_sdw_quirk_table[] = {
DMI_EXACT_MATCH(DMI_PRODUCT_SKU, "0B01") DMI_EXACT_MATCH(DMI_PRODUCT_SKU, "0B01")
}, },
.driver_data = (void *)(SOF_SDW_TGL_HDMI | .driver_data = (void *)(SOF_SDW_TGL_HDMI |
RT711_JD2 | RT711_JD2),
SOF_SDW_FOUR_SPK),
}, },
{ {
.callback = sof_sdw_quirk_cb, .callback = sof_sdw_quirk_cb,
...@@ -361,8 +347,7 @@ static const struct dmi_system_id sof_sdw_quirk_table[] = { ...@@ -361,8 +347,7 @@ static const struct dmi_system_id sof_sdw_quirk_table[] = {
DMI_EXACT_MATCH(DMI_PRODUCT_SKU, "0B11") DMI_EXACT_MATCH(DMI_PRODUCT_SKU, "0B11")
}, },
.driver_data = (void *)(SOF_SDW_TGL_HDMI | .driver_data = (void *)(SOF_SDW_TGL_HDMI |
RT711_JD2 | RT711_JD2),
SOF_SDW_FOUR_SPK),
}, },
{ {
.callback = sof_sdw_quirk_cb, .callback = sof_sdw_quirk_cb,
...@@ -371,8 +356,7 @@ static const struct dmi_system_id sof_sdw_quirk_table[] = { ...@@ -371,8 +356,7 @@ static const struct dmi_system_id sof_sdw_quirk_table[] = {
DMI_EXACT_MATCH(DMI_PRODUCT_SKU, "0B12") DMI_EXACT_MATCH(DMI_PRODUCT_SKU, "0B12")
}, },
.driver_data = (void *)(SOF_SDW_TGL_HDMI | .driver_data = (void *)(SOF_SDW_TGL_HDMI |
RT711_JD2 | RT711_JD2),
SOF_SDW_FOUR_SPK),
}, },
{ {
.callback = sof_sdw_quirk_cb, .callback = sof_sdw_quirk_cb,
...@@ -400,8 +384,7 @@ static const struct dmi_system_id sof_sdw_quirk_table[] = { ...@@ -400,8 +384,7 @@ static const struct dmi_system_id sof_sdw_quirk_table[] = {
DMI_EXACT_MATCH(DMI_PRODUCT_SKU, "0B29"), DMI_EXACT_MATCH(DMI_PRODUCT_SKU, "0B29"),
}, },
.driver_data = (void *)(SOF_SDW_TGL_HDMI | .driver_data = (void *)(SOF_SDW_TGL_HDMI |
RT711_JD2 | RT711_JD2),
SOF_SDW_FOUR_SPK),
}, },
{ {
.callback = sof_sdw_quirk_cb, .callback = sof_sdw_quirk_cb,
...@@ -429,8 +412,7 @@ static const struct dmi_system_id sof_sdw_quirk_table[] = { ...@@ -429,8 +412,7 @@ static const struct dmi_system_id sof_sdw_quirk_table[] = {
DMI_EXACT_MATCH(DMI_PRODUCT_SKU, "0BDA") DMI_EXACT_MATCH(DMI_PRODUCT_SKU, "0BDA")
}, },
.driver_data = (void *)(SOF_SDW_TGL_HDMI | .driver_data = (void *)(SOF_SDW_TGL_HDMI |
RT711_JD2 | RT711_JD2),
SOF_SDW_FOUR_SPK),
}, },
{ {
.callback = sof_sdw_quirk_cb, .callback = sof_sdw_quirk_cb,
...@@ -449,8 +431,7 @@ static const struct dmi_system_id sof_sdw_quirk_table[] = { ...@@ -449,8 +431,7 @@ static const struct dmi_system_id sof_sdw_quirk_table[] = {
DMI_EXACT_MATCH(DMI_PRODUCT_SKU, "0C10"), DMI_EXACT_MATCH(DMI_PRODUCT_SKU, "0C10"),
}, },
/* No Jack */ /* No Jack */
.driver_data = (void *)(SOF_SDW_TGL_HDMI | .driver_data = (void *)(SOF_SDW_TGL_HDMI),
SOF_SDW_FOUR_SPK),
}, },
{ {
.callback = sof_sdw_quirk_cb, .callback = sof_sdw_quirk_cb,
...@@ -459,8 +440,7 @@ static const struct dmi_system_id sof_sdw_quirk_table[] = { ...@@ -459,8 +440,7 @@ static const struct dmi_system_id sof_sdw_quirk_table[] = {
DMI_EXACT_MATCH(DMI_PRODUCT_SKU, "0C11") DMI_EXACT_MATCH(DMI_PRODUCT_SKU, "0C11")
}, },
.driver_data = (void *)(SOF_SDW_TGL_HDMI | .driver_data = (void *)(SOF_SDW_TGL_HDMI |
RT711_JD2 | RT711_JD2),
SOF_SDW_FOUR_SPK),
}, },
{ {
.callback = sof_sdw_quirk_cb, .callback = sof_sdw_quirk_cb,
...@@ -469,8 +449,7 @@ static const struct dmi_system_id sof_sdw_quirk_table[] = { ...@@ -469,8 +449,7 @@ static const struct dmi_system_id sof_sdw_quirk_table[] = {
DMI_EXACT_MATCH(DMI_PRODUCT_SKU, "0C40") DMI_EXACT_MATCH(DMI_PRODUCT_SKU, "0C40")
}, },
.driver_data = (void *)(SOF_SDW_TGL_HDMI | .driver_data = (void *)(SOF_SDW_TGL_HDMI |
RT711_JD2 | RT711_JD2),
SOF_SDW_FOUR_SPK),
}, },
{ {
.callback = sof_sdw_quirk_cb, .callback = sof_sdw_quirk_cb,
...@@ -479,8 +458,7 @@ static const struct dmi_system_id sof_sdw_quirk_table[] = { ...@@ -479,8 +458,7 @@ static const struct dmi_system_id sof_sdw_quirk_table[] = {
DMI_EXACT_MATCH(DMI_PRODUCT_SKU, "0C4F") DMI_EXACT_MATCH(DMI_PRODUCT_SKU, "0C4F")
}, },
.driver_data = (void *)(SOF_SDW_TGL_HDMI | .driver_data = (void *)(SOF_SDW_TGL_HDMI |
RT711_JD2 | RT711_JD2),
SOF_SDW_FOUR_SPK),
}, },
/* MeteorLake devices */ /* MeteorLake devices */
{ {
...@@ -2010,9 +1988,7 @@ static int mc_probe(struct platform_device *pdev) ...@@ -2010,9 +1988,7 @@ static int mc_probe(struct platform_device *pdev)
amp_num += codec_info_list[i].amp_num; amp_num += codec_info_list[i].amp_num;
card->components = devm_kasprintf(card->dev, GFP_KERNEL, card->components = devm_kasprintf(card->dev, GFP_KERNEL,
"cfg-spk:%d cfg-amp:%d", "cfg-amp:%d", amp_num);
(sof_sdw_quirk & SOF_SDW_FOUR_SPK)
? 4 : 2, amp_num);
if (!card->components) if (!card->components)
return -ENOMEM; return -ENOMEM;
......
...@@ -45,6 +45,7 @@ enum { ...@@ -45,6 +45,7 @@ enum {
}; };
#define SOF_JACK_JDSRC(quirk) ((quirk) & GENMASK(3, 0)) #define SOF_JACK_JDSRC(quirk) ((quirk) & GENMASK(3, 0))
/* Deprecated and no longer supported by the code */
#define SOF_SDW_FOUR_SPK BIT(4) #define SOF_SDW_FOUR_SPK BIT(4)
#define SOF_SDW_TGL_HDMI BIT(5) #define SOF_SDW_TGL_HDMI BIT(5)
#define SOF_SDW_PCH_DMIC BIT(6) #define SOF_SDW_PCH_DMIC BIT(6)
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment