[alsa-devel] [PATCH -next] sparc: fix missing unlock on error in snd_cs4231_playback_prepare()

Takashi Iwai tiwai at suse.de
Mon Nov 11 16:23:40 CET 2013


At Mon, 11 Nov 2013 22:21:33 +0800,
Wei Yongjun wrote:
> 
> From: Wei Yongjun <yongjun_wei at trendmicro.com.cn>
> 
> Add the missing unlock before return from function
> snd_cs4231_playback_prepare() in the error handling
> case.
> 
> Signed-off-by: Wei Yongjun <yongjun_wei at trendmicro.com.cn>

Thanks, applied.


Takashi

> ---
>  sound/sparc/cs4231.c | 11 ++++++++---
>  1 file changed, 8 insertions(+), 3 deletions(-)
> 
> diff --git a/sound/sparc/cs4231.c b/sound/sparc/cs4231.c
> index b47f6fe..dbb1b625 100644
> --- a/sound/sparc/cs4231.c
> +++ b/sound/sparc/cs4231.c
> @@ -907,19 +907,24 @@ static int snd_cs4231_playback_prepare(struct snd_pcm_substream *substream)
>  	struct snd_cs4231 *chip = snd_pcm_substream_chip(substream);
>  	struct snd_pcm_runtime *runtime = substream->runtime;
>  	unsigned long flags;
> +	int ret = 0;
>  
>  	spin_lock_irqsave(&chip->lock, flags);
>  
>  	chip->image[CS4231_IFACE_CTRL] &= ~(CS4231_PLAYBACK_ENABLE |
>  					    CS4231_PLAYBACK_PIO);
>  
> -	if (WARN_ON(runtime->period_size > 0xffff + 1))
> -		return -EINVAL;
> +	if (WARN_ON(runtime->period_size > 0xffff + 1)) {
> +		ret = -EINVAL;
> +		goto out;
> +	}
>  
>  	chip->p_periods_sent = 0;
> +
> +out:
>  	spin_unlock_irqrestore(&chip->lock, flags);
>  
> -	return 0;
> +	return ret;
>  }
>  
>  static int snd_cs4231_capture_hw_params(struct snd_pcm_substream *substream,
> 


More information about the Alsa-devel mailing list