Message ID | 1441502008-14116-1-git-send-email-shawn.lin@rock-chips.com (mailing list archive) |
---|---|
State | New, archived |
Headers | show |
On Sun, Sep 06, 2015 at 09:13:28AM +0800, Shawn Lin wrote: > @@ -460,7 +463,6 @@ static int rockchip_i2s_probe(struct platform_device *pdev) > i2s->playback_dma_data.addr = res->start + I2S_TXDR; > i2s->playback_dma_data.addr_width = DMA_SLAVE_BUSWIDTH_4_BYTES; > i2s->playback_dma_data.maxburst = 4; > - > i2s->capture_dma_data.addr = res->start + I2S_RXDR; > i2s->capture_dma_data.addr_width = DMA_SLAVE_BUSWIDTH_4_BYTES; > i2s->capture_dma_data.maxburst = 4; This random whitespace change shouldn't be in here. > @@ -489,6 +491,18 @@ static int rockchip_i2s_probe(struct platform_device *pdev) > goto err_pcm_register; > } > > + dma_quirk = snd_dmaengine_pcm_get_quirks(&pdev->dev); > + if (dma_quirk == ROCKCHIP_I2S_BROKEN_BURST_LEN) { > + /* I'd expect this to be a switch statement given the way this is written.
? 2015/9/11 19:53, Mark Brown ??: > On Sun, Sep 06, 2015 at 09:13:28AM +0800, Shawn Lin wrote: > >> @@ -460,7 +463,6 @@ static int rockchip_i2s_probe(struct platform_device *pdev) >> i2s->playback_dma_data.addr = res->start + I2S_TXDR; >> i2s->playback_dma_data.addr_width = DMA_SLAVE_BUSWIDTH_4_BYTES; >> i2s->playback_dma_data.maxburst = 4; >> - >> i2s->capture_dma_data.addr = res->start + I2S_RXDR; >> i2s->capture_dma_data.addr_width = DMA_SLAVE_BUSWIDTH_4_BYTES; >> i2s->capture_dma_data.maxburst = 4; > > This random whitespace change shouldn't be in here. yes, sorry for this bit. > >> @@ -489,6 +491,18 @@ static int rockchip_i2s_probe(struct platform_device *pdev) >> goto err_pcm_register; >> } >> >> + dma_quirk = snd_dmaengine_pcm_get_quirks(&pdev->dev); >> + if (dma_quirk == ROCKCHIP_I2S_BROKEN_BURST_LEN) { >> + /* > > I'd expect this to be a switch statement given the way this is written. Ahh.. agreed, but we don't expect more quriks for this driver. ??))) Will be done for the next version. Thanks. >
diff --git a/sound/soc/rockchip/rockchip_i2s.c b/sound/soc/rockchip/rockchip_i2s.c index acb5be5..b06e08a 100644 --- a/sound/soc/rockchip/rockchip_i2s.c +++ b/sound/soc/rockchip/rockchip_i2s.c @@ -23,6 +23,8 @@ #define DRV_NAME "rockchip-i2s" +#define ROCKCHIP_I2S_BROKEN_BURST_LEN (1<<0) /* broken burst len */ + struct rk_i2s_dev { struct device *dev; @@ -418,6 +420,7 @@ static int rockchip_i2s_probe(struct platform_device *pdev) struct rk_i2s_dev *i2s; struct resource *res; void __iomem *regs; + int dma_quirk; int ret; i2s = devm_kzalloc(&pdev->dev, sizeof(*i2s), GFP_KERNEL); @@ -460,7 +463,6 @@ static int rockchip_i2s_probe(struct platform_device *pdev) i2s->playback_dma_data.addr = res->start + I2S_TXDR; i2s->playback_dma_data.addr_width = DMA_SLAVE_BUSWIDTH_4_BYTES; i2s->playback_dma_data.maxburst = 4; - i2s->capture_dma_data.addr = res->start + I2S_RXDR; i2s->capture_dma_data.addr_width = DMA_SLAVE_BUSWIDTH_4_BYTES; i2s->capture_dma_data.maxburst = 4; @@ -489,6 +491,18 @@ static int rockchip_i2s_probe(struct platform_device *pdev) goto err_pcm_register; } + dma_quirk = snd_dmaengine_pcm_get_quirks(&pdev->dev); + if (dma_quirk == ROCKCHIP_I2S_BROKEN_BURST_LEN) { + /* + * Unfortunately, we find broken burst len here, + * just have to limit maxburst to ONE in order to avoid + * non-multiple burst len access fail the dmaengine if + * it can't support flush peripheral function. + */ + i2s->playback_dma_data.maxburst = 1; + i2s->capture_dma_data.maxburst = 1; + } + return 0; err_pcm_register: