linuxppc-dev.lists.ozlabs.org archive mirror
 help / color / mirror / Atom feed
* [PATCH v3 0/9] fsldma: lockup fixes
@ 2011-03-03 17:54 Ira W. Snyder
  2011-03-03 17:54 ` [PATCH v3 1/9] dmatest: fix automatic buffer unmap type Ira W. Snyder
                   ` (9 more replies)
  0 siblings, 10 replies; 13+ messages in thread
From: Ira W. Snyder @ 2011-03-03 17:54 UTC (permalink / raw)
  To: linuxppc-dev; +Cc: dan.j.williams, linux-kernel, Ira W. Snyder

Hello everyone,

I've been chasing random infrequent controller lockups in the fsldma driver
for a long time. I finally managed to find the problem and fix it. I'm not
quite sure about the exact sequence of events which causes the race
condition, but it is related to using the hardware registers to track the
controller state. See the patch changelogs for more detail.

The problems were quickly found by turning on DMAPOOL_DEBUG inside
mm/dmapool.c. This poisons memory allocated with the dmapool API.

With dmapool poisoning turned on, the dmatest driver would start producing
failures within a few seconds. After this patchset has been applied, I have
run several iterations of the 10 threads per channel, 100000 iterations per
thread test without any problems. I have also tested it with the CARMA
drivers (posted at linuxppc-dev previously), which make use of the external
control features.

While making the previous changes, I noticed that the fsldma driver does
not respect the automatic DMA unmapping of src and dst buffers. I have
added support for this feature. This also required a fix to dmatest, which
was sending incorrect flags.

The "support async_tx dependencies" patch could be split apart from the
automatic unmapping patch if it is desirable. They both touch the same
piece of code, so I thought it was ok to combine them. Let me know.

I would really like to see this go into 2.6.39. I think we can get it
reviewed before then. :)

Much thanks goes to Felix Radensky for testing on a P2020 (85xx DMA IP core).
I wouldn't have been able to track down the problems on 85xx without his
dilligent testing.

v2 -> v3:
- use chan_dbg() and chan_err() macros for channel printk

v1 -> v2:
- reordered patches (dmatest change is first now)
- fix problems on 85xx controller
- only set correct bits for 83xx in dma_halt()

Ira W. Snyder (9):
  dmatest: fix automatic buffer unmap type
  fsldma: move related helper functions near each other
  fsldma: use channel name in printk output
  fsldma: improve link descriptor debugging
  fsldma: minor codingstyle and consistency fixes
  fsldma: fix controller lockups
  fsldma: support async_tx dependencies and automatic unmapping
  fsldma: reduce locking during descriptor cleanup
  fsldma: make halt behave nicely on all supported controllers

 drivers/dma/dmatest.c |    7 +-
 drivers/dma/fsldma.c  |  551 +++++++++++++++++++++++++++----------------------
 drivers/dma/fsldma.h  |    6 +-
 3 files changed, 311 insertions(+), 253 deletions(-)

-- 
1.7.3.4

^ permalink raw reply	[flat|nested] 13+ messages in thread

end of thread, other threads:[~2011-03-22  0:49 UTC | newest]

Thread overview: 13+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2011-03-03 17:54 [PATCH v3 0/9] fsldma: lockup fixes Ira W. Snyder
2011-03-03 17:54 ` [PATCH v3 1/9] dmatest: fix automatic buffer unmap type Ira W. Snyder
2011-03-03 17:54 ` [PATCH v3 2/9] fsldma: move related helper functions near each other Ira W. Snyder
2011-03-03 17:54 ` [PATCH v3 3/9] fsldma: use channel name in printk output Ira W. Snyder
2011-03-22  0:49   ` Dan Williams
2011-03-03 17:54 ` [PATCH v3 4/9] fsldma: improve link descriptor debugging Ira W. Snyder
2011-03-03 17:54 ` [PATCH v3 5/9] fsldma: minor codingstyle and consistency fixes Ira W. Snyder
2011-03-03 17:54 ` [PATCH v3 6/9] fsldma: fix controller lockups Ira W. Snyder
2011-03-03 17:54 ` [PATCH v3 7/9] fsldma: support async_tx dependencies and automatic unmapping Ira W. Snyder
2011-03-03 20:51   ` Dan Williams
2011-03-03 17:55 ` [PATCH v3 8/9] fsldma: reduce locking during descriptor cleanup Ira W. Snyder
2011-03-03 17:55 ` [PATCH v3 9/9] fsldma: make halt behave nicely on all supported controllers Ira W. Snyder
2011-03-04 22:28 ` [PATCH v3 0/9] fsldma: lockup fixes Felix Radensky

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).