Commit 123af904 authored by Dan Carpenter's avatar Dan Carpenter Committed by Mark Brown

ASoC: au1x: Fix timeout tests in au1xac97c_ac97_read()

The loop timeout doesn't work because it's a post op and ends with "tmo"
set to -1.  I changed it from a post-op to a pre-op and I changed the
initial the starting value from 5 to 6 so we still iterate 5 times.  I
left the other as it was because it's a large number.

Fixes: b3c70c9e ("ASoC: Alchemy AC97C/I2SC audio support")
Signed-off-by: default avatarDan Carpenter <dan.carpenter@oracle.com>
Signed-off-by: default avatarMark Brown <broonie@kernel.org>
parent 4fbd8d19
...@@ -91,8 +91,8 @@ static unsigned short au1xac97c_ac97_read(struct snd_ac97 *ac97, ...@@ -91,8 +91,8 @@ static unsigned short au1xac97c_ac97_read(struct snd_ac97 *ac97,
do { do {
mutex_lock(&ctx->lock); mutex_lock(&ctx->lock);
tmo = 5; tmo = 6;
while ((RD(ctx, AC97_STATUS) & STAT_CP) && tmo--) while ((RD(ctx, AC97_STATUS) & STAT_CP) && --tmo)
udelay(21); /* wait an ac97 frame time */ udelay(21); /* wait an ac97 frame time */
if (!tmo) { if (!tmo) {
pr_debug("ac97rd timeout #1\n"); pr_debug("ac97rd timeout #1\n");
...@@ -105,7 +105,7 @@ static unsigned short au1xac97c_ac97_read(struct snd_ac97 *ac97, ...@@ -105,7 +105,7 @@ static unsigned short au1xac97c_ac97_read(struct snd_ac97 *ac97,
* poll, Forrest, poll... * poll, Forrest, poll...
*/ */
tmo = 0x10000; tmo = 0x10000;
while ((RD(ctx, AC97_STATUS) & STAT_CP) && tmo--) while ((RD(ctx, AC97_STATUS) & STAT_CP) && --tmo)
asm volatile ("nop"); asm volatile ("nop");
data = RD(ctx, AC97_CMDRESP); data = RD(ctx, AC97_CMDRESP);
......
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