source: rtems/c/src/lib/libcpu/m68k/mcf5272/include/mcf5272.h @ ee5769a

4.104.114.84.95
Last change on this file since ee5769a was ee5769a, checked in by Ralf Corsepius <ralf.corsepius@…>, on Oct 21, 2004 at 1:21:26 PM

2004-10-21 Ralf Corsepius <ralf_corsepius@…>

  • clock/ckinit.c, include/mcf5272.h, timer/timer.c: Use POSIX fixed-size types.
  • Property mode set to 100644
File size: 20.1 KB
Line 
1/*
2 * Coldfire MCF5272 definitions.
3 * Contents of this file based on information provided in
4 * Motorola MCF5272 User's Manual.
5 *
6 * Copyright (C) 2004 Jay Monkman <jtm@lopingdog.com>
7 *
8 * The license and distribution terms for this file may be
9 * found in the file LICENSE in this distribution or at
10 *
11 * http://www.OARcorp.com/rtems/license.html.
12 *
13 * @(#) mcf5206e.h,v 1.1 2001/10/26 19:32:40 joel Exp
14 */
15
16#ifndef __MCF5272_H__
17#define __MCF5272_H__
18
19#ifndef ASM
20#include <rtems.h>
21#endif
22
23#define bit(x) (1 << (x))
24
25#define MCF5272_SIM_BASE(mbar)    ((mbar) + 0x0000)
26#define MCF5272_INT_BASE(mbar)    ((mbar) + 0x0020)
27#define MCF5272_CS_BASE(mbar)     ((mbar) + 0x0040)
28#define MCF5272_GPIO_BASE(mbar)   ((mbar) + 0x0080)
29#define MCF5272_QSPI_BASE(mbar)   ((mbar) + 0x00A0)
30#define MCF5272_PWM_BASE(mbar)    ((mbar) + 0x00C0)
31#define MCF5272_DMAC_BASE(mbar)   ((mbar) + 0x00E0)
32#define MCF5272_UART0_BASE(mbar)  ((mbar) + 0x0100)
33#define MCF5272_UART1_BASE(mbar)  ((mbar) + 0x0140)
34#define MCF5272_SDRAMC_BASE(mbar) ((mbar) + 0x0180)
35#define MCF5272_TIMER_BASE(mbar)  ((mbar) + 0x0200)
36#define MCF5272_PLIC_BASE(mbar)   ((mbar) + 0x0300)
37#define MCF5272_ENET_BASE(mbar)   ((mbar) + 0x0840)
38#define MCF5272_USB_BASE(mbar)    ((mbar) + 0x1000)
39
40
41/* RAMBAR - SRAM Base Address Register */
42#define MCF5272_RAMBAR_BA  (0xfffff000) /* SRAM Base Address */
43#define MCF5272_RAMBAR_WP  (0x00000100) /* Write Protect */
44#define MCF5272_RAMBAR_CI  (0x00000020) /* CPU Space mask */
45#define MCF5272_RAMBAR_SC  (0x00000010) /* Supervisor Code Space Mask */
46#define MCF5272_RAMBAR_SD  (0x00000008) /* Supervisor Data Space Mask */
47#define MCF5272_RAMBAR_UC  (0x00000004) /* User Code Space Mask */
48#define MCF5272_RAMBAR_UD  (0x00000002) /* User Data Space Mask */
49#define MCF5272_RAMBAR_V   (0x00000001) /* Contents of RAMBAR are valid */
50
51/* MBAR - Module Base Address Register */
52#define MCF5272_MBAR_BA  (0xffff0000) /* Base Address */
53#define MCF5272_MBAR_SC  (0x00000010) /* Supervisor Code Space Mask */
54#define MCF5272_MBAR_SD  (0x00000008) /* Supervisor Data Space Mask */
55#define MCF5272_MBAR_UC  (0x00000004) /* User Code Space Mask */
56#define MCF5272_MBAR_UD  (0x00000002) /* User Data Space Mask */
57#define MCF5272_MBAR_V   (0x00000001) /* Contents of MBAR are valid */
58
59/* CACR - Cache Control Register */
60#define MCF5272_CACR_CENB  (0x80000000) /* Cache Enable */
61#define MCF5272_CACR_CPDI  (0x10000000) /* Disable CPUSHL Invalidation */
62#define MCF5272_CACR_CFRZ  (0x08000000) /* Cache Freeze */
63#define MCF5272_CACR_CINV  (0x01000000) /* Cache Invalidate */
64#define MCF5272_CACR_CEIB  (0x00000400) /* Cache Enable Noncacheable
65                                           instruction bursting */
66#define MCF5272_CACR_DCM   (0x00000200) /* Default cache mode - noncacheable*/
67#define MCF5272_CACR_DBWE  (0x00000100) /* Default Buffered Write Enable */
68#define MCF5272_CACR_DWP   (0x00000020) /* Default Write Protection */
69#define MCF5272_CACR_CLNF  (0x00000003) /* Cache Line Fill */
70
71/* ACRx - Cache Access Control Registers */
72#define MCF5272_ACR_BA        (0xff000000) /* Address Base */
73#define MCF5272_ACR_BAM       (0x00ff0000) /* Address Mask */
74#define MCF5272_ACR_EN        (0x00008000) /* Enable */
75#define MCF5272_ACR_SM_USR    (0x00000000) /* Match if user mode */
76#define MCF5272_ACR_SM_SVR    (0x00002000) /* Match if supervisor mode */
77#define MCF5272_ACR_SM_ANY    (0x00004000) /* Match Always */
78#define MCF527_ACR_CM         (0x00000040) /* Cache Mode (1 - noncacheable) */
79#define MCF5272_ACR_BWE       (0x00000020) /* Buffered Write Enable */
80#define MCF5272_ACR_WP        (0x00000004) /* Write Protect */
81#define MCF5272_ACR_BASE(base) ((base) & MCF5272_ACR_BA)
82#define MCF5272_ACR_MASK(mask) (((mask) >> 8) & MCF5272_ACR_BAM)
83
84
85#define MCF5272_ICR1_INT1_PI     (bit(31))
86#define MCF5272_ICR1_INT1_IPL(x) ((x) << 28)
87#define MCF5272_ICR1_INT1_MASK   ((7) << 28)
88#define MCF5272_ICR1_INT2_PI     (bit(27))
89#define MCF5272_ICR1_INT2_IPL(x) ((x) << 24)
90#define MCF5272_ICR1_INT2_MASK   ((7) << 24)
91#define MCF5272_ICR1_INT3_PI     (bit(23))
92#define MCF5272_ICR1_INT3_IPL(x) ((x) << 20)
93#define MCF5272_ICR1_INT3_MASK   ((7) << 20)
94#define MCF5272_ICR1_INT3_PI     (bit(19))
95#define MCF5272_ICR1_INT3_IPL(x) ((x) << 16)
96#define MCF5272_ICR1_INT3_MASK   ((7) << 16)
97#define MCF5272_ICR1_TMR0_PI     (bit(15))
98#define MCF5272_ICR1_TMR0_IPL(x) ((x) << 12)
99#define MCF5272_ICR1_TMR0_MASK   ((7) << 12)
100#define MCF5272_ICR1_TMR1_PI     (bit(11))
101#define MCF5272_ICR1_TMR1_IPL(x) ((x) << 8)
102#define MCF5272_ICR1_TMR1_MASK   ((7) << 8)
103#define MCF5272_ICR1_TMR2_PI     (bit(7))
104#define MCF5272_ICR1_TMR2_IPL(x) ((x) << 4)
105#define MCF5272_ICR1_TMR2_MASK   ((7) << 4)
106#define MCF5272_ICR1_TMR3_PI     (bit(3))
107#define MCF5272_ICR1_TMR3_IPL(x) ((x) << 0)
108#define MCF5272_ICR1_TMR3_MASK   ((7) << 0)
109
110#define MCF5272_ICR3_USB4_PI     (bit(31))
111#define MCF5272_ICR3_USB4_IPL(x) ((x) << 28)
112#define MCF5272_ICR3_USB4_MASK   ((7) << 28)
113#define MCF5272_ICR3_USB5_PI     (bit(27))
114#define MCF5272_ICR3_USB5_IPL(x) ((x) << 24)
115#define MCF5272_ICR3_USB5_MASK   ((7) << 24)
116#define MCF5272_ICR3_USB6_PI     (bit(23))
117#define MCF5272_ICR3_USB6_IPL(x) ((x) << 20)
118#define MCF5272_ICR3_USB6_MASK   ((7) << 20)
119#define MCF5272_ICR3_USB7_PI     (bit(19))
120#define MCF5272_ICR3_USB7_IPL(x) ((x) << 16)
121#define MCF5272_ICR3_USB7_MASK   ((7) << 16)
122#define MCF5272_ICR3_DMA_PI     (bit(15))
123#define MCF5272_ICR3_DMA_IPL(x) ((x) << 12)
124#define MCF5272_ICR3_DMA_MASK   ((7) << 12)
125#define MCF5272_ICR3_ERX_PI     (bit(11))
126#define MCF5272_ICR3_ERX_IPL(x) ((x) << 8)
127#define MCF5272_ICR3_ERX_MASK   ((7) << 8)
128#define MCF5272_ICR3_ETX_PI     (bit(7))
129#define MCF5272_ICR3_ETX_IPL(x) ((x) << 4)
130#define MCF5272_ICR3_ETX_MASK   ((7) << 4)
131#define MCF5272_ICR3_ENTC_PI     (bit(3))
132#define MCF5272_ICR3_ENTC_IPL(x) ((x) << 0)
133#define MCF5272_ICR3_ENTC_MASK   ((7) << 0)
134
135
136#define MCF5272_USR_RB        (bit(7))
137#define MCF5272_USR_FE        (bit(6))
138#define MCF5272_USR_PE        (bit(5))
139#define MCF5272_USR_OE        (bit(4))
140#define MCF5272_USR_TXEMP     (bit(3))
141#define MCF5272_USR_TXRDY     (bit(2))
142#define MCF5272_USR_FFULL     (bit(1))
143#define MCF5272_USR_RXRDY     (bit(0))
144
145#define MCF5272_TMR_PS_MASK     0xff00
146#define MCF5272_TMR_PS_SHIFT    8
147#define MCF5272_TMR_CE_DISABLE  (0 << 6)
148#define MCF5272_TMR_CE_RISING   (1 << 6)
149#define MCF5272_TMR_CE_FALLING  (2 << 6)
150#define MCF5272_TMR_CE_ANY      (3 << 6)
151#define MCF5272_TMR_OM          (bit(5))
152#define MCF5272_TMR_ORI         (bit(4))
153#define MCF5272_TMR_FRR         (bit(3))
154#define MCF5272_TMR_CLK_STOP    (0 << 1)
155#define MCF5272_TMR_CLK_MSTR    (1 << 1)
156#define MCF5272_TMR_CLK_MSTR16  (2 << 1)
157#define MCF5272_TMR_CLK_TIN     (3 << 1)
158#define MCF5272_TMR_RST         (bit(0))
159#define MCF5272_TER_REF (bit(1))
160#define MCF5272_TER_CAP (bit(0))
161
162#define MCF5272_SCR_PRI         (bit(8))
163#define MCF5272_SCR_AR          (bit(7))
164#define MCF5272_SCR_SRST        (bit(6))
165#define MCF5272_SCR_BUSLOCK     (bit(3))
166#define MCF5272_SCR_HWR_128     (0)
167#define MCF5272_SCR_HWR_256     (1)
168#define MCF5272_SCR_HWR_512     (2)
169#define MCF5272_SCR_HWR_1024    (3)
170#define MCF5272_SCR_HWR_2048    (4)
171#define MCF5272_SCR_HWR_4096    (5)
172#define MCF5272_SCR_HWR_8192    (6)
173#define MCF5272_SCR_HWR_16384   (7)
174
175#define MCF5272_SPR_ADC         (bit(15))
176#define MCF5272_SPR_WPV         (bit(15))
177#define MCF5272_SPR_SMV         (bit(15))
178#define MCF5272_SPR_PE          (bit(15))
179#define MCF5272_SPR_HWT         (bit(15))
180#define MCF5272_SPR_RPV         (bit(15))
181#define MCF5272_SPR_EXT         (bit(15))
182#define MCF5272_SPR_SUV         (bit(15))
183#define MCF5272_SPR_ADCEN       (bit(15))
184#define MCF5272_SPR_WPVEN       (bit(15))
185#define MCF5272_SPR_SMVEN       (bit(15))
186#define MCF5272_SPR_PEEN        (bit(15))
187#define MCF5272_SPR_HWTEN       (bit(15))
188#define MCF5272_SPR_RPVEN       (bit(15))
189#define MCF5272_SPR_EXTEN       (bit(15))
190#define MCF5272_SPR_SUVEN       (bit(15))
191
192#define MCF5272_ENET_TX_RT      (bit(25))
193#define MCF5272_ENET_ETHERN_EN  (bit(1))
194#define MCF5272_ENET_RESET      (bit(0))
195
196#define MCF5272_ENET_EIR_HBERR  (bit(31))
197#define MCF5272_ENET_EIR_BABR   (bit(30))
198#define MCF5272_ENET_EIR_BABT   (bit(29))
199#define MCF5272_ENET_EIR_GRA    (bit(28))
200#define MCF5272_ENET_EIR_TXF    (bit(27))
201#define MCF5272_ENET_EIR_TXB    (bit(26))
202#define MCF5272_ENET_EIR_RXF    (bit(25))
203#define MCF5272_ENET_EIR_RXB    (bit(24))
204#define MCF5272_ENET_EIR_MII    (bit(23))
205#define MCF5272_ENET_EIR_EBERR  (bit(22))
206#define MCF5272_ENET_EIR_UMINT  (bit(21))
207
208#define MCF5272_ENET_RCR_PROM   (bit(3))
209#define MCF5272_ENET_RCR_MII    (bit(2))
210#define MCF5272_ENET_RCR_DRT    (bit(1))
211#define MCF5272_ENET_RCR_LOOP   (bit(0))
212
213#define MCF5272_ENET_TCR_FDEN   (bit(2))
214#define MCF5272_ENET_TCR_HBC    (bit(1))
215#define MCF5272_ENET_TCR_GTS    (bit(0))
216
217
218#ifndef ASM
219typedef struct {
220    volatile uint32_t mbar;       /* READ ONLY!! */
221
222    volatile uint16_t scr;
223    volatile uint16_t _res0;
224
225    volatile uint16_t _res1;
226    volatile uint16_t spr;
227
228    volatile uint32_t pmr;
229
230    volatile uint16_t _res2;
231    volatile uint16_t alpr;
232
233    volatile uint32_t dir;
234} sim_regs_t;
235
236typedef struct {
237    volatile uint32_t icr1;
238    volatile uint32_t icr2;
239    volatile uint32_t icr3;
240    volatile uint32_t icr4;
241    volatile uint32_t isr;
242    volatile uint32_t pitr;
243    volatile uint32_t piwr;
244    volatile uint8_t  _res0[3];
245    volatile uint8_t  pivr;
246} intctrl_regs_t;
247
248typedef struct {
249    volatile uint32_t csbr0;
250    volatile uint32_t csor0;
251    volatile uint32_t csbr1;
252    volatile uint32_t csor1;
253    volatile uint32_t csbr2;
254    volatile uint32_t csor2;
255    volatile uint32_t csbr3;
256    volatile uint32_t csor3;
257    volatile uint32_t csbr4;
258    volatile uint32_t csor4;
259    volatile uint32_t csbr5;
260    volatile uint32_t csor5;
261    volatile uint32_t csbr6;
262    volatile uint32_t csor6;
263    volatile uint32_t csbr7;
264    volatile uint32_t csor7;
265} chipsel_regs_t;
266
267typedef struct {
268    volatile uint32_t pacnt;
269
270    volatile uint16_t paddr;
271    volatile uint16_t _res0;
272
273    volatile uint16_t _res1;
274    volatile uint16_t padat;
275
276    volatile uint32_t pbcnt;
277
278    volatile uint16_t pbddr;
279    volatile uint16_t _res2;
280
281    volatile uint16_t _res3;
282    volatile uint16_t pbdat;
283
284    volatile uint16_t pcddr; 
285    volatile uint16_t _res4;
286
287    volatile uint16_t _res5;
288    volatile uint16_t pcdat;
289
290    volatile uint32_t pdcnt;
291} gpio_regs_t;
292
293typedef struct {
294    volatile uint32_t qmr;
295    volatile uint32_t qdlyr;
296    volatile uint32_t qwr;
297    volatile uint32_t qir;
298    volatile uint32_t qar;
299    volatile uint32_t qdr;
300} qspi_regs_t;
301
302typedef struct {
303    volatile uint8_t pwcr1;
304    volatile uint8_t _res0[3];
305
306    volatile uint8_t pwcr2;
307    volatile uint8_t _res1[3];
308
309    volatile uint8_t pwcr3;
310    volatile uint8_t _res2[3];
311
312    volatile uint8_t pwwd1;
313    volatile uint8_t _res3[3];
314
315    volatile uint8_t pwwd2;
316    volatile uint8_t _res4[3];
317
318    volatile uint8_t pwwd3;
319    volatile uint8_t _res5[3];
320} pwm_regs_t;
321
322typedef struct {
323    volatile uint32_t dcmr;
324   
325    volatile uint16_t _res0;
326    volatile uint16_t dcir;
327
328    volatile uint32_t dbcr;
329
330    volatile uint32_t dsar;
331
332    volatile uint32_t ddar;
333} dma_regs_t;
334
335typedef struct {
336    volatile uint8_t umr;              /* 0x000 */
337    volatile uint8_t _res0[3];
338
339    volatile uint8_t ucsr;             /* 0x004 */
340    volatile uint8_t _res2[3];
341
342    volatile uint8_t ucr;              /* 0x008 */
343    volatile uint8_t _res3[3];
344
345    volatile uint8_t udata;            /* 0x00c */
346    volatile uint8_t _res4[3];
347
348    volatile uint8_t uccr;             /* 0x010 */
349    volatile uint8_t _res6[3];
350
351    volatile uint8_t uisr;             /* 0x014 */
352    volatile uint8_t _res8[3];
353
354    volatile uint8_t ubg1;             /* 0x018 */
355    volatile uint8_t _res10[3];
356
357    volatile uint8_t ubg2;             /* 0x01c */
358    volatile uint8_t _res11[3];
359
360    volatile uint8_t uabr1;            /* 0x020 */
361    volatile uint8_t _res12[3];
362
363    volatile uint8_t uabr2;            /* 0x024 */
364    volatile uint8_t _res13[3];
365
366    volatile uint8_t utxfcsr;          /* 0x028 */
367    volatile uint8_t _res14[3];
368
369    volatile uint8_t urxfcsr;          /* 0x02c */
370    volatile uint8_t _res15[3];
371
372    volatile uint8_t ufpdn;            /* 0x030 */
373    volatile uint8_t _res16[3];
374
375    volatile uint8_t uip;              /* 0x034 */
376    volatile uint8_t _res17[3];
377
378    volatile uint8_t uop1;             /* 0x038 */
379    volatile uint8_t _res18[3];
380
381    volatile uint8_t uop0;             /* 0x03c */
382    volatile uint8_t _res19[3];
383} uart_regs_t;
384
385typedef struct {
386    volatile uint16_t tmr0;
387    volatile uint16_t _res0;
388
389    volatile uint16_t trr0;
390    volatile uint16_t _res1;
391
392    volatile uint16_t tcap0;
393    volatile uint16_t _res2;
394
395    volatile uint16_t tcn0;
396    volatile uint16_t _res3;
397
398    volatile uint16_t ter0;
399    volatile uint16_t _res4;
400
401    volatile uint8_t  _res40[12];
402
403    volatile uint16_t tmr1;
404    volatile uint16_t _res5;
405
406    volatile uint16_t trr1;
407    volatile uint16_t _res6;
408
409    volatile uint16_t tcap1;
410    volatile uint16_t _res7;
411
412    volatile uint16_t tcn1;
413    volatile uint16_t _res8;
414
415    volatile uint16_t ter1;
416    volatile uint16_t _res9;
417
418    volatile uint8_t  _res91[12];
419
420    volatile uint16_t tmr2;
421    volatile uint16_t _res10;
422
423    volatile uint16_t trr2;
424    volatile uint16_t _res11;
425
426    volatile uint16_t tcap2;
427    volatile uint16_t _res12;
428
429    volatile uint16_t tcn2;
430    volatile uint16_t _res13;
431
432    volatile uint16_t ter2;
433    volatile uint16_t _res14;
434
435    volatile uint8_t  _res140[12];
436
437    volatile uint16_t tmr3;
438    volatile uint16_t _res15;
439
440    volatile uint16_t trr3;
441    volatile uint16_t _res16;
442
443    volatile uint16_t tcap3;
444    volatile uint16_t _res17;
445
446    volatile uint16_t tcn3;
447    volatile uint16_t _res18;
448
449    volatile uint16_t ter3;
450    volatile uint16_t _res19;
451
452    volatile uint8_t  _res190[12];
453
454    volatile uint16_t wrrr;
455    volatile uint16_t _res20;
456
457    volatile uint16_t wirr;
458    volatile uint16_t _res21;
459
460    volatile uint16_t wcr;
461    volatile uint16_t _res22;
462
463    volatile uint16_t wer;
464    volatile uint16_t _res23;
465} timer_regs_t;
466
467typedef struct {
468    volatile uint32_t p0b1rr;
469    volatile uint32_t p1b1rr;
470    volatile uint32_t p2b1rr;
471    volatile uint32_t p3b1rr;
472    volatile uint32_t p0b2rr;
473    volatile uint32_t p1b2rr;
474    volatile uint32_t p2b2rr;
475    volatile uint32_t p3b2rr;
476
477    volatile uint8_t  p0drr;
478    volatile uint8_t  p1drr;
479    volatile uint8_t  p2drr;
480    volatile uint8_t  p3drr;
481
482    volatile uint32_t p0b1tr;
483    volatile uint32_t p1b1tr;
484    volatile uint32_t p2b1tr;
485    volatile uint32_t p3b1tr;
486    volatile uint32_t p0b2tr;
487    volatile uint32_t p1b2tr;
488    volatile uint32_t p2b2tr;
489    volatile uint32_t p3b2tr;
490
491    volatile uint8_t  p0dtr;
492    volatile uint8_t  p1dtr;
493    volatile uint8_t  p2dtr;
494    volatile uint8_t  p3dtr;
495
496    volatile uint16_t p0cr;
497    volatile uint16_t p1cr;
498    volatile uint16_t p2cr;
499    volatile uint16_t p3cr;
500    volatile uint16_t p0icr;
501    volatile uint16_t p1icr;
502    volatile uint16_t p2icr;
503    volatile uint16_t p3icr;
504    volatile uint16_t p0gmr;
505    volatile uint16_t p1gmr;
506    volatile uint16_t p2gmr;
507    volatile uint16_t p3gmr;
508    volatile uint16_t p0gmt;
509    volatile uint16_t p1gmt;
510    volatile uint16_t p2gmt;
511    volatile uint16_t p3gmt;
512
513    volatile uint8_t  _res0;
514    volatile uint8_t  pgmts;
515    volatile uint8_t  pgmta;
516    volatile uint8_t  _res1;
517    volatile uint8_t  p0gcir;
518    volatile uint8_t  p1gcir;
519    volatile uint8_t  p2gcir;
520    volatile uint8_t  p3gcir;
521    volatile uint8_t  p0gcit;
522    volatile uint8_t  p1gcit;
523    volatile uint8_t  p2gcit;
524    volatile uint8_t  p3gcit;
525    volatile uint8_t  _res3[3];
526    volatile uint8_t  pgcitsr;
527    volatile uint8_t  _res4[3];
528    volatile uint8_t  pdcsr;
529
530    volatile uint16_t p0psr;
531    volatile uint16_t p1psr;
532    volatile uint16_t p2psr;
533    volatile uint16_t p3psr;
534    volatile uint16_t pasr;
535    volatile uint8_t  _res5;
536    volatile uint8_t  plcr;
537    volatile uint16_t _res6;
538    volatile uint16_t pdrqr;
539    volatile uint16_t p0sdr;
540    volatile uint16_t p1sdr;
541    volatile uint16_t p2sdr;
542    volatile uint16_t p3sdr;
543    volatile uint16_t _res7;
544    volatile uint16_t pcsr;
545} plic_regs_t;
546
547typedef struct {
548    volatile uint32_t ecr;
549    volatile uint32_t eir;
550    volatile uint32_t eimr;
551    volatile uint32_t ivsr;
552    volatile uint32_t rdar;
553    volatile uint32_t tdar;
554    volatile uint32_t _res0[10];
555    volatile uint32_t mmfr;
556    volatile uint32_t mscr;
557    volatile uint32_t _res1[17];
558    volatile uint32_t frbr;
559    volatile uint32_t frsr;
560    volatile uint32_t _res2[4];
561    volatile uint32_t tfwr;
562    volatile uint32_t _res3[1];
563    volatile uint32_t tfsr;
564    volatile uint32_t _res4[21];
565    volatile uint32_t rcr;
566    volatile uint32_t mflr;
567    volatile uint32_t _res5[14];
568    volatile uint32_t tcr;
569    volatile uint32_t _res6[158];
570    volatile uint32_t malr;
571    volatile uint32_t maur;
572    volatile uint32_t htur;
573    volatile uint32_t htlr;
574    volatile uint32_t erdsr;
575    volatile uint32_t etdsr;
576    volatile uint32_t emrbr;
577/*    volatile uint8_t  fifo[448]; */
578} enet_regs_t;
579
580typedef struct {
581    volatile uint16_t _res0;
582    volatile uint16_t fnr;
583    volatile uint16_t _res1;
584    volatile uint16_t fnmr;
585    volatile uint16_t _res2;
586    volatile uint16_t rfmr;
587    volatile uint16_t _res3;
588    volatile uint16_t rfmmr;
589    volatile uint8_t  _res4[3]; 
590    volatile uint8_t  far;
591    volatile uint32_t asr;
592    volatile uint32_t drr1;
593    volatile uint32_t drr2;
594    volatile uint16_t _res5; 
595    volatile uint16_t specr;
596    volatile uint16_t _res6;
597    volatile uint16_t ep0sr;
598
599    volatile uint32_t iep0cfg;
600    volatile uint32_t oep0cfg;
601    volatile uint32_t ep1cfg;
602    volatile uint32_t ep2cfg;
603    volatile uint32_t ep3cfg;
604    volatile uint32_t ep4cfg;
605    volatile uint32_t ep5cfg;
606    volatile uint32_t ep6cfg;
607    volatile uint32_t ep7cfg;
608    volatile uint32_t ep0ctl;
609
610    volatile uint16_t _res7;
611    volatile uint16_t ep1ctl;
612    volatile uint16_t _res8;
613    volatile uint16_t ep2ctl;
614    volatile uint16_t _res9;
615    volatile uint16_t ep3ctl;
616    volatile uint16_t _res10;
617    volatile uint16_t ep4ctl;
618    volatile uint16_t _res11;
619    volatile uint16_t ep5ctl;
620    volatile uint16_t _res12;
621    volatile uint16_t ep6ctl;
622    volatile uint16_t _res13;
623    volatile uint16_t ep7ctl;
624
625    volatile uint32_t ep0isr;
626
627    volatile uint16_t _res14;
628    volatile uint16_t ep1isr;
629    volatile uint16_t _res15;
630    volatile uint16_t ep2isr;
631    volatile uint16_t _res16;
632    volatile uint16_t ep3isr;
633    volatile uint16_t _res17;
634    volatile uint16_t ep4isr;
635    volatile uint16_t _res18;
636    volatile uint16_t ep5isr;
637    volatile uint16_t _res19;
638    volatile uint16_t ep6isr;
639    volatile uint16_t _res20;
640    volatile uint16_t ep7isr;
641
642    volatile uint32_t ep0imr;
643
644    volatile uint16_t _res21;
645    volatile uint16_t ep1imr;
646    volatile uint16_t _res22;
647    volatile uint16_t ep2imr;
648    volatile uint16_t _res23;
649    volatile uint16_t ep3imr;
650    volatile uint16_t _res24;
651    volatile uint16_t ep4imr;
652    volatile uint16_t _res25;
653    volatile uint16_t ep5imr;
654    volatile uint16_t _res26;
655    volatile uint16_t ep6imr;
656    volatile uint16_t _res27;
657    volatile uint16_t ep7imr;
658
659    volatile uint32_t ep0dr;
660    volatile uint32_t ep1dr;
661    volatile uint32_t ep2dr;
662    volatile uint32_t ep3dr;
663    volatile uint32_t ep4dr;
664    volatile uint32_t ep5dr;
665    volatile uint32_t ep6dr;
666    volatile uint32_t ep7dr;
667
668    volatile uint16_t _res28;
669    volatile uint16_t ep0dpr;
670    volatile uint16_t _res29;
671    volatile uint16_t ep1dpr;
672    volatile uint16_t _res30;
673    volatile uint16_t ep2dpr;
674    volatile uint16_t _res31;
675    volatile uint16_t ep3dpr;
676    volatile uint16_t _res32;
677    volatile uint16_t ep4dpr;
678    volatile uint16_t _res33;
679    volatile uint16_t ep5dpr;
680    volatile uint16_t _res34;
681    volatile uint16_t ep6dpr;
682    volatile uint16_t _res35;
683    volatile uint16_t ep7dpr;
684/*    uint8_t  ram[1024]; */
685} usb_regs_t;
686
687extern intctrl_regs_t *g_intctrl_regs;
688extern chipsel_regs_t *g_chipsel_regs;
689extern gpio_regs_t *g_gpio_regs;
690extern qspi_regs_t *g_qspi_regs;
691extern pwm_regs_t *g_pwm_regs;
692extern dma_regs_t *g_dma_regs;
693extern uart_regs_t *g_uart0_regs;
694extern uart_regs_t *g_uart1_regs;
695extern timer_regs_t *g_timer_regs;
696extern plic_regs_t *g_plic_regs;
697extern enet_regs_t *g_enet_regs;
698extern usb_regs_t *g_usb_regs;
699
700#endif /* ASM */
701
702#endif /* __MCF5272_H__ */
Note: See TracBrowser for help on using the repository browser.