Subversion Repositories freemyipod

Rev

Rev 221 | Show entire file | Ignore whitespace | Details | Blame | Last modification | View Log | RSS feed

Rev 221 Rev 265
Line 26... Line 26...
26
 
26
 
27
#include "global.h"
27
#include "global.h"
28
 
28
 
29
 
29
 
30
/////CLKCON/////
30
/////CLKCON/////
31
#define CLKCON       (*((volatile uint32_t*)(0x3C500000)))
31
#define CLKCON       (*((uint32_t volatile*)(0x3C500000)))
32
#define PLL0PMS      (*((volatile uint32_t*)(0x3C500004)))
32
#define PLL0PMS      (*((uint32_t volatile*)(0x3C500004)))
33
#define PLL1PMS      (*((volatile uint32_t*)(0x3C500008)))
33
#define PLL1PMS      (*((uint32_t volatile*)(0x3C500008)))
34
#define PLL2PMS      (*((volatile uint32_t*)(0x3C50000C)))
34
#define PLL2PMS      (*((uint32_t volatile*)(0x3C50000C)))
35
#define PLL0LCNT     (*((volatile uint32_t*)(0x3C500014)))
35
#define PLL0LCNT     (*((uint32_t volatile*)(0x3C500014)))
36
#define PLL1LCNT     (*((volatile uint32_t*)(0x3C500018)))
36
#define PLL1LCNT     (*((uint32_t volatile*)(0x3C500018)))
37
#define PLL2LCNT     (*((volatile uint32_t*)(0x3C50001C)))
37
#define PLL2LCNT     (*((uint32_t volatile*)(0x3C50001C)))
38
#define PLLLOCK      (*((volatile uint32_t*)(0x3C500020)))
38
#define PLLLOCK      (*((uint32_t volatile*)(0x3C500020)))
39
#define PLLCON       (*((volatile uint32_t*)(0x3C500024)))
39
#define PLLCON       (*((uint32_t volatile*)(0x3C500024)))
40
#define PWRMODE      (*((volatile uint32_t*)(0x3C50002C)))
40
#define PWRMODE      (*((uint32_t volatile*)(0x3C50002C)))
41
#define SWRCON       (*((volatile uint32_t*)(0x3C500030)))
41
#define SWRCON       (*((uint32_t volatile*)(0x3C500030)))
42
#define RSTSR        (*((volatile uint32_t*)(0x3C500034)))
42
#define RSTSR        (*((uint32_t volatile*)(0x3C500034)))
43
#define DSPCLKMD     (*((volatile uint32_t*)(0x3C500038)))
43
#define DSPCLKMD     (*((uint32_t volatile*)(0x3C500038)))
44
#define CLKCON2      (*((volatile uint32_t*)(0x3C50003C)))
44
#define CLKCON2      (*((uint32_t volatile*)(0x3C50003C)))
45
#define PWRCON(i)    (*((volatile uint32_t*)(0x3C500000 + ((i) == 1 ? 0x40 : 0x28))))
45
#define PWRCON(i)    (*((uint32_t volatile*)(0x3C500000 + ((i) == 1 ? 0x40 : 0x28))))
46
 
46
 
47
 
47
 
48
/////ICU/////
48
/////ICU/////
49
#define SRCPND       (*((volatile uint32_t*)(0x39C00000)))
49
#define SRCPND       (*((uint32_t volatile*)(0x39C00000)))
50
#define INTMOD       (*((volatile uint32_t*)(0x39C00004)))
50
#define INTMOD       (*((uint32_t volatile*)(0x39C00004)))
51
#define INTMSK       (*((volatile uint32_t*)(0x39C00008)))
51
#define INTMSK       (*((uint32_t volatile*)(0x39C00008)))
52
#define INTPRIO      (*((volatile uint32_t*)(0x39C0000C)))
52
#define INTPRIO      (*((uint32_t volatile*)(0x39C0000C)))
53
#define INTPND       (*((volatile uint32_t*)(0x39C00010)))
53
#define INTPND       (*((uint32_t volatile*)(0x39C00010)))
54
#define INTOFFSET    (*((volatile uint32_t*)(0x39C00014)))
54
#define INTOFFSET    (*((uint32_t volatile*)(0x39C00014)))
55
#define EINTPOL      (*((volatile uint32_t*)(0x39C00018)))
55
#define EINTPOL      (*((uint32_t volatile*)(0x39C00018)))
56
#define EINTPEND     (*((volatile uint32_t*)(0x39C0001C)))
56
#define EINTPEND     (*((uint32_t volatile*)(0x39C0001C)))
57
#define EINTMSK      (*((volatile uint32_t*)(0x39C00020)))
57
#define EINTMSK      (*((uint32_t volatile*)(0x39C00020)))
58
 
58
 
59
 
59
 
60
/////GPIO/////
60
/////GPIO/////
61
#define PCON0        (*((volatile uint32_t*)(0x3CF00000)))
61
#define PCON0        (*((uint32_t volatile*)(0x3CF00000)))
62
#define PDAT0        (*((volatile uint32_t*)(0x3CF00004)))
62
#define PDAT0        (*((uint32_t volatile*)(0x3CF00004)))
63
#define PCON1        (*((volatile uint32_t*)(0x3CF00010)))
63
#define PCON1        (*((uint32_t volatile*)(0x3CF00010)))
64
#define PDAT1        (*((volatile uint32_t*)(0x3CF00014)))
64
#define PDAT1        (*((uint32_t volatile*)(0x3CF00014)))
65
#define PCON2        (*((volatile uint32_t*)(0x3CF00020)))
65
#define PCON2        (*((uint32_t volatile*)(0x3CF00020)))
66
#define PDAT2        (*((volatile uint32_t*)(0x3CF00024)))
66
#define PDAT2        (*((uint32_t volatile*)(0x3CF00024)))
67
#define PCON3        (*((volatile uint32_t*)(0x3CF00030)))
67
#define PCON3        (*((uint32_t volatile*)(0x3CF00030)))
68
#define PDAT3        (*((volatile uint32_t*)(0x3CF00034)))
68
#define PDAT3        (*((uint32_t volatile*)(0x3CF00034)))
69
#define PCON4        (*((volatile uint32_t*)(0x3CF00040)))
69
#define PCON4        (*((uint32_t volatile*)(0x3CF00040)))
70
#define PDAT4        (*((volatile uint32_t*)(0x3CF00044)))
70
#define PDAT4        (*((uint32_t volatile*)(0x3CF00044)))
71
#define PCON5        (*((volatile uint32_t*)(0x3CF00050)))
71
#define PCON5        (*((uint32_t volatile*)(0x3CF00050)))
72
#define PDAT5        (*((volatile uint32_t*)(0x3CF00054)))
72
#define PDAT5        (*((uint32_t volatile*)(0x3CF00054)))
73
#define PUNK5        (*((volatile uint32_t*)(0x3CF0005C)))
73
#define PUNK5        (*((uint32_t volatile*)(0x3CF0005C)))
74
#define PCON6        (*((volatile uint32_t*)(0x3CF00060)))
74
#define PCON6        (*((uint32_t volatile*)(0x3CF00060)))
75
#define PDAT6        (*((volatile uint32_t*)(0x3CF00064)))
75
#define PDAT6        (*((uint32_t volatile*)(0x3CF00064)))
76
#define PCON7        (*((volatile uint32_t*)(0x3CF00070)))
76
#define PCON7        (*((uint32_t volatile*)(0x3CF00070)))
77
#define PDAT7        (*((volatile uint32_t*)(0x3CF00074)))
77
#define PDAT7        (*((uint32_t volatile*)(0x3CF00074)))
78
#define PCON10       (*((volatile uint32_t*)(0x3CF000A0)))
78
#define PCON10       (*((uint32_t volatile*)(0x3CF000A0)))
79
#define PDAT10       (*((volatile uint32_t*)(0x3CF000A4)))
79
#define PDAT10       (*((uint32_t volatile*)(0x3CF000A4)))
80
#define PCON11       (*((volatile uint32_t*)(0x3CF000B0)))
80
#define PCON11       (*((uint32_t volatile*)(0x3CF000B0)))
81
#define PDAT11       (*((volatile uint32_t*)(0x3CF000B4)))
81
#define PDAT11       (*((uint32_t volatile*)(0x3CF000B4)))
82
#define PCON14       (*((volatile uint32_t*)(0x3CF000E0)))
82
#define PCON14       (*((uint32_t volatile*)(0x3CF000E0)))
83
#define PDAT14       (*((volatile uint32_t*)(0x3CF000E4)))
83
#define PDAT14       (*((uint32_t volatile*)(0x3CF000E4)))
84
#define PCON15       (*((volatile uint32_t*)(0x3CF000F0)))
84
#define PCON15       (*((uint32_t volatile*)(0x3CF000F0)))
85
#define PUNK15       (*((volatile uint32_t*)(0x3CF000FC)))
85
#define PUNK15       (*((uint32_t volatile*)(0x3CF000FC)))
86
 
86
 
87
 
87
 
88
/////IODMA/////
88
/////IODMA/////
89
#define DMABASE0     (*((volatile uint32_t*)(0x38400000)))
89
#define DMABASE0     (*((void* volatile*)(0x38400000)))
90
#define DMACON0      (*((volatile uint32_t*)(0x38400004)))
90
#define DMACON0      (*((uint32_t volatile*)(0x38400004)))
91
#define DMATCNT0     (*((volatile uint32_t*)(0x38400008)))
91
#define DMATCNT0     (*((uint32_t volatile*)(0x38400008)))
92
#define DMACADDR0    (*((volatile uint32_t*)(0x3840000C)))
92
#define DMACADDR0    (*((void* volatile*)(0x3840000C)))
93
#define DMACTCNT0    (*((volatile uint32_t*)(0x38400010)))
93
#define DMACTCNT0    (*((uint32_t volatile*)(0x38400010)))
94
#define DMACOM0      (*((volatile uint32_t*)(0x38400014)))
94
#define DMACOM0      (*((uint32_t volatile*)(0x38400014)))
95
#define DMANOF0      (*((volatile uint32_t*)(0x38400018)))
95
#define DMANOF0      (*((uint32_t volatile*)(0x38400018)))
96
#define DMABASE1     (*((volatile uint32_t*)(0x38400020)))
96
#define DMABASE1     (*((void* volatile*)(0x38400020)))
97
#define DMACON1      (*((volatile uint32_t*)(0x38400024)))
97
#define DMACON1      (*((uint32_t volatile*)(0x38400024)))
98
#define DMATCNT1     (*((volatile uint32_t*)(0x38400028)))
98
#define DMATCNT1     (*((uint32_t volatile*)(0x38400028)))
99
#define DMACADDR1    (*((volatile uint32_t*)(0x3840002C)))
99
#define DMACADDR1    (*((void* volatile*)(0x3840002C)))
100
#define DMACTCNT1    (*((volatile uint32_t*)(0x38400030)))
100
#define DMACTCNT1    (*((uint32_t volatile*)(0x38400030)))
101
#define DMACOM1      (*((volatile uint32_t*)(0x38400034)))
101
#define DMACOM1      (*((uint32_t volatile*)(0x38400034)))
102
#define DMABASE2     (*((volatile uint32_t*)(0x38400040)))
102
#define DMABASE2     (*((void* volatile*)(0x38400040)))
103
#define DMACON2      (*((volatile uint32_t*)(0x38400044)))
103
#define DMACON2      (*((uint32_t volatile*)(0x38400044)))
104
#define DMATCNT2     (*((volatile uint32_t*)(0x38400048)))
104
#define DMATCNT2     (*((uint32_t volatile*)(0x38400048)))
105
#define DMACADDR2    (*((volatile uint32_t*)(0x3840004C)))
105
#define DMACADDR2    (*((void* volatile*)(0x3840004C)))
106
#define DMACTCNT2    (*((volatile uint32_t*)(0x38400050)))
106
#define DMACTCNT2    (*((uint32_t volatile*)(0x38400050)))
107
#define DMACOM2      (*((volatile uint32_t*)(0x38400054)))
107
#define DMACOM2      (*((uint32_t volatile*)(0x38400054)))
108
#define DMABASE3     (*((volatile uint32_t*)(0x38400060)))
108
#define DMABASE3     (*((void* volatile*)(0x38400060)))
109
#define DMACON3      (*((volatile uint32_t*)(0x38400064)))
109
#define DMACON3      (*((uint32_t volatile*)(0x38400064)))
110
#define DMATCNT3     (*((volatile uint32_t*)(0x38400068)))
110
#define DMATCNT3     (*((uint32_t volatile*)(0x38400068)))
111
#define DMACADDR3    (*((volatile uint32_t*)(0x3840006C)))
111
#define DMACADDR3    (*((void* volatile*)(0x3840006C)))
112
#define DMACTCNT3    (*((volatile uint32_t*)(0x38400070)))
112
#define DMACTCNT3    (*((uint32_t volatile*)(0x38400070)))
113
#define DMACOM3      (*((volatile uint32_t*)(0x38400074)))
113
#define DMACOM3      (*((uint32_t volatile*)(0x38400074)))
114
#define DMABASE4     (*((volatile uint32_t*)(0x38400080)))
114
#define DMABASE4     (*((void* volatile*)(0x38400080)))
115
#define DMACON4      (*((volatile uint32_t*)(0x38400084)))
115
#define DMACON4      (*((uint32_t volatile*)(0x38400084)))
116
#define DMATCNT4     (*((volatile uint32_t*)(0x38400088)))
116
#define DMATCNT4     (*((uint32_t volatile*)(0x38400088)))
117
#define DMACADDR4    (*((volatile uint32_t*)(0x3840008C)))
117
#define DMACADDR4    (*((void* volatile*)(0x3840008C)))
118
#define DMACTCNT4    (*((volatile uint32_t*)(0x38400090)))
118
#define DMACTCNT4    (*((uint32_t volatile*)(0x38400090)))
119
#define DMACOM4      (*((volatile uint32_t*)(0x38400094)))
119
#define DMACOM4      (*((uint32_t volatile*)(0x38400094)))
120
#define DMABASE5     (*((volatile uint32_t*)(0x384000A0)))
120
#define DMABASE5     (*((void* volatile*)(0x384000A0)))
121
#define DMACON5      (*((volatile uint32_t*)(0x384000A4)))
121
#define DMACON5      (*((uint32_t volatile*)(0x384000A4)))
122
#define DMATCNT5     (*((volatile uint32_t*)(0x384000A8)))
122
#define DMATCNT5     (*((uint32_t volatile*)(0x384000A8)))
123
#define DMACADDR5    (*((volatile uint32_t*)(0x384000AC)))
123
#define DMACADDR5    (*((void* volatile*)(0x384000AC)))
124
#define DMACTCNT5    (*((volatile uint32_t*)(0x384000B0)))
124
#define DMACTCNT5    (*((uint32_t volatile*)(0x384000B0)))
125
#define DMACOM5      (*((volatile uint32_t*)(0x384000B4)))
125
#define DMACOM5      (*((uint32_t volatile*)(0x384000B4)))
126
#define DMABASE6     (*((volatile uint32_t*)(0x384000C0)))
126
#define DMABASE6     (*((void* volatile*)(0x384000C0)))
127
#define DMACON6      (*((volatile uint32_t*)(0x384000C4)))
127
#define DMACON6      (*((uint32_t volatile*)(0x384000C4)))
128
#define DMATCNT6     (*((volatile uint32_t*)(0x384000C8)))
128
#define DMATCNT6     (*((uint32_t volatile*)(0x384000C8)))
129
#define DMACADDR6    (*((volatile uint32_t*)(0x384000CC)))
129
#define DMACADDR6    (*((void* volatile*)(0x384000CC)))
130
#define DMACTCNT6    (*((volatile uint32_t*)(0x384000D0)))
130
#define DMACTCNT6    (*((uint32_t volatile*)(0x384000D0)))
131
#define DMACOM6      (*((volatile uint32_t*)(0x384000D4)))
131
#define DMACOM6      (*((uint32_t volatile*)(0x384000D4)))
132
#define DMABASE7     (*((volatile uint32_t*)(0x384000E0)))
132
#define DMABASE7     (*((void* volatile*)(0x384000E0)))
133
#define DMACON7      (*((volatile uint32_t*)(0x384000E4)))
133
#define DMACON7      (*((uint32_t volatile*)(0x384000E4)))
134
#define DMATCNT7     (*((volatile uint32_t*)(0x384000E8)))
134
#define DMATCNT7     (*((uint32_t volatile*)(0x384000E8)))
135
#define DMACADDR7    (*((volatile uint32_t*)(0x384000EC)))
135
#define DMACADDR7    (*((void* volatile*)(0x384000EC)))
136
#define DMACTCNT7    (*((volatile uint32_t*)(0x384000F0)))
136
#define DMACTCNT7    (*((uint32_t volatile*)(0x384000F0)))
137
#define DMACOM7      (*((volatile uint32_t*)(0x384000F4)))
137
#define DMACOM7      (*((uint32_t volatile*)(0x384000F4)))
138
#define DMABASE8     (*((volatile uint32_t*)(0x38400100)))
138
#define DMABASE8     (*((void* volatile*)(0x38400100)))
139
#define DMACON8      (*((volatile uint32_t*)(0x38400104)))
139
#define DMACON8      (*((uint32_t volatile*)(0x38400104)))
140
#define DMATCNT8     (*((volatile uint32_t*)(0x38400108)))
140
#define DMATCNT8     (*((uint32_t volatile*)(0x38400108)))
141
#define DMACADDR8    (*((volatile uint32_t*)(0x3840010C)))
141
#define DMACADDR8    (*((void* volatile*)(0x3840010C)))
142
#define DMACTCNT8    (*((volatile uint32_t*)(0x38400110)))
142
#define DMACTCNT8    (*((uint32_t volatile*)(0x38400110)))
143
#define DMACOM8      (*((volatile uint32_t*)(0x38400114)))
143
#define DMACOM8      (*((uint32_t volatile*)(0x38400114)))
144
#define DMAALLST     (*((volatile uint32_t*)(0x38400180)))
144
#define DMAALLST     (*((uint32_t volatile*)(0x38400180)))
145
#define DMAALLST2    (*((volatile uint32_t*)(0x38400184)))
145
#define DMAALLST2    (*((uint32_t volatile*)(0x38400184)))
146
#define DMACON_DEVICE_SHIFT    30
146
#define DMACON_DEVICE_SHIFT    30
147
#define DMACON_DIRECTION_SHIFT 29
147
#define DMACON_DIRECTION_SHIFT 29
148
#define DMACON_DATA_SIZE_SHIFT 22
148
#define DMACON_DATA_SIZE_SHIFT 22
149
#define DMACON_BURST_LEN_SHIFT 19
149
#define DMACON_BURST_LEN_SHIFT 19
150
#define DMACOM_START           4
150
#define DMACOM_START           4
Line 167... Line 167...
167
#define DMAALLST_CHAN2_MASK    (0xF << 8)
167
#define DMAALLST_CHAN2_MASK    (0xF << 8)
168
#define DMAALLST_CHAN3_MASK    (0xF << 12)
168
#define DMAALLST_CHAN3_MASK    (0xF << 12)
169
 
169
 
170
 
170
 
171
/////FMC/////
171
/////FMC/////
172
#define FMCTRL0      (*((volatile uint32_t*)(0x39400000)))
172
#define FMCTRL0      (*((uint32_t volatile*)(0x39400000)))
173
#define FMCTRL1      (*((volatile uint32_t*)(0x39400004)))
173
#define FMCTRL1      (*((uint32_t volatile*)(0x39400004)))
174
#define FMCMD        (*((volatile uint32_t*)(0x39400008)))
174
#define FMCMD        (*((uint32_t volatile*)(0x39400008)))
175
#define FMADDR0      (*((volatile uint32_t*)(0x3940000C)))
175
#define FMADDR0      (*((uint32_t volatile*)(0x3940000C)))
176
#define FMADDR1      (*((volatile uint32_t*)(0x39400010)))
176
#define FMADDR1      (*((uint32_t volatile*)(0x39400010)))
177
#define FMANUM       (*((volatile uint32_t*)(0x3940002C)))
177
#define FMANUM       (*((uint32_t volatile*)(0x3940002C)))
178
#define FMDNUM       (*((volatile uint32_t*)(0x39400030)))
178
#define FMDNUM       (*((uint32_t volatile*)(0x39400030)))
179
#define FMCSTAT      (*((volatile uint32_t*)(0x39400048)))
179
#define FMCSTAT      (*((uint32_t volatile*)(0x39400048)))
180
#define FMFIFO       (*((volatile uint32_t*)(0x39400080)))
180
#define FMFIFO       (*((uint32_t volatile*)(0x39400080)))
181
#define RS_ECC_CTRL  (*((volatile uint32_t*)(0x39400100)))
181
#define RS_ECC_CTRL  (*((uint32_t volatile*)(0x39400100)))
182
#define FMCTRL0_ENABLEDMA      (1 << 10)
182
#define FMCTRL0_ENABLEDMA      (1 << 10)
183
#define FMCTRL0_UNK1           (1 << 11)
183
#define FMCTRL0_UNK1           (1 << 11)
184
#define FMCTRL1_DOTRANSADDR    (1 << 0)
184
#define FMCTRL1_DOTRANSADDR    (1 << 0)
185
#define FMCTRL1_DOREADDATA     (1 << 1)
185
#define FMCTRL1_DOREADDATA     (1 << 1)
186
#define FMCTRL1_DOWRITEDATA    (1 << 2)
186
#define FMCTRL1_DOWRITEDATA    (1 << 2)
Line 195... Line 195...
195
#define FMCSTAT_BANK2READY     (1 << 6)
195
#define FMCSTAT_BANK2READY     (1 << 6)
196
#define FMCSTAT_BANK3READY     (1 << 7)
196
#define FMCSTAT_BANK3READY     (1 << 7)
197
 
197
 
198
 
198
 
199
/////ECC/////
199
/////ECC/////
200
#define ECC_DATA_PTR  (*((volatile uint32_t*)(0x39E00004)))
200
#define ECC_DATA_PTR  (*((void* volatile*)(0x39E00004)))
201
#define ECC_SPARE_PTR (*((volatile uint32_t*)(0x39E00008)))
201
#define ECC_SPARE_PTR (*((void* volatile*)(0x39E00008)))
202
#define ECC_CTRL      (*((volatile uint32_t*)(0x39E0000C)))
202
#define ECC_CTRL      (*((uint32_t volatile*)(0x39E0000C)))
203
#define ECC_RESULT    (*((volatile uint32_t*)(0x39E00010)))
203
#define ECC_RESULT    (*((uint32_t volatile*)(0x39E00010)))
204
#define ECC_UNK1      (*((volatile uint32_t*)(0x39E00014)))
204
#define ECC_UNK1      (*((uint32_t volatile*)(0x39E00014)))
205
#define ECC_INT_CLR   (*((volatile uint32_t*)(0x39E00040)))
205
#define ECC_INT_CLR   (*((uint32_t volatile*)(0x39E00040)))
206
#define ECCCTRL_STARTDECODING  (1 << 0)
206
#define ECCCTRL_STARTDECODING  (1 << 0)
207
#define ECCCTRL_STARTENCODING  (1 << 1)
207
#define ECCCTRL_STARTENCODING  (1 << 1)
208
#define ECCCTRL_STARTDECNOSYND (1 << 2)
208
#define ECCCTRL_STARTDECNOSYND (1 << 2)
209
 
209
 
210
 
210
 
211
/////CLICKWHEEL/////
211
/////CLICKWHEEL/////
212
#define WHEEL00      (*((volatile uint32_t*)(0x3C200000)))
212
#define WHEEL00      (*((uint32_t volatile*)(0x3C200000)))
213
#define WHEEL04      (*((volatile uint32_t*)(0x3C200004)))
213
#define WHEEL04      (*((uint32_t volatile*)(0x3C200004)))
214
#define WHEEL08      (*((volatile uint32_t*)(0x3C200008)))
214
#define WHEEL08      (*((uint32_t volatile*)(0x3C200008)))
215
#define WHEEL0C      (*((volatile uint32_t*)(0x3C20000C)))
215
#define WHEEL0C      (*((uint32_t volatile*)(0x3C20000C)))
216
#define WHEEL10      (*((volatile uint32_t*)(0x3C200010)))
216
#define WHEEL10      (*((uint32_t volatile*)(0x3C200010)))
217
#define WHEELINT     (*((volatile uint32_t*)(0x3C200014)))
217
#define WHEELINT     (*((uint32_t volatile*)(0x3C200014)))
218
#define WHEELRX      (*((volatile uint32_t*)(0x3C200018)))
218
#define WHEELRX      (*((uint32_t volatile*)(0x3C200018)))
219
#define WHEELTX      (*((volatile uint32_t*)(0x3C20001C)))
219
#define WHEELTX      (*((uint32_t volatile*)(0x3C20001C)))
220
 
220
 
221
 
221
 
222
/////AES/////
222
/////AES/////
223
#define AESCONTROL   (*((volatile uint32_t*)(0x39800000)))
223
#define AESCONTROL   (*((uint32_t volatile*)(0x39800000)))
224
#define AESGO        (*((volatile uint32_t*)(0x39800004)))
224
#define AESGO        (*((uint32_t volatile*)(0x39800004)))
225
#define AESUNKREG0   (*((volatile uint32_t*)(0x39800008)))
225
#define AESUNKREG0   (*((uint32_t volatile*)(0x39800008)))
226
#define AESSTATUS    (*((volatile uint32_t*)(0x3980000C)))
226
#define AESSTATUS    (*((uint32_t volatile*)(0x3980000C)))
227
#define AESUNKREG1   (*((volatile uint32_t*)(0x39800010)))
227
#define AESUNKREG1   (*((uint32_t volatile*)(0x39800010)))
228
#define AESKEYLEN    (*((volatile uint32_t*)(0x39800014)))
228
#define AESKEYLEN    (*((uint32_t volatile*)(0x39800014)))
229
#define AESOUTSIZE   (*((volatile uint32_t*)(0x39800018)))
229
#define AESOUTSIZE   (*((uint32_t volatile*)(0x39800018)))
230
#define AESOUTADDR   (*((volatile uint32_t*)(0x39800020)))
230
#define AESOUTADDR   (*((void* volatile*)(0x39800020)))
231
#define AESINSIZE    (*((volatile uint32_t*)(0x39800024)))
231
#define AESINSIZE    (*((uint32_t volatile*)(0x39800024)))
232
#define AESINADDR    (*((volatile uint32_t*)(0x39800028)))
232
#define AESINADDR    (*((const void* volatile*)(0x39800028)))
233
#define AESAUXSIZE   (*((volatile uint32_t*)(0x3980002C)))
233
#define AESAUXSIZE   (*((uint32_t volatile*)(0x3980002C)))
234
#define AESAUXADDR   (*((volatile uint32_t*)(0x39800030)))
234
#define AESAUXADDR   (*((void* volatile*)(0x39800030)))
235
#define AESSIZE3     (*((volatile uint32_t*)(0x39800034)))
235
#define AESSIZE3     (*((uint32_t volatile*)(0x39800034)))
236
#define AESKEY         ((volatile uint32_t*)(0x3980004C))
236
#define AESKEY         ((uint32_t volatile*)(0x3980004C))
237
#define AESTYPE      (*((volatile uint32_t*)(0x3980006C)))
237
#define AESTYPE      (*((uint32_t volatile*)(0x3980006C)))
238
#define AESIV          ((volatile uint32_t*)(0x39800074))
238
#define AESIV          ((uint32_t volatile*)(0x39800074))
239
#define AESTYPE2     (*((volatile uint32_t*)(0x39800088)))
239
#define AESTYPE2     (*((uint32_t volatile*)(0x39800088)))
240
#define AESUNKREG2   (*((volatile uint32_t*)(0x3980008C)))
240
#define AESUNKREG2   (*((uint32_t volatile*)(0x3980008C)))
241
 
241
 
242
/////HASH/////
242
/////HASH/////
243
#define HASHCTRL     (*((volatile uint32_t*)(0x3C600000)))
243
#define HASHCTRL     (*((uint32_t volatile*)(0x3C600000)))
244
#define HASHRESULT     ((volatile uint32_t*)(0x3C600020))
244
#define HASHRESULT     ((uint32_t volatile*)(0x3C600020))
245
#define HASHDATAIN     ((volatile uint32_t*)(0x3C600040))
245
#define HASHDATAIN     ((uint32_t volatile*)(0x3C600040))
246
 
246
 
247
 
247
 
248
/////TIMER/////
248
/////TIMER/////
249
#define TACON        (*((volatile uint32_t*)(0x3C700000)))
249
#define TACON        (*((uint32_t volatile*)(0x3C700000)))
250
#define TACMD        (*((volatile uint32_t*)(0x3C700004)))
250
#define TACMD        (*((uint32_t volatile*)(0x3C700004)))
251
#define TADATA0      (*((volatile uint32_t*)(0x3C700008)))
251
#define TADATA0      (*((uint32_t volatile*)(0x3C700008)))
252
#define TADATA1      (*((volatile uint32_t*)(0x3C70000C)))
252
#define TADATA1      (*((uint32_t volatile*)(0x3C70000C)))
253
#define TAPRE        (*((volatile uint32_t*)(0x3C700010)))
253
#define TAPRE        (*((uint32_t volatile*)(0x3C700010)))
254
#define TACNT        (*((volatile uint32_t*)(0x3C700014)))
254
#define TACNT        (*((uint32_t volatile*)(0x3C700014)))
255
#define TBCON        (*((volatile uint32_t*)(0x3C700020)))
255
#define TBCON        (*((uint32_t volatile*)(0x3C700020)))
256
#define TBCMD        (*((volatile uint32_t*)(0x3C700024)))
256
#define TBCMD        (*((uint32_t volatile*)(0x3C700024)))
257
#define TBDATA0      (*((volatile uint32_t*)(0x3C700028)))
257
#define TBDATA0      (*((uint32_t volatile*)(0x3C700028)))
258
#define TBDATA1      (*((volatile uint32_t*)(0x3C70002C)))
258
#define TBDATA1      (*((uint32_t volatile*)(0x3C70002C)))
259
#define TBPRE        (*((volatile uint32_t*)(0x3C700030)))
259
#define TBPRE        (*((uint32_t volatile*)(0x3C700030)))
260
#define TBCNT        (*((volatile uint32_t*)(0x3C700034)))
260
#define TBCNT        (*((uint32_t volatile*)(0x3C700034)))
261
#define TCCON        (*((volatile uint32_t*)(0x3C700040)))
261
#define TCCON        (*((uint32_t volatile*)(0x3C700040)))
262
#define TCCMD        (*((volatile uint32_t*)(0x3C700044)))
262
#define TCCMD        (*((uint32_t volatile*)(0x3C700044)))
263
#define TCDATA0      (*((volatile uint32_t*)(0x3C700048)))
263
#define TCDATA0      (*((uint32_t volatile*)(0x3C700048)))
264
#define TCDATA1      (*((volatile uint32_t*)(0x3C70004C)))
264
#define TCDATA1      (*((uint32_t volatile*)(0x3C70004C)))
265
#define TCPRE        (*((volatile uint32_t*)(0x3C700050)))
265
#define TCPRE        (*((uint32_t volatile*)(0x3C700050)))
266
#define TCCNT        (*((volatile uint32_t*)(0x3C700054)))
266
#define TCCNT        (*((uint32_t volatile*)(0x3C700054)))
267
#define TDCON        (*((volatile uint32_t*)(0x3C700060)))
267
#define TDCON        (*((uint32_t volatile*)(0x3C700060)))
268
#define TDCMD        (*((volatile uint32_t*)(0x3C700064)))
268
#define TDCMD        (*((uint32_t volatile*)(0x3C700064)))
269
#define TDDATA0      (*((volatile uint32_t*)(0x3C700068)))
269
#define TDDATA0      (*((uint32_t volatile*)(0x3C700068)))
270
#define TDDATA1      (*((volatile uint32_t*)(0x3C70006C)))
270
#define TDDATA1      (*((uint32_t volatile*)(0x3C70006C)))
271
#define TDPRE        (*((volatile uint32_t*)(0x3C700070)))
271
#define TDPRE        (*((uint32_t volatile*)(0x3C700070)))
272
#define TDCNT        (*((volatile uint32_t*)(0x3C700074)))
272
#define TDCNT        (*((uint32_t volatile*)(0x3C700074)))
273
 
273
 
274
 
274
 
275
/////USB/////
275
/////USB/////
276
#define OTGBASE 0x38800000
276
#define OTGBASE 0x38800000
277
#define PHYBASE 0x3C400000
277
#define PHYBASE 0x3C400000
-
 
278
#define SYNOPSYSOTG_CLOCK 0
-
 
279
#define SYNOPSYSOTG_AHBCFG 0x27
278
 
280
 
279
 
281
 
280
/////I2C/////
282
/////I2C/////
281
#define IICCON       (*((volatile uint32_t*)(0x3C900000)))
283
#define IICCON       (*((uint32_t volatile*)(0x3C900000)))
282
#define IICSTAT      (*((volatile uint32_t*)(0x3C900004)))
284
#define IICSTAT      (*((uint32_t volatile*)(0x3C900004)))
283
#define IICADD       (*((volatile uint32_t*)(0x3C900008)))
285
#define IICADD       (*((uint32_t volatile*)(0x3C900008)))
284
#define IICDS        (*((volatile uint32_t*)(0x3C90000C)))
286
#define IICDS        (*((uint32_t volatile*)(0x3C90000C)))
285
 
287
 
286
 
288
 
287
/////CLOCK GATES/////
289
/////CLOCK GATES/////
288
#define CLOCKGATE_USB_1 14
290
#define CLOCKGATE_USB_1 14
289
#define CLOCKGATE_USB_2 43
291
#define CLOCKGATE_USB_2 43