D2: Make the nand driver's sanity checks a little more... sane. This should allow...
[kugel-rb.git] / firmware / export / isp1583.h
blob5a5840acc69d56f4a4e159328dd6fd808acb5da5
1 /***************************************************************************
2 * __________ __ ___.
3 * Open \______ \ ____ ____ | | _\_ |__ _______ ___
4 * Source | _// _ \_/ ___\| |/ /| __ \ / _ \ \/ /
5 * Jukebox | | ( <_> ) \___| < | \_\ ( <_> > < <
6 * Firmware |____|_ /\____/ \___ >__|_ \|___ /\____/__/\_ \
7 * \/ \/ \/ \/ \/
8 * $Id$
10 * Copyright (C) 2008 by Maurus Cuelenaere
12 * All files in this archive are subject to the GNU General Public License.
13 * See the file COPYING in the source tree root for full license agreement.
15 * This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY
16 * KIND, either express or implied.
18 ****************************************************************************/
19 #ifndef ISP1583_H
20 #define ISP1583_H
22 #include "usb-target.h"
24 #ifndef ISP1583_H_OVERRIDE
25 /* Initialization registers */
26 #define ISP1583_INIT_ADDRESS (*((volatile unsigned char*)(ISP1583_IOBASE+0x0)))
27 #define ISP1583_INIT_MODE (*((volatile unsigned short*)(ISP1583_IOBASE+0xC)))
28 #define ISP1583_INIT_INTCONF (*((volatile unsigned char*)(ISP1583_IOBASE+0x10)))
29 #define ISP1583_INIT_OTG (*((volatile unsigned char*)(ISP1583_IOBASE+0x12)))
30 #define ISP1583_INIT_INTEN_A (*((volatile unsigned long*)(ISP1583_IOBASE+0x14)))
31 #define ISP1583_INIT_INTEN_B
32 #define ISP1583_INIT_INTEN_READ ISP1583_INIT_INTEN_A
33 /* Data Flow registers */
34 #define ISP1583_DFLOW_EPINDEX (*((volatile unsigned char*)(ISP1583_IOBASE+0xC2)))
35 #define ISP1583_DFLOW_CTRLFUN (*((volatile unsigned char*)(ISP1583_IOBASE+0x28)))
36 #define ISP1583_DFLOW_DATA (*((volatile unsigned short*)(ISP1583_IOBASE+0x20)))
37 #define ISP1583_DFLOW_BUFLEN (*((volatile unsigned short*)(ISP1583_IOBASE+0x1C)))
38 #define ISP1583_DFLOW_BUFSTAT (*((volatile unsigned char*)(ISP1583_IOBASE+0x1E)))
39 #define ISP1583_DFLOW_MAXPKSZ (*((volatile unsigned short*)(ISP1583_IOBASE+0x04)))
40 #define ISP1583_DFLOW_EPTYPE (*((volatile unsigned short*)(ISP1583_IOBASE+0x08)))
41 /* DMA registers */
42 #define ISP1583_DMA_ENDPOINT (*((volatile unsigned char*)(ISP1583_IOBASE+0x58)))
43 /* General registers */
44 #define ISP1583_GEN_INT_A (*((volatile unsigned long*)(ISP1583_IOBASE+0x18)))
45 #define ISP1583_GEN_INT_B
46 #define ISP1583_GEN_INT_READ ISP1583_GEN_INT_A
47 #define ISP1583_GEN_CHIPID (*((volatile unsigned long*)(ISP1583_IOBASE+0x70))) /* Size=3 bytes */
48 #define ISP1583_GEN_FRAMEN0 (*((volatile unsigned short*)(ISP1583_IOBASE+0x74)))
49 #define ISP1583_GEN_SCRATCH (*((volatile unsigned short*)(ISP1583_IOBASE+0x78)))
50 #define ISP1583_GEN_UNLCKDEV (*((volatile unsigned short*)(ISP1583_IOBASE+0x7C)))
51 #define ISP1583_GEN_TSTMOD (*((volatile unsigned char*)(ISP1583_IOBASE+0x84)))
53 #define set_int_value(a,b,value) a = value;
54 #endif
56 #define ISP1583_UNLOCK_CODE (unsigned short)0xAA37
58 /* Initialization registers' bits */
60 /* Initialization OTG register bits */
61 #define INIT_OTG_BSESS_VALID (1 << 4)
63 /* Initialization Mode register bits */
64 #define INIT_MODE_TEST2 (1 << 15)
65 #define INIT_MODE_TEST1 (1 << 14)
66 #define INIT_MODE_TEST0 (1 << 13)
67 #define INIT_MODE_DMA_CLKON (1 << 9)
68 #define INIT_MODE_VBUSSTAT (1 << 8)
69 #define INIT_MODE_CLKAON (1 << 7)
70 #define INIT_MODE_SNDRSU (1 << 6)
71 #define INIT_MODE_GOSUSP (1 << 5)
72 #define INIT_MODE_SFRESET (1 << 4)
73 #define INIT_MODE_GLINTENA (1 << 3)
74 #define INIT_MODE_WKUPCS (1 << 2)
75 #define INIT_MODE_PWRON (1 << 1)
76 #define INIT_MODE_SOFTCT (1 << 0)
78 /* Initialization Interrupt Enable register bits */
79 #define INIT_INTEN_IEP7TX (1 << 25)
80 #define INIT_INTEN_IEP7RX (1 << 24)
81 #define INIT_INTEN_IEP6TX (1 << 23)
82 #define INIT_INTEN_IEP6RX (1 << 22)
83 #define INIT_INTEN_IEP5TX (1 << 21)
84 #define INIT_INTEN_IEP5RX (1 << 20)
85 #define INIT_INTEN_IEP4TX (1 << 19)
86 #define INIT_INTEN_IEP4RX (1 << 18)
87 #define INIT_INTEN_IEP3TX (1 << 17)
88 #define INIT_INTEN_IEP3RX (1 << 16)
89 #define INIT_INTEN_IEP2TX (1 << 15)
90 #define INIT_INTEN_IEP2RX (1 << 14)
91 #define INIT_INTEN_IEP1TX (1 << 13)
92 #define INIT_INTEN_IEP1RX (1 << 12)
93 #define INIT_INTEN_IEP0TX (1 << 11)
94 #define INIT_INTEN_IEP0RX (1 << 10)
95 #define INIT_INTEN_IEP0SETUP (1 << 8)
96 #define INIT_INTEN_IEVBUS (1 << 7)
97 #define INIT_INTEN_IEDMA (1 << 6)
98 #define INIT_INTEN_IEHS_STA (1 << 5)
99 #define INIT_INTEN_IERESM (1 << 4)
100 #define INIT_INTEN_IESUSP (1 << 3)
101 #define INIT_INTEN_IEPSOF (1 << 2)
102 #define INIT_INTEN_IESOF (1 << 1)
103 #define INIT_INTEN_IEBRST (1 << 0)
105 /* Initialization Interrupt Configuration register bits */
106 #define INIT_INTCONF_INTLVL (1 << 1)
107 #define INIT_INTCONF_INTPOL (1 << 0)
109 /* Initialization Address register bits */
110 #define INIT_ADDRESS_DEVEN (1 << 7)
112 /* Data Flow registers' bits */
114 /* Data Flow Endpoint Index register bits */
115 #define DFLOW_EPINDEX_EP0SETUP (1 << 5)
117 /* Data Flow Control Function register bits */
118 #define DFLOW_CTRLFUN_CLBUF (1 << 4)
119 #define DFLOW_CTRLFUN_VENDP (1 << 3)
120 #define DFLOW_CTRLFUN_DSEN (1 << 2)
121 #define DFLOW_CTRLFUN_STATUS (1 << 1)
122 #define DFLOW_CTRLFUN_STALL (1 << 0)
124 /* Data Flow Endpoint Type register bits */
125 #define DFLOW_EPTYPE_NOEMPKT (1 << 4)
126 #define DFLOW_EPTYPE_ENABLE (1 << 3)
127 #define DFLOW_EPTYPE_DBLBUF (1 << 2)
129 /* General registers' bits */
131 /* General Test Mode register bits */
132 #define GEN_TSTMOD_FORCEHS (1 << 7)
133 #define GEN_TSTMOD_FORCEFS (1 << 4)
134 #define GEN_TSTMOD_PRBS (1 << 3)
135 #define GEN_TSTMOD_KSTATE (1 << 2)
136 #define GEN_TSTMOD_JSTATE (1 << 1)
137 #define GEN_TSTMOD_SE0_NAK (1 << 0)
139 /* Interrupts */
140 #define INT_IEP7TX (1 << 25)
141 #define INT_IEP7RX (1 << 24)
142 #define INT_IEP6TX (1 << 23)
143 #define INT_IEP6RX (1 << 22)
144 #define INT_IEP5TX (1 << 21)
145 #define INT_IEP5RX (1 << 20)
146 #define INT_IEP4TX (1 << 19)
147 #define INT_IEP4RX (1 << 18)
148 #define INT_IEP3TX (1 << 17)
149 #define INT_IEP3RX (1 << 16)
150 #define INT_IEP2TX (1 << 15)
151 #define INT_IEP2RX (1 << 14)
152 #define INT_IEP1TX (1 << 13)
153 #define INT_IEP1RX (1 << 12)
154 #define INT_IEP0TX (1 << 11)
155 #define INT_IEP0RX (1 << 10)
156 #define INT_IEP0SETUP (1 << 8)
157 #define INT_IEVBUS (1 << 7)
158 #define INT_IEDMA (1 << 6)
159 #define INT_IEHS_STA (1 << 5)
160 #define INT_IERESM (1 << 4)
161 #define INT_IESUSP (1 << 3)
162 #define INT_IEPSOF (1 << 2)
163 #define INT_IESOF (1 << 1)
164 #define INT_IEBRST (1 << 0)
166 #define INT_EP_MASK ( INT_IEP0RX | INT_IEP0TX | INT_IEP1RX | INT_IEP1TX | INT_IEP2RX | INT_IEP2TX | INT_IEP3RX | INT_IEP3TX | INT_IEP4RX | INT_IEP4TX | INT_IEP5RX | INT_IEP5TX | INT_IEP6RX | INT_IEP6TX | INT_IEP7RX | INT_IEP7TX )
168 #define STANDARD_INTEN ( INIT_INTEN_IEBRST | INIT_INTEN_IEHS_STA | INT_IESUSP | INT_IERESM | INIT_INTEN_IEVBUS | INIT_INTEN_IEP0SETUP | INIT_INTEN_IEP0RX | INIT_INTEN_IEP0TX )
169 #define STANDARD_INIT_MODE ( INIT_MODE_CLKAON | INIT_MODE_GLINTENA )
171 #ifdef USE_IRAM
172 #define IRAM_ATTR __attribute__ ((section(".icode")))
173 #else
174 #define IRAM_ATTR
175 #endif
177 #include "usb_drv.h"
179 #endif