diff options
Diffstat (limited to 'sound/core/pcm_dmaengine.c')
| -rw-r--r-- | sound/core/pcm_dmaengine.c | 28 | 
1 files changed, 15 insertions, 13 deletions
diff --git a/sound/core/pcm_dmaengine.c b/sound/core/pcm_dmaengine.c index aa924d9b798..76cbb9ec953 100644 --- a/sound/core/pcm_dmaengine.c +++ b/sound/core/pcm_dmaengine.c @@ -63,23 +63,19 @@ int snd_hwparams_to_dma_slave_config(const struct snd_pcm_substream *substream,  	struct dma_slave_config *slave_config)  {  	enum dma_slave_buswidth buswidth; +	int bits; -	switch (params_format(params)) { -	case SNDRV_PCM_FORMAT_S8: +	bits = snd_pcm_format_physical_width(params_format(params)); +	if (bits < 8 || bits > 64) +		return -EINVAL; +	else if (bits == 8)  		buswidth = DMA_SLAVE_BUSWIDTH_1_BYTE; -		break; -	case SNDRV_PCM_FORMAT_S16_LE: +	else if (bits == 16)  		buswidth = DMA_SLAVE_BUSWIDTH_2_BYTES; -		break; -	case SNDRV_PCM_FORMAT_S18_3LE: -	case SNDRV_PCM_FORMAT_S20_3LE: -	case SNDRV_PCM_FORMAT_S24_LE: -	case SNDRV_PCM_FORMAT_S32_LE: +	else if (bits <= 32)  		buswidth = DMA_SLAVE_BUSWIDTH_4_BYTES; -		break; -	default: -		return -EINVAL; -	} +	else +		buswidth = DMA_SLAVE_BUSWIDTH_8_BYTES;  	if (substream->stream == SNDRV_PCM_STREAM_PLAYBACK) {  		slave_config->direction = DMA_MEM_TO_DEV; @@ -186,6 +182,7 @@ static int dmaengine_pcm_prepare_and_submit(struct snd_pcm_substream *substream)  int snd_dmaengine_pcm_trigger(struct snd_pcm_substream *substream, int cmd)  {  	struct dmaengine_pcm_runtime_data *prtd = substream_to_prtd(substream); +	struct snd_pcm_runtime *runtime = substream->runtime;  	int ret;  	switch (cmd) { @@ -200,6 +197,11 @@ int snd_dmaengine_pcm_trigger(struct snd_pcm_substream *substream, int cmd)  		dmaengine_resume(prtd->dma_chan);  		break;  	case SNDRV_PCM_TRIGGER_SUSPEND: +		if (runtime->info & SNDRV_PCM_INFO_PAUSE) +			dmaengine_pause(prtd->dma_chan); +		else +			dmaengine_terminate_all(prtd->dma_chan); +		break;  	case SNDRV_PCM_TRIGGER_PAUSE_PUSH:  		dmaengine_pause(prtd->dma_chan);  		break;  | 
