|
@@ -148,10 +148,14 @@ static int kirkwood_dma_open(struct snd_pcm_substream *substream)
|
|
|
dram = mv_mbus_dram_info();
|
|
dram = mv_mbus_dram_info();
|
|
|
addr = substream->dma_buffer.addr;
|
|
addr = substream->dma_buffer.addr;
|
|
|
if (substream->stream == SNDRV_PCM_STREAM_PLAYBACK) {
|
|
if (substream->stream == SNDRV_PCM_STREAM_PLAYBACK) {
|
|
|
|
|
+ if (priv->substream_play)
|
|
|
|
|
+ return -EBUSY;
|
|
|
priv->substream_play = substream;
|
|
priv->substream_play = substream;
|
|
|
kirkwood_dma_conf_mbus_windows(priv->io,
|
|
kirkwood_dma_conf_mbus_windows(priv->io,
|
|
|
KIRKWOOD_PLAYBACK_WIN, addr, dram);
|
|
KIRKWOOD_PLAYBACK_WIN, addr, dram);
|
|
|
} else {
|
|
} else {
|
|
|
|
|
+ if (priv->substream_rec)
|
|
|
|
|
+ return -EBUSY;
|
|
|
priv->substream_rec = substream;
|
|
priv->substream_rec = substream;
|
|
|
kirkwood_dma_conf_mbus_windows(priv->io,
|
|
kirkwood_dma_conf_mbus_windows(priv->io,
|
|
|
KIRKWOOD_RECORD_WIN, addr, dram);
|
|
KIRKWOOD_RECORD_WIN, addr, dram);
|