Subversion Repositories freemyipod

Rev

Details | Last modification | View Log | RSS feed

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