Commit dde109fb authored by Michal Bachraty's avatar Michal Bachraty Committed by Mark Brown

ASoC: McASP: Fix data rotation for playback. Enables 24bit audio playback

u32 rotate = (32 - word_length) / 4;
This implementation is wrong, but it works only for 16, or 32 bit audio data.
(rotation for 16 or 32 bit is same as in code I present) Mcasp rotated data in
4 bits (max value 0x7)and then masks them . That data are sended to i2s bus.
For 24 bit or 20 bit or other data formats, this code rotates data badly and
you hear somethink like noise.  You need to use
u32 rotate = (word_length / 4) & 0x7;
to proper data rotation.
Signed-off-by: default avatarMichal Bachraty <michal.bachraty@streamunlimited.com>
Signed-off-by: default avatarMark Brown <broonie@opensource.wolfsonmicro.com>
parent 949db153
...@@ -626,7 +626,7 @@ static int davinci_config_channel_size(struct davinci_audio_dev *dev, ...@@ -626,7 +626,7 @@ static int davinci_config_channel_size(struct davinci_audio_dev *dev,
int word_length) int word_length)
{ {
u32 fmt; u32 fmt;
u32 rotate = (32 - word_length) / 4; u32 rotate = (word_length / 4) & 0x7;
u32 mask = (1ULL << word_length) - 1; u32 mask = (1ULL << word_length) - 1;
/* /*
......
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