cachepc-linux

Fork of AMDESE/linux with modifications for CachePC side-channel attack
git clone https://git.sinitax.com/sinitax/cachepc-linux
Log | Files | Refs | README | LICENSE | sfeed.txt

ti-edma.txt (7516B)


      1Texas Instruments eDMA
      2
      3The eDMA3 consists of two components: Channel controller (CC) and Transfer
      4Controller(s) (TC). The CC is the main entry for DMA users since it is
      5responsible for the DMA channel handling, while the TCs are responsible to
      6execute the actual DMA tansfer.
      7
      8------------------------------------------------------------------------------
      9eDMA3 Channel Controller
     10
     11Required properties:
     12--------------------
     13- compatible:	Should be:
     14		- "ti,edma3-tpcc" for the channel controller(s) on OMAP,
     15		  AM33xx and AM43xx SoCs.
     16		- "ti,k2g-edma3-tpcc", "ti,edma3-tpcc" for the
     17		  channel controller(s) on 66AK2G.
     18- #dma-cells:	Should be set to <2>. The first number is the DMA request
     19		number and the second is the TC the channel is serviced on.
     20- reg:		Memory map of eDMA CC
     21- reg-names:	"edma3_cc"
     22- interrupts:	Interrupt lines for CCINT, MPERR and CCERRINT.
     23- interrupt-names: "edma3_ccint", "edma3_mperr" and "edma3_ccerrint"
     24- ti,tptcs:	List of TPTCs associated with the eDMA in the following form:
     25		<&tptc_phandle TC_priority_number>. The highest priority is 0.
     26
     27SoC-specific Required properties:
     28--------------------------------
     29The following are mandatory properties for OMAP, AM33xx and AM43xx SoCs only:
     30- ti,hwmods:	Name of the hwmods associated to the eDMA CC.
     31
     32The following are mandatory properties for 66AK2G SoCs only:
     33- power-domains:Should contain a phandle to a PM domain provider node
     34		and an args specifier containing the device id
     35		value. This property is as per the binding,
     36		Documentation/devicetree/bindings/soc/ti/sci-pm-domain.yaml
     37
     38Optional properties:
     39-------------------
     40- ti,edma-memcpy-channels: List of channels allocated to be used for memcpy, iow
     41		these channels will be SW triggered channels. See example.
     42- ti,edma-reserved-slot-ranges: PaRAM slot ranges which should not be used by
     43		the driver, they are allocated to be used by for example the
     44		DSP. See example.
     45- dma-channel-mask: Mask of usable channels.
     46		Single uint32 for EDMA with 32 channels, array of two uint32 for
     47		EDMA with 64 channels. See example and
     48		Documentation/devicetree/bindings/dma/dma-common.yaml
     49
     50
     51------------------------------------------------------------------------------
     52eDMA3 Transfer Controller
     53
     54Required properties:
     55--------------------
     56- compatible:	Should be:
     57		- "ti,edma3-tptc" for the transfer controller(s) on OMAP,
     58		  AM33xx and AM43xx SoCs.
     59		- "ti,k2g-edma3-tptc", "ti,edma3-tptc" for the
     60		  transfer controller(s) on 66AK2G.
     61- reg:		Memory map of eDMA TC
     62- interrupts:	Interrupt number for TCerrint.
     63
     64SoC-specific Required properties:
     65--------------------------------
     66The following are mandatory properties for OMAP, AM33xx and AM43xx SoCs only:
     67- ti,hwmods:	Name of the hwmods associated to the eDMA TC.
     68
     69The following are mandatory properties for 66AK2G SoCs only:
     70- power-domains:Should contain a phandle to a PM domain provider node
     71		and an args specifier containing the device id
     72		value. This property is as per the binding,
     73		Documentation/devicetree/bindings/soc/ti/sci-pm-domain.yaml
     74
     75Optional properties:
     76-------------------
     77- interrupt-names: "edma3_tcerrint"
     78
     79------------------------------------------------------------------------------
     80Examples:
     81
     821.
     83edma: edma@49000000 {
     84	compatible = "ti,edma3-tpcc";
     85	ti,hwmods = "tpcc";
     86	reg =	<0x49000000 0x10000>;
     87	reg-names = "edma3_cc";
     88	interrupts = <12 13 14>;
     89	interrupt-names = "edma3_ccint", "edma3_mperr", "edma3_ccerrint";
     90	dma-requests = <64>;
     91	#dma-cells = <2>;
     92
     93	ti,tptcs = <&edma_tptc0 7>, <&edma_tptc1 7>, <&edma_tptc2 0>;
     94
     95	/* Channel 20 and 21 is allocated for memcpy */
     96	ti,edma-memcpy-channels = <20 21>;
     97	/* The following PaRAM slots are reserved: 35-44 and 100-109 */
     98	ti,edma-reserved-slot-ranges = <35 10>, <100 10>;
     99	/* The following channels are reserved: 35-44 */
    100	dma-channel-mask = <0xffffffff /* Channel 0-31 */
    101			    0xffffe007>; /* Channel 32-63 */
    102};
    103
    104edma_tptc0: tptc@49800000 {
    105	compatible = "ti,edma3-tptc";
    106	ti,hwmods = "tptc0";
    107	reg =	<0x49800000 0x100000>;
    108	interrupts = <112>;
    109	interrupt-names = "edm3_tcerrint";
    110};
    111
    112edma_tptc1: tptc@49900000 {
    113	compatible = "ti,edma3-tptc";
    114	ti,hwmods = "tptc1";
    115	reg =	<0x49900000 0x100000>;
    116	interrupts = <113>;
    117	interrupt-names = "edm3_tcerrint";
    118};
    119
    120edma_tptc2: tptc@49a00000 {
    121	compatible = "ti,edma3-tptc";
    122	ti,hwmods = "tptc2";
    123	reg =	<0x49a00000 0x100000>;
    124	interrupts = <114>;
    125	interrupt-names = "edm3_tcerrint";
    126};
    127
    128sham: sham@53100000 {
    129	compatible = "ti,omap4-sham";
    130	ti,hwmods = "sham";
    131	reg = <0x53100000 0x200>;
    132	interrupts = <109>;
    133	/* DMA channel 36 executed on eDMA TC0 - low priority queue */
    134	dmas = <&edma 36 0>;
    135	dma-names = "rx";
    136};
    137
    138mcasp0: mcasp@48038000 {
    139	compatible = "ti,am33xx-mcasp-audio";
    140	ti,hwmods = "mcasp0";
    141	reg = <0x48038000 0x2000>,
    142		<0x46000000 0x400000>;
    143	reg-names = "mpu", "dat";
    144	interrupts = <80>, <81>;
    145	interrupt-names = "tx", "rx";
    146	/* DMA channels 8 and 9 executed on eDMA TC2 - high priority queue */
    147	dmas = <&edma 8 2>,
    148	       <&edma 9 2>;
    149	dma-names = "tx", "rx";
    150};
    151
    1522.
    153edma1: edma@2728000 {
    154	compatible = "ti,k2g-edma3-tpcc", "ti,edma3-tpcc";
    155	reg =	<0x02728000 0x8000>;
    156	reg-names = "edma3_cc";
    157	interrupts = <GIC_SPI 208 IRQ_TYPE_EDGE_RISING>,
    158			<GIC_SPI 219 IRQ_TYPE_EDGE_RISING>,
    159			<GIC_SPI 220 IRQ_TYPE_EDGE_RISING>;
    160	interrupt-names = "edma3_ccint", "emda3_mperr",
    161			  "edma3_ccerrint";
    162	dma-requests = <64>;
    163	#dma-cells = <2>;
    164
    165	ti,tptcs = <&edma1_tptc0 7>, <&edma1_tptc1 0>;
    166
    167	/*
    168	 * memcpy is disabled, can be enabled with:
    169	 * ti,edma-memcpy-channels = <12 13 14 15>;
    170	 * for example.
    171	 */
    172
    173	power-domains = <&k2g_pds 0x4f>;
    174};
    175
    176edma1_tptc0: tptc@27b0000 {
    177	compatible = "ti,k2g-edma3-tptc", "ti,edma3-tptc";
    178	reg =	<0x027b0000 0x400>;
    179	power-domains = <&k2g_pds 0x4f>;
    180};
    181
    182edma1_tptc1: tptc@27b8000 {
    183	compatible = "ti,k2g-edma3-tptc", "ti,edma3-tptc";
    184	reg =	<0x027b8000 0x400>;
    185	power-domains = <&k2g_pds 0x4f>;
    186};
    187
    188mmc0: mmc@23000000 {
    189	compatible = "ti,k2g-hsmmc", "ti,omap4-hsmmc";
    190	reg = <0x23000000 0x400>;
    191	interrupts = <GIC_SPI 96 IRQ_TYPE_EDGE_RISING>;
    192	dmas = <&edma1 24 0>, <&edma1 25 0>;
    193	dma-names = "tx", "rx";
    194	bus-width = <4>;
    195	ti,needs-special-reset;
    196	no-1-8-v;
    197	max-frequency = <96000000>;
    198	power-domains = <&k2g_pds 0xb>;
    199	clocks = <&k2g_clks 0xb 1>, <&k2g_clks 0xb 2>;
    200	clock-names = "fck", "mmchsdb_fck";
    201};
    202
    203------------------------------------------------------------------------------
    204DEPRECATED binding, new DTS files must use the ti,edma3-tpcc/ti,edma3-tptc
    205binding.
    206
    207Required properties:
    208- compatible : "ti,edma3"
    209- #dma-cells: Should be set to <1>
    210              Clients should use a single channel number per DMA request.
    211- reg: Memory map for accessing module
    212- interrupts: Exactly 3 interrupts need to be specified in the order:
    213              1. Transfer completion interrupt.
    214              2. Memory protection interrupt.
    215              3. Error interrupt.
    216Optional properties:
    217- ti,hwmods: Name of the hwmods associated to the EDMA
    218- ti,edma-xbar-event-map: Crossbar event to channel map
    219
    220Deprecated properties:
    221Listed here in case one wants to boot an old kernel with new DTB. These
    222properties might need to be added to the new DTS files.
    223- ti,edma-regions: Number of regions
    224- ti,edma-slots: Number of slots
    225- dma-channels: Specify total DMA channels per CC
    226
    227Example:
    228
    229edma: edma@49000000 {
    230	reg = <0x49000000 0x10000>;
    231	interrupt-parent = <&intc>;
    232	interrupts = <12 13 14>;
    233	compatible = "ti,edma3";
    234	ti,hwmods = "tpcc", "tptc0", "tptc1", "tptc2";
    235	#dma-cells = <1>;
    236	ti,edma-xbar-event-map = /bits/ 16 <1 12
    237					    2 13>;
    238};