Subversion Repositories freemyipod

Rev

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

Rev 111 Rev 265
Line 26... Line 26...
26
 
26
 
27
#include "global.h"
27
#include "global.h"
28
 
28
 
29
 
29
 
30
/////SYSCON/////
30
/////SYSCON/////
31
#define PWRCON(i)    (*((volatile uint32_t*)(0x3C500000 \
31
#define PWRCON(i)    (*((uint32_t volatile*)(0x3C500000 \
32
                                           + ((i) == 4 ? 0x6C : \
32
                                           + ((i) == 4 ? 0x6C : \
33
                                             ((i) == 3 ? 0x68 : \
33
                                             ((i) == 3 ? 0x68 : \
34
                                             ((i) == 2 ? 0x58 : \
34
                                             ((i) == 2 ? 0x58 : \
35
                                             ((i) == 1 ? 0x4C : \
35
                                             ((i) == 1 ? 0x4C : \
36
                                                         0x48)))))))
36
                                                         0x48)))))))
37
 
37
 
38
 
38
 
39
/////TIMER/////
39
/////TIMER/////
40
#define TACON        (*((volatile uint32_t*)(0x3C700000)))
40
#define TACON        (*((uint32_t volatile*)(0x3C700000)))
41
#define TACMD        (*((volatile uint32_t*)(0x3C700004)))
41
#define TACMD        (*((uint32_t volatile*)(0x3C700004)))
42
#define TADATA0      (*((volatile uint32_t*)(0x3C700008)))
42
#define TADATA0      (*((uint32_t volatile*)(0x3C700008)))
43
#define TADATA1      (*((volatile uint32_t*)(0x3C70000C)))
43
#define TADATA1      (*((uint32_t volatile*)(0x3C70000C)))
44
#define TAPRE        (*((volatile uint32_t*)(0x3C700010)))
44
#define TAPRE        (*((uint32_t volatile*)(0x3C700010)))
45
#define TACNT        (*((volatile uint32_t*)(0x3C700014)))
45
#define TACNT        (*((uint32_t volatile*)(0x3C700014)))
46
#define TBCON        (*((volatile uint32_t*)(0x3C700020)))
46
#define TBCON        (*((uint32_t volatile*)(0x3C700020)))
47
#define TBCMD        (*((volatile uint32_t*)(0x3C700024)))
47
#define TBCMD        (*((uint32_t volatile*)(0x3C700024)))
48
#define TBDATA0      (*((volatile uint32_t*)(0x3C700028)))
48
#define TBDATA0      (*((uint32_t volatile*)(0x3C700028)))
49
#define TBDATA1      (*((volatile uint32_t*)(0x3C70002C)))
49
#define TBDATA1      (*((uint32_t volatile*)(0x3C70002C)))
50
#define TBPRE        (*((volatile uint32_t*)(0x3C700030)))
50
#define TBPRE        (*((uint32_t volatile*)(0x3C700030)))
51
#define TBCNT        (*((volatile uint32_t*)(0x3C700034)))
51
#define TBCNT        (*((uint32_t volatile*)(0x3C700034)))
52
#define TCCON        (*((volatile uint32_t*)(0x3C700040)))
52
#define TCCON        (*((uint32_t volatile*)(0x3C700040)))
53
#define TCCMD        (*((volatile uint32_t*)(0x3C700044)))
53
#define TCCMD        (*((uint32_t volatile*)(0x3C700044)))
54
#define TCDATA0      (*((volatile uint32_t*)(0x3C700048)))
54
#define TCDATA0      (*((uint32_t volatile*)(0x3C700048)))
55
#define TCDATA1      (*((volatile uint32_t*)(0x3C70004C)))
55
#define TCDATA1      (*((uint32_t volatile*)(0x3C70004C)))
56
#define TCPRE        (*((volatile uint32_t*)(0x3C700050)))
56
#define TCPRE        (*((uint32_t volatile*)(0x3C700050)))
57
#define TCCNT        (*((volatile uint32_t*)(0x3C700054)))
57
#define TCCNT        (*((uint32_t volatile*)(0x3C700054)))
58
#define TDCON        (*((volatile uint32_t*)(0x3C700060)))
58
#define TDCON        (*((uint32_t volatile*)(0x3C700060)))
59
#define TDCMD        (*((volatile uint32_t*)(0x3C700064)))
59
#define TDCMD        (*((uint32_t volatile*)(0x3C700064)))
60
#define TDDATA0      (*((volatile uint32_t*)(0x3C700068)))
60
#define TDDATA0      (*((uint32_t volatile*)(0x3C700068)))
61
#define TDDATA1      (*((volatile uint32_t*)(0x3C70006C)))
61
#define TDDATA1      (*((uint32_t volatile*)(0x3C70006C)))
62
#define TDPRE        (*((volatile uint32_t*)(0x3C700070)))
62
#define TDPRE        (*((uint32_t volatile*)(0x3C700070)))
63
#define TDCNT        (*((volatile uint32_t*)(0x3C700074)))
63
#define TDCNT        (*((uint32_t volatile*)(0x3C700074)))
64
#define TECON        (*((volatile uint32_t*)(0x3C7000A0)))
64
#define TECON        (*((uint32_t volatile*)(0x3C7000A0)))
65
#define TECMD        (*((volatile uint32_t*)(0x3C7000A4)))
65
#define TECMD        (*((uint32_t volatile*)(0x3C7000A4)))
66
#define TEDATA0      (*((volatile uint32_t*)(0x3C7000A8)))
66
#define TEDATA0      (*((uint32_t volatile*)(0x3C7000A8)))
67
#define TEDATA1      (*((volatile uint32_t*)(0x3C7000AC)))
67
#define TEDATA1      (*((uint32_t volatile*)(0x3C7000AC)))
68
#define TEPRE        (*((volatile uint32_t*)(0x3C7000B0)))
68
#define TEPRE        (*((uint32_t volatile*)(0x3C7000B0)))
69
#define TECNT        (*((volatile uint32_t*)(0x3C7000B4)))
69
#define TECNT        (*((uint32_t volatile*)(0x3C7000B4)))
70
#define TFCON        (*((volatile uint32_t*)(0x3C7000C0)))
70
#define TFCON        (*((uint32_t volatile*)(0x3C7000C0)))
71
#define TFCMD        (*((volatile uint32_t*)(0x3C7000C4)))
71
#define TFCMD        (*((uint32_t volatile*)(0x3C7000C4)))
72
#define TFDATA0      (*((volatile uint32_t*)(0x3C7000C8)))
72
#define TFDATA0      (*((uint32_t volatile*)(0x3C7000C8)))
73
#define TFDATA1      (*((volatile uint32_t*)(0x3C7000CC)))
73
#define TFDATA1      (*((uint32_t volatile*)(0x3C7000CC)))
74
#define TFPRE        (*((volatile uint32_t*)(0x3C7000D0)))
74
#define TFPRE        (*((uint32_t volatile*)(0x3C7000D0)))
75
#define TFCNT        (*((volatile uint32_t*)(0x3C7000D4)))
75
#define TFCNT        (*((uint32_t volatile*)(0x3C7000D4)))
76
#define TGCON        (*((volatile uint32_t*)(0x3C7000E0)))
76
#define TGCON        (*((uint32_t volatile*)(0x3C7000E0)))
77
#define TGCMD        (*((volatile uint32_t*)(0x3C7000E4)))
77
#define TGCMD        (*((uint32_t volatile*)(0x3C7000E4)))
78
#define TGDATA0      (*((volatile uint32_t*)(0x3C7000E8)))
78
#define TGDATA0      (*((uint32_t volatile*)(0x3C7000E8)))
79
#define TGDATA1      (*((volatile uint32_t*)(0x3C7000EC)))
79
#define TGDATA1      (*((uint32_t volatile*)(0x3C7000EC)))
80
#define TGPRE        (*((volatile uint32_t*)(0x3C7000F0)))
80
#define TGPRE        (*((uint32_t volatile*)(0x3C7000F0)))
81
#define TGCNT        (*((volatile uint32_t*)(0x3C7000F4)))
81
#define TGCNT        (*((uint32_t volatile*)(0x3C7000F4)))
82
#define THCON        (*((volatile uint32_t*)(0x3C700100)))
82
#define THCON        (*((uint32_t volatile*)(0x3C700100)))
83
#define THCMD        (*((volatile uint32_t*)(0x3C700104)))
83
#define THCMD        (*((uint32_t volatile*)(0x3C700104)))
84
#define THDATA0      (*((volatile uint32_t*)(0x3C700108)))
84
#define THDATA0      (*((uint32_t volatile*)(0x3C700108)))
85
#define THDATA1      (*((volatile uint32_t*)(0x3C70010C)))
85
#define THDATA1      (*((uint32_t volatile*)(0x3C70010C)))
86
#define THPRE        (*((volatile uint32_t*)(0x3C700110)))
86
#define THPRE        (*((uint32_t volatile*)(0x3C700110)))
87
#define THCNT        (*((volatile uint32_t*)(0x3C700114)))
87
#define THCNT        (*((uint32_t volatile*)(0x3C700114)))
88
 
88
 
89
 
89
 
90
/////USB/////
90
/////USB/////
91
#define OTGBASE 0x38400000
91
#define OTGBASE 0x38400000
92
#define PHYBASE 0x3C400000
92
#define PHYBASE 0x3C400000
-
 
93
#define SYNOPSYSOTG_CLOCK 0x11
-
 
94
#define SYNOPSYSOTG_AHBCFG 0x2B
93
 
95
 
94
 
96
 
95
/////I2C/////
97
/////I2C/////
96
#define IICCON(bus)  (*((volatile uint32_t*)(0x3C600000 + 0x300000 * (bus))))
98
#define IICCON(bus)  (*((uint32_t volatile*)(0x3C600000 + 0x300000 * (bus))))
97
#define IICSTAT(bus) (*((volatile uint32_t*)(0x3C600004 + 0x300000 * (bus))))
99
#define IICSTAT(bus) (*((uint32_t volatile*)(0x3C600004 + 0x300000 * (bus))))
98
#define IICADD(bus)  (*((volatile uint32_t*)(0x3C600008 + 0x300000 * (bus))))
100
#define IICADD(bus)  (*((uint32_t volatile*)(0x3C600008 + 0x300000 * (bus))))
99
#define IICDS(bus)   (*((volatile uint32_t*)(0x3C60000C + 0x300000 * (bus))))
101
#define IICDS(bus)   (*((uint32_t volatile*)(0x3C60000C + 0x300000 * (bus))))
100
 
102
 
101
 
103
 
102
/////INTERRUPTS/////
104
/////INTERRUPT CONTROLLERS/////
103
#define VICIRQSTATUS(v)       (*((volatile uint32_t*)(0x38E00000 + 0x1000 * (v))))
105
#define VICIRQSTATUS(v)       (*((uint32_t volatile*)(0x38E00000 + 0x1000 * (v))))
104
#define VICFIQSTATUS(v)       (*((volatile uint32_t*)(0x38E00004 + 0x1000 * (v))))
106
#define VICFIQSTATUS(v)       (*((uint32_t volatile*)(0x38E00004 + 0x1000 * (v))))
105
#define VICRAWINTR(v)         (*((volatile uint32_t*)(0x38E00008 + 0x1000 * (v))))
107
#define VICRAWINTR(v)         (*((uint32_t volatile*)(0x38E00008 + 0x1000 * (v))))
106
#define VICINTSELECT(v)       (*((volatile uint32_t*)(0x38E0000C + 0x1000 * (v))))
108
#define VICINTSELECT(v)       (*((uint32_t volatile*)(0x38E0000C + 0x1000 * (v))))
107
#define VICINTENABLE(v)       (*((volatile uint32_t*)(0x38E00010 + 0x1000 * (v))))
109
#define VICINTENABLE(v)       (*((uint32_t volatile*)(0x38E00010 + 0x1000 * (v))))
108
#define VICINTENCLEAR(v)      (*((volatile uint32_t*)(0x38E00014 + 0x1000 * (v))))
110
#define VICINTENCLEAR(v)      (*((uint32_t volatile*)(0x38E00014 + 0x1000 * (v))))
109
#define VICSOFTINT(v)         (*((volatile uint32_t*)(0x38E00018 + 0x1000 * (v))))
111
#define VICSOFTINT(v)         (*((uint32_t volatile*)(0x38E00018 + 0x1000 * (v))))
110
#define VICSOFTINTCLEAR(v)    (*((volatile uint32_t*)(0x38E0001C + 0x1000 * (v))))
112
#define VICSOFTINTCLEAR(v)    (*((uint32_t volatile*)(0x38E0001C + 0x1000 * (v))))
111
#define VICPROTECTION(v)      (*((volatile uint32_t*)(0x38E00020 + 0x1000 * (v))))
113
#define VICPROTECTION(v)      (*((uint32_t volatile*)(0x38E00020 + 0x1000 * (v))))
112
#define VICSWPRIORITYMASK(v)  (*((volatile uint32_t*)(0x38E00024 + 0x1000 * (v))))
114
#define VICSWPRIORITYMASK(v)  (*((uint32_t volatile*)(0x38E00024 + 0x1000 * (v))))
113
#define VICPRIORITYDAISY(v)   (*((volatile uint32_t*)(0x38E00028 + 0x1000 * (v))))
115
#define VICPRIORITYDAISY(v)   (*((uint32_t volatile*)(0x38E00028 + 0x1000 * (v))))
114
#define VICVECTADDR(v, i)     (*((volatile uint32_t*)(0x38E00100 + 0x1000 * (v) + 4 * (i))))
116
#define VICVECTADDR(v, i)     (*((uint32_t volatile*)(0x38E00100 + 0x1000 * (v) + 4 * (i))))
115
#define VICVECTPRIORITY(v, i) (*((volatile uint32_t*)(0x38E00200 + 0x1000 * (v) + 4 * (i))))
117
#define VICVECTPRIORITY(v, i) (*((uint32_t volatile*)(0x38E00200 + 0x1000 * (v) + 4 * (i))))
116
#define VICADDRESS(v)         (*((volatile uint32_t*)(0x38E00F00 + 0x1000 * (v))))
118
#define VICADDRESS(v)         (*((const void* volatile*)(0x38E00F00 + 0x1000 * (v))))
117
#define VIC0IRQSTATUS         (*((volatile uint32_t*)(0x38E00000)))
119
#define VIC0IRQSTATUS         (*((uint32_t volatile*)(0x38E00000)))
118
#define VIC0FIQSTATUS         (*((volatile uint32_t*)(0x38E00004)))
120
#define VIC0FIQSTATUS         (*((uint32_t volatile*)(0x38E00004)))
119
#define VIC0RAWINTR           (*((volatile uint32_t*)(0x38E00008)))
121
#define VIC0RAWINTR           (*((uint32_t volatile*)(0x38E00008)))
120
#define VIC0INTSELECT         (*((volatile uint32_t*)(0x38E0000C)))
122
#define VIC0INTSELECT         (*((uint32_t volatile*)(0x38E0000C)))
121
#define VIC0INTENABLE         (*((volatile uint32_t*)(0x38E00010)))
123
#define VIC0INTENABLE         (*((uint32_t volatile*)(0x38E00010)))
122
#define VIC0INTENCLEAR        (*((volatile uint32_t*)(0x38E00014)))
124
#define VIC0INTENCLEAR        (*((uint32_t volatile*)(0x38E00014)))
123
#define VIC0SOFTINT           (*((volatile uint32_t*)(0x38E00018)))
125
#define VIC0SOFTINT           (*((uint32_t volatile*)(0x38E00018)))
124
#define VIC0SOFTINTCLEAR      (*((volatile uint32_t*)(0x38E0001C)))
126
#define VIC0SOFTINTCLEAR      (*((uint32_t volatile*)(0x38E0001C)))
125
#define VIC0PROTECTION        (*((volatile uint32_t*)(0x38E00020)))
127
#define VIC0PROTECTION        (*((uint32_t volatile*)(0x38E00020)))
126
#define VIC0SWPRIORITYMASK    (*((volatile uint32_t*)(0x38E00024)))
128
#define VIC0SWPRIORITYMASK    (*((uint32_t volatile*)(0x38E00024)))
127
#define VIC0PRIORITYDAISY     (*((volatile uint32_t*)(0x38E00028)))
129
#define VIC0PRIORITYDAISY     (*((uint32_t volatile*)(0x38E00028)))
128
#define VIC0VECTADDR(i)       (*((volatile uint32_t*)(0x38E00100 + 4 * (i))))
130
#define VIC0VECTADDR(i)       (*((const void* volatile*)(0x38E00100 + 4 * (i))))
129
#define VIC0VECTADDR0         (*((volatile uint32_t*)(0x38E00100)))
131
#define VIC0VECTADDR0         (*((const void* volatile*)(0x38E00100)))
130
#define VIC0VECTADDR1         (*((volatile uint32_t*)(0x38E00104)))
132
#define VIC0VECTADDR1         (*((const void* volatile*)(0x38E00104)))
131
#define VIC0VECTADDR2         (*((volatile uint32_t*)(0x38E00108)))
133
#define VIC0VECTADDR2         (*((const void* volatile*)(0x38E00108)))
132
#define VIC0VECTADDR3         (*((volatile uint32_t*)(0x38E0010C)))
134
#define VIC0VECTADDR3         (*((const void* volatile*)(0x38E0010C)))
133
#define VIC0VECTADDR4         (*((volatile uint32_t*)(0x38E00110)))
135
#define VIC0VECTADDR4         (*((const void* volatile*)(0x38E00110)))
134
#define VIC0VECTADDR5         (*((volatile uint32_t*)(0x38E00114)))
136
#define VIC0VECTADDR5         (*((const void* volatile*)(0x38E00114)))
135
#define VIC0VECTADDR6         (*((volatile uint32_t*)(0x38E00118)))
137
#define VIC0VECTADDR6         (*((const void* volatile*)(0x38E00118)))
136
#define VIC0VECTADDR7         (*((volatile uint32_t*)(0x38E0011C)))
138
#define VIC0VECTADDR7         (*((const void* volatile*)(0x38E0011C)))
137
#define VIC0VECTADDR8         (*((volatile uint32_t*)(0x38E00120)))
139
#define VIC0VECTADDR8         (*((const void* volatile*)(0x38E00120)))
138
#define VIC0VECTADDR9         (*((volatile uint32_t*)(0x38E00124)))
140
#define VIC0VECTADDR9         (*((const void* volatile*)(0x38E00124)))
139
#define VIC0VECTADDR10        (*((volatile uint32_t*)(0x38E00128)))
141
#define VIC0VECTADDR10        (*((const void* volatile*)(0x38E00128)))
140
#define VIC0VECTADDR11        (*((volatile uint32_t*)(0x38E0012C)))
142
#define VIC0VECTADDR11        (*((const void* volatile*)(0x38E0012C)))
141
#define VIC0VECTADDR12        (*((volatile uint32_t*)(0x38E00130)))
143
#define VIC0VECTADDR12        (*((const void* volatile*)(0x38E00130)))
142
#define VIC0VECTADDR13        (*((volatile uint32_t*)(0x38E00134)))
144
#define VIC0VECTADDR13        (*((const void* volatile*)(0x38E00134)))
143
#define VIC0VECTADDR14        (*((volatile uint32_t*)(0x38E00138)))
145
#define VIC0VECTADDR14        (*((const void* volatile*)(0x38E00138)))
144
#define VIC0VECTADDR15        (*((volatile uint32_t*)(0x38E0013C)))
146
#define VIC0VECTADDR15        (*((const void* volatile*)(0x38E0013C)))
145
#define VIC0VECTADDR16        (*((volatile uint32_t*)(0x38E00140)))
147
#define VIC0VECTADDR16        (*((const void* volatile*)(0x38E00140)))
146
#define VIC0VECTADDR17        (*((volatile uint32_t*)(0x38E00144)))
148
#define VIC0VECTADDR17        (*((const void* volatile*)(0x38E00144)))
147
#define VIC0VECTADDR18        (*((volatile uint32_t*)(0x38E00148)))
149
#define VIC0VECTADDR18        (*((const void* volatile*)(0x38E00148)))
148
#define VIC0VECTADDR19        (*((volatile uint32_t*)(0x38E0014C)))
150
#define VIC0VECTADDR19        (*((const void* volatile*)(0x38E0014C)))
149
#define VIC0VECTADDR20        (*((volatile uint32_t*)(0x38E00150)))
151
#define VIC0VECTADDR20        (*((const void* volatile*)(0x38E00150)))
150
#define VIC0VECTADDR21        (*((volatile uint32_t*)(0x38E00154)))
152
#define VIC0VECTADDR21        (*((const void* volatile*)(0x38E00154)))
151
#define VIC0VECTADDR22        (*((volatile uint32_t*)(0x38E00158)))
153
#define VIC0VECTADDR22        (*((const void* volatile*)(0x38E00158)))
152
#define VIC0VECTADDR23        (*((volatile uint32_t*)(0x38E0015C)))
154
#define VIC0VECTADDR23        (*((const void* volatile*)(0x38E0015C)))
153
#define VIC0VECTADDR24        (*((volatile uint32_t*)(0x38E00160)))
155
#define VIC0VECTADDR24        (*((const void* volatile*)(0x38E00160)))
154
#define VIC0VECTADDR25        (*((volatile uint32_t*)(0x38E00164)))
156
#define VIC0VECTADDR25        (*((const void* volatile*)(0x38E00164)))
155
#define VIC0VECTADDR26        (*((volatile uint32_t*)(0x38E00168)))
157
#define VIC0VECTADDR26        (*((const void* volatile*)(0x38E00168)))
156
#define VIC0VECTADDR27        (*((volatile uint32_t*)(0x38E0016C)))
158
#define VIC0VECTADDR27        (*((const void* volatile*)(0x38E0016C)))
157
#define VIC0VECTADDR28        (*((volatile uint32_t*)(0x38E00170)))
159
#define VIC0VECTADDR28        (*((const void* volatile*)(0x38E00170)))
158
#define VIC0VECTADDR29        (*((volatile uint32_t*)(0x38E00174)))
160
#define VIC0VECTADDR29        (*((const void* volatile*)(0x38E00174)))
159
#define VIC0VECTADDR30        (*((volatile uint32_t*)(0x38E00178)))
161
#define VIC0VECTADDR30        (*((const void* volatile*)(0x38E00178)))
160
#define VIC0VECTADDR31        (*((volatile uint32_t*)(0x38E0017C)))
162
#define VIC0VECTADDR31        (*((const void* volatile*)(0x38E0017C)))
161
#define VIC0VECTPRIORITY(i)   (*((volatile uint32_t*)(0x38E00200 + 4 * (i))))
163
#define VIC0VECTPRIORITY(i)   (*((uint32_t volatile*)(0x38E00200 + 4 * (i))))
162
#define VIC0VECTPRIORITY0     (*((volatile uint32_t*)(0x38E00200)))
164
#define VIC0VECTPRIORITY0     (*((uint32_t volatile*)(0x38E00200)))
163
#define VIC0VECTPRIORITY1     (*((volatile uint32_t*)(0x38E00204)))
165
#define VIC0VECTPRIORITY1     (*((uint32_t volatile*)(0x38E00204)))
164
#define VIC0VECTPRIORITY2     (*((volatile uint32_t*)(0x38E00208)))
166
#define VIC0VECTPRIORITY2     (*((uint32_t volatile*)(0x38E00208)))
165
#define VIC0VECTPRIORITY3     (*((volatile uint32_t*)(0x38E0020C)))
167
#define VIC0VECTPRIORITY3     (*((uint32_t volatile*)(0x38E0020C)))
166
#define VIC0VECTPRIORITY4     (*((volatile uint32_t*)(0x38E00210)))
168
#define VIC0VECTPRIORITY4     (*((uint32_t volatile*)(0x38E00210)))
167
#define VIC0VECTPRIORITY5     (*((volatile uint32_t*)(0x38E00214)))
169
#define VIC0VECTPRIORITY5     (*((uint32_t volatile*)(0x38E00214)))
168
#define VIC0VECTPRIORITY6     (*((volatile uint32_t*)(0x38E00218)))
170
#define VIC0VECTPRIORITY6     (*((uint32_t volatile*)(0x38E00218)))
169
#define VIC0VECTPRIORITY7     (*((volatile uint32_t*)(0x38E0021C)))
171
#define VIC0VECTPRIORITY7     (*((uint32_t volatile*)(0x38E0021C)))
170
#define VIC0VECTPRIORITY8     (*((volatile uint32_t*)(0x38E00220)))
172
#define VIC0VECTPRIORITY8     (*((uint32_t volatile*)(0x38E00220)))
171
#define VIC0VECTPRIORITY9     (*((volatile uint32_t*)(0x38E00224)))
173
#define VIC0VECTPRIORITY9     (*((uint32_t volatile*)(0x38E00224)))
172
#define VIC0VECTPRIORITY10    (*((volatile uint32_t*)(0x38E00228)))
174
#define VIC0VECTPRIORITY10    (*((uint32_t volatile*)(0x38E00228)))
173
#define VIC0VECTPRIORITY11    (*((volatile uint32_t*)(0x38E0022C)))
175
#define VIC0VECTPRIORITY11    (*((uint32_t volatile*)(0x38E0022C)))
174
#define VIC0VECTPRIORITY12    (*((volatile uint32_t*)(0x38E00230)))
176
#define VIC0VECTPRIORITY12    (*((uint32_t volatile*)(0x38E00230)))
175
#define VIC0VECTPRIORITY13    (*((volatile uint32_t*)(0x38E00234)))
177
#define VIC0VECTPRIORITY13    (*((uint32_t volatile*)(0x38E00234)))
176
#define VIC0VECTPRIORITY14    (*((volatile uint32_t*)(0x38E00238)))
178
#define VIC0VECTPRIORITY14    (*((uint32_t volatile*)(0x38E00238)))
177
#define VIC0VECTPRIORITY15    (*((volatile uint32_t*)(0x38E0023C)))
179
#define VIC0VECTPRIORITY15    (*((uint32_t volatile*)(0x38E0023C)))
178
#define VIC0VECTPRIORITY16    (*((volatile uint32_t*)(0x38E00240)))
180
#define VIC0VECTPRIORITY16    (*((uint32_t volatile*)(0x38E00240)))
179
#define VIC0VECTPRIORITY17    (*((volatile uint32_t*)(0x38E00244)))
181
#define VIC0VECTPRIORITY17    (*((uint32_t volatile*)(0x38E00244)))
180
#define VIC0VECTPRIORITY18    (*((volatile uint32_t*)(0x38E00248)))
182
#define VIC0VECTPRIORITY18    (*((uint32_t volatile*)(0x38E00248)))
181
#define VIC0VECTPRIORITY19    (*((volatile uint32_t*)(0x38E0024C)))
183
#define VIC0VECTPRIORITY19    (*((uint32_t volatile*)(0x38E0024C)))
182
#define VIC0VECTPRIORITY20    (*((volatile uint32_t*)(0x38E00250)))
184
#define VIC0VECTPRIORITY20    (*((uint32_t volatile*)(0x38E00250)))
183
#define VIC0VECTPRIORITY21    (*((volatile uint32_t*)(0x38E00254)))
185
#define VIC0VECTPRIORITY21    (*((uint32_t volatile*)(0x38E00254)))
184
#define VIC0VECTPRIORITY22    (*((volatile uint32_t*)(0x38E00258)))
186
#define VIC0VECTPRIORITY22    (*((uint32_t volatile*)(0x38E00258)))
185
#define VIC0VECTPRIORITY23    (*((volatile uint32_t*)(0x38E0025C)))
187
#define VIC0VECTPRIORITY23    (*((uint32_t volatile*)(0x38E0025C)))
186
#define VIC0VECTPRIORITY24    (*((volatile uint32_t*)(0x38E00260)))
188
#define VIC0VECTPRIORITY24    (*((uint32_t volatile*)(0x38E00260)))
187
#define VIC0VECTPRIORITY25    (*((volatile uint32_t*)(0x38E00264)))
189
#define VIC0VECTPRIORITY25    (*((uint32_t volatile*)(0x38E00264)))
188
#define VIC0VECTPRIORITY26    (*((volatile uint32_t*)(0x38E00268)))
190
#define VIC0VECTPRIORITY26    (*((uint32_t volatile*)(0x38E00268)))
189
#define VIC0VECTPRIORITY27    (*((volatile uint32_t*)(0x38E0026C)))
191
#define VIC0VECTPRIORITY27    (*((uint32_t volatile*)(0x38E0026C)))
190
#define VIC0VECTPRIORITY28    (*((volatile uint32_t*)(0x38E00270)))
192
#define VIC0VECTPRIORITY28    (*((uint32_t volatile*)(0x38E00270)))
191
#define VIC0VECTPRIORITY29    (*((volatile uint32_t*)(0x38E00274)))
193
#define VIC0VECTPRIORITY29    (*((uint32_t volatile*)(0x38E00274)))
192
#define VIC0VECTPRIORITY30    (*((volatile uint32_t*)(0x38E00278)))
194
#define VIC0VECTPRIORITY30    (*((uint32_t volatile*)(0x38E00278)))
193
#define VIC0VECTPRIORITY31    (*((volatile uint32_t*)(0x38E0027C)))
195
#define VIC0VECTPRIORITY31    (*((uint32_t volatile*)(0x38E0027C)))
194
#define VIC0ADDRESS           (*((volatile uint32_t*)(0x38E00F00)))
196
#define VIC0ADDRESS           (*((void* volatile*)(0x38E00F00)))
195
#define VIC1IRQSTATUS         (*((volatile uint32_t*)(0x38E01000)))
197
#define VIC1IRQSTATUS         (*((uint32_t volatile*)(0x38E01000)))
196
#define VIC1FIQSTATUS         (*((volatile uint32_t*)(0x38E01004)))
198
#define VIC1FIQSTATUS         (*((uint32_t volatile*)(0x38E01004)))
197
#define VIC1RAWINTR           (*((volatile uint32_t*)(0x38E01008)))
199
#define VIC1RAWINTR           (*((uint32_t volatile*)(0x38E01008)))
198
#define VIC1INTSELECT         (*((volatile uint32_t*)(0x38E0100C)))
200
#define VIC1INTSELECT         (*((uint32_t volatile*)(0x38E0100C)))
199
#define VIC1INTENABLE         (*((volatile uint32_t*)(0x38E01010)))
201
#define VIC1INTENABLE         (*((uint32_t volatile*)(0x38E01010)))
200
#define VIC1INTENCLEAR        (*((volatile uint32_t*)(0x38E01014)))
202
#define VIC1INTENCLEAR        (*((uint32_t volatile*)(0x38E01014)))
201
#define VIC1SOFTINT           (*((volatile uint32_t*)(0x38E01018)))
203
#define VIC1SOFTINT           (*((uint32_t volatile*)(0x38E01018)))
202
#define VIC1SOFTINTCLEAR      (*((volatile uint32_t*)(0x38E0101C)))
204
#define VIC1SOFTINTCLEAR      (*((uint32_t volatile*)(0x38E0101C)))
203
#define VIC1PROTECTION        (*((volatile uint32_t*)(0x38E01020)))
205
#define VIC1PROTECTION        (*((uint32_t volatile*)(0x38E01020)))
204
#define VIC1SWPRIORITYMASK    (*((volatile uint32_t*)(0x38E01024)))
206
#define VIC1SWPRIORITYMASK    (*((uint32_t volatile*)(0x38E01024)))
205
#define VIC1PRIORITYDAISY     (*((volatile uint32_t*)(0x38E01028)))
207
#define VIC1PRIORITYDAISY     (*((uint32_t volatile*)(0x38E01028)))
206
#define VIC1VECTADDR(i)       (*((volatile uint32_t*)(0x38E01100 + 4 * (i))))
208
#define VIC1VECTADDR(i)       (*((const void* volatile*)(0x38E01100 + 4 * (i))))
207
#define VIC1VECTADDR0         (*((volatile uint32_t*)(0x38E01100)))
209
#define VIC1VECTADDR0         (*((const void* volatile*)(0x38E01100)))
208
#define VIC1VECTADDR1         (*((volatile uint32_t*)(0x38E01104)))
210
#define VIC1VECTADDR1         (*((const void* volatile*)(0x38E01104)))
209
#define VIC1VECTADDR2         (*((volatile uint32_t*)(0x38E01108)))
211
#define VIC1VECTADDR2         (*((const void* volatile*)(0x38E01108)))
210
#define VIC1VECTADDR3         (*((volatile uint32_t*)(0x38E0110C)))
212
#define VIC1VECTADDR3         (*((const void* volatile*)(0x38E0110C)))
211
#define VIC1VECTADDR4         (*((volatile uint32_t*)(0x38E01110)))
213
#define VIC1VECTADDR4         (*((const void* volatile*)(0x38E01110)))
212
#define VIC1VECTADDR5         (*((volatile uint32_t*)(0x38E01114)))
214
#define VIC1VECTADDR5         (*((const void* volatile*)(0x38E01114)))
213
#define VIC1VECTADDR6         (*((volatile uint32_t*)(0x38E01118)))
215
#define VIC1VECTADDR6         (*((const void* volatile*)(0x38E01118)))
214
#define VIC1VECTADDR7         (*((volatile uint32_t*)(0x38E0111C)))
216
#define VIC1VECTADDR7         (*((const void* volatile*)(0x38E0111C)))
215
#define VIC1VECTADDR8         (*((volatile uint32_t*)(0x38E01120)))
217
#define VIC1VECTADDR8         (*((const void* volatile*)(0x38E01120)))
216
#define VIC1VECTADDR9         (*((volatile uint32_t*)(0x38E01124)))
218
#define VIC1VECTADDR9         (*((const void* volatile*)(0x38E01124)))
217
#define VIC1VECTADDR10        (*((volatile uint32_t*)(0x38E01128)))
219
#define VIC1VECTADDR10        (*((const void* volatile*)(0x38E01128)))
218
#define VIC1VECTADDR11        (*((volatile uint32_t*)(0x38E0112C)))
220
#define VIC1VECTADDR11        (*((const void* volatile*)(0x38E0112C)))
219
#define VIC1VECTADDR12        (*((volatile uint32_t*)(0x38E01130)))
221
#define VIC1VECTADDR12        (*((const void* volatile*)(0x38E01130)))
220
#define VIC1VECTADDR13        (*((volatile uint32_t*)(0x38E01134)))
222
#define VIC1VECTADDR13        (*((const void* volatile*)(0x38E01134)))
221
#define VIC1VECTADDR14        (*((volatile uint32_t*)(0x38E01138)))
223
#define VIC1VECTADDR14        (*((const void* volatile*)(0x38E01138)))
222
#define VIC1VECTADDR15        (*((volatile uint32_t*)(0x38E0113C)))
224
#define VIC1VECTADDR15        (*((const void* volatile*)(0x38E0113C)))
223
#define VIC1VECTADDR16        (*((volatile uint32_t*)(0x38E01140)))
225
#define VIC1VECTADDR16        (*((const void* volatile*)(0x38E01140)))
224
#define VIC1VECTADDR17        (*((volatile uint32_t*)(0x38E01144)))
226
#define VIC1VECTADDR17        (*((const void* volatile*)(0x38E01144)))
225
#define VIC1VECTADDR18        (*((volatile uint32_t*)(0x38E01148)))
227
#define VIC1VECTADDR18        (*((const void* volatile*)(0x38E01148)))
226
#define VIC1VECTADDR19        (*((volatile uint32_t*)(0x38E0114C)))
228
#define VIC1VECTADDR19        (*((const void* volatile*)(0x38E0114C)))
227
#define VIC1VECTADDR20        (*((volatile uint32_t*)(0x38E01150)))
229
#define VIC1VECTADDR20        (*((const void* volatile*)(0x38E01150)))
228
#define VIC1VECTADDR21        (*((volatile uint32_t*)(0x38E01154)))
230
#define VIC1VECTADDR21        (*((const void* volatile*)(0x38E01154)))
229
#define VIC1VECTADDR22        (*((volatile uint32_t*)(0x38E01158)))
231
#define VIC1VECTADDR22        (*((const void* volatile*)(0x38E01158)))
230
#define VIC1VECTADDR23        (*((volatile uint32_t*)(0x38E0115C)))
232
#define VIC1VECTADDR23        (*((const void* volatile*)(0x38E0115C)))
231
#define VIC1VECTADDR24        (*((volatile uint32_t*)(0x38E01160)))
233
#define VIC1VECTADDR24        (*((const void* volatile*)(0x38E01160)))
232
#define VIC1VECTADDR25        (*((volatile uint32_t*)(0x38E01164)))
234
#define VIC1VECTADDR25        (*((const void* volatile*)(0x38E01164)))
233
#define VIC1VECTADDR26        (*((volatile uint32_t*)(0x38E01168)))
235
#define VIC1VECTADDR26        (*((const void* volatile*)(0x38E01168)))
234
#define VIC1VECTADDR27        (*((volatile uint32_t*)(0x38E0116C)))
236
#define VIC1VECTADDR27        (*((const void* volatile*)(0x38E0116C)))
235
#define VIC1VECTADDR28        (*((volatile uint32_t*)(0x38E01170)))
237
#define VIC1VECTADDR28        (*((const void* volatile*)(0x38E01170)))
236
#define VIC1VECTADDR29        (*((volatile uint32_t*)(0x38E01174)))
238
#define VIC1VECTADDR29        (*((const void* volatile*)(0x38E01174)))
237
#define VIC1VECTADDR30        (*((volatile uint32_t*)(0x38E01178)))
239
#define VIC1VECTADDR30        (*((const void* volatile*)(0x38E01178)))
238
#define VIC1VECTADDR31        (*((volatile uint32_t*)(0x38E0117C)))
240
#define VIC1VECTADDR31        (*((const void* volatile*)(0x38E0117C)))
239
#define VIC1VECTPRIORITY(i)   (*((volatile uint32_t*)(0x38E01200 + 4 * (i))))
241
#define VIC1VECTPRIORITY(i)   (*((uint32_t volatile*)(0x38E01200 + 4 * (i))))
240
#define VIC1VECTPRIORITY0     (*((volatile uint32_t*)(0x38E01200)))
242
#define VIC1VECTPRIORITY0     (*((uint32_t volatile*)(0x38E01200)))
241
#define VIC1VECTPRIORITY1     (*((volatile uint32_t*)(0x38E01204)))
243
#define VIC1VECTPRIORITY1     (*((uint32_t volatile*)(0x38E01204)))
242
#define VIC1VECTPRIORITY2     (*((volatile uint32_t*)(0x38E01208)))
244
#define VIC1VECTPRIORITY2     (*((uint32_t volatile*)(0x38E01208)))
243
#define VIC1VECTPRIORITY3     (*((volatile uint32_t*)(0x38E0120C)))
245
#define VIC1VECTPRIORITY3     (*((uint32_t volatile*)(0x38E0120C)))
244
#define VIC1VECTPRIORITY4     (*((volatile uint32_t*)(0x38E01210)))
246
#define VIC1VECTPRIORITY4     (*((uint32_t volatile*)(0x38E01210)))
245
#define VIC1VECTPRIORITY5     (*((volatile uint32_t*)(0x38E01214)))
247
#define VIC1VECTPRIORITY5     (*((uint32_t volatile*)(0x38E01214)))
246
#define VIC1VECTPRIORITY6     (*((volatile uint32_t*)(0x38E01218)))
248
#define VIC1VECTPRIORITY6     (*((uint32_t volatile*)(0x38E01218)))
247
#define VIC1VECTPRIORITY7     (*((volatile uint32_t*)(0x38E0121C)))
249
#define VIC1VECTPRIORITY7     (*((uint32_t volatile*)(0x38E0121C)))
248
#define VIC1VECTPRIORITY8     (*((volatile uint32_t*)(0x38E01220)))
250
#define VIC1VECTPRIORITY8     (*((uint32_t volatile*)(0x38E01220)))
249
#define VIC1VECTPRIORITY9     (*((volatile uint32_t*)(0x38E01224)))
251
#define VIC1VECTPRIORITY9     (*((uint32_t volatile*)(0x38E01224)))
250
#define VIC1VECTPRIORITY10    (*((volatile uint32_t*)(0x38E01228)))
252
#define VIC1VECTPRIORITY10    (*((uint32_t volatile*)(0x38E01228)))
251
#define VIC1VECTPRIORITY11    (*((volatile uint32_t*)(0x38E0122C)))
253
#define VIC1VECTPRIORITY11    (*((uint32_t volatile*)(0x38E0122C)))
252
#define VIC1VECTPRIORITY12    (*((volatile uint32_t*)(0x38E01230)))
254
#define VIC1VECTPRIORITY12    (*((uint32_t volatile*)(0x38E01230)))
253
#define VIC1VECTPRIORITY13    (*((volatile uint32_t*)(0x38E01234)))
255
#define VIC1VECTPRIORITY13    (*((uint32_t volatile*)(0x38E01234)))
254
#define VIC1VECTPRIORITY14    (*((volatile uint32_t*)(0x38E01238)))
256
#define VIC1VECTPRIORITY14    (*((uint32_t volatile*)(0x38E01238)))
255
#define VIC1VECTPRIORITY15    (*((volatile uint32_t*)(0x38E0123C)))
257
#define VIC1VECTPRIORITY15    (*((uint32_t volatile*)(0x38E0123C)))
256
#define VIC1VECTPRIORITY16    (*((volatile uint32_t*)(0x38E01240)))
258
#define VIC1VECTPRIORITY16    (*((uint32_t volatile*)(0x38E01240)))
257
#define VIC1VECTPRIORITY17    (*((volatile uint32_t*)(0x38E01244)))
259
#define VIC1VECTPRIORITY17    (*((uint32_t volatile*)(0x38E01244)))
258
#define VIC1VECTPRIORITY18    (*((volatile uint32_t*)(0x38E01248)))
260
#define VIC1VECTPRIORITY18    (*((uint32_t volatile*)(0x38E01248)))
259
#define VIC1VECTPRIORITY19    (*((volatile uint32_t*)(0x38E0124C)))
261
#define VIC1VECTPRIORITY19    (*((uint32_t volatile*)(0x38E0124C)))
260
#define VIC1VECTPRIORITY20    (*((volatile uint32_t*)(0x38E01250)))
262
#define VIC1VECTPRIORITY20    (*((uint32_t volatile*)(0x38E01250)))
261
#define VIC1VECTPRIORITY21    (*((volatile uint32_t*)(0x38E01254)))
263
#define VIC1VECTPRIORITY21    (*((uint32_t volatile*)(0x38E01254)))
262
#define VIC1VECTPRIORITY22    (*((volatile uint32_t*)(0x38E01258)))
264
#define VIC1VECTPRIORITY22    (*((uint32_t volatile*)(0x38E01258)))
263
#define VIC1VECTPRIORITY23    (*((volatile uint32_t*)(0x38E0125C)))
265
#define VIC1VECTPRIORITY23    (*((uint32_t volatile*)(0x38E0125C)))
264
#define VIC1VECTPRIORITY24    (*((volatile uint32_t*)(0x38E01260)))
266
#define VIC1VECTPRIORITY24    (*((uint32_t volatile*)(0x38E01260)))
265
#define VIC1VECTPRIORITY25    (*((volatile uint32_t*)(0x38E01264)))
267
#define VIC1VECTPRIORITY25    (*((uint32_t volatile*)(0x38E01264)))
266
#define VIC1VECTPRIORITY26    (*((volatile uint32_t*)(0x38E01268)))
268
#define VIC1VECTPRIORITY26    (*((uint32_t volatile*)(0x38E01268)))
267
#define VIC1VECTPRIORITY27    (*((volatile uint32_t*)(0x38E0126C)))
269
#define VIC1VECTPRIORITY27    (*((uint32_t volatile*)(0x38E0126C)))
268
#define VIC1VECTPRIORITY28    (*((volatile uint32_t*)(0x38E01270)))
270
#define VIC1VECTPRIORITY28    (*((uint32_t volatile*)(0x38E01270)))
269
#define VIC1VECTPRIORITY29    (*((volatile uint32_t*)(0x38E01274)))
271
#define VIC1VECTPRIORITY29    (*((uint32_t volatile*)(0x38E01274)))
270
#define VIC1VECTPRIORITY30    (*((volatile uint32_t*)(0x38E01278)))
272
#define VIC1VECTPRIORITY30    (*((uint32_t volatile*)(0x38E01278)))
271
#define VIC1VECTPRIORITY31    (*((volatile uint32_t*)(0x38E0127C)))
273
#define VIC1VECTPRIORITY31    (*((uint32_t volatile*)(0x38E0127C)))
272
#define VIC1ADDRESS           (*((volatile uint32_t*)(0x38E01F00)))
274
#define VIC1ADDRESS           (*((void* volatile*)(0x38E01F00)))
-
 
275
 
-
 
276
 
-
 
277
/////GPIO/////
-
 
278
#define PCON(i)       (*((uint32_t volatile*)(0x3cf00000 + ((i) << 5))))
-
 
279
#define PDAT(i)       (*((uint32_t volatile*)(0x3cf00004 + ((i) << 5))))
-
 
280
#define PCON0         (*((uint32_t volatile*)(0x3cf00000)))
-
 
281
#define PDAT0         (*((uint32_t volatile*)(0x3cf00004)))
-
 
282
#define PCON1         (*((uint32_t volatile*)(0x3cf00020)))
-
 
283
#define PDAT1         (*((uint32_t volatile*)(0x3cf00024)))
-
 
284
#define PCON2         (*((uint32_t volatile*)(0x3cf00040)))
-
 
285
#define PDAT2         (*((uint32_t volatile*)(0x3cf00044)))
-
 
286
#define PCON3         (*((uint32_t volatile*)(0x3cf00060)))
-
 
287
#define PDAT3         (*((uint32_t volatile*)(0x3cf00064)))
-
 
288
#define PCON4         (*((uint32_t volatile*)(0x3cf00080)))
-
 
289
#define PDAT4         (*((uint32_t volatile*)(0x3cf00084)))
-
 
290
#define PCON5         (*((uint32_t volatile*)(0x3cf000a0)))
-
 
291
#define PDAT5         (*((uint32_t volatile*)(0x3cf000a4)))
-
 
292
#define PCON6         (*((uint32_t volatile*)(0x3cf000c0)))
-
 
293
#define PDAT6         (*((uint32_t volatile*)(0x3cf000c4)))
-
 
294
#define PCON7         (*((uint32_t volatile*)(0x3cf000e0)))
-
 
295
#define PDAT7         (*((uint32_t volatile*)(0x3cf000e4)))
-
 
296
#define PCON8         (*((uint32_t volatile*)(0x3cf00100)))
-
 
297
#define PDAT8         (*((uint32_t volatile*)(0x3cf00104)))
-
 
298
#define PCON9         (*((uint32_t volatile*)(0x3cf00120)))
-
 
299
#define PDAT9         (*((uint32_t volatile*)(0x3cf00124)))
-
 
300
#define PCONA         (*((uint32_t volatile*)(0x3cf00140)))
-
 
301
#define PDATA         (*((uint32_t volatile*)(0x3cf00144)))
-
 
302
#define PCONB         (*((uint32_t volatile*)(0x3cf00160)))
-
 
303
#define PDATB         (*((uint32_t volatile*)(0x3cf00164)))
-
 
304
#define PCONC         (*((uint32_t volatile*)(0x3cf00180)))
-
 
305
#define PDATC         (*((uint32_t volatile*)(0x3cf00184)))
-
 
306
#define PCOND         (*((uint32_t volatile*)(0x3cf001a0)))
-
 
307
#define PDATD         (*((uint32_t volatile*)(0x3cf001a4)))
-
 
308
#define PCONE         (*((uint32_t volatile*)(0x3cf001c0)))
-
 
309
#define PDATE         (*((uint32_t volatile*)(0x3cf001c4)))
-
 
310
#define PCONF         (*((uint32_t volatile*)(0x3cf001e0)))
-
 
311
#define PDATF         (*((uint32_t volatile*)(0x3cf001e4)))
-
 
312
#define GPIOCMD       (*((uint32_t volatile*)(0x3cf00200)))
-
 
313
 
-
 
314
 
-
 
315
/////SPI/////
-
 
316
#define SPIBASE(i)      ((i) == 2 ? 0x3d200000 : \
-
 
317
                         (i) == 1 ? 0x3ce00000 : \
-
 
318
                                    0x3c300000)
-
 
319
#define SPICLKGATE(i)   ((i) == 2 ? 0x2f : \
-
 
320
                         (i) == 1 ? 0x2b : \
-
 
321
                                    0x22)
-
 
322
#define SPICTRL(i)    (*((uint32_t volatile*)(SPIBASE(i))))
-
 
323
#define SPISETUP(i)   (*((uint32_t volatile*)(SPIBASE(i) + 0x4)))
-
 
324
#define SPISTATUS(i)  (*((uint32_t volatile*)(SPIBASE(i) + 0x8)))
-
 
325
#define SPIUNKREG1(i) (*((uint32_t volatile*)(SPIBASE(i) + 0xc)))
-
 
326
#define SPITXDATA(i)  (*((uint32_t volatile*)(SPIBASE(i) + 0x10)))
-
 
327
#define SPIRXDATA(i)  (*((uint32_t volatile*)(SPIBASE(i) + 0x20)))
-
 
328
#define SPICLKDIV(i)  (*((uint32_t volatile*)(SPIBASE(i) + 0x30)))
-
 
329
#define SPIRXLIMIT(i) (*((uint32_t volatile*)(SPIBASE(i) + 0x34)))
-
 
330
#define SPIUNKREG3(i) (*((uint32_t volatile*)(SPIBASE(i) + 0x38)))
-
 
331
 
-
 
332
 
-
 
333
/////AES/////
-
 
334
#define AESCONTROL    (*((uint32_t volatile*)(0x38c00000)))
-
 
335
#define AESGO         (*((uint32_t volatile*)(0x38c00004)))
-
 
336
#define AESUNKREG0    (*((uint32_t volatile*)(0x38c00008)))
-
 
337
#define AESSTATUS     (*((uint32_t volatile*)(0x38c0000c)))
-
 
338
#define AESUNKREG1    (*((uint32_t volatile*)(0x38c00010)))
-
 
339
#define AESKEYLEN     (*((uint32_t volatile*)(0x38c00014)))
-
 
340
#define AESOUTSIZE    (*((uint32_t volatile*)(0x38c00018)))
-
 
341
#define AESOUTADDR    (*((void* volatile*)(0x38c00020)))
-
 
342
#define AESINSIZE     (*((uint32_t volatile*)(0x38c00024)))
-
 
343
#define AESINADDR     (*((const void* volatile*)(0x38c00028)))
-
 
344
#define AESAUXSIZE    (*((uint32_t volatile*)(0x38c0002c)))
-
 
345
#define AESAUXADDR    (*((void* volatile*)(0x38c00030)))
-
 
346
#define AESSIZE3      (*((uint32_t volatile*)(0x38c00034)))
-
 
347
#define AESKEY          ((uint32_t volatile*)(0x38c0004c))
-
 
348
#define AESTYPE       (*((uint32_t volatile*)(0x38c0006c)))
-
 
349
#define AESIV           ((uint32_t volatile*)(0x38c00074))
-
 
350
#define AESTYPE2      (*((uint32_t volatile*)(0x38c00088)))
-
 
351
#define AESUNKREG2    (*((uint32_t volatile*)(0x38c0008c)))
-
 
352
 
-
 
353
 
-
 
354
/////SHA1/////
-
 
355
#define SHA1CONFIG    (*((uint32_t volatile*)(0x38000000)))
-
 
356
#define SHA1RESET     (*((uint32_t volatile*)(0x38000004)))
-
 
357
#define SHA1RESULT      ((uint32_t volatile*)(0x38000020))
-
 
358
#define SHA1DATAIN      ((uint32_t volatile*)(0x38000040))
-
 
359
 
-
 
360
 
-
 
361
/////DMA/////
-
 
362
#define DMACINTSTS(d)       (*((uint32_t volatile*)(0x38200000 + 0x1700000 * (d))))
-
 
363
#define DMACINTTCSTS(d)     (*((uint32_t volatile*)(0x38200004 + 0x1700000 * (d))))
-
 
364
#define DMACINTTCCLR(d)     (*((uint32_t volatile*)(0x38200008 + 0x1700000 * (d))))
-
 
365
#define DMACINTERRSTS(d)    (*((uint32_t volatile*)(0x3820000c + 0x1700000 * (d))))
-
 
366
#define DMACINTERRCLR(d)    (*((uint32_t volatile*)(0x38200010 + 0x1700000 * (d))))
-
 
367
#define DMACRAWINTTCSTS(d)  (*((uint32_t volatile*)(0x38200014 + 0x1700000 * (d))))
-
 
368
#define DMACRAWINTERRSTS(d) (*((uint32_t volatile*)(0x38200018 + 0x1700000 * (d))))
-
 
369
#define DMACENABLEDCHANS(d) (*((uint32_t volatile*)(0x3820001c + 0x1700000 * (d))))
-
 
370
#define DMACSOFTBREQ(d)     (*((uint32_t volatile*)(0x38200020 + 0x1700000 * (d))))
-
 
371
#define DMACSOFTSREQ(d)     (*((uint32_t volatile*)(0x38200024 + 0x1700000 * (d))))
-
 
372
#define DMACSOFTLBREQ(d)    (*((uint32_t volatile*)(0x38200028 + 0x1700000 * (d))))
-
 
373
#define DMACSOFTLSREQ(d)    (*((uint32_t volatile*)(0x3820002c + 0x1700000 * (d))))
-
 
374
#define DMACCONFIG(d)       (*((uint32_t volatile*)(0x38200030 + 0x1700000 * (d))))
-
 
375
#define DMACSYNC(d)         (*((uint32_t volatile*)(0x38200034 + 0x1700000 * (d))))
-
 
376
#define DMACCSRCADDR(d, c)  (*((const void* volatile*)(0x38200100 + 0x1700000 * (d) + 0x20 * (c))))
-
 
377
#define DMACCDESTADDR(d, c) (*((void* volatile*)(0x38200104 + 0x1700000 * (d) + 0x20 * (c))))
-
 
378
#define DMACCLLI(d, c)      (*((const void* volatile*)(0x38200108 + 0x1700000 * (d) + 0x20 * (c))))
-
 
379
#define DMACCCONTROL(d, c)  (*((uint32_t volatile*)(0x3820010c + 0x1700000 * (d) + 0x20 * (c))))
-
 
380
#define DMACCCONFIG(d, c)   (*((uint32_t volatile*)(0x38200110 + 0x1700000 * (d) + 0x20 * (c))))
-
 
381
#define DMAC0INTSTS         (*((uint32_t volatile*)(0x38200000)))
-
 
382
#define DMAC0INTTCSTS       (*((uint32_t volatile*)(0x38200004)))
-
 
383
#define DMAC0INTTCCLR       (*((uint32_t volatile*)(0x38200008)))
-
 
384
#define DMAC0INTERRSTS      (*((uint32_t volatile*)(0x3820000c)))
-
 
385
#define DMAC0INTERRCLR      (*((uint32_t volatile*)(0x38200010)))
-
 
386
#define DMAC0RAWINTTCSTS    (*((uint32_t volatile*)(0x38200014)))
-
 
387
#define DMAC0RAWINTERRSTS   (*((uint32_t volatile*)(0x38200018)))
-
 
388
#define DMAC0ENABLEDCHANS   (*((uint32_t volatile*)(0x3820001c)))
-
 
389
#define DMAC0SOFTBREQ       (*((uint32_t volatile*)(0x38200020)))
-
 
390
#define DMAC0SOFTSREQ       (*((uint32_t volatile*)(0x38200024)))
-
 
391
#define DMAC0SOFTLBREQ      (*((uint32_t volatile*)(0x38200028)))
-
 
392
#define DMAC0SOFTLSREQ      (*((uint32_t volatile*)(0x3820002c)))
-
 
393
#define DMAC0CONFIG         (*((uint32_t volatile*)(0x38200030)))
-
 
394
#define DMAC0SYNC           (*((uint32_t volatile*)(0x38200034)))
-
 
395
#define DMAC0CSRCADDR(c)    (*((const void* volatile*)(0x38200100 + 0x20 * (c))))
-
 
396
#define DMAC0CDESTADDR(c)   (*((void* volatile*)(0x38200104 + 0x20 * (c))))
-
 
397
#define DMAC0CLLI(c)        (*((const void* volatile*)(0x38200108 + 0x20 * (c))))
-
 
398
#define DMAC0CCONTROL(c)    (*((uint32_t volatile*)(0x3820010c + 0x20 * (c))))
-
 
399
#define DMAC0CCONFIG(c)     (*((uint32_t volatile*)(0x38200110 + 0x20 * (c))))
-
 
400
#define DMAC0C0SRCADDR      (*((const void* volatile*)(0x38200100)))
-
 
401
#define DMAC0C0DESTADDR     (*((void* volatile*)(0x38200104)))
-
 
402
#define DMAC0C0LLI          (*((const void* volatile*)(0x38200108)))
-
 
403
#define DMAC0C0CONTROL      (*((uint32_t volatile*)(0x3820010c)))
-
 
404
#define DMAC0C0CONFIG       (*((uint32_t volatile*)(0x38200110)))
-
 
405
#define DMAC0C1SRCADDR      (*((const void* volatile*)(0x38200120)))
-
 
406
#define DMAC0C1DESTADDR     (*((void* volatile*)(0x38200124)))
-
 
407
#define DMAC0C1LLI          (*((const void* volatile*)(0x38200128)))
-
 
408
#define DMAC0C1CONTROL      (*((uint32_t volatile*)(0x3820012c)))
-
 
409
#define DMAC0C1CONFIG       (*((uint32_t volatile*)(0x38200130)))
-
 
410
#define DMAC0C2SRCADDR      (*((const void* volatile*)(0x38200140)))
-
 
411
#define DMAC0C2DESTADDR     (*((void* volatile*)(0x38200144)))
-
 
412
#define DMAC0C2LLI          (*((const void* volatile*)(0x38200148)))
-
 
413
#define DMAC0C2CONTROL      (*((uint32_t volatile*)(0x3820014c)))
-
 
414
#define DMAC0C2CONFIG       (*((uint32_t volatile*)(0x38200150)))
-
 
415
#define DMAC0C3SRCADDR      (*((const void* volatile*)(0x38200160)))
-
 
416
#define DMAC0C3DESTADDR     (*((void* volatile*)(0x38200164)))
-
 
417
#define DMAC0C3LLI          (*((const void* volatile*)(0x38200168)))
-
 
418
#define DMAC0C3CONTROL      (*((uint32_t volatile*)(0x3820016c)))
-
 
419
#define DMAC0C3CONFIG       (*((uint32_t volatile*)(0x38200170)))
-
 
420
#define DMAC0C4SRCADDR      (*((const void* volatile*)(0x38200180)))
-
 
421
#define DMAC0C4DESTADDR     (*((void* volatile*)(0x38200184)))
-
 
422
#define DMAC0C4LLI          (*((const void* volatile*)(0x38200188)))
-
 
423
#define DMAC0C4CONTROL      (*((uint32_t volatile*)(0x3820018c)))
-
 
424
#define DMAC0C4CONFIG       (*((uint32_t volatile*)(0x38200190)))
-
 
425
#define DMAC0C5SRCADDR      (*((const void* volatile*)(0x382001a0)))
-
 
426
#define DMAC0C5DESTADDR     (*((void* volatile*)(0x382001a4)))
-
 
427
#define DMAC0C5LLI          (*((const void* volatile*)(0x382001a8)))
-
 
428
#define DMAC0C5CONTROL      (*((uint32_t volatile*)(0x382001ac)))
-
 
429
#define DMAC0C5CONFIG       (*((uint32_t volatile*)(0x382001b0)))
-
 
430
#define DMAC0C6SRCADDR      (*((const void* volatile*)(0x382001c0)))
-
 
431
#define DMAC0C6DESTADDR     (*((void* volatile*)(0x382001c4)))
-
 
432
#define DMAC0C6LLI          (*((const void* volatile*)(0x382001c8)))
-
 
433
#define DMAC0C6CONTROL      (*((uint32_t volatile*)(0x382001cc)))
-
 
434
#define DMAC0C6CONFIG       (*((uint32_t volatile*)(0x382001d0)))
-
 
435
#define DMAC0C7SRCADDR      (*((const void* volatile*)(0x382001e0)))
-
 
436
#define DMAC0C7DESTADDR     (*((void* volatile*)(0x382001e4)))
-
 
437
#define DMAC0C7LLI          (*((const void* volatile*)(0x382001e8)))
-
 
438
#define DMAC0C7CONTROL      (*((uint32_t volatile*)(0x382001ec)))
-
 
439
#define DMAC0C7CONFIG       (*((uint32_t volatile*)(0x382001f0)))
-
 
440
#define DMAC1INTSTS         (*((uint32_t volatile*)(0x39900000)))
-
 
441
#define DMAC1INTTCSTS       (*((uint32_t volatile*)(0x39900004)))
-
 
442
#define DMAC1INTTCCLR       (*((uint32_t volatile*)(0x39900008)))
-
 
443
#define DMAC1INTERRSTS      (*((uint32_t volatile*)(0x3990000c)))
-
 
444
#define DMAC1INTERRCLR      (*((uint32_t volatile*)(0x39900010)))
-
 
445
#define DMAC1RAWINTTCSTS    (*((uint32_t volatile*)(0x39900014)))
-
 
446
#define DMAC1RAWINTERRSTS   (*((uint32_t volatile*)(0x39900018)))
-
 
447
#define DMAC1ENABLEDCHANS   (*((uint32_t volatile*)(0x3990001c)))
-
 
448
#define DMAC1SOFTBREQ       (*((uint32_t volatile*)(0x39900020)))
-
 
449
#define DMAC1SOFTSREQ       (*((uint32_t volatile*)(0x39900024)))
-
 
450
#define DMAC1SOFTLBREQ      (*((uint32_t volatile*)(0x39900028)))
-
 
451
#define DMAC1SOFTLSREQ      (*((uint32_t volatile*)(0x3990002c)))
-
 
452
#define DMAC1CONFIG         (*((uint32_t volatile*)(0x39900030)))
-
 
453
#define DMAC1SYNC           (*((uint32_t volatile*)(0x39900034)))
-
 
454
#define DMAC1CSRCADDR(c)    (*((const void* volatile*)(0x39900100 + 0x20 * (c))))
-
 
455
#define DMAC1CDESTADDR(c)   (*((void* volatile*)(0x39900104 + 0x20 * (c))))
-
 
456
#define DMAC1CLLI(c)        (*((const void* volatile*)(0x39900108 + 0x20 * (c))))
-
 
457
#define DMAC1CCONTROL(c)    (*((uint32_t volatile*)(0x3990010c + 0x20 * (c))))
-
 
458
#define DMAC1CCONFIG(c)     (*((uint32_t volatile*)(0x39900110 + 0x20 * (c))))
-
 
459
#define DMAC1C0SRCADDR      (*((const void* volatile*)(0x39900100)))
-
 
460
#define DMAC1C0DESTADDR     (*((void* volatile*)(0x39900104)))
-
 
461
#define DMAC1C0LLI          (*((const void* volatile*)(0x39900108)))
-
 
462
#define DMAC1C0CONTROL      (*((uint32_t volatile*)(0x3990010c)))
-
 
463
#define DMAC1C0CONFIG       (*((uint32_t volatile*)(0x39900110)))
-
 
464
#define DMAC1C1SRCADDR      (*((const void* volatile*)(0x39900120)))
-
 
465
#define DMAC1C1DESTADDR     (*((void* volatile*)(0x39900124)))
-
 
466
#define DMAC1C1LLI          (*((const void* volatile*)(0x39900128)))
-
 
467
#define DMAC1C1CONTROL      (*((uint32_t volatile*)(0x3990012c)))
-
 
468
#define DMAC1C1CONFIG       (*((uint32_t volatile*)(0x39900130)))
-
 
469
#define DMAC1C2SRCADDR      (*((const void* volatile*)(0x39900140)))
-
 
470
#define DMAC1C2DESTADDR     (*((void* volatile*)(0x39900144)))
-
 
471
#define DMAC1C2LLI          (*((const void* volatile*)(0x39900148)))
-
 
472
#define DMAC1C2CONTROL      (*((uint32_t volatile*)(0x3990014c)))
-
 
473
#define DMAC1C2CONFIG       (*((uint32_t volatile*)(0x39900150)))
-
 
474
#define DMAC1C3SRCADDR      (*((const void* volatile*)(0x39900160)))
-
 
475
#define DMAC1C3DESTADDR     (*((void* volatile*)(0x39900164)))
-
 
476
#define DMAC1C3LLI          (*((volatile vvoid**)(0x39900168)))
-
 
477
#define DMAC1C3CONTROL      (*((uint32_t volatile*)(0x3990016c)))
-
 
478
#define DMAC1C3CONFIG       (*((uint32_t volatile*)(0x39900170)))
-
 
479
#define DMAC1C4SRCADDR      (*((const void* volatile*)(0x39900180)))
-
 
480
#define DMAC1C4DESTADDR     (*((void* volatile*)(0x39900184)))
-
 
481
#define DMAC1C4LLI          (*((const void* volatile*)(0x39900188)))
-
 
482
#define DMAC1C4CONTROL      (*((uint32_t volatile*)(0x3990018c)))
-
 
483
#define DMAC1C4CONFIG       (*((uint32_t volatile*)(0x39900190)))
-
 
484
#define DMAC1C5SRCADDR      (*((const void* volatile*)(0x399001a0)))
-
 
485
#define DMAC1C5DESTADDR     (*((void* volatile*)(0x399001a4)))
-
 
486
#define DMAC1C5LLI          (*((const void* volatile*)(0x399001a8)))
-
 
487
#define DMAC1C5CONTROL      (*((uint32_t volatile*)(0x399001ac)))
-
 
488
#define DMAC1C5CONFIG       (*((uint32_t volatile*)(0x399001b0)))
-
 
489
#define DMAC1C6SRCADDR      (*((const void* volatile*)(0x399001c0)))
-
 
490
#define DMAC1C6DESTADDR     (*((void* volatile*)(0x399001c4)))
-
 
491
#define DMAC1C6LLI          (*((const void* volatile*)(0x399001c8)))
-
 
492
#define DMAC1C6CONTROL      (*((uint32_t volatile*)(0x399001cc)))
-
 
493
#define DMAC1C6CONFIG       (*((uint32_t volatile*)(0x399001d0)))
-
 
494
#define DMAC1C7SRCADDR      (*((const void* volatile*)(0x399001e0)))
-
 
495
#define DMAC1C7DESTADDR     (*((void* volatile*)(0x399001e4)))
-
 
496
#define DMAC1C7LLI          (*((const void* volatile*)(0x399001e8)))
-
 
497
#define DMAC1C7CONTROL      (*((uint32_t volatile*)(0x399001ec)))
-
 
498
#define DMAC1C7CONFIG       (*((uint32_t volatile*)(0x399001f0)))
-
 
499
 
-
 
500
 
-
 
501
/////LCD/////
-
 
502
#define LCDWCMD   (*((uint32_t volatile*)(0x38300004)))
-
 
503
#define LCDSTATUS (*((uint32_t volatile*)(0x3830001c)))
-
 
504
#define LCDWDATA  (*((uint32_t volatile*)(0x38300040)))
273
 
505
 
274
 
506
 
275
/////CLOCK GATES/////
507
/////CLOCK GATES/////
276
#define CLOCKGATE_USB_1 2
508
#define CLOCKGATE_USB_1 2
277
#define CLOCKGATE_USB_2 35
509
#define CLOCKGATE_USB_2 35
278
 
510
 
279
 
511
 
280
/////INTERRUPTS/////
512
/////INTERRUPTS/////
281
#define IRQ_TIMER 8
513
#define IRQ_TIMER 8
282
#define IRQ_USB_FUNC 19
514
#define IRQ_USB_FUNC 19
-
 
515
#define IRQ_DMAC(d) 16 + d
-
 
516
#define IRQ_DMAC0 16
-
 
517
#define IRQ_DMAC1 17
283
 
518
 
284
 
519
 
285
#endif
520
#endif