[PATCH 1/2] s3c24xx: DMA: don't use autoreload feature

Vasily Khoruzhick anarsoul at gmail.com
Wed Sep 8 02:27:43 EDT 2010


В сообщении от 8 сентября 2010 02:37:00 автор Ben Dooks написал:
> On 08/09/10 00:23, Vasily Khoruzhick wrote:
> > Some integrated DMA-capable hardware doesn't like autoreload
> > feature of s3c24xx DMA-engine, that's why s3cmci driver
> > didn't work with DMA transfers enabled.
> > 
> > I rewrote DMA driver not to use autoreload feature and removed
> > all pre-loading features. Buffer re-load is fast enought to perform
> > it in IRQ handler, and anyway I don't see any reason to waste CPU
> > cycles on waiting for buffer load. Driver is much simplier now,
> > it was tested with s3cmci and s3c24xx-i2s drivers on s3c2442 and
> > s3c2410 SoCs and works just nice.
> 
> I found this really necessary, especially on systems where some
> drivers can keep the cpu irq load high, such as pio hard-discs.
> 
> Can this be changed to a flag that is set to control the behaviour
> on a per driver basis?

Well, that's not easy and result will be a bit complicated :) Your 
implementation has 4 states and actively uses autoreload flag, but when 
there's no autoreload/pre-loading there's only 2 states. Btw, all DMA-capable 
HW on S3C24xx has FIFO, so missing pre-loading should not give big impact, as 
HW can be fed from FIFO for some time. Can you test if this patch causes some 
problems on your HW with pio hard-discs?

Regards
Vasily
-------------- next part --------------
A non-text attachment was scrubbed...
Name: not available
Type: application/pgp-signature
Size: 198 bytes
Desc: This is a digitally signed message part.
URL: <http://lists.infradead.org/pipermail/linux-arm-kernel/attachments/20100908/0e46a31b/attachment.sig>


More information about the linux-arm-kernel mailing list