|
@@ -141,13 +141,22 @@ static inline void i2s_clear_irqs(struct dw_i2s_dev *dev, u32 stream)
|
|
|
static void i2s_start(struct dw_i2s_dev *dev,
|
|
|
struct snd_pcm_substream *substream)
|
|
|
{
|
|
|
-
|
|
|
+ u32 i, irq;
|
|
|
i2s_write_reg(dev->i2s_base, IER, 1);
|
|
|
|
|
|
- if (substream->stream == SNDRV_PCM_STREAM_PLAYBACK)
|
|
|
+ if (substream->stream == SNDRV_PCM_STREAM_PLAYBACK) {
|
|
|
+ for (i = 0; i < 4; i++) {
|
|
|
+ irq = i2s_read_reg(dev->i2s_base, IMR(i));
|
|
|
+ i2s_write_reg(dev->i2s_base, IMR(i), irq & ~0x30);
|
|
|
+ }
|
|
|
i2s_write_reg(dev->i2s_base, ITER, 1);
|
|
|
- else
|
|
|
+ } else {
|
|
|
+ for (i = 0; i < 4; i++) {
|
|
|
+ irq = i2s_read_reg(dev->i2s_base, IMR(i));
|
|
|
+ i2s_write_reg(dev->i2s_base, IMR(i), irq & ~0x03);
|
|
|
+ }
|
|
|
i2s_write_reg(dev->i2s_base, IRER, 1);
|
|
|
+ }
|
|
|
|
|
|
i2s_write_reg(dev->i2s_base, CER, 1);
|
|
|
}
|