Commit 302df269 authored by Jerome Brunet's avatar Jerome Brunet Committed by Mark Brown

ASoC: meson: axg-tdm: restrict formats depending on slot width

Restrict the formats possible on the TDM interface depending on the width
of the TDM slot and let dpcm merging do the rest.

Fixes: d60e4f1e ("ASoC: meson: add tdm interface driver")
Signed-off-by: default avatarJerome Brunet <jbrunet@baylibre.com>
Signed-off-by: default avatarMark Brown <broonie@kernel.org>
parent dadfab72
...@@ -42,6 +42,7 @@ int axg_tdm_set_tdm_slots(struct snd_soc_dai *dai, u32 *tx_mask, ...@@ -42,6 +42,7 @@ int axg_tdm_set_tdm_slots(struct snd_soc_dai *dai, u32 *tx_mask,
struct axg_tdm_stream *rx = (struct axg_tdm_stream *) struct axg_tdm_stream *rx = (struct axg_tdm_stream *)
dai->capture_dma_data; dai->capture_dma_data;
unsigned int tx_slots, rx_slots; unsigned int tx_slots, rx_slots;
unsigned int fmt = 0;
tx_slots = axg_tdm_slots_total(tx_mask); tx_slots = axg_tdm_slots_total(tx_mask);
rx_slots = axg_tdm_slots_total(rx_mask); rx_slots = axg_tdm_slots_total(rx_mask);
...@@ -52,38 +53,45 @@ int axg_tdm_set_tdm_slots(struct snd_soc_dai *dai, u32 *tx_mask, ...@@ -52,38 +53,45 @@ int axg_tdm_set_tdm_slots(struct snd_soc_dai *dai, u32 *tx_mask,
return -EINVAL; return -EINVAL;
} }
/*
* Amend the dai driver channel number and let dpcm channel merge do
* its job
*/
if (tx) {
tx->mask = tx_mask;
dai->driver->playback.channels_max = tx_slots;
}
if (rx) {
rx->mask = rx_mask;
dai->driver->capture.channels_max = rx_slots;
}
iface->slots = slots; iface->slots = slots;
switch (slot_width) { switch (slot_width) {
case 0: case 0:
/* defaults width to 32 if not provided */ slot_width = 32;
iface->slot_width = 32; /* Fall-through */
break;
case 8:
case 16:
case 24:
case 32: case 32:
iface->slot_width = slot_width; fmt |= SNDRV_PCM_FMTBIT_S32_LE;
/* Fall-through */
case 24:
fmt |= SNDRV_PCM_FMTBIT_S24_LE;
fmt |= SNDRV_PCM_FMTBIT_S20_LE;
/* Fall-through */
case 16:
fmt |= SNDRV_PCM_FMTBIT_S16_LE;
/* Fall-through */
case 8:
fmt |= SNDRV_PCM_FMTBIT_S8;
break; break;
default: default:
dev_err(dai->dev, "unsupported slot width: %d\n", slot_width); dev_err(dai->dev, "unsupported slot width: %d\n", slot_width);
return -EINVAL; return -EINVAL;
} }
iface->slot_width = slot_width;
/* Amend the dai driver and let dpcm merge do its job */
if (tx) {
tx->mask = tx_mask;
dai->driver->playback.channels_max = tx_slots;
dai->driver->playback.formats = fmt;
}
if (rx) {
rx->mask = rx_mask;
dai->driver->capture.channels_max = rx_slots;
dai->driver->capture.formats = fmt;
}
return 0; return 0;
} }
EXPORT_SYMBOL_GPL(axg_tdm_set_tdm_slots); EXPORT_SYMBOL_GPL(axg_tdm_set_tdm_slots);
......
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