Commit 8ecb6ca6 authored by Arnd Bergmann's avatar Arnd Bergmann

Merge tag 'davinci-for-v3.11/soc-2' of...

Merge tag 'davinci-for-v3.11/soc-2' of git://git.kernel.org/pub/scm/linux/kernel/git/nsekhar/linux-davinci into next/soc

From Sekhar Nori:

DaVinci SoC updates for v3.11 - part 2

This pull request adds DT and runtime PM to
EDMA ARM private API so it can be used on
DT enabled DaVinci and OMAP platforms.

Also adds DMA channel crossbar mapping
support to be used by DT-enabled platforms
which use it.

* tag 'davinci-for-v3.11/soc-2' of git://git.kernel.org/pub/scm/linux/kernel/git/nsekhar/linux-davinci:
  dmaengine: edma: enable build for AM33XX
  ARM: edma: Add EDMA crossbar event mux support
  ARM: edma: Add DT and runtime PM support to the private EDMA API
  dmaengine: edma: Add TI EDMA device tree binding
  ARM: edma: Convert to devm_* api
Signed-off-by: default avatarArnd Bergmann <arnd@arndb.de>
parents 3aae7ab0 e65abbbc
TI EDMA
Required properties:
- compatible : "ti,edma3"
- ti,edma-regions: Number of regions
- ti,edma-slots: Number of slots
- #dma-cells: Should be set to <1>
Clients should use a single channel number per DMA request.
- dma-channels: Specify total DMA channels per CC
- reg: Memory map for accessing module
- interrupt-parent: Interrupt controller the interrupt is routed through
- interrupts: Exactly 3 interrupts need to be specified in the order:
1. Transfer completion interrupt.
2. Memory protection interrupt.
3. Error interrupt.
Optional properties:
- ti,hwmods: Name of the hwmods associated to the EDMA
- ti,edma-xbar-event-map: Crossbar event to channel map
Example:
edma: edma@49000000 {
reg = <0x49000000 0x10000>;
interrupt-parent = <&intc>;
interrupts = <12 13 14>;
compatible = "ti,edma3";
ti,hwmods = "tpcc", "tptc0", "tptc1", "tptc2";
#dma-cells = <1>;
dma-channels = <64>;
ti,edma-regions = <4>;
ti,edma-slots = <256>;
ti,edma-xbar-event-map = <1 12
2 13>;
};
This diff is collapsed.
...@@ -105,27 +105,27 @@ struct platform_device da8xx_serial_device = { ...@@ -105,27 +105,27 @@ struct platform_device da8xx_serial_device = {
}, },
}; };
static const s8 da8xx_queue_tc_mapping[][2] = { static s8 da8xx_queue_tc_mapping[][2] = {
/* {event queue no, TC no} */ /* {event queue no, TC no} */
{0, 0}, {0, 0},
{1, 1}, {1, 1},
{-1, -1} {-1, -1}
}; };
static const s8 da8xx_queue_priority_mapping[][2] = { static s8 da8xx_queue_priority_mapping[][2] = {
/* {event queue no, Priority} */ /* {event queue no, Priority} */
{0, 3}, {0, 3},
{1, 7}, {1, 7},
{-1, -1} {-1, -1}
}; };
static const s8 da850_queue_tc_mapping[][2] = { static s8 da850_queue_tc_mapping[][2] = {
/* {event queue no, TC no} */ /* {event queue no, TC no} */
{0, 0}, {0, 0},
{-1, -1} {-1, -1}
}; };
static const s8 da850_queue_priority_mapping[][2] = { static s8 da850_queue_priority_mapping[][2] = {
/* {event queue no, Priority} */ /* {event queue no, Priority} */
{0, 3}, {0, 3},
{-1, -1} {-1, -1}
......
...@@ -58,14 +58,14 @@ ...@@ -58,14 +58,14 @@
#define TNETV107X_DMACH_SDIO1_RX 28 #define TNETV107X_DMACH_SDIO1_RX 28
#define TNETV107X_DMACH_SDIO1_TX 29 #define TNETV107X_DMACH_SDIO1_TX 29
static const s8 edma_tc_mapping[][2] = { static s8 edma_tc_mapping[][2] = {
/* event queue no TC no */ /* event queue no TC no */
{ 0, 0 }, { 0, 0 },
{ 1, 1 }, { 1, 1 },
{ -1, -1 } { -1, -1 }
}; };
static const s8 edma_priority_mapping[][2] = { static s8 edma_priority_mapping[][2] = {
/* event queue no Prio */ /* event queue no Prio */
{ 0, 3 }, { 0, 3 },
{ 1, 7 }, { 1, 7 },
......
...@@ -569,7 +569,7 @@ static u8 dm355_default_priorities[DAVINCI_N_AINTC_IRQ] = { ...@@ -569,7 +569,7 @@ static u8 dm355_default_priorities[DAVINCI_N_AINTC_IRQ] = {
/*----------------------------------------------------------------------*/ /*----------------------------------------------------------------------*/
static const s8 static s8
queue_tc_mapping[][2] = { queue_tc_mapping[][2] = {
/* {event queue no, TC no} */ /* {event queue no, TC no} */
{0, 0}, {0, 0},
...@@ -577,7 +577,7 @@ queue_tc_mapping[][2] = { ...@@ -577,7 +577,7 @@ queue_tc_mapping[][2] = {
{-1, -1}, {-1, -1},
}; };
static const s8 static s8
queue_priority_mapping[][2] = { queue_priority_mapping[][2] = {
/* {event queue no, Priority} */ /* {event queue no, Priority} */
{0, 3}, {0, 3},
......
...@@ -826,7 +826,7 @@ static u8 dm365_default_priorities[DAVINCI_N_AINTC_IRQ] = { ...@@ -826,7 +826,7 @@ static u8 dm365_default_priorities[DAVINCI_N_AINTC_IRQ] = {
}; };
/* Four Transfer Controllers on DM365 */ /* Four Transfer Controllers on DM365 */
static const s8 static s8
dm365_queue_tc_mapping[][2] = { dm365_queue_tc_mapping[][2] = {
/* {event queue no, TC no} */ /* {event queue no, TC no} */
{0, 0}, {0, 0},
...@@ -836,7 +836,7 @@ dm365_queue_tc_mapping[][2] = { ...@@ -836,7 +836,7 @@ dm365_queue_tc_mapping[][2] = {
{-1, -1}, {-1, -1},
}; };
static const s8 static s8
dm365_queue_priority_mapping[][2] = { dm365_queue_priority_mapping[][2] = {
/* {event queue no, Priority} */ /* {event queue no, Priority} */
{0, 7}, {0, 7},
......
...@@ -497,7 +497,7 @@ static u8 dm644x_default_priorities[DAVINCI_N_AINTC_IRQ] = { ...@@ -497,7 +497,7 @@ static u8 dm644x_default_priorities[DAVINCI_N_AINTC_IRQ] = {
/*----------------------------------------------------------------------*/ /*----------------------------------------------------------------------*/
static const s8 static s8
queue_tc_mapping[][2] = { queue_tc_mapping[][2] = {
/* {event queue no, TC no} */ /* {event queue no, TC no} */
{0, 0}, {0, 0},
...@@ -505,7 +505,7 @@ queue_tc_mapping[][2] = { ...@@ -505,7 +505,7 @@ queue_tc_mapping[][2] = {
{-1, -1}, {-1, -1},
}; };
static const s8 static s8
queue_priority_mapping[][2] = { queue_priority_mapping[][2] = {
/* {event queue no, Priority} */ /* {event queue no, Priority} */
{0, 3}, {0, 3},
......
...@@ -531,7 +531,7 @@ static u8 dm646x_default_priorities[DAVINCI_N_AINTC_IRQ] = { ...@@ -531,7 +531,7 @@ static u8 dm646x_default_priorities[DAVINCI_N_AINTC_IRQ] = {
/*----------------------------------------------------------------------*/ /*----------------------------------------------------------------------*/
/* Four Transfer Controllers on DM646x */ /* Four Transfer Controllers on DM646x */
static const s8 static s8
dm646x_queue_tc_mapping[][2] = { dm646x_queue_tc_mapping[][2] = {
/* {event queue no, TC no} */ /* {event queue no, TC no} */
{0, 0}, {0, 0},
...@@ -541,7 +541,7 @@ dm646x_queue_tc_mapping[][2] = { ...@@ -541,7 +541,7 @@ dm646x_queue_tc_mapping[][2] = {
{-1, -1}, {-1, -1},
}; };
static const s8 static s8
dm646x_queue_priority_mapping[][2] = { dm646x_queue_priority_mapping[][2] = {
/* {event queue no, Priority} */ /* {event queue no, Priority} */
{0, 4}, {0, 4},
......
...@@ -17,6 +17,7 @@ config ARCH_OMAP2PLUS ...@@ -17,6 +17,7 @@ config ARCH_OMAP2PLUS
select PROC_DEVICETREE if PROC_FS select PROC_DEVICETREE if PROC_FS
select SOC_BUS select SOC_BUS
select SPARSE_IRQ select SPARSE_IRQ
select TI_PRIV_EDMA
select USE_OF select USE_OF
help help
Systems based on OMAP2, OMAP3, OMAP4 or OMAP5 Systems based on OMAP2, OMAP3, OMAP4 or OMAP5
......
...@@ -213,7 +213,7 @@ config SIRF_DMA ...@@ -213,7 +213,7 @@ config SIRF_DMA
config TI_EDMA config TI_EDMA
tristate "TI EDMA support" tristate "TI EDMA support"
depends on ARCH_DAVINCI depends on ARCH_DAVINCI || ARCH_OMAP
select DMA_ENGINE select DMA_ENGINE
select DMA_VIRTUAL_CHANNELS select DMA_VIRTUAL_CHANNELS
default n default n
......
...@@ -175,8 +175,9 @@ struct edma_soc_info { ...@@ -175,8 +175,9 @@ struct edma_soc_info {
/* Resource reservation for other cores */ /* Resource reservation for other cores */
struct edma_rsv_info *rsv; struct edma_rsv_info *rsv;
const s8 (*queue_tc_mapping)[2]; s8 (*queue_tc_mapping)[2];
const s8 (*queue_priority_mapping)[2]; s8 (*queue_priority_mapping)[2];
const s16 (*xbar_chans)[2];
}; };
#endif #endif
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment