[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <7d700845-da72-5c40-31f9-c3faa7ca93a2@st.com>
Date: Tue, 1 Aug 2017 10:42:57 +0200
From: Arnaud Pouliquen <arnaud.pouliquen@...com>
To: <srinivas.kandagatla@...aro.org>, Jyri Sarha <jsarha@...com>,
Mark Brown <broonie@...nel.org>, <alsa-devel@...a-project.org>
CC: Archit Taneja <architt@...eaurora.org>,
David Airlie <airlied@...ux.ie>,
<linux-kernel@...r.kernel.org>,
Liam Girdwood <lgirdwood@...il.com>,
<dri-devel@...ts.freedesktop.org>, Takashi Iwai <tiwai@...e.com>,
Andrzej Hajda <a.hajda@...sung.com>
Subject: Re: [alsa-devel] [PATCH v2 2/2] drm/bridge: adv7511: restrict audio
sample sizes
Hello Srinivas,
On 08/01/2017 12:49 AM, srinivas.kandagatla@...aro.org wrote:
> From: Srinivas Kandagatla <srinivas.kandagatla@...aro.org>
>
> ADV7533 only supports audio samples word width from 16-24 bits.
> This patch restricts the audio sample sizes to the supported ones,
> so that sound card does not report wrong list of supported hwparms.
>
> Without this patch aplay would fail when playing a 32 bit audio.
>
> Signed-off-by: Srinivas Kandagatla <srinivas.kandagatla@...aro.org>
> ---
> drivers/gpu/drm/bridge/adv7511/adv7511_audio.c | 2 ++
> 1 file changed, 2 insertions(+)
>
> diff --git a/drivers/gpu/drm/bridge/adv7511/adv7511_audio.c b/drivers/gpu/drm/bridge/adv7511/adv7511_audio.c
> index 67469c26bae8..d01d0aa0eef7 100644
> --- a/drivers/gpu/drm/bridge/adv7511/adv7511_audio.c
> +++ b/drivers/gpu/drm/bridge/adv7511/adv7511_audio.c
> @@ -214,6 +214,8 @@ static struct hdmi_codec_pdata codec_data = {
> .ops = &adv7511_codec_ops,
> .max_i2s_channels = 2,
> .i2s = 1,
> + .formats = (SNDRV_PCM_FMTBIT_S16_LE | SNDRV_PCM_FMTBIT_S16_BE |
> + SNDRV_PCM_FMTBIT_S24_LE | SNDRV_PCM_FMTBIT_S24_BE),
> };
I'm not sure that this limitation is needed.
I already used ADV7513 and i did not observe this limitation.
I had a look to ADV7533 data-sheet. it should support 32 and 64 bits I2S
format bus, with 16 or 24 bits precision sample. So it should support
SNDRV_PCM_FMTBIT_S32_LE and SNDRV_PCM_FMTBIT_S32_BE
As example, if you configure bus in Left justified format with 24 bits
sample length, 32 bits application samples should be truncated to 24
bits samples at ADV7533 I2S interface level (LSB dropped).
Perhaps i missed something... but look like more an I2S bus
configuration issue in your DT card description, that that a miss in the
drivers.
Regards
Arnaud
>
> int adv7511_audio_init(struct device *dev, struct adv7511 *adv7511)
>
Powered by blists - more mailing lists