diff options
Diffstat (limited to 'drivers/dma/fsl_raid.h')
-rw-r--r-- | drivers/dma/fsl_raid.h | 306 |
1 files changed, 306 insertions, 0 deletions
diff --git a/drivers/dma/fsl_raid.h b/drivers/dma/fsl_raid.h new file mode 100644 index 000000000000..69d743c04973 --- /dev/null +++ b/drivers/dma/fsl_raid.h | |||
@@ -0,0 +1,306 @@ | |||
1 | /* | ||
2 | * drivers/dma/fsl_raid.h | ||
3 | * | ||
4 | * Freescale RAID Engine device driver | ||
5 | * | ||
6 | * Author: | ||
7 | * Harninder Rai <harninder.rai@freescale.com> | ||
8 | * Naveen Burmi <naveenburmi@freescale.com> | ||
9 | * | ||
10 | * Rewrite: | ||
11 | * Xuelin Shi <xuelin.shi@freescale.com> | ||
12 | |||
13 | * Copyright (c) 2010-2012 Freescale Semiconductor, Inc. | ||
14 | * | ||
15 | * Redistribution and use in source and binary forms, with or without | ||
16 | * modification, are permitted provided that the following conditions are met: | ||
17 | * * Redistributions of source code must retain the above copyright | ||
18 | * notice, this list of conditions and the following disclaimer. | ||
19 | * * Redistributions in binary form must reproduce the above copyright | ||
20 | * notice, this list of conditions and the following disclaimer in the | ||
21 | * documentation and/or other materials provided with the distribution. | ||
22 | * * Neither the name of Freescale Semiconductor nor the | ||
23 | * names of its contributors may be used to endorse or promote products | ||
24 | * derived from this software without specific prior written permission. | ||
25 | * | ||
26 | * ALTERNATIVELY, this software may be distributed under the terms of the | ||
27 | * GNU General Public License ("GPL") as published by the Free Software | ||
28 | * Foundation, either version 2 of that License or (at your option) any | ||
29 | * later version. | ||
30 | * | ||
31 | * THIS SOFTWARE IS PROVIDED BY Freescale Semiconductor ``AS IS'' AND ANY | ||
32 | * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED | ||
33 | * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE | ||
34 | * DISCLAIMED. IN NO EVENT SHALL Freescale Semiconductor BE LIABLE FOR ANY | ||
35 | * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES | ||
36 | * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; | ||
37 | * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND | ||
38 | * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | ||
39 | * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||
40 | * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||
41 | * | ||
42 | */ | ||
43 | |||
44 | #define FSL_RE_MAX_CHANS 4 | ||
45 | #define FSL_RE_DPAA_MODE BIT(30) | ||
46 | #define FSL_RE_NON_DPAA_MODE BIT(31) | ||
47 | #define FSL_RE_GFM_POLY 0x1d000000 | ||
48 | #define FSL_RE_ADD_JOB(x) ((x) << 16) | ||
49 | #define FSL_RE_RMVD_JOB(x) ((x) << 16) | ||
50 | #define FSL_RE_CFG1_CBSI 0x08000000 | ||
51 | #define FSL_RE_CFG1_CBS0 0x00080000 | ||
52 | #define FSL_RE_SLOT_FULL_SHIFT 8 | ||
53 | #define FSL_RE_SLOT_FULL(x) ((x) >> FSL_RE_SLOT_FULL_SHIFT) | ||
54 | #define FSL_RE_SLOT_AVAIL_SHIFT 8 | ||
55 | #define FSL_RE_SLOT_AVAIL(x) ((x) >> FSL_RE_SLOT_AVAIL_SHIFT) | ||
56 | #define FSL_RE_PQ_OPCODE 0x1B | ||
57 | #define FSL_RE_XOR_OPCODE 0x1A | ||
58 | #define FSL_RE_MOVE_OPCODE 0x8 | ||
59 | #define FSL_RE_FRAME_ALIGN 16 | ||
60 | #define FSL_RE_BLOCK_SIZE 0x3 /* 4096 bytes */ | ||
61 | #define FSL_RE_CACHEABLE_IO 0x0 | ||
62 | #define FSL_RE_BUFFER_OUTPUT 0x0 | ||
63 | #define FSL_RE_INTR_ON_ERROR 0x1 | ||
64 | #define FSL_RE_DATA_DEP 0x1 | ||
65 | #define FSL_RE_ENABLE_DPI 0x0 | ||
66 | #define FSL_RE_RING_SIZE 0x400 | ||
67 | #define FSL_RE_RING_SIZE_MASK (FSL_RE_RING_SIZE - 1) | ||
68 | #define FSL_RE_RING_SIZE_SHIFT 8 | ||
69 | #define FSL_RE_ADDR_BIT_SHIFT 4 | ||
70 | #define FSL_RE_ADDR_BIT_MASK (BIT(FSL_RE_ADDR_BIT_SHIFT) - 1) | ||
71 | #define FSL_RE_ERROR 0x40000000 | ||
72 | #define FSL_RE_INTR 0x80000000 | ||
73 | #define FSL_RE_CLR_INTR 0x80000000 | ||
74 | #define FSL_RE_PAUSE 0x80000000 | ||
75 | #define FSL_RE_ENABLE 0x80000000 | ||
76 | #define FSL_RE_REG_LIODN_MASK 0x00000FFF | ||
77 | |||
78 | #define FSL_RE_CDB_OPCODE_MASK 0xF8000000 | ||
79 | #define FSL_RE_CDB_OPCODE_SHIFT 27 | ||
80 | #define FSL_RE_CDB_EXCLEN_MASK 0x03000000 | ||
81 | #define FSL_RE_CDB_EXCLEN_SHIFT 24 | ||
82 | #define FSL_RE_CDB_EXCLQ1_MASK 0x00F00000 | ||
83 | #define FSL_RE_CDB_EXCLQ1_SHIFT 20 | ||
84 | #define FSL_RE_CDB_EXCLQ2_MASK 0x000F0000 | ||
85 | #define FSL_RE_CDB_EXCLQ2_SHIFT 16 | ||
86 | #define FSL_RE_CDB_BLKSIZE_MASK 0x0000C000 | ||
87 | #define FSL_RE_CDB_BLKSIZE_SHIFT 14 | ||
88 | #define FSL_RE_CDB_CACHE_MASK 0x00003000 | ||
89 | #define FSL_RE_CDB_CACHE_SHIFT 12 | ||
90 | #define FSL_RE_CDB_BUFFER_MASK 0x00000800 | ||
91 | #define FSL_RE_CDB_BUFFER_SHIFT 11 | ||
92 | #define FSL_RE_CDB_ERROR_MASK 0x00000400 | ||
93 | #define FSL_RE_CDB_ERROR_SHIFT 10 | ||
94 | #define FSL_RE_CDB_NRCS_MASK 0x0000003C | ||
95 | #define FSL_RE_CDB_NRCS_SHIFT 6 | ||
96 | #define FSL_RE_CDB_DEPEND_MASK 0x00000008 | ||
97 | #define FSL_RE_CDB_DEPEND_SHIFT 3 | ||
98 | #define FSL_RE_CDB_DPI_MASK 0x00000004 | ||
99 | #define FSL_RE_CDB_DPI_SHIFT 2 | ||
100 | |||
101 | /* | ||
102 | * the largest cf block is 19*sizeof(struct cmpnd_frame), which is 304 bytes. | ||
103 | * here 19 = 1(cdb)+2(dest)+16(src), align to 64bytes, that is 320 bytes. | ||
104 | * the largest cdb block: struct pq_cdb which is 180 bytes, adding to cf block | ||
105 | * 320+180=500, align to 64bytes, that is 512 bytes. | ||
106 | */ | ||
107 | #define FSL_RE_CF_DESC_SIZE 320 | ||
108 | #define FSL_RE_CF_CDB_SIZE 512 | ||
109 | #define FSL_RE_CF_CDB_ALIGN 64 | ||
110 | |||
111 | struct fsl_re_ctrl { | ||
112 | /* General Configuration Registers */ | ||
113 | __be32 global_config; /* Global Configuration Register */ | ||
114 | u8 rsvd1[4]; | ||
115 | __be32 galois_field_config; /* Galois Field Configuration Register */ | ||
116 | u8 rsvd2[4]; | ||
117 | __be32 jq_wrr_config; /* WRR Configuration register */ | ||
118 | u8 rsvd3[4]; | ||
119 | __be32 crc_config; /* CRC Configuration register */ | ||
120 | u8 rsvd4[228]; | ||
121 | __be32 system_reset; /* System Reset Register */ | ||
122 | u8 rsvd5[252]; | ||
123 | __be32 global_status; /* Global Status Register */ | ||
124 | u8 rsvd6[832]; | ||
125 | __be32 re_liodn_base; /* LIODN Base Register */ | ||
126 | u8 rsvd7[1712]; | ||
127 | __be32 re_version_id; /* Version ID register of RE */ | ||
128 | __be32 re_version_id_2; /* Version ID 2 register of RE */ | ||
129 | u8 rsvd8[512]; | ||
130 | __be32 host_config; /* Host I/F Configuration Register */ | ||
131 | }; | ||
132 | |||
133 | struct fsl_re_chan_cfg { | ||
134 | /* Registers for JR interface */ | ||
135 | __be32 jr_config_0; /* Job Queue Configuration 0 Register */ | ||
136 | __be32 jr_config_1; /* Job Queue Configuration 1 Register */ | ||
137 | __be32 jr_interrupt_status; /* Job Queue Interrupt Status Register */ | ||
138 | u8 rsvd1[4]; | ||
139 | __be32 jr_command; /* Job Queue Command Register */ | ||
140 | u8 rsvd2[4]; | ||
141 | __be32 jr_status; /* Job Queue Status Register */ | ||
142 | u8 rsvd3[228]; | ||
143 | |||
144 | /* Input Ring */ | ||
145 | __be32 inbring_base_h; /* Inbound Ring Base Address Register - High */ | ||
146 | __be32 inbring_base_l; /* Inbound Ring Base Address Register - Low */ | ||
147 | __be32 inbring_size; /* Inbound Ring Size Register */ | ||
148 | u8 rsvd4[4]; | ||
149 | __be32 inbring_slot_avail; /* Inbound Ring Slot Available Register */ | ||
150 | u8 rsvd5[4]; | ||
151 | __be32 inbring_add_job; /* Inbound Ring Add Job Register */ | ||
152 | u8 rsvd6[4]; | ||
153 | __be32 inbring_cnsmr_indx; /* Inbound Ring Consumer Index Register */ | ||
154 | u8 rsvd7[220]; | ||
155 | |||
156 | /* Output Ring */ | ||
157 | __be32 oubring_base_h; /* Outbound Ring Base Address Register - High */ | ||
158 | __be32 oubring_base_l; /* Outbound Ring Base Address Register - Low */ | ||
159 | __be32 oubring_size; /* Outbound Ring Size Register */ | ||
160 | u8 rsvd8[4]; | ||
161 | __be32 oubring_job_rmvd; /* Outbound Ring Job Removed Register */ | ||
162 | u8 rsvd9[4]; | ||
163 | __be32 oubring_slot_full; /* Outbound Ring Slot Full Register */ | ||
164 | u8 rsvd10[4]; | ||
165 | __be32 oubring_prdcr_indx; /* Outbound Ring Producer Index */ | ||
166 | }; | ||
167 | |||
168 | /* | ||
169 | * Command Descriptor Block (CDB) for unicast move command. | ||
170 | * In RAID Engine terms, memcpy is done through move command | ||
171 | */ | ||
172 | struct fsl_re_move_cdb { | ||
173 | __be32 cdb32; | ||
174 | }; | ||
175 | |||
176 | /* Data protection/integrity related fields */ | ||
177 | #define FSL_RE_DPI_APPS_MASK 0xC0000000 | ||
178 | #define FSL_RE_DPI_APPS_SHIFT 30 | ||
179 | #define FSL_RE_DPI_REF_MASK 0x30000000 | ||
180 | #define FSL_RE_DPI_REF_SHIFT 28 | ||
181 | #define FSL_RE_DPI_GUARD_MASK 0x0C000000 | ||
182 | #define FSL_RE_DPI_GUARD_SHIFT 26 | ||
183 | #define FSL_RE_DPI_ATTR_MASK 0x03000000 | ||
184 | #define FSL_RE_DPI_ATTR_SHIFT 24 | ||
185 | #define FSL_RE_DPI_META_MASK 0x0000FFFF | ||
186 | |||
187 | struct fsl_re_dpi { | ||
188 | __be32 dpi32; | ||
189 | __be32 ref; | ||
190 | }; | ||
191 | |||
192 | /* | ||
193 | * CDB for GenQ command. In RAID Engine terminology, XOR is | ||
194 | * done through this command | ||
195 | */ | ||
196 | struct fsl_re_xor_cdb { | ||
197 | __be32 cdb32; | ||
198 | u8 gfm[16]; | ||
199 | struct fsl_re_dpi dpi_dest_spec; | ||
200 | struct fsl_re_dpi dpi_src_spec[16]; | ||
201 | }; | ||
202 | |||
203 | /* CDB for no-op command */ | ||
204 | struct fsl_re_noop_cdb { | ||
205 | __be32 cdb32; | ||
206 | }; | ||
207 | |||
208 | /* | ||
209 | * CDB for GenQQ command. In RAID Engine terminology, P/Q is | ||
210 | * done through this command | ||
211 | */ | ||
212 | struct fsl_re_pq_cdb { | ||
213 | __be32 cdb32; | ||
214 | u8 gfm_q1[16]; | ||
215 | u8 gfm_q2[16]; | ||
216 | struct fsl_re_dpi dpi_dest_spec[2]; | ||
217 | struct fsl_re_dpi dpi_src_spec[16]; | ||
218 | }; | ||
219 | |||
220 | /* Compound frame */ | ||
221 | #define FSL_RE_CF_ADDR_HIGH_MASK 0x000000FF | ||
222 | #define FSL_RE_CF_EXT_MASK 0x80000000 | ||
223 | #define FSL_RE_CF_EXT_SHIFT 31 | ||
224 | #define FSL_RE_CF_FINAL_MASK 0x40000000 | ||
225 | #define FSL_RE_CF_FINAL_SHIFT 30 | ||
226 | #define FSL_RE_CF_LENGTH_MASK 0x000FFFFF | ||
227 | #define FSL_RE_CF_BPID_MASK 0x00FF0000 | ||
228 | #define FSL_RE_CF_BPID_SHIFT 16 | ||
229 | #define FSL_RE_CF_OFFSET_MASK 0x00001FFF | ||
230 | |||
231 | struct fsl_re_cmpnd_frame { | ||
232 | __be32 addr_high; | ||
233 | __be32 addr_low; | ||
234 | __be32 efrl32; | ||
235 | __be32 rbro32; | ||
236 | }; | ||
237 | |||
238 | /* Frame descriptor */ | ||
239 | #define FSL_RE_HWDESC_LIODN_MASK 0x3F000000 | ||
240 | #define FSL_RE_HWDESC_LIODN_SHIFT 24 | ||
241 | #define FSL_RE_HWDESC_BPID_MASK 0x00FF0000 | ||
242 | #define FSL_RE_HWDESC_BPID_SHIFT 16 | ||
243 | #define FSL_RE_HWDESC_ELIODN_MASK 0x0000F000 | ||
244 | #define FSL_RE_HWDESC_ELIODN_SHIFT 12 | ||
245 | #define FSL_RE_HWDESC_FMT_SHIFT 29 | ||
246 | #define FSL_RE_HWDESC_FMT_MASK (0x3 << FSL_RE_HWDESC_FMT_SHIFT) | ||
247 | |||
248 | struct fsl_re_hw_desc { | ||
249 | __be32 lbea32; | ||
250 | __be32 addr_low; | ||
251 | __be32 fmt32; | ||
252 | __be32 status; | ||
253 | }; | ||
254 | |||
255 | /* Raid Engine device private data */ | ||
256 | struct fsl_re_drv_private { | ||
257 | u8 total_chans; | ||
258 | struct dma_device dma_dev; | ||
259 | struct fsl_re_ctrl *re_regs; | ||
260 | struct fsl_re_chan *re_jrs[FSL_RE_MAX_CHANS]; | ||
261 | struct dma_pool *cf_desc_pool; | ||
262 | struct dma_pool *hw_desc_pool; | ||
263 | }; | ||
264 | |||
265 | /* Per job ring data structure */ | ||
266 | struct fsl_re_chan { | ||
267 | char name[16]; | ||
268 | spinlock_t desc_lock; /* queue lock */ | ||
269 | struct list_head ack_q; /* wait to acked queue */ | ||
270 | struct list_head active_q; /* already issued on hw, not completed */ | ||
271 | struct list_head submit_q; | ||
272 | struct list_head free_q; /* alloc available queue */ | ||
273 | struct device *dev; | ||
274 | struct fsl_re_drv_private *re_dev; | ||
275 | struct dma_chan chan; | ||
276 | struct fsl_re_chan_cfg *jrregs; | ||
277 | int irq; | ||
278 | struct tasklet_struct irqtask; | ||
279 | u32 alloc_count; | ||
280 | |||
281 | /* hw descriptor ring for inbound queue*/ | ||
282 | dma_addr_t inb_phys_addr; | ||
283 | struct fsl_re_hw_desc *inb_ring_virt_addr; | ||
284 | u32 inb_count; | ||
285 | |||
286 | /* hw descriptor ring for outbound queue */ | ||
287 | dma_addr_t oub_phys_addr; | ||
288 | struct fsl_re_hw_desc *oub_ring_virt_addr; | ||
289 | u32 oub_count; | ||
290 | }; | ||
291 | |||
292 | /* Async transaction descriptor */ | ||
293 | struct fsl_re_desc { | ||
294 | struct dma_async_tx_descriptor async_tx; | ||
295 | struct list_head node; | ||
296 | struct fsl_re_hw_desc hwdesc; | ||
297 | struct fsl_re_chan *re_chan; | ||
298 | |||
299 | /* hwdesc will point to cf_addr */ | ||
300 | void *cf_addr; | ||
301 | dma_addr_t cf_paddr; | ||
302 | |||
303 | void *cdb_addr; | ||
304 | dma_addr_t cdb_paddr; | ||
305 | int status; | ||
306 | }; | ||