Commit d69a1555 authored by xliu's avatar xliu Committed by Mark Brown

ASoC: Intel: cirrus-common: fix incorrect channel mapping

The default mapping of ASPRX1 (DAC source) is slot 0. Change the slot
mapping of right amplifiers (WR and TR) to slot 1 to receive right
channel data. Also update the ACPI instance ID mapping according to HW
configuration.
Signed-off-by: default avatarxliu <xiang.liu@cirrus.com>
Signed-off-by: default avatarBrent Lu <brent.lu@intel.com>
Acked-by: default avatarPierre-Louis Bossart <pierre-louis.bossart@linux.intel.com>
Link: https://lore.kernel.org/r/20220602051922.1232457-1-brent.lu@intel.comSigned-off-by: default avatarMark Brown <broonie@kernel.org>
parent ef8d89b8
...@@ -54,22 +54,29 @@ static struct snd_soc_dai_link_component cs35l41_components[] = { ...@@ -54,22 +54,29 @@ static struct snd_soc_dai_link_component cs35l41_components[] = {
}, },
}; };
/*
* Mapping between ACPI instance id and speaker position.
*
* Four speakers:
* 0: Tweeter left, 1: Woofer left
* 2: Tweeter right, 3: Woofer right
*/
static struct snd_soc_codec_conf cs35l41_codec_conf[] = { static struct snd_soc_codec_conf cs35l41_codec_conf[] = {
{ {
.dlc = COMP_CODEC_CONF(CS35L41_DEV0_NAME), .dlc = COMP_CODEC_CONF(CS35L41_DEV0_NAME),
.name_prefix = "WL", .name_prefix = "TL",
}, },
{ {
.dlc = COMP_CODEC_CONF(CS35L41_DEV1_NAME), .dlc = COMP_CODEC_CONF(CS35L41_DEV1_NAME),
.name_prefix = "WR", .name_prefix = "WL",
}, },
{ {
.dlc = COMP_CODEC_CONF(CS35L41_DEV2_NAME), .dlc = COMP_CODEC_CONF(CS35L41_DEV2_NAME),
.name_prefix = "TL", .name_prefix = "TR",
}, },
{ {
.dlc = COMP_CODEC_CONF(CS35L41_DEV3_NAME), .dlc = COMP_CODEC_CONF(CS35L41_DEV3_NAME),
.name_prefix = "TR", .name_prefix = "WR",
}, },
}; };
...@@ -101,6 +108,21 @@ static int cs35l41_init(struct snd_soc_pcm_runtime *rtd) ...@@ -101,6 +108,21 @@ static int cs35l41_init(struct snd_soc_pcm_runtime *rtd)
return ret; return ret;
} }
/*
* Channel map:
*
* TL/WL: ASPRX1 on slot 0, ASPRX2 on slot 1 (default)
* TR/WR: ASPRX1 on slot 1, ASPRX2 on slot 0
*/
static const struct {
unsigned int rx[2];
} cs35l41_channel_map[] = {
{.rx = {0, 1}}, /* TL */
{.rx = {0, 1}}, /* WL */
{.rx = {1, 0}}, /* TR */
{.rx = {1, 0}}, /* WR */
};
static int cs35l41_hw_params(struct snd_pcm_substream *substream, static int cs35l41_hw_params(struct snd_pcm_substream *substream,
struct snd_pcm_hw_params *params) struct snd_pcm_hw_params *params)
{ {
...@@ -134,6 +156,16 @@ static int cs35l41_hw_params(struct snd_pcm_substream *substream, ...@@ -134,6 +156,16 @@ static int cs35l41_hw_params(struct snd_pcm_substream *substream,
ret); ret);
return ret; return ret;
} }
/* setup channel map */
ret = snd_soc_dai_set_channel_map(codec_dai, 0, NULL,
ARRAY_SIZE(cs35l41_channel_map[i].rx),
(unsigned int *)cs35l41_channel_map[i].rx);
if (ret < 0) {
dev_err(codec_dai->dev, "fail to set channel map, ret %d\n",
ret);
return ret;
}
} }
return 0; return 0;
......
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