sound/soc/codecs/wm8962.c | 35 +++++++++++++++++++++++++++++++---- 1 file changed, 31 insertions(+), 4 deletions(-)
The slot_width can be different with the params_width(), for example,
DSP_A mode, slot_width = 32, but data format is S16_LE, if the word
length is configured to be 16, there is no sound on the right speaker.
So add .set_tdm_slot() callback function to configure the slot_width and
update the word length according to slot_width in hw_params().
Signed-off-by: Shengjiu Wang <shengjiu.wang@nxp.com>
---
Changes in v2:
- remove the check in tdm_slot() function.
- use slots / 2 for tdm_slots, as external is one slot one channel, but
internal is one slot two channels.
sound/soc/codecs/wm8962.c | 35 +++++++++++++++++++++++++++++++----
1 file changed, 31 insertions(+), 4 deletions(-)
diff --git a/sound/soc/codecs/wm8962.c b/sound/soc/codecs/wm8962.c
index bff864467416..8d2435bf44ea 100644
--- a/sound/soc/codecs/wm8962.c
+++ b/sound/soc/codecs/wm8962.c
@@ -85,6 +85,8 @@ struct wm8962_priv {
int irq;
bool master_flag;
+ int tdm_width;
+ int tdm_slots;
};
/* We can't use the same notifier block for more than one supply and
@@ -2612,6 +2614,19 @@ static int wm8962_set_bias_level(struct snd_soc_component *component,
return 0;
}
+static int wm8962_set_tdm_slot(struct snd_soc_dai *dai, unsigned int tx_mask,
+ unsigned int rx_mask, int slots, int slot_width)
+{
+ struct snd_soc_component *component = dai->component;
+ struct wm8962_priv *wm8962 = snd_soc_component_get_drvdata(component);
+
+ wm8962->tdm_width = slot_width;
+ /* External is one slot one channel, but internal is one slot two channels */
+ wm8962->tdm_slots = slots / 2;
+
+ return 0;
+}
+
static const struct {
int rate;
int reg;
@@ -2639,10 +2654,21 @@ static int wm8962_hw_params(struct snd_pcm_substream *substream,
int i;
int aif0 = 0;
int adctl3 = 0;
+ int width;
+
+ if (wm8962->tdm_width && wm8962->tdm_slots) {
+ wm8962->bclk = snd_soc_calc_bclk(params_rate(params),
+ wm8962->tdm_width,
+ params_channels(params),
+ wm8962->tdm_slots);
+ width = wm8962->tdm_width;
+ } else {
+ wm8962->bclk = snd_soc_params_to_bclk(params);
+ width = params_width(params);
- wm8962->bclk = snd_soc_params_to_bclk(params);
- if (params_channels(params) == 1)
- wm8962->bclk *= 2;
+ if (params_channels(params) == 1)
+ wm8962->bclk *= 2;
+ }
wm8962->lrclk = params_rate(params);
@@ -2660,7 +2686,7 @@ static int wm8962_hw_params(struct snd_pcm_substream *substream,
if (wm8962->lrclk % 8000 == 0)
adctl3 |= WM8962_SAMPLE_RATE_INT_MODE;
- switch (params_width(params)) {
+ switch (width) {
case 16:
break;
case 20:
@@ -3039,6 +3065,7 @@ static const struct snd_soc_dai_ops wm8962_dai_ops = {
.hw_params = wm8962_hw_params,
.set_sysclk = wm8962_set_dai_sysclk,
.set_fmt = wm8962_set_dai_fmt,
+ .set_tdm_slot = wm8962_set_tdm_slot,
.mute_stream = wm8962_mute,
.no_capture_mute = 1,
};
--
2.34.1
On Wed, 28 Jan 2026 10:59:55 +0800, Shengjiu Wang wrote:
> The slot_width can be different with the params_width(), for example,
> DSP_A mode, slot_width = 32, but data format is S16_LE, if the word
> length is configured to be 16, there is no sound on the right speaker.
>
> So add .set_tdm_slot() callback function to configure the slot_width and
> update the word length according to slot_width in hw_params().
>
> [...]
Applied to
https://git.kernel.org/pub/scm/linux/kernel/git/broonie/sound.git for-next
Thanks!
[1/1] ASoC: wm8962: add .set_tdm_slot callback function
commit: ab3f4f0c7f3aa050cd602cc32830e24ac4aaee97
All being well this means that it will be integrated into the linux-next
tree (usually sometime in the next 24 hours) and sent to Linus during
the next merge window (or sooner if it is a bug fix), however if
problems are discovered then the patch may be dropped or reverted.
You may get further e-mails resulting from automated or manual testing
and review of the tree, please engage with people reporting problems and
send followup patches addressing any issues that are reported if needed.
If any updates are required or you are submitting further changes they
should be sent as incremental updates against current git, existing
patches will not be replaced.
Please add any relevant lists and maintainers to the CCs when replying
to this mail.
Thanks,
Mark
On Wed, Jan 28, 2026 at 10:59:55AM +0800, Shengjiu Wang wrote: > The slot_width can be different with the params_width(), for example, > DSP_A mode, slot_width = 32, but data format is S16_LE, if the word > length is configured to be 16, there is no sound on the right speaker. > > So add .set_tdm_slot() callback function to configure the slot_width and > update the word length according to slot_width in hw_params(). > > Signed-off-by: Shengjiu Wang <shengjiu.wang@nxp.com> > --- Reviewed-by: Charles Keepax <ckeepax@opensource.cirrus.com> Thanks, Charles
© 2016 - 2026 Red Hat, Inc.