[PATCH RFC v2 0/5] MPC512x DMA slave s/g support, OF DMA lookup
Gerhard Sittig
gsi at denx.de
Sun Jul 14 22:01:56 EST 2013
this series
- introduces slave s/g support (that's support for DMA transfers which
involve peripherals in contrast to mem-to-mem transfers)
- adds device tree based lookup support for DMA channels
- combines floating patches and related feedback which already covered
several aspects of what the suggested LPB driver needs, to demonstrate
how integration might be done
- carries Q&D SD card support to enable another DMA client during test,
while this patch needs to get dropped upon pickup
changes since v1:
- re-order mpc8308 related code paths for improved readability, no
change in behaviour, introduction of symbolic channel names here
already
- squash 'execute() start condition' and 'terminate all' into the
introduction of 'slave s/g prep' and 'device control' support; refuse
s/g lists with more than one item since slave support is operational
yet proper s/g support is missing (can get addressed later)
- always start transfers from software on MPC8308 as there are no
external request lines for peripheral flow control
- drop dt-bindings header file and symbolic channel names in OF nodes
known issues:
- it's yet to get confirmed whether MPC8308 can use slave support or
whether the DMA controller's driver shall actively reject it, the
information that's available so far suggests that peripheral transfers
to IP bus attached I/O is useful and shall not get blocked right away
- currently encoded constraints do work for SD card and LPB test suite
(all known DMA clients ATM), but will need more tuning or support for
automatic adjustment for transfers of arbitrary length
oh, and I'd like to get feedback on whether attribution handling is
appropriate, as I had to squash patches from several authors to not
break bisectability (compilation had worked, but the code had not run
successfully on all previously supported hardware)
Alexander, when you pickup this series and improve slave s/g support and
adjust it for more general use, you have my OK to incorporate and
further adjust the parts that I've contributed
Alexander Popov (1):
dma: mpc512x: add support for peripheral transfers
Gerhard Sittig (3):
dma: mpc512x: re-order mpc8308 specific instructions
dma: mpc512x: register for device tree channel lookup
HACK mmc: mxcmmc: enable clocks for the MPC512x
Lars-Peter Clausen (1):
dma: of: Add common xlate function for matching by channel id
.../devicetree/bindings/dma/mpc512x-dma.txt | 55 +++++
arch/powerpc/boot/dts/mpc5121.dtsi | 1 +
drivers/dma/mpc512x_dma.c | 237 +++++++++++++++++---
drivers/dma/of-dma.c | 47 ++++
drivers/mmc/host/mxcmmc.c | 41 ++--
include/linux/of_dma.h | 4 +
6 files changed, 344 insertions(+), 41 deletions(-)
create mode 100644 Documentation/devicetree/bindings/dma/mpc512x-dma.txt
--
1.7.10.4
More information about the Linuxppc-dev
mailing list