]> git.kernelconcepts.de Git - karo-tx-uboot.git/blob - include/asm-arm/arch-ks8695/platform.h
Replace "#include <asm-$ARCH/$FILE>" with "#include <asm/$FILE>"
[karo-tx-uboot.git] / include / asm-arm / arch-ks8695 / platform.h
1 /*
2  * This program is free software; you can redistribute it and/or modify
3  * it under the terms of the GNU General Public License as published by
4  * the Free Software Foundation; either version 2 of the License, or
5  * (at your option) any later version.
6  *
7  * This program is distributed in the hope that it will be useful,
8  * but WITHOUT ANY WARRANTY; without even the implied warranty of
9  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
10  * GNU General Public License for more details.
11  *
12  * You should have received a copy of the GNU General Public License
13  * along with this program; if not, write to the Free Software
14  * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
15  */
16 #ifndef __address_h
17 #define __address_h                     1
18
19 #define KS8695_SDRAM_START          0x00000000
20 #define KS8695_SDRAM_SIZE           0x01000000
21 #define KS8695_MEM_SIZE             KS8695_SDRAM_SIZE
22 #define KS8695_MEM_START            KS8695_SDRAM_START
23
24 #define KS8695_PCMCIA_IO_BASE       0x03800000
25 #define KS8695_PCMCIA_IO_SIZE       0x00040000
26
27 #define KS8695_IO_BASE              0x03FF0000
28 #define KS8695_IO_SIZE              0x00010000
29
30 #define KS8695_SYSTEN_CONFIG        0x00
31 #define KS8695_SYSTEN_BUS_CLOCK     0x04
32
33 #define KS8695_FLASH_START          0x02800000
34 #define KS8695_FLASH_SIZE           0x00400000
35
36 /*i/o control registers offset difinitions*/
37 #define KS8695_IO_CTRL0             0x4000
38 #define KS8695_IO_CTRL1             0x4004
39 #define KS8695_IO_CTRL2             0x4008
40 #define KS8695_IO_CTRL3             0x400C
41
42 /*memory control registers offset difinitions*/
43 #define KS8695_MEM_CTRL0            0x4010
44 #define KS8695_MEM_CTRL1            0x4014
45 #define KS8695_MEM_CTRL2            0x4018
46 #define KS8695_MEM_CTRL3            0x401C
47 #define KS8695_MEM_GENERAL          0x4020
48 #define KS8695_SDRAM_CTRL0          0x4030
49 #define KS8695_SDRAM_CTRL1          0x4034
50 #define KS8695_SDRAM_GENERAL        0x4038
51 #define KS8695_SDRAM_BUFFER         0x403C
52 #define KS8695_SDRAM_REFRESH        0x4040
53
54 /*WAN control registers offset difinitions*/
55 #define KS8695_WAN_DMA_TX           0x6000
56 #define KS8695_WAN_DMA_RX           0x6004
57 #define KS8695_WAN_DMA_TX_START     0x6008
58 #define KS8695_WAN_DMA_RX_START     0x600C
59 #define KS8695_WAN_TX_LIST          0x6010
60 #define KS8695_WAN_RX_LIST          0x6014
61 #define KS8695_WAN_MAC_LOW          0x6018
62 #define KS8695_WAN_MAC_HIGH         0x601C
63 #define KS8695_WAN_MAC_ELOW         0x6080
64 #define KS8695_WAN_MAC_EHIGH        0x6084
65
66 /*LAN control registers offset difinitions*/
67 #define KS8695_LAN_DMA_TX           0x8000
68 #define KS8695_LAN_DMA_RX           0x8004
69 #define KS8695_LAN_DMA_TX_START     0x8008
70 #define KS8695_LAN_DMA_RX_START     0x800C
71 #define KS8695_LAN_TX_LIST          0x8010
72 #define KS8695_LAN_RX_LIST          0x8014
73 #define KS8695_LAN_MAC_LOW          0x8018
74 #define KS8695_LAN_MAC_HIGH         0x801C
75 #define KS8695_LAN_MAC_ELOW         0X8080
76 #define KS8695_LAN_MAC_EHIGH        0X8084
77
78 /*HPNA control registers offset difinitions*/
79 #define KS8695_HPNA_DMA_TX          0xA000
80 #define KS8695_HPNA_DMA_RX          0xA004
81 #define KS8695_HPNA_DMA_TX_START    0xA008
82 #define KS8695_HPNA_DMA_RX_START    0xA00C
83 #define KS8695_HPNA_TX_LIST         0xA010
84 #define KS8695_HPNA_RX_LIST         0xA014
85 #define KS8695_HPNA_MAC_LOW         0xA018
86 #define KS8695_HPNA_MAC_HIGH        0xA01C
87 #define KS8695_HPNA_MAC_ELOW        0xA080
88 #define KS8695_HPNA_MAC_EHIGH       0xA084
89
90 /*UART control registers offset difinitions*/
91 #define KS8695_UART_RX_BUFFER       0xE000
92 #define KS8695_UART_TX_HOLDING      0xE004
93
94 #define KS8695_UART_FIFO_CTRL       0xE008
95 #define KS8695_UART_FIFO_TRIG01     0x00
96 #define KS8695_UART_FIFO_TRIG04     0x80
97 #define KS8695_UART_FIFO_TXRST      0x03
98 #define KS8695_UART_FIFO_RXRST      0x02
99 #define KS8695_UART_FIFO_FEN        0x01
100
101 #define KS8695_UART_LINE_CTRL       0xE00C
102 #define KS8695_UART_LINEC_BRK       0x40
103 #define KS8695_UART_LINEC_EPS       0x10
104 #define KS8695_UART_LINEC_PEN       0x08
105 #define KS8695_UART_LINEC_STP2      0x04
106 #define KS8695_UART_LINEC_WLEN8     0x03
107 #define KS8695_UART_LINEC_WLEN7     0x02
108 #define KS8695_UART_LINEC_WLEN6     0x01
109 #define KS8695_UART_LINEC_WLEN5     0x00
110
111 #define KS8695_UART_MODEM_CTRL      0xE010
112 #define KS8695_UART_MODEMC_RTS      0x02
113 #define KS8695_UART_MODEMC_DTR      0x01
114
115 #define KS8695_UART_LINE_STATUS     0xE014
116 #define KS8695_UART_LINES_TXFE      0x20
117 #define KS8695_UART_LINES_BE        0x10
118 #define KS8695_UART_LINES_FE        0x08
119 #define KS8695_UART_LINES_PE        0x04
120 #define KS8695_UART_LINES_OE        0x02
121 #define KS8695_UART_LINES_RXFE      0x01
122 #define KS8695_UART_LINES_ANY       (KS8695_UART_LINES_OE|KS8695_UART_LINES_BE|KS8695_UART_LINES_PE|KS8695_UART_LINES_FE)
123
124 #define KS8695_UART_MODEM_STATUS    0xE018
125 #define KS8695_UART_MODEM_DCD       0x80
126 #define KS8695_UART_MODEM_DSR       0x20
127 #define KS8695_UART_MODEM_CTS       0x10
128 #define KS8695_UART_MODEM_DDCD      0x08
129 #define KS8695_UART_MODEM_DDSR      0x02
130 #define KS8695_UART_MODEM_DCTS      0x01
131 #define UART8695_MODEM_ANY          0xFF
132
133 #define KS8695_UART_DIVISOR         0xE01C
134 #define KS8695_UART_STATUS          0xE020
135
136 /*Interrupt controlller registers offset difinitions*/
137 #define KS8695_INT_CONTL            0xE200
138 #define KS8695_INT_ENABLE           0xE204
139 #define KS8695_INT_ENABLE_MODEM     0x0800
140 #define KS8695_INT_ENABLE_ERR       0x0400
141 #define KS8695_INT_ENABLE_RX        0x0200
142 #define KS8695_INT_ENABLE_TX        0x0100
143
144 #define KS8695_INT_STATUS           0xE208
145 #define KS8695_INT_WAN_PRIORITY     0xE20C
146 #define KS8695_INT_HPNA_PRIORITY    0xE210
147 #define KS8695_INT_LAN_PRIORITY     0xE214
148 #define KS8695_INT_TIMER_PRIORITY   0xE218
149 #define KS8695_INT_UART_PRIORITY    0xE21C
150 #define KS8695_INT_EXT_PRIORITY     0xE220
151 #define KS8695_INT_CHAN_PRIORITY    0xE224
152 #define KS8695_INT_BUSERROR_PRO     0xE228
153 #define KS8695_INT_MASK_STATUS      0xE22C
154 #define KS8695_FIQ_PEND_PRIORITY    0xE230
155 #define KS8695_IRQ_PEND_PRIORITY    0xE234
156
157 /*timer registers offset difinitions*/
158 #define KS8695_TIMER_CTRL           0xE400
159 #define KS8695_TIMER1               0xE404
160 #define KS8695_TIMER0               0xE408
161 #define KS8695_TIMER1_PCOUNT        0xE40C
162 #define KS8695_TIMER0_PCOUNT        0xE410
163
164 /*GPIO registers offset difinitions*/
165 #define KS8695_GPIO_MODE            0xE600
166 #define KS8695_GPIO_CTRL            0xE604
167 #define KS8695_GPIO_DATA            0xE608
168
169 /*SWITCH registers offset difinitions*/
170 #define KS8695_SWITCH_CTRL0         0xE800
171 #define KS8695_SWITCH_CTRL1         0xE804
172 #define KS8695_SWITCH_PORT1         0xE808
173 #define KS8695_SWITCH_PORT2         0xE80C
174 #define KS8695_SWITCH_PORT3         0xE810
175 #define KS8695_SWITCH_PORT4         0xE814
176 #define KS8695_SWITCH_PORT5         0xE818
177 #define KS8695_SWITCH_AUTO0         0xE81C
178 #define KS8695_SWITCH_AUTO1         0xE820
179 #define KS8695_SWITCH_LUE_CTRL      0xE824
180 #define KS8695_SWITCH_LUE_HIGH      0xE828
181 #define KS8695_SWITCH_LUE_LOW       0xE82C
182 #define KS8695_SWITCH_ADVANCED      0xE830
183
184 #define KS8695_SWITCH_LPPM12        0xE874
185 #define KS8695_SWITCH_LPPM34        0xE878
186
187 /*host communication registers difinitions*/
188 #define KS8695_DSCP_HIGH            0xE834
189 #define KS8695_DSCP_LOW             0xE838
190 #define KS8695_SWITCH_MAC_HIGH      0xE83C
191 #define KS8695_SWITCH_MAC_LOW       0xE840
192
193 /*miscellaneours registers difinitions*/
194 #define KS8695_MANAGE_COUNTER       0xE844
195 #define KS8695_MANAGE_DATA          0xE848
196 #define KS8695_LAN12_POWERMAGR      0xE84C
197 #define KS8695_LAN34_POWERMAGR      0xE850
198
199 #define KS8695_DEVICE_ID            0xEA00
200 #define KS8695_REVISION_ID          0xEA04
201
202 #define KS8695_MISC_CONTROL         0xEA08
203 #define KS8695_WAN_CONTROL          0xEA0C
204 #define KS8695_WAN_POWERMAGR        0xEA10
205 #define KS8695_WAN_PHY_CONTROL      0xEA14
206 #define KS8695_WAN_PHY_STATUS       0xEA18
207
208 /* bus clock definitions*/
209 #define KS8695_BUS_CLOCK_125MHZ     0x0
210 #define KS8695_BUS_CLOCK_100MHZ     0x1
211 #define KS8695_BUS_CLOCK_62MHZ      0x2
212 #define KS8695_BUS_CLOCK_50MHZ      0x3
213 #define KS8695_BUS_CLOCK_41MHZ      0x4
214 #define KS8695_BUS_CLOCK_33MHZ      0x5
215 #define KS8695_BUS_CLOCK_31MHZ      0x6
216 #define KS8695_BUS_CLOCK_25MHZ      0x7
217
218 /* -------------------------------------------------------------------------------
219  *  definations for IRQ
220  * -------------------------------------------------------------------------------*/
221
222 #define KS8695_INT_EXT_INT0                    2
223 #define KS8695_INT_EXT_INT1                    3
224 #define KS8695_INT_EXT_INT2                    4
225 #define KS8695_INT_EXT_INT3                    5
226 #define KS8695_INT_TIMERINT0                   6
227 #define KS8695_INT_TIMERINT1                   7
228 #define KS8695_INT_UART_TX                     8
229 #define KS8695_INT_UART_RX                     9
230 #define KS8695_INT_UART_LINE_ERR               10
231 #define KS8695_INT_UART_MODEMS                 11
232 #define KS8695_INT_LAN_STOP_RX                 12
233 #define KS8695_INT_LAN_STOP_TX                 13
234 #define KS8695_INT_LAN_BUF_RX_STATUS           14
235 #define KS8695_INT_LAN_BUF_TX_STATUS           15
236 #define KS8695_INT_LAN_RX_STATUS               16
237 #define KS8695_INT_LAN_TX_STATUS               17
238 #define KS8695_INT_HPAN_STOP_RX                18
239 #define KS8695_INT_HPNA_STOP_TX                19
240 #define KS8695_INT_HPNA_BUF_RX_STATUS          20
241 #define KS8695_INT_HPNA_BUF_TX_STATUS          21
242 #define KS8695_INT_HPNA_RX_STATUS              22
243 #define KS8695_INT_HPNA_TX_STATUS              23
244 #define KS8695_INT_BUS_ERROR                   24
245 #define KS8695_INT_WAN_STOP_RX                 25
246 #define KS8695_INT_WAN_STOP_TX                 26
247 #define KS8695_INT_WAN_BUF_RX_STATUS           27
248 #define KS8695_INT_WAN_BUF_TX_STATUS           28
249 #define KS8695_INT_WAN_RX_STATUS               29
250 #define KS8695_INT_WAN_TX_STATUS               30
251
252 #define KS8695_INT_UART                        KS8695_INT_UART_TX
253
254 /* -------------------------------------------------------------------------------
255  *  Interrupt bit positions
256  *
257  * -------------------------------------------------------------------------------
258  */
259
260 #define KS8695_INTMASK_EXT_INT0                ( 1 << KS8695_INT_EXT_INT0 )
261 #define KS8695_INTMASK_EXT_INT1                ( 1 << KS8695_INT_EXT_INT1 )
262 #define KS8695_INTMASK_EXT_INT2                ( 1 << KS8695_INT_EXT_INT2 )
263 #define KS8695_INTMASK_EXT_INT3                ( 1 << KS8695_INT_EXT_INT3 )
264 #define KS8695_INTMASK_TIMERINT0               ( 1 << KS8695_INT_TIMERINT0 )
265 #define KS8695_INTMASK_TIMERINT1               ( 1 << KS8695_INT_TIMERINT1 )
266 #define KS8695_INTMASK_UART_TX                 ( 1 << KS8695_INT_UART_TX  )
267 #define KS8695_INTMASK_UART_RX                 ( 1 << KS8695_INT_UART_RX  )
268 #define KS8695_INTMASK_UART_LINE_ERR           ( 1 << KS8695_INT_UART_LINE_ERR )
269 #define KS8695_INTMASK_UART_MODEMS             ( 1 << KS8695_INT_UART_MODEMS )
270 #define KS8695_INTMASK_LAN_STOP_RX             ( 1 << KS8695_INT_LAN_STOP_RX )
271 #define KS8695_INTMASK_LAN_STOP_TX             ( 1 << KS8695_INT_LAN_STOP_TX )
272 #define KS8695_INTMASK_LAN_BUF_RX_STATUS       ( 1 << KS8695_INT_LAN_BUF_RX_STATUS )
273 #define KS8695_INTMASK_LAN_BUF_TX_STATUS       ( 1 << KS8695_INT_LAN_BUF_TX_STATUS )
274 #define KS8695_INTMASK_LAN_RX_STATUS           ( 1 << KS8695_INT_LAN_RX_STATUS )
275 #define KS8695_INTMASK_LAN_TX_STATUS           ( 1 << KS8695_INT_LAN_RX_STATUS )
276 #define KS8695_INTMASK_HPAN_STOP_RX            ( 1 << KS8695_INT_HPAN_STOP_RX )
277 #define KS8695_INTMASK_HPNA_STOP_TX            ( 1 << KS8695_INT_HPNA_STOP_TX )
278 #define KS8695_INTMASK_HPNA_BUF_RX_STATUS      ( 1 << KS8695_INT_HPNA_BUF_RX_STATUS )
279 #define KS8695_INTMAKS_HPNA_BUF_TX_STATUS      ( 1 << KS8695_INT_HPNA_BUF_TX_STATUS
280 #define KS8695_INTMASK_HPNA_RX_STATUS          ( 1 << KS8695_INT_HPNA_RX_STATUS )
281 #define KS8695_INTMASK_HPNA_TX_STATUS          ( 1 << KS8695_INT_HPNA_TX_STATUS )
282 #define KS8695_INTMASK_BUS_ERROR               ( 1 << KS8695_INT_BUS_ERROR )
283 #define KS8695_INTMASK_WAN_STOP_RX             ( 1 << KS8695_INT_WAN_STOP_RX )
284 #define KS8695_INTMASK_WAN_STOP_TX             ( 1 << KS8695_INT_WAN_STOP_TX )
285 #define KS8695_INTMASK_WAN_BUF_RX_STATUS       ( 1 << KS8695_INT_WAN_BUF_RX_STATUS )
286 #define KS8695_INTMASK_WAN_BUF_TX_STATUS       ( 1 << KS8695_INT_WAN_BUF_TX_STATUS )
287 #define KS8695_INTMASK_WAN_RX_STATUS           ( 1 << KS8695_INT_WAN_RX_STATUS )
288 #define KS8695_INTMASK_WAN_TX_STATUS           ( 1 << KS8695_INT_WAN_TX_STATUS )
289
290 #define KS8695_SC_VALID_INT                    0xFFFFFFFF
291 #define MAXIRQNUM                              31
292
293 /*
294  *  Timer definitions
295  *
296  *  Use timer 1 & 2
297  *  (both run at 25MHz).
298  *
299  */
300 #define TICKS_PER_uSEC                  25
301 #define mSEC_1                          1000
302 #define mSEC_10                         (mSEC_1 * 10)
303
304 #endif
305
306 /*      END */