Book a Demo!
CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutPoliciesSign UpSign In
torvalds
GitHub Repository: torvalds/linux
Path: blob/master/drivers/dma/fsl_raid.h
26278 views
1
/*
2
* drivers/dma/fsl_raid.h
3
*
4
* Freescale RAID Engine device driver
5
*
6
* Author:
7
* Harninder Rai <[email protected]>
8
* Naveen Burmi <[email protected]>
9
*
10
* Rewrite:
11
* Xuelin Shi <[email protected]>
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
};
307
308