async_tx: remove walk of tx->parent chain in dma_wait_for_async_tx
authorDan Williams <dan.j.williams@intel.com>
Tue, 14 Jul 2009 19:19:02 +0000 (12:19 -0700)
committerDan Williams <dan.j.williams@intel.com>
Sun, 30 Aug 2009 02:09:27 +0000 (19:09 -0700)
commit95475e57113c66aac7583925736ed2e2d58c990d
tree933aa0ca3bffef5b1457c516fbe3e8690b4c4cb1
parentaf1f951eb6ef27b01cbfb3f6c21b770af4368a6d
async_tx: remove walk of tx->parent chain in dma_wait_for_async_tx

We currently walk the parent chain when waiting for a given tx to
complete however this walk may race with the driver cleanup routine.
The routines in async_raid6_recov.c may fall back to the synchronous
path at any point so we need to be prepared to call async_tx_quiesce()
(which calls  dma_wait_for_async_tx).  To remove the ->parent walk we
guarantee that every time a dependency is attached ->issue_pending() is
invoked, then we can simply poll the initial descriptor until
completion.

This also allows for a lighter weight 'issue pending' implementation as
there is no longer a requirement to iterate through all the channels'
->issue_pending() routines as long as operations have been submitted in
an ordered chain.  async_tx_issue_pending() is added for this case.

Signed-off-by: Dan Williams <dan.j.williams@intel.com>
crypto/async_tx/async_tx.c
drivers/dma/dmaengine.c
include/linux/async_tx.h