Go to the documentation of this file.
15 #include <linux/device.h>
18 #define MAX_DMA_PACKET_SIZE_SHIFT 11
19 #define MAX_DMA_PACKET_SIZE (1 << MAX_DMA_PACKET_SIZE_SHIFT)
105 #ifdef CONFIG_COH901318
126 #define COH901318_MOD32_MASK (0x1F)
127 #define COH901318_WORD_MASK (0xFFFFFFFF)
129 #define COH901318_INT_STATUS1 (0x0000)
130 #define COH901318_INT_STATUS2 (0x0004)
132 #define COH901318_TC_INT_STATUS1 (0x0008)
133 #define COH901318_TC_INT_STATUS2 (0x000C)
135 #define COH901318_TC_INT_CLEAR1 (0x0010)
136 #define COH901318_TC_INT_CLEAR2 (0x0014)
138 #define COH901318_RAW_TC_INT_STATUS1 (0x0018)
139 #define COH901318_RAW_TC_INT_STATUS2 (0x001C)
141 #define COH901318_BE_INT_STATUS1 (0x0020)
142 #define COH901318_BE_INT_STATUS2 (0x0024)
144 #define COH901318_BE_INT_CLEAR1 (0x0028)
145 #define COH901318_BE_INT_CLEAR2 (0x002C)
147 #define COH901318_RAW_BE_INT_STATUS1 (0x0030)
148 #define COH901318_RAW_BE_INT_STATUS2 (0x0034)
153 #define COH901318_CX_CFG (0x0100)
154 #define COH901318_CX_CFG_SPACING (0x04)
156 #define COH901318_CX_CFG_CH_ENABLE (0x00000001)
157 #define COH901318_CX_CFG_CH_DISABLE (0x00000000)
159 #define COH901318_CX_CFG_RM_MASK (0x00000006)
160 #define COH901318_CX_CFG_RM_MEMORY_TO_MEMORY (0x0 << 1)
161 #define COH901318_CX_CFG_RM_PRIMARY_TO_MEMORY (0x1 << 1)
162 #define COH901318_CX_CFG_RM_MEMORY_TO_PRIMARY (0x1 << 1)
163 #define COH901318_CX_CFG_RM_PRIMARY_TO_SECONDARY (0x3 << 1)
164 #define COH901318_CX_CFG_RM_SECONDARY_TO_PRIMARY (0x3 << 1)
166 #define COH901318_CX_CFG_LCRF_SHIFT 3
167 #define COH901318_CX_CFG_LCRF_MASK (0x000001F8)
168 #define COH901318_CX_CFG_LCR_DISABLE (0x00000000)
170 #define COH901318_CX_CFG_TC_IRQ_ENABLE (0x00000200)
171 #define COH901318_CX_CFG_TC_IRQ_DISABLE (0x00000000)
173 #define COH901318_CX_CFG_BE_IRQ_ENABLE (0x00000400)
174 #define COH901318_CX_CFG_BE_IRQ_DISABLE (0x00000000)
179 #define COH901318_CX_STAT (0x0200)
180 #define COH901318_CX_STAT_SPACING (0x04)
181 #define COH901318_CX_STAT_RBE_IRQ_IND (0x00000008)
182 #define COH901318_CX_STAT_RTC_IRQ_IND (0x00000004)
183 #define COH901318_CX_STAT_ACTIVE (0x00000002)
184 #define COH901318_CX_STAT_ENABLED (0x00000001)
189 #define COH901318_CX_CTRL (0x0400)
190 #define COH901318_CX_CTRL_SPACING (0x10)
192 #define COH901318_CX_CTRL_TC_ENABLE (0x00001000)
193 #define COH901318_CX_CTRL_TC_DISABLE (0x00000000)
195 #define COH901318_CX_CTRL_TC_VALUE_MASK (0x00000FFF)
197 #define COH901318_CX_CTRL_BURST_COUNT_MASK (0x0000E000)
198 #define COH901318_CX_CTRL_BURST_COUNT_64_BYTES (0x7 << 13)
199 #define COH901318_CX_CTRL_BURST_COUNT_48_BYTES (0x6 << 13)
200 #define COH901318_CX_CTRL_BURST_COUNT_32_BYTES (0x5 << 13)
201 #define COH901318_CX_CTRL_BURST_COUNT_16_BYTES (0x4 << 13)
202 #define COH901318_CX_CTRL_BURST_COUNT_8_BYTES (0x3 << 13)
203 #define COH901318_CX_CTRL_BURST_COUNT_4_BYTES (0x2 << 13)
204 #define COH901318_CX_CTRL_BURST_COUNT_2_BYTES (0x1 << 13)
205 #define COH901318_CX_CTRL_BURST_COUNT_1_BYTE (0x0 << 13)
207 #define COH901318_CX_CTRL_SRC_BUS_SIZE_MASK (0x00030000)
208 #define COH901318_CX_CTRL_SRC_BUS_SIZE_32_BITS (0x2 << 16)
209 #define COH901318_CX_CTRL_SRC_BUS_SIZE_16_BITS (0x1 << 16)
210 #define COH901318_CX_CTRL_SRC_BUS_SIZE_8_BITS (0x0 << 16)
212 #define COH901318_CX_CTRL_SRC_ADDR_INC_ENABLE (0x00040000)
213 #define COH901318_CX_CTRL_SRC_ADDR_INC_DISABLE (0x00000000)
215 #define COH901318_CX_CTRL_DST_BUS_SIZE_MASK (0x00180000)
216 #define COH901318_CX_CTRL_DST_BUS_SIZE_32_BITS (0x2 << 19)
217 #define COH901318_CX_CTRL_DST_BUS_SIZE_16_BITS (0x1 << 19)
218 #define COH901318_CX_CTRL_DST_BUS_SIZE_8_BITS (0x0 << 19)
220 #define COH901318_CX_CTRL_DST_ADDR_INC_ENABLE (0x00200000)
221 #define COH901318_CX_CTRL_DST_ADDR_INC_DISABLE (0x00000000)
223 #define COH901318_CX_CTRL_MASTER_MODE_MASK (0x00C00000)
224 #define COH901318_CX_CTRL_MASTER_MODE_M2R_M1W (0x3 << 22)
225 #define COH901318_CX_CTRL_MASTER_MODE_M1R_M2W (0x2 << 22)
226 #define COH901318_CX_CTRL_MASTER_MODE_M2RW (0x1 << 22)
227 #define COH901318_CX_CTRL_MASTER_MODE_M1RW (0x0 << 22)
229 #define COH901318_CX_CTRL_TCP_ENABLE (0x01000000)
230 #define COH901318_CX_CTRL_TCP_DISABLE (0x00000000)
232 #define COH901318_CX_CTRL_TC_IRQ_ENABLE (0x02000000)
233 #define COH901318_CX_CTRL_TC_IRQ_DISABLE (0x00000000)
235 #define COH901318_CX_CTRL_HSP_ENABLE (0x04000000)
236 #define COH901318_CX_CTRL_HSP_DISABLE (0x00000000)
237 #define COH901318_CX_CTRL_HSS_ENABLE (0x08000000)
238 #define COH901318_CX_CTRL_HSS_DISABLE (0x00000000)
240 #define COH901318_CX_CTRL_DDMA_MASK (0x30000000)
241 #define COH901318_CX_CTRL_DDMA_LEGACY (0x0 << 28)
242 #define COH901318_CX_CTRL_DDMA_DEMAND_DMA1 (0x1 << 28)
243 #define COH901318_CX_CTRL_DDMA_DEMAND_DMA2 (0x2 << 28)
245 #define COH901318_CX_CTRL_PRDD_MASK (0x40000000)
246 #define COH901318_CX_CTRL_PRDD_DEST (0x1 << 30)
247 #define COH901318_CX_CTRL_PRDD_SOURCE (0x0 << 30)
252 #define COH901318_CX_SRC_ADDR (0x0404)
253 #define COH901318_CX_SRC_ADDR_SPACING (0x10)
258 #define COH901318_CX_DST_ADDR (0x0408)
259 #define COH901318_CX_DST_ADDR_SPACING (0x10)
264 #define COH901318_CX_LNK_ADDR (0x040C)
265 #define COH901318_CX_LNK_ADDR_SPACING (0x10)
266 #define COH901318_CX_LNK_LINK_IMMEDIATE (0x00000001)