Skip to content

Commit 25dcb5d

Browse files
Peter Ujfalusivinodkoul
Peter Ujfalusi
authored andcommitted
dmaengine: ti: New driver for K3 UDMA
Split patch for review containing: defines, structs, io and low level functions and interrupt callbacks. DMA driver for Texas Instruments K3 NAVSS Unified DMA – Peripheral Root Complex (UDMA-P) The UDMA-P is intended to perform similar (but significantly upgraded) functions as the packet-oriented DMA used on previous SoC devices. The UDMA-P module supports the transmission and reception of various packet types. The UDMA-P is architected to facilitate the segmentation and reassembly of SoC DMA data structure compliant packets to/from smaller data blocks that are natively compatible with the specific requirements of each connected peripheral. Multiple Tx and Rx channels are provided within the DMA which allow multiple segmentation or reassembly operations to be ongoing. The DMA controller maintains state information for each of the channels which allows packet segmentation and reassembly operations to be time division multiplexed between channels in order to share the underlying DMA hardware. An external DMA scheduler is used to control the ordering and rate at which this multiplexing occurs for Transmit operations. The ordering and rate of Receive operations is indirectly controlled by the order in which blocks are pushed into the DMA on the Rx PSI-L interface. The UDMA-P also supports acting as both a UTC and UDMA-C for its internal channels. Channels in the UDMA-P can be configured to be either Packet-Based or Third-Party channels on a channel by channel basis. The initial driver supports: - MEM_TO_MEM (TR mode) - DEV_TO_MEM (Packet / TR mode) - MEM_TO_DEV (Packet / TR mode) - Cyclic (Packet / TR mode) - Metadata for descriptors Signed-off-by: Peter Ujfalusi <[email protected]> Tested-by: Keerthy <[email protected]> Reviewed-by: Grygorii Strashko <[email protected]> Link: https://lore.kernel.org/r/[email protected] Signed-off-by: Vinod Koul <[email protected]>
1 parent d3cd299 commit 25dcb5d

File tree

4 files changed

+3505
-0
lines changed

4 files changed

+3505
-0
lines changed

drivers/dma/ti/Kconfig

Lines changed: 13 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -34,6 +34,19 @@ config DMA_OMAP
3434
Enable support for the TI sDMA (System DMA or DMA4) controller. This
3535
DMA engine is found on OMAP and DRA7xx parts.
3636

37+
config TI_K3_UDMA
38+
bool "Texas Instruments UDMA support"
39+
depends on ARCH_K3 || COMPILE_TEST
40+
depends on TI_SCI_PROTOCOL
41+
depends on TI_SCI_INTA_IRQCHIP
42+
select DMA_ENGINE
43+
select DMA_VIRTUAL_CHANNELS
44+
select TI_K3_RINGACC
45+
select TI_K3_PSIL
46+
help
47+
Enable support for the TI UDMA (Unified DMA) controller. This
48+
DMA engine is used in AM65x and j721e.
49+
3750
config TI_K3_PSIL
3851
bool
3952

drivers/dma/ti/Makefile

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -2,5 +2,6 @@
22
obj-$(CONFIG_TI_CPPI41) += cppi41.o
33
obj-$(CONFIG_TI_EDMA) += edma.o
44
obj-$(CONFIG_DMA_OMAP) += omap-dma.o
5+
obj-$(CONFIG_TI_K3_UDMA) += k3-udma.o
56
obj-$(CONFIG_TI_K3_PSIL) += k3-psil.o k3-psil-am654.o k3-psil-j721e.o
67
obj-$(CONFIG_TI_DMA_CROSSBAR) += dma-crossbar.o

0 commit comments

Comments
 (0)