diff options
Diffstat (limited to 'sound/sparc/cs4231.c')
| -rw-r--r-- | sound/sparc/cs4231.c | 24 | 
1 files changed, 16 insertions, 8 deletions
diff --git a/sound/sparc/cs4231.c b/sound/sparc/cs4231.c index 54aaad2a10f..4e91bcaa366 100644 --- a/sound/sparc/cs4231.c +++ b/sound/sparc/cs4231.c @@ -429,7 +429,8 @@ static void snd_cs4231_advance_dma(struct cs4231_dma_control *dma_cont,  		unsigned int period_size = snd_pcm_lib_period_bytes(substream);  		unsigned int offset = period_size * (*periods_sent); -		BUG_ON(period_size >= (1 << 24)); +		if (WARN_ON(period_size >= (1 << 24))) +			return;  		if (dma_cont->request(dma_cont,  				      runtime->dma_addr + offset, period_size)) @@ -906,18 +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); -	BUG_ON(runtime->period_size > 0xffff + 1); +	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, @@ -1558,7 +1565,8 @@ static int snd_cs4231_mixer(struct snd_card *card)  static int dev; -static int cs4231_attach_begin(struct snd_card **rcard) +static int cs4231_attach_begin(struct platform_device *op, +			       struct snd_card **rcard)  {  	struct snd_card *card;  	struct snd_cs4231 *chip; @@ -1574,8 +1582,8 @@ static int cs4231_attach_begin(struct snd_card **rcard)  		return -ENOENT;  	} -	err = snd_card_create(index[dev], id[dev], THIS_MODULE, -			      sizeof(struct snd_cs4231), &card); +	err = snd_card_new(&op->dev, index[dev], id[dev], THIS_MODULE, +			   sizeof(struct snd_cs4231), &card);  	if (err < 0)  		return err; @@ -1862,7 +1870,7 @@ static int cs4231_sbus_probe(struct platform_device *op)  	struct snd_card *card;  	int err; -	err = cs4231_attach_begin(&card); +	err = cs4231_attach_begin(op, &card);  	if (err)  		return err; @@ -2053,7 +2061,7 @@ static int cs4231_ebus_probe(struct platform_device *op)  	struct snd_card *card;  	int err; -	err = cs4231_attach_begin(&card); +	err = cs4231_attach_begin(op, &card);  	if (err)  		return err;  | 
