Go to the documentation of this file.
18 #define REG_RD( scope, inst, reg ) \
19 REG_READ( reg_##scope##_##reg, \
20 (inst) + REG_RD_ADDR_##scope##_##reg )
24 #define REG_WR( scope, inst, reg, val ) \
25 REG_WRITE( reg_##scope##_##reg, \
26 (inst) + REG_WR_ADDR_##scope##_##reg, (val) )
30 #define REG_RD_VECT( scope, inst, reg, index ) \
31 REG_READ( reg_##scope##_##reg, \
32 (inst) + REG_RD_ADDR_##scope##_##reg + \
33 (index) * STRIDE_##scope##_##reg )
37 #define REG_WR_VECT( scope, inst, reg, index, val ) \
38 REG_WRITE( reg_##scope##_##reg, \
39 (inst) + REG_WR_ADDR_##scope##_##reg + \
40 (index) * STRIDE_##scope##_##reg, (val) )
44 #define REG_RD_INT( scope, inst, reg ) \
45 REG_READ( int, (inst) + REG_RD_ADDR_##scope##_##reg )
49 #define REG_WR_INT( scope, inst, reg, val ) \
50 REG_WRITE( int, (inst) + REG_WR_ADDR_##scope##_##reg, (val) )
53 #ifndef REG_RD_INT_VECT
54 #define REG_RD_INT_VECT( scope, inst, reg, index ) \
55 REG_READ( int, (inst) + REG_RD_ADDR_##scope##_##reg + \
56 (index) * STRIDE_##scope##_##reg )
59 #ifndef REG_WR_INT_VECT
60 #define REG_WR_INT_VECT( scope, inst, reg, index, val ) \
61 REG_WRITE( int, (inst) + REG_WR_ADDR_##scope##_##reg + \
62 (index) * STRIDE_##scope##_##reg, (val) )
66 #define REG_TYPE_CONV( type, orgtype, val ) \
67 ( { union { orgtype o; type n; } r; r.o = val; r.n; } )
71 #define reg_page_size 8192
75 #define REG_ADDR( scope, inst, reg ) \
76 ( (inst) + REG_RD_ADDR_##scope##_##reg )
80 #define REG_ADDR_VECT( scope, inst, reg, index ) \
81 ( (inst) + REG_RD_ADDR_##scope##_##reg + \
82 (index) * STRIDE_##scope##_##reg )
89 #define REG_RD_ADDR_dma_rw_data 0
90 #define REG_WR_ADDR_dma_rw_data 0
94 #define REG_RD_ADDR_dma_rw_data_next 4
95 #define REG_WR_ADDR_dma_rw_data_next 4
99 #define REG_RD_ADDR_dma_rw_data_buf 8
100 #define REG_WR_ADDR_dma_rw_data_buf 8
104 unsigned int eol : 1;
105 unsigned int dummy1 : 2;
106 unsigned int out_eop : 1;
109 unsigned int dummy2 : 26;
111 #define REG_RD_ADDR_dma_rw_data_ctrl 12
112 #define REG_WR_ADDR_dma_rw_data_ctrl 12
116 unsigned int dummy1 : 3;
117 unsigned int in_eop : 1;
118 unsigned int dummy2 : 28;
120 #define REG_RD_ADDR_dma_rw_data_stat 16
121 #define REG_WR_ADDR_dma_rw_data_stat 16
125 unsigned int md : 16;
126 unsigned int dummy1 : 16;
128 #define REG_RD_ADDR_dma_rw_data_md 20
129 #define REG_WR_ADDR_dma_rw_data_md 20
133 unsigned int md_s : 16;
134 unsigned int dummy1 : 16;
136 #define REG_RD_ADDR_dma_rw_data_md_s 24
137 #define REG_WR_ADDR_dma_rw_data_md_s 24
141 #define REG_RD_ADDR_dma_rw_data_after 28
142 #define REG_WR_ADDR_dma_rw_data_after 28
146 #define REG_RD_ADDR_dma_rw_ctxt 32
147 #define REG_WR_ADDR_dma_rw_ctxt 32
151 #define REG_RD_ADDR_dma_rw_ctxt_next 36
152 #define REG_WR_ADDR_dma_rw_ctxt_next 36
156 unsigned int eol : 1;
157 unsigned int dummy1 : 3;
159 unsigned int dummy2 : 1;
162 unsigned int dummy3 : 24;
164 #define REG_RD_ADDR_dma_rw_ctxt_ctrl 40
165 #define REG_WR_ADDR_dma_rw_ctxt_ctrl 40
169 unsigned int dummy1 : 7;
170 unsigned int dis : 1;
171 unsigned int dummy2 : 24;
173 #define REG_RD_ADDR_dma_rw_ctxt_stat 44
174 #define REG_WR_ADDR_dma_rw_ctxt_stat 44
178 unsigned int md0 : 16;
179 unsigned int dummy1 : 16;
181 #define REG_RD_ADDR_dma_rw_ctxt_md0 48
182 #define REG_WR_ADDR_dma_rw_ctxt_md0 48
186 unsigned int md0_s : 16;
187 unsigned int dummy1 : 16;
189 #define REG_RD_ADDR_dma_rw_ctxt_md0_s 52
190 #define REG_WR_ADDR_dma_rw_ctxt_md0_s 52
194 #define REG_RD_ADDR_dma_rw_ctxt_md1 56
195 #define REG_WR_ADDR_dma_rw_ctxt_md1 56
199 #define REG_RD_ADDR_dma_rw_ctxt_md1_s 60
200 #define REG_WR_ADDR_dma_rw_ctxt_md1_s 60
204 #define REG_RD_ADDR_dma_rw_ctxt_md2 64
205 #define REG_WR_ADDR_dma_rw_ctxt_md2 64
209 #define REG_RD_ADDR_dma_rw_ctxt_md2_s 68
210 #define REG_WR_ADDR_dma_rw_ctxt_md2_s 68
214 #define REG_RD_ADDR_dma_rw_ctxt_md3 72
215 #define REG_WR_ADDR_dma_rw_ctxt_md3 72
219 #define REG_RD_ADDR_dma_rw_ctxt_md3_s 76
220 #define REG_WR_ADDR_dma_rw_ctxt_md3_s 76
224 #define REG_RD_ADDR_dma_rw_ctxt_md4 80
225 #define REG_WR_ADDR_dma_rw_ctxt_md4 80
229 #define REG_RD_ADDR_dma_rw_ctxt_md4_s 84
230 #define REG_WR_ADDR_dma_rw_ctxt_md4_s 84
234 #define REG_RD_ADDR_dma_rw_saved_data 88
235 #define REG_WR_ADDR_dma_rw_saved_data 88
239 #define REG_RD_ADDR_dma_rw_saved_data_buf 92
240 #define REG_WR_ADDR_dma_rw_saved_data_buf 92
244 #define REG_RD_ADDR_dma_rw_group 96
245 #define REG_WR_ADDR_dma_rw_group 96
249 #define REG_RD_ADDR_dma_rw_group_next 100
250 #define REG_WR_ADDR_dma_rw_group_next 100
254 unsigned int eol : 1;
255 unsigned int tol : 1;
256 unsigned int bol : 1;
257 unsigned int dummy1 : 1;
259 unsigned int dummy2 : 2;
261 unsigned int dummy3 : 24;
263 #define REG_RD_ADDR_dma_rw_group_ctrl 104
264 #define REG_WR_ADDR_dma_rw_group_ctrl 104
268 unsigned int dummy1 : 7;
269 unsigned int dis : 1;
270 unsigned int dummy2 : 24;
272 #define REG_RD_ADDR_dma_rw_group_stat 108
273 #define REG_WR_ADDR_dma_rw_group_stat 108
277 unsigned int md : 16;
278 unsigned int dummy1 : 16;
280 #define REG_RD_ADDR_dma_rw_group_md 112
281 #define REG_WR_ADDR_dma_rw_group_md 112
285 unsigned int md_s : 16;
286 unsigned int dummy1 : 16;
288 #define REG_RD_ADDR_dma_rw_group_md_s 116
289 #define REG_WR_ADDR_dma_rw_group_md_s 116
293 #define REG_RD_ADDR_dma_rw_group_up 120
294 #define REG_WR_ADDR_dma_rw_group_up 120
298 #define REG_RD_ADDR_dma_rw_group_down 124
299 #define REG_WR_ADDR_dma_rw_group_down 124
303 unsigned int cont_data : 1;
304 unsigned int dummy1 : 31;
306 #define REG_RD_ADDR_dma_rw_cmd 128
307 #define REG_WR_ADDR_dma_rw_cmd 128
313 unsigned int dummy1 : 30;
315 #define REG_RD_ADDR_dma_rw_cfg 132
316 #define REG_WR_ADDR_dma_rw_cfg 132
321 unsigned int list_state : 3;
322 unsigned int stream_cmd_src : 8;
323 unsigned int dummy1 : 8;
326 #define REG_RD_ADDR_dma_rw_stat 136
327 #define REG_WR_ADDR_dma_rw_stat 136
332 unsigned int ctxt : 1;
334 unsigned int in_eop : 1;
335 unsigned int stream_cmd : 1;
336 unsigned int dummy1 : 27;
338 #define REG_RD_ADDR_dma_rw_intr_mask 140
339 #define REG_WR_ADDR_dma_rw_intr_mask 140
344 unsigned int ctxt : 1;
346 unsigned int in_eop : 1;
347 unsigned int stream_cmd : 1;
348 unsigned int dummy1 : 27;
350 #define REG_RD_ADDR_dma_rw_ack_intr 144
351 #define REG_WR_ADDR_dma_rw_ack_intr 144
356 unsigned int ctxt : 1;
358 unsigned int in_eop : 1;
359 unsigned int stream_cmd : 1;
360 unsigned int dummy1 : 27;
362 #define REG_RD_ADDR_dma_r_intr 148
367 unsigned int ctxt : 1;
369 unsigned int in_eop : 1;
370 unsigned int stream_cmd : 1;
371 unsigned int dummy1 : 27;
373 #define REG_RD_ADDR_dma_r_masked_intr 152
378 unsigned int dummy1 : 6;
380 unsigned int dummy2 : 7;
383 #define REG_RD_ADDR_dma_rw_stream_cmd 156
384 #define REG_WR_ADDR_dma_rw_stream_cmd 156