2014-07-14 22:47:26 +02:00
subdir-ccflags-$(CONFIG_DMADEVICES_DEBUG) := -DDEBUG
subdir-ccflags-$(CONFIG_DMADEVICES_VDEBUG) += -DVERBOSE_DEBUG
2010-02-09 22:34:54 +01:00
2006-05-23 17:50:37 -07:00
obj-$(CONFIG_DMA_ENGINE) += dmaengine.o
2012-04-13 12:07:23 +01:00
obj-$(CONFIG_DMA_VIRTUAL_CHANNELS) += virt-dma.o
2013-04-09 14:05:43 +03:00
obj-$(CONFIG_DMA_ACPI) += acpi-dma.o
2013-02-12 09:15:02 -08:00
obj-$(CONFIG_DMA_OF) += of-dma.o
2008-07-08 11:58:45 -07:00
obj-$(CONFIG_DMATEST) += dmatest.o
2009-07-28 14:32:12 -07:00
obj-$(CONFIG_INTEL_IOATDMA) += ioat/
dmaengine: driver for the iop32x, iop33x, and iop13xx raid engines
The Intel(R) IOP series of i/o processors integrate an Xscale core with
raid acceleration engines. The capabilities per platform are:
iop219:
(2) copy engines
iop321:
(2) copy engines
(1) xor and block fill engine
iop33x:
(2) copy and crc32c engines
(1) xor, xor zero sum, pq, pq zero sum, and block fill engine
iop34x (iop13xx):
(2) copy, crc32c, xor, xor zero sum, and block fill engines
(1) copy, crc32c, xor, xor zero sum, pq, pq zero sum, and block fill engine
The driver supports the features of the async_tx api:
* asynchronous notification of operation completion
* implicit (interupt triggered) handling of inter-channel transaction
dependencies
The driver adapts to the platform it is running by two methods.
1/ #include <asm/arch/adma.h> which defines the hardware specific
iop_chan_* and iop_desc_* routines as a series of static inline
functions
2/ The private platform data attached to the platform_device defines the
capabilities of the channels
20070626: Callbacks are run in a tasklet. Given the recent discussion on
LKML about killing tasklets in favor of workqueues I did a quick conversion
of the driver. Raid5 resync performance dropped from 50MB/s to 30MB/s, so
the tasklet implementation remains until a generic softirq interface is
available.
Changelog:
* fixed a slot allocation bug in do_iop13xx_adma_xor that caused too few
slots to be requested eventually leading to data corruption
* enabled the slot allocation routine to attempt to free slots before
returning -ENOMEM
* switched the cleanup routine to solely use the software chain and the
status register to determine if a descriptor is complete. This is
necessary to support other IOP engines that do not have status writeback
capability
* make the driver iop generic
* modified the allocation routines to understand allocating a group of
slots for a single operation
* added a null xor initialization operation for the xor only channel on
iop3xx
* support xor operations on buffers larger than the hardware maximum
* split the do_* routines into separate prep, src/dest set, submit stages
* added async_tx support (dependent operations initiation at cleanup time)
* simplified group handling
* added interrupt support (callbacks via tasklets)
* brought the pending depth inline with ioat (i.e. 4 descriptors)
* drop dma mapping methods, suggested by Chris Leech
* don't use inline in C files, Adrian Bunk
* remove static tasklet declarations
* make iop_adma_alloc_slots easier to read and remove chances for a
corrupted descriptor chain
* fix locking bug in iop_adma_alloc_chan_resources, Benjamin Herrenschmidt
* convert capabilities over to dma_cap_mask_t
* fixup sparse warnings
* add descriptor flush before iop_chan_enable
* checkpatch.pl fixes
* gpl v2 only correction
* move set_src, set_dest, submit to async_tx methods
* move group_list and phys to async_tx
Cc: Russell King <rmk@arm.linux.org.uk>
Signed-off-by: Dan Williams <dan.j.williams@intel.com>
2007-01-02 13:52:26 -07:00
obj-$(CONFIG_INTEL_IOP_ADMA) += iop-adma.o
2008-03-01 07:42:48 -07:00
obj-$(CONFIG_FSL_DMA) += fsldma.o
2015-02-23 16:24:42 +02:00
obj-$(CONFIG_HSU_DMA) += hsu/
2010-02-05 03:42:52 +00:00
obj-$(CONFIG_MPC512X_DMA) += mpc512x_dma.o
2012-10-12 17:52:45 +02:00
obj-$(CONFIG_PPC_BESTCOMM) += bestcomm/
2008-07-08 11:58:36 -07:00
obj-$(CONFIG_MV_XOR) += mv_xor.o
2013-06-05 15:26:45 +03:00
obj-$(CONFIG_DW_DMAC_CORE) += dw/
2009-07-03 19:24:33 +02:00
obj-$(CONFIG_AT_HDMAC) += at_hdmac.o
2014-10-22 17:22:18 +02:00
obj-$(CONFIG_AT_XDMAC) += at_xdmac.o
i.MX31: Image Processing Unit DMA and IRQ drivers
i.MX3x SoCs contain an Image Processing Unit, consisting of a Control
Module (CM), Display Interface (DI), Synchronous Display Controller (SDC),
Asynchronous Display Controller (ADC), Image Converter (IC), Post-Filter
(PF), Camera Sensor Interface (CSI), and an Image DMA Controller (IDMAC).
CM contains, among other blocks, an Interrupt Generator (IG) and a Clock
and Reset Control Unit (CRCU). This driver serves IDMAC and IG. They are
supported over dmaengine and irq-chip APIs respectively.
IDMAC is a specialised DMA controller, its DMA channels cannot be used for
general-purpose operations, even though it might be possible to configure
a memory-to-memory channel for memcpy operation. This driver will not work
with generic dmaengine clients, clients, wishing to use it must use
respective wrapper structures, they also must specify which channels they
require, as channels are hard-wired to specific IPU functions.
Acked-by: Sascha Hauer <s.hauer@pengutronix.de>
Signed-off-by: Guennadi Liakhovetski <lg@denx.de>
Signed-off-by: Dan Williams <dan.j.williams@intel.com>
2009-01-19 15:36:21 -07:00
obj-$(CONFIG_MX3_IPU) += ipu/
2009-04-23 00:40:30 +09:00
obj-$(CONFIG_TXX9_DMAC) += txx9dmac.o
2014-07-09 00:42:19 +02:00
obj-$(CONFIG_RENESAS_DMA) += sh/
2009-11-19 19:49:17 +01:00
obj-$(CONFIG_COH901318) += coh901318.o coh901318_lli.o
2009-12-11 21:24:44 -07:00
obj-$(CONFIG_AMCC_PPC440SPE_ADMA) += ppc4xx/
2010-09-30 13:56:34 +00:00
obj-$(CONFIG_IMX_SDMA) += imx-sdma.o
2010-10-06 10:25:55 +02:00
obj-$(CONFIG_IMX_DMA) += imx-dma.o
2011-02-27 00:47:42 +08:00
obj-$(CONFIG_MXS_DMA) += mxs-dma.o
dmaengine: pxa: add pxa dmaengine driver
This is a new driver for pxa SoCs, which is also compatible with the former
mmp_pdma.
The rationale behind a new driver (as opposed to incremental patching) was :
- the new driver relies on virt-dma, which obsoletes all the internal
structures of mmp_pdma (sw_desc, hw_desc, ...), and by consequence all the
functions
- mmp_pdma allocates dma coherent descriptors containing not only hardware
descriptors but linked list information
The new driver only puts the dma hardware descriptors (ie. 4 u32) into the
dma pool allocated memory. This changes completely the way descriptors are
handled
- the architecture behind the interrupt/tasklet management was rewritten to be
more conforming to virt-dma
- the buffers alignment is handled differently
The former driver assumed that the DMA channel stopped between each
descriptor. The new one chains descriptors to let the channel running. This
is a necessary guarantee for real-time high bandwidth usecases such as video
capture on "old" architectures such as pxa.
- hot chaining / cold chaining / no chaining
Whenever possible, submitting a descriptor "hot chains" it to a running
channel. There is still no guarantee that the descriptor will be issued, as
the channel might be stopped just before the descriptor is submitted. Yet
this allows to submit several video buffers, and resubmit a buffer while
another is under handling.
As before, dma_async_issue_pending() is the only guarantee to have all the
buffers issued.
When an alignment issue is detected (ie. one address in a descriptor is not
a multiple of 8), if the already running channel is in "aligned mode", the
channel will stop, and restarted in "misaligned mode" to finished the issued
list.
- descriptors reusing
A submitted, issued and completed descriptor can be reused, ie resubmitted if
it was prepared with the proper flag (DMA_PREP_ACK). Only a channel
resources release will in this case release that buffer.
This allows a rolling ring of buffers to be reused, where there are several
thousands of hardware descriptors used (video buffer for example).
Additionally, a set of more casual features is introduced :
- debugging traces
- lockless way to know if a descriptor is terminated or not
The driver was tested on zylonite board (pxa3xx) and mioa701 (pxa27x),
with dmatest, pxa_camera and pxamci.
Signed-off-by: Robert Jarzmik <robert.jarzmik@free.fr>
Signed-off-by: Vinod Koul <vinod.koul@intel.com>
2015-05-25 23:29:20 +02:00
obj-$(CONFIG_PXA_DMA) += pxa_dma.o
2010-03-25 19:44:21 +01:00
obj-$(CONFIG_TIMB_DMA) += timb_dma.o
2011-10-27 19:22:39 -07:00
obj-$(CONFIG_SIRF_DMA) += sirf-dma.o
2012-08-22 21:09:34 -04:00
obj-$(CONFIG_TI_EDMA) += edma.o
2010-03-30 15:33:42 +02:00
obj-$(CONFIG_STE_DMA40) += ste_dma40.o ste_dma40_ll.o
2012-06-06 10:55:27 +05:30
obj-$(CONFIG_TEGRA20_APB_DMA) += tegra20-apb-dma.o
2013-10-08 06:42:10 +09:00
obj-$(CONFIG_S3C24XX_DMAC) += s3c24xx-dma.o
2010-05-23 20:28:19 -07:00
obj-$(CONFIG_PL330_DMA) += pl330.o
2010-07-30 16:23:03 +08:00
obj-$(CONFIG_PCH_DMA) += pch_dma.o
2010-09-28 15:57:37 +02:00
obj-$(CONFIG_AMBA_PL08X) += amba-pl08x.o
2011-05-29 13:10:02 +03:00
obj-$(CONFIG_EP93XX_DMA) += ep93xx_dma.o
DMA: sa11x0: add SA-11x0 DMA driver
Add support for the SA-11x0 DMA driver, which replaces the private
API version in arch/arm/mach-sa1100/dma.c.
We model this as a set of virtual DMA channels, one for each request
signal, and assign the virtual DMA channel to a physical DMA channel
when there is work to be done. This allows DMA users to claim their
channels, and hold them while not in use, without affecting the
availability of the physical channels.
Another advantage over this approach, compared to the private version,
is that a channel can be reconfigured on the fly without having to
release and re-request it - which for the IrDA driver, allows us to
use DMA for SIR mode transmit without eating up three physical
channels. As IrDA is half-duplex, we actually only need one physical
channel, and this architecture allows us to achieve that.
Signed-off-by: Russell King <rmk+kernel@arm.linux.org.uk>
2012-01-09 21:44:07 +00:00
obj-$(CONFIG_DMA_SA11X0) += sa11x0-dma.o
2012-06-15 11:04:08 +08:00
obj-$(CONFIG_MMP_TDMA) += mmp_tdma.o
2012-04-13 12:10:24 +01:00
obj-$(CONFIG_DMA_OMAP) += omap-dma.o
2015-04-09 12:35:49 +03:00
obj-$(CONFIG_TI_DMA_CROSSBAR) += ti-dma-crossbar.o
2014-01-06 20:18:24 +01:00
obj-$(CONFIG_DMA_BCM2835) += bcm2835-dma.o
dmaengine: mmp-pdma support
1. virtual channel vs. physical channel
Virtual channel is managed by dmaengine
Physical channel handling resource, such as irq
Physical channel is alloced dynamically as descending priority,
freed immediately when irq done.
The availble highest priority physically channel will alwayes be alloced
Issue pending list -> alloc highest dma physically channel available -> dma done -> free physically channel
2. list: running list & pending list
submit: desc list -> pending list
issue_pending_list: if (IDLE) pending list -> running list; free pending list (RUN)
irq: free running list (IDLE)
check pendlist -> pending list -> running list; free pending list (RUN)
3. irq:
Each list generate one irq, calling callback
One list may contain several desc chain, in such case, make sure only the last desc list generate irq.
4. async
Submit will add desc chain to pending list, which can be multi-called
If multi desc chain is submitted, only the last desc would generate irq -> call back
If IDLE, issue_pending_list start pending_list, transforming pendlist to running list
If RUN, irq will start pending list
5. test
5.1 pxa3xx_nand on pxa910
5.2 insmod dmatest.ko (threads_per_chan=y)
By default drivers/dma/dmatest.c test every channel and test memcpy with 1 threads per channel
Signed-off-by: Zhangfei Gao <zhangfei.gao@marvell.com>
Acked-by: Arnd Bergmann <arnd@arndb.de>
Signed-off-by: Vinod Koul <vinod.koul@linux.intel.com>
2012-09-03 11:03:45 +08:00
obj-$(CONFIG_MMP_PDMA) += mmp_pdma.o
2013-05-30 18:25:02 +02:00
obj-$(CONFIG_DMA_JZ4740) += dma-jz4740.o
2015-03-18 16:16:36 +00:00
obj-$(CONFIG_DMA_JZ4780) += dma-jz4780.o
2013-06-20 12:13:04 +02:00
obj-$(CONFIG_TI_CPPI41) += cppi41.o
2013-08-27 10:20:10 +08:00
obj-$(CONFIG_K3_DMA) += k3dma.o
2014-01-17 09:46:05 +01:00
obj-$(CONFIG_MOXART_DMA) += moxart-dma.o
2015-03-03 14:26:22 +08:00
obj-$(CONFIG_FSL_RAID) += fsl_raid.o
2014-03-29 18:53:16 +05:30
obj-$(CONFIG_FSL_EDMA) += fsl-edma.o
obj-$(CONFIG_QCOM_BAM_DMA) += qcom_bam_dma.o
2014-04-23 20:23:26 +05:30
obj-y += xilinx/
2014-07-11 14:04:21 -07:00
obj-$(CONFIG_INTEL_MIC_X100_DMA) += mic_x100_dma.o
2014-07-19 12:48:51 +02:00
obj-$(CONFIG_NBPFAXI_DMA) += nbpfaxi.o
2014-07-17 21:46:16 +02:00
obj-$(CONFIG_DMA_SUN6I) += sun6i-dma.o
2014-12-11 14:59:17 -08:00
obj-$(CONFIG_IMG_MDC_DMA) += img-mdc-dma.o
2015-03-18 19:17:34 +05:30
obj-$(CONFIG_XGENE_DMA) += xgene-dma.o