s3c2440reg.h revision 1.2.6.2 1 1.2.6.2 yamt /*-
2 1.2.6.2 yamt * Copyright (c) 2012 The NetBSD Foundation, Inc.
3 1.2.6.2 yamt * All rights reserved.
4 1.2.6.2 yamt *
5 1.2.6.2 yamt * This code is derived from software contributed to The NetBSD Foundation
6 1.2.6.2 yamt * by Paul Fleischer <paul (at) xpg.dk>
7 1.2.6.2 yamt *
8 1.2.6.2 yamt * Redistribution and use in source and binary forms, with or without
9 1.2.6.2 yamt * modification, are permitted provided that the following conditions
10 1.2.6.2 yamt * are met:
11 1.2.6.2 yamt * 1. Redistributions of source code must retain the above copyright
12 1.2.6.2 yamt * notice, this list of conditions and the following disclaimer.
13 1.2.6.2 yamt * 2. Redistributions in binary form must reproduce the above copyright
14 1.2.6.2 yamt * notice, this list of conditions and the following disclaimer in the
15 1.2.6.2 yamt * documentation and/or other materials provided with the distribution.
16 1.2.6.2 yamt *
17 1.2.6.2 yamt * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
18 1.2.6.2 yamt * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
19 1.2.6.2 yamt * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
20 1.2.6.2 yamt * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
21 1.2.6.2 yamt * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
22 1.2.6.2 yamt * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
23 1.2.6.2 yamt * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
24 1.2.6.2 yamt * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
25 1.2.6.2 yamt * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
26 1.2.6.2 yamt * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
27 1.2.6.2 yamt * POSSIBILITY OF SUCH DAMAGE.
28 1.2.6.2 yamt */
29 1.2.6.2 yamt
30 1.2.6.2 yamt /* Derived from s3c2410reg.h */
31 1.2.6.2 yamt
32 1.2.6.2 yamt /*
33 1.2.6.2 yamt * Copyright (c) 2003, 2004 Genetec corporation. All rights reserved.
34 1.2.6.2 yamt * Written by Hiroyuki Bessho for Genetec corporation.
35 1.2.6.2 yamt *
36 1.2.6.2 yamt * Redistribution and use in source and binary forms, with or without
37 1.2.6.2 yamt * modification, are permitted provided that the following conditions
38 1.2.6.2 yamt * are met:
39 1.2.6.2 yamt * 1. Redistributions of source code must retain the above copyright
40 1.2.6.2 yamt * notice, this list of conditions and the following disclaimer.
41 1.2.6.2 yamt * 2. Redistributions in binary form must reproduce the above copyright
42 1.2.6.2 yamt * notice, this list of conditions and the following disclaimer in the
43 1.2.6.2 yamt * documentation and/or other materials provided with the distribution.
44 1.2.6.2 yamt * 3. The name of Genetec corporation may not be used to endorse
45 1.2.6.2 yamt * or promote products derived from this software without specific prior
46 1.2.6.2 yamt * written permission.
47 1.2.6.2 yamt *
48 1.2.6.2 yamt * THIS SOFTWARE IS PROVIDED BY GENETEC CORP. ``AS IS'' AND
49 1.2.6.2 yamt * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
50 1.2.6.2 yamt * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
51 1.2.6.2 yamt * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL GENETEC CORP.
52 1.2.6.2 yamt * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
53 1.2.6.2 yamt * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
54 1.2.6.2 yamt * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
55 1.2.6.2 yamt * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
56 1.2.6.2 yamt * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
57 1.2.6.2 yamt * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
58 1.2.6.2 yamt * POSSIBILITY OF SUCH DAMAGE.
59 1.2.6.2 yamt */
60 1.2.6.2 yamt
61 1.2.6.2 yamt
62 1.2.6.2 yamt /*
63 1.2.6.2 yamt * Samsung S3C2440X processor is ARM920T based integrated CPU
64 1.2.6.2 yamt *
65 1.2.6.2 yamt * Reference:
66 1.2.6.2 yamt * S3C2440X User's Manual
67 1.2.6.2 yamt */
68 1.2.6.2 yamt #ifndef _ARM_S3C2XX0_S3C2440REG_H_
69 1.2.6.2 yamt #define _ARM_S3C2XX0_S3C2440REG_H_
70 1.2.6.2 yamt
71 1.2.6.2 yamt /* common definitions for S3C2800, S3C2400 and S3C2410 */
72 1.2.6.2 yamt #include <arm/s3c2xx0/s3c2xx0reg.h>
73 1.2.6.2 yamt /* common definitions for S3C2400 and S3C2410 */
74 1.2.6.2 yamt #include <arm/s3c2xx0/s3c24x0reg.h>
75 1.2.6.2 yamt
76 1.2.6.2 yamt /*
77 1.2.6.2 yamt * Memory Map
78 1.2.6.2 yamt */
79 1.2.6.2 yamt #define S3C2440_BANK_SIZE 0x08000000
80 1.2.6.2 yamt #define S3C2440_BANK_START(n) (S3C2440_BANK_SIZE*(n))
81 1.2.6.2 yamt #define S3C2440_SDRAM_START S3C2440_BANK_START(6)
82 1.2.6.2 yamt
83 1.2.6.2 yamt /*
84 1.2.6.2 yamt * Physical address of integrated peripherals
85 1.2.6.2 yamt */
86 1.2.6.2 yamt #define S3C2440_MEMCTL_BASE 0x48000000 /* memory controller */
87 1.2.6.2 yamt #define S3C2440_USBHC_BASE 0x49000000 /* USB Host controller */
88 1.2.6.2 yamt #define S3C2440_INTCTL_BASE 0x4a000000 /* Interrupt controller */
89 1.2.6.2 yamt #define S3C2440_DMAC_BASE 0x4b000000
90 1.2.6.2 yamt #define S3C2440_DMAC_SIZE 0xe4
91 1.2.6.2 yamt #define S3C2440_CLKMAN_BASE 0x4c000000 /* clock & power management */
92 1.2.6.2 yamt #define S3C2440_LCDC_BASE 0x4d000000 /* LCD controller */
93 1.2.6.2 yamt #define S3C2440_NANDFC_BASE 0x4e000000 /* NAND Flash controller */
94 1.2.6.2 yamt #define S3C2440_NANDFC_SIZE 0x18
95 1.2.6.2 yamt #define S3C2440_UART0_BASE 0x50000000
96 1.2.6.2 yamt #define S3C2440_UART_BASE(n) (S3C2440_UART0_BASE+0x4000*(n))
97 1.2.6.2 yamt #define S3C2440_TIMER_BASE 0x51000000
98 1.2.6.2 yamt #define S3C2440_USBDC_BASE 0x5200140
99 1.2.6.2 yamt #define S3C2440_USBDC_SIZE 0x130
100 1.2.6.2 yamt #define S3C2440_WDT_BASE 0x53000000
101 1.2.6.2 yamt #define S3C2440_IIC_BASE 0x54000000
102 1.2.6.2 yamt #define S3C2440_IIS_BASE 0x55000000
103 1.2.6.2 yamt #define S3C2440_GPIO_BASE 0x56000000
104 1.2.6.2 yamt #define S3C2440_GPIO_SIZE 0xd0
105 1.2.6.2 yamt #define S3C2440_RTC_BASE 0x57000000
106 1.2.6.2 yamt #define S3C2440_RTC_SIZE 0x8B
107 1.2.6.2 yamt #define S3C2440_ADC_BASE 0x58000000
108 1.2.6.2 yamt #define S3C2440_ADC_SIZE 0x18
109 1.2.6.2 yamt #define S3C2440_SPI0_BASE 0x59000000
110 1.2.6.2 yamt #define S3C2440_SPI1_BASE 0x59000020
111 1.2.6.2 yamt #define S3C2440_SDI_BASE 0x5a000000 /* SD Interface */
112 1.2.6.2 yamt #define S3C2440_SDI_SIZE 0x44
113 1.2.6.2 yamt
114 1.2.6.2 yamt /* interrupt control (additional defs for 2440) */
115 1.2.6.2 yamt #define ICU_LEN (32+11)
116 1.2.6.2 yamt
117 1.2.6.2 yamt #define INTCTL_SUBSRCPND 0x18 /* sub source pending (2410+2440 only) */
118 1.2.6.2 yamt #define INTCTL_INTSUBMSK 0x1c /* sub mask (2410+2440 only) */
119 1.2.6.2 yamt
120 1.2.6.2 yamt /* 2440 has more than 32 interrupt sources. These are sub-sources
121 1.2.6.2 yamt * that are OR-ed into main interrupt sources, and controlled via
122 1.2.6.2 yamt * SUBSRCPND and SUBSRCMSK registers */
123 1.2.6.2 yamt
124 1.2.6.2 yamt #define S3C2440_SUBIRQ_MIN 32
125 1.2.6.2 yamt #define S3C2440_SUBIRQ_MAX (32+10)
126 1.2.6.2 yamt
127 1.2.6.2 yamt /* cascaded to INT_ADCTC */
128 1.2.6.2 yamt #define S3C2440_INT_ADC (S3C2440_SUBIRQ_MIN+10) /* AD converter */
129 1.2.6.2 yamt #define S3C2440_INT_TC (S3C2440_SUBIRQ_MIN+9) /* Touch screen */
130 1.2.6.2 yamt /* cascaded to INT_UART2 */
131 1.2.6.2 yamt #define S3C2440_INT_ERR2 (S3C2440_SUBIRQ_MIN+8) /* UART2 Error interrupt */
132 1.2.6.2 yamt #define S3C2440_INT_TXD2 (S3C2440_SUBIRQ_MIN+7) /* UART2 Tx interrupt */
133 1.2.6.2 yamt #define S3C2440_INT_RXD2 (S3C2440_SUBIRQ_MIN+6) /* UART2 Rx interrupt */
134 1.2.6.2 yamt /* cascaded to INT_UART1 */
135 1.2.6.2 yamt #define S3C2440_INT_ERR1 (S3C2440_SUBIRQ_MIN+5) /* UART1 Error interrupt */
136 1.2.6.2 yamt #define S3C2440_INT_TXD1 (S3C2440_SUBIRQ_MIN+4) /* UART1 Tx interrupt */
137 1.2.6.2 yamt #define S3C2440_INT_RXD1 (S3C2440_SUBIRQ_MIN+3) /* UART1 Rx interrupt */
138 1.2.6.2 yamt /* cascaded to INT_UART0 */
139 1.2.6.2 yamt #define S3C2440_INT_ERR0 (S3C2440_SUBIRQ_MIN+2) /* UART0 Error interrupt */
140 1.2.6.2 yamt #define S3C2440_INT_TXD0 (S3C2440_SUBIRQ_MIN+1) /* UART0 Tx interrupt */
141 1.2.6.2 yamt #define S3C2440_INT_RXD0 (S3C2440_SUBIRQ_MIN+0) /* UART0 Rx interrupt */
142 1.2.6.2 yamt
143 1.2.6.2 yamt #define S3C2440_INTCTL_SIZE 0x20
144 1.2.6.2 yamt
145 1.2.6.2 yamt
146 1.2.6.2 yamt /* Clock control */
147 1.2.6.2 yamt #define CLKMAN_LOCKTIME 0x00
148 1.2.6.2 yamt #define CLKMAN_MPLLCON 0x04
149 1.2.6.2 yamt #define CLKMAN_UPLLCON 0x08
150 1.2.6.2 yamt #define CLKMAN_CLKCON 0x0c
151 1.2.6.2 yamt #define CLKCON_SPI (1<<18)
152 1.2.6.2 yamt #define CLKCON_IIS (1<<17)
153 1.2.6.2 yamt #define CLKCON_IIC (1<<16)
154 1.2.6.2 yamt #define CLKCON_ADC (1<<15)
155 1.2.6.2 yamt #define CLKCON_RTC (1<<14)
156 1.2.6.2 yamt #define CLKCON_GPIO (1<<13)
157 1.2.6.2 yamt #define CLKCON_UART2 (1<<12)
158 1.2.6.2 yamt #define CLKCON_UART1 (1<<11)
159 1.2.6.2 yamt #define CLKCON_UART0 (1<<10) /* PCLK to UART0 */
160 1.2.6.2 yamt #define CLKCON_SDI (1<<9)
161 1.2.6.2 yamt #define CLKCON_TIMER (1<<8) /* PCLK to TIMER */
162 1.2.6.2 yamt #define CLKCON_USBD (1<<7) /* PCLK to USB device controller */
163 1.2.6.2 yamt #define CLKCON_USBH (1<<6) /* PCLK to USB host controller */
164 1.2.6.2 yamt #define CLKCON_LCDC (1<<5) /* PCLK to LCD controller */
165 1.2.6.2 yamt #define CLKCON_NANDFC (1<<4) /* PCLK to NAND Flash controller */
166 1.2.6.2 yamt #define CLKCON_IDLE (1<<2) /* 1=transition to IDLE mode */
167 1.2.6.2 yamt #define CLKCON_STOP (1<<0) /* 1=transition to STOP mode */
168 1.2.6.2 yamt #define CLKMAN_CLKSLOW 0x10
169 1.2.6.2 yamt #define CLKMAN_CLKDIVN 0x14
170 1.2.6.2 yamt #define CLKDIVN_HDIVN_MASK 0x6
171 1.2.6.2 yamt #define CLKDIVN_HDIVN_SHIFT 1
172 1.2.6.2 yamt #define CLKDIVN_PDIVN (1<<0) /* pclk=hclk/2 */
173 1.2.6.2 yamt #define CLKMAN_CAMDIVN 0x18
174 1.2.6.2 yamt #define CLKCAMDIVN_HCLK4_HALF (1<<8) /* Modifies HDIVN division rate if CLKDIVN[2:1] == 10b*/
175 1.2.6.2 yamt #define CLKCAMDIVN_HCLK3_HALF (1<<9) /* Modifies HDIVN division rate if CLKDIVN[2:1] == 11b*/
176 1.2.6.2 yamt
177 1.2.6.2 yamt /* NAND Flash controller */
178 1.2.6.2 yamt #define NANDFC_NFCONF 0x00 /* Configuration */
179 1.2.6.2 yamt #define NANDFC_NFCMD 0x08 /* command */
180 1.2.6.2 yamt #define NANDFC_NFADDR 0x0C /* address */
181 1.2.6.2 yamt #define NANDFC_NFDATA 0x10 /* data */
182 1.2.6.2 yamt #define NANDFC_NFSTAT 0x20 /* operation status */
183 1.2.6.2 yamt #define NANDFC_NFECC 0x34 /* ecc */
184 1.2.6.2 yamt
185 1.2.6.2 yamt /* GPIO */
186 1.2.6.2 yamt #define GPIO_PACON 0x00 /* port A configuration */
187 1.2.6.2 yamt #define PCON_INPUT 0 /* Input port */
188 1.2.6.2 yamt #define PCON_OUTPUT 1 /* Output port */
189 1.2.6.2 yamt #define PCON_ALTFUN 2 /* Alternate function */
190 1.2.6.2 yamt #define PCON_ALTFUN2 3 /* Alternate function */
191 1.2.6.2 yamt #define GPIO_PADAT 0x04 /* port A data */
192 1.2.6.2 yamt #define GPIO_PBCON 0x10
193 1.2.6.2 yamt #define GPIO_PBDAT 0x14
194 1.2.6.2 yamt #define GPIO_PBUP 0x18
195 1.2.6.2 yamt #define GPIO_PCCON 0x20
196 1.2.6.2 yamt #define GPIO_PCDAT 0x24
197 1.2.6.2 yamt #define GPIO_PCUP 0x28
198 1.2.6.2 yamt #define GPIO_PDCON 0x30
199 1.2.6.2 yamt #define GPIO_PDDAT 0x34
200 1.2.6.2 yamt #define GPIO_PDUP 0x38
201 1.2.6.2 yamt #define GPIO_PECON 0x40
202 1.2.6.2 yamt #define GPIO_PEDAT 0x44
203 1.2.6.2 yamt #define GPIO_PEUP 0x48
204 1.2.6.2 yamt #define GPIO_PFCON 0x50
205 1.2.6.2 yamt #define GPIO_PFDAT 0x54
206 1.2.6.2 yamt #define GPIO_PFUP 0x58
207 1.2.6.2 yamt #define GPIO_PGCON 0x60
208 1.2.6.2 yamt #define GPIO_PGDAT 0x64
209 1.2.6.2 yamt #define GPIO_PGUP 0x68
210 1.2.6.2 yamt #define GPIO_PHCON 0x70
211 1.2.6.2 yamt #define GPIO_PHDAT 0x74
212 1.2.6.2 yamt #define GPIO_PHUP 0x78
213 1.2.6.2 yamt #define GPIO_MISCCR 0x80 /* miscellaneous control */
214 1.2.6.2 yamt #define GPIO_DCLKCON 0x84 /* DCLK 0/1 */
215 1.2.6.2 yamt #define GPIO_EXTINT(n) (0x88+4*(n)) /* external int control 0/1/2 */
216 1.2.6.2 yamt #define GPIO_EINTFLT(n) (0x94+4*(n)) /* external int filter control 0..3 */
217 1.2.6.2 yamt #define GPIO_EINTMASK 0xa4
218 1.2.6.2 yamt #define GPIO_EINTPEND 0xa8
219 1.2.6.2 yamt #define GPIO_GSTATUS0 0xac /* external pin status */
220 1.2.6.2 yamt #define GPIO_GSTATUS1 0xb0 /* external pin status */
221 1.2.6.2 yamt
222 1.2.6.2 yamt #define GPIO_SET_FUNC(v,port,func) \
223 1.2.6.2 yamt (((v) & ~(3<<(2*(port))))|((func)<<(2*(port))))
224 1.2.6.2 yamt #define GPIO_SET_DATA(v,pin,val) \
225 1.2.6.2 yamt ( ((v) & ~(1<<pin)) | (((val)&0x1)<<pin) )
226 1.2.6.2 yamt
227 1.2.6.2 yamt #define EXTINTR_LOW 0x00
228 1.2.6.2 yamt #define EXTINTR_HIGH 0x01
229 1.2.6.2 yamt #define EXTINTR_FALLING 0x02
230 1.2.6.2 yamt #define EXTINTR_RISING 0x04
231 1.2.6.2 yamt #define EXTINTR_BOTH 0x06
232 1.2.6.2 yamt
233 1.2.6.2 yamt /* RTC */
234 1.2.6.2 yamt #define RTC_RTCCON 0x40
235 1.2.6.2 yamt #define RTCCON_CLKRST (1<<3)
236 1.2.6.2 yamt #define RTCCON_CNTSEL (1<<2)
237 1.2.6.2 yamt #define RTCCON_CLKSEL (1<<1)
238 1.2.6.2 yamt #define RTCCON_RTCEN (1<<0)
239 1.2.6.2 yamt #define RTC_TICNT 0x44
240 1.2.6.2 yamt #define TICNT_INT 0x80
241 1.2.6.2 yamt #define TICNT_COUNT_MASK 0x7F
242 1.2.6.2 yamt #define RTC_BCDSEC 0x70
243 1.2.6.2 yamt #define RTC_BCDMIN 0x74
244 1.2.6.2 yamt #define RTC_BCDHOUR 0x78
245 1.2.6.2 yamt #define RTC_BCDDATE 0x7C
246 1.2.6.2 yamt #define RTC_BCDDAY 0x80
247 1.2.6.2 yamt #define RTC_BCDMON 0x84
248 1.2.6.2 yamt #define RTC_BCDYEAR 0x88
249 1.2.6.2 yamt
250 1.2.6.2 yamt /* UART */
251 1.2.6.2 yamt #undef UFCON_TXTRIGGER_0
252 1.2.6.2 yamt #undef UFCON_TXTRIGGER_4
253 1.2.6.2 yamt #undef UFCON_TXTRIGGER_8
254 1.2.6.2 yamt #undef UFCON_TXTRIGGER_16
255 1.2.6.2 yamt #undef UFCON_RXTRIGGER_4
256 1.2.6.2 yamt #undef UFCON_RXTRIGGER_8
257 1.2.6.2 yamt #undef UFCON_RXTRIGGER_12
258 1.2.6.2 yamt #undef UFCON_RXTRIGGER_16
259 1.2.6.2 yamt #define UFCON_TXTRIGGER_0 (0<<6)
260 1.2.6.2 yamt #define UFCON_TXTRIGGER_16 (1<<6)
261 1.2.6.2 yamt #define UFCON_TXTRIGGER_32 (2<<6)
262 1.2.6.2 yamt #define UFCON_TXTRIGGER_48 (3<<6)
263 1.2.6.2 yamt #define UFCON_RXTRIGGER_1 (0<<4)
264 1.2.6.2 yamt #define UFCON_RXTRIGGER_8 (1<<4)
265 1.2.6.2 yamt #define UFCON_RXTRIGGER_16 (2<<4)
266 1.2.6.2 yamt #define UFCON_RXTRIGGER_32 (3<<4)
267 1.2.6.2 yamt #undef UFSTAT_TXFULL
268 1.2.6.2 yamt #define UFSTAT_TXFULL (1<<14) /* Tx fifo full */
269 1.2.6.2 yamt #undef UFSTAT_RXFULL
270 1.2.6.2 yamt #define UFSTAT_RXFULL (1<<6) /* Rx fifo full */
271 1.2.6.2 yamt #undef UFSTAT_TXCOUNT_SHIFT
272 1.2.6.2 yamt #undef UFSTAT_TXCOUNT
273 1.2.6.2 yamt #define UFSTAT_TXCOUNT_SHIFT 8
274 1.2.6.2 yamt #define UFSTAT_TXCOUNT (0x3f<<UFSTAT_TXCOUNT_SHIFT)
275 1.2.6.2 yamt #undef UFSTAT_RXCOUNT_SHIFT
276 1.2.6.2 yamt #undef UFSTAT_RXCOUNT
277 1.2.6.2 yamt #define UFSTAT_RXCOUNT_SHIFT 0
278 1.2.6.2 yamt #define UFSTAT_RXCOUNT (0x3f<<UFSTAT_RXCOUNT_SHIFT)
279 1.2.6.2 yamt
280 1.2.6.2 yamt
281 1.2.6.2 yamt /* SD interface */
282 1.2.6.2 yamt #define SDI_CON 0x00
283 1.2.6.2 yamt #define SDICON_ENCLK (1<<0)
284 1.2.6.2 yamt #define SDICON_RWAIT_EN (1<<2)
285 1.2.6.2 yamt #define SDICON_RCV_IO_INT (1<<3)
286 1.2.6.2 yamt #define SDICON_BYTE_ORDER_A (0<<4)
287 1.2.6.2 yamt #define SDICON_BYTE_ORDER_B (1<<4)
288 1.2.6.2 yamt #define SDICON_CTYP_MMC (1<<5)
289 1.2.6.2 yamt #define SDICON_CTYP_SD (0<<5)
290 1.2.6.2 yamt #define SDICON_SD_RESET (1<<8)
291 1.2.6.2 yamt #define SDI_PRE 0x04
292 1.2.6.2 yamt #define SDI_CMD_ARG 0x08
293 1.2.6.2 yamt #define SDI_CMD_CON 0x0C
294 1.2.6.2 yamt #define SDICMDCON_CMD_MASK 0x3F
295 1.2.6.2 yamt #define SDICMDCON_HOST_CMD (1<<6) /* 01 in bits 6 and 7 */
296 1.2.6.2 yamt #define SDICMDCON_CARD_RSP (0<<6) /* 00 in buts 6 and 8 */
297 1.2.6.2 yamt #define SDICMDCON_CMST (1<<8)
298 1.2.6.2 yamt #define SDICMDCON_WAIT_RSP (1<<9)
299 1.2.6.2 yamt #define SDICMDCON_LONG_RSP (1<<10)
300 1.2.6.2 yamt #define SDICMDCON_WITH_DATA (1<<11)
301 1.2.6.2 yamt #define SDICMDCON_ABORT_CMD (1<<12)
302 1.2.6.2 yamt #define SDI_CMD_STA 0x10
303 1.2.6.2 yamt #define SDICMDSTA_RSP_MASK 0x03F
304 1.2.6.2 yamt #define SDICMDSTA_CMD_ON (1<<8)
305 1.2.6.2 yamt #define SDICMDSTA_RSP_FIN (1<<9)
306 1.2.6.2 yamt #define SDICMDSTA_CMD_TIMEOUT (1<<10)
307 1.2.6.2 yamt #define SDICMDSTA_CMD_SENT (1<<11)
308 1.2.6.2 yamt #define SDICMDSTA_RSP_CRC (1<<12)
309 1.2.6.2 yamt #define SDI_RSP0 0x14
310 1.2.6.2 yamt #define SDI_RSP1 0x18
311 1.2.6.2 yamt #define SDI_RSP2 0x1C
312 1.2.6.2 yamt #define SDI_RSP3 0x20
313 1.2.6.2 yamt #define SDI_DTIMER 0x24
314 1.2.6.2 yamt #define SDI_BSIZE 0x28
315 1.2.6.2 yamt #define SDI_DAT_CON 0x2C
316 1.2.6.2 yamt #define SDIDATCON_BLKNUM_MASK 0xFFF
317 1.2.6.2 yamt #define SDIDATCON_DATMODE_NOOP (0 << 12)
318 1.2.6.2 yamt #define SDIDATCON_DATMODE_BUSY (1 << 12)
319 1.2.6.2 yamt #define SDIDATCON_DATMODE_RECEIVE (2 << 12)
320 1.2.6.2 yamt #define SDIDATCON_DATMODE_TRANSMIT (3 << 12)
321 1.2.6.2 yamt #define SDIDATCON_DTST (1 << 14)
322 1.2.6.2 yamt #define SDIDATCON_ENDMA (1 << 15)
323 1.2.6.2 yamt #define SDIDATCON_WIDEBUS (1 << 16)
324 1.2.6.2 yamt #define SDIDATCON_BLKMODE (1 << 17)
325 1.2.6.2 yamt #define SDIDATCON_BACMD (1 << 18)
326 1.2.6.2 yamt #define SDIDATCON_RACMD (1 << 19)
327 1.2.6.2 yamt #define SDIDATCON_TARSP (1 << 20)
328 1.2.6.2 yamt #define SDIDATCON_PRD_TYPE (1 << 21)
329 1.2.6.2 yamt #define SDIDATCON_DATA_BYTE (0 << 22)
330 1.2.6.2 yamt #define SDIDATCON_DATA_HALFWORD (1 << 22)
331 1.2.6.2 yamt #define SDIDATCON_DATA_WORD (2 << 22)
332 1.2.6.2 yamt #define SDIDATCON_BURST4 (1 << 24)
333 1.2.6.2 yamt #define SDI_DAT_CNT 0x30
334 1.2.6.2 yamt #define SDIDATCNT_BLK_CNT_MASK 0xFFF
335 1.2.6.2 yamt #define SDIDATCNT_BLK_CNT(reg) (reg & SDIDATCON_BLKNUM_MASK)
336 1.2.6.2 yamt #define SDIDATCNT_BLK_NUM_CNT_MASK 0xFFF000
337 1.2.6.2 yamt #define SDIDATCNT_BLK_NUM_CNT_SHIFT 12
338 1.2.6.2 yamt #define SDIDATCNT_BLK_NUM_CNT(reg) ( (reg & SDIDATCNT_BLK_NUM_CNT_MASK) >> SDIDATCNT_BLK_NUM_CNT_SHIFT)
339 1.2.6.2 yamt #define SDI_DAT_STA 0x34
340 1.2.6.2 yamt #define SDIDATSTA_RX (1 << 0)
341 1.2.6.2 yamt #define SDIDATSTA_TX (1 << 1)
342 1.2.6.2 yamt #define SDIDATSTA_BUSY_FIN (1 << 3)
343 1.2.6.2 yamt #define SDIDATSTA_DATA_FIN (1 << 4)
344 1.2.6.2 yamt #define SDIDATSTA_DATA_TIMEOUT (1 << 5)
345 1.2.6.2 yamt #define SDIDATSTA_CRC_DAT_FAIL (1 << 6)
346 1.2.6.2 yamt #define SDIDATSTA_CRC_STATUS_FAIL (1 << 7)
347 1.2.6.2 yamt #define SDIDATSTA_SDIO_INT (1 << 9)
348 1.2.6.2 yamt #define SDIDATSTA_RWAIT_REQ (1 << 10)
349 1.2.6.2 yamt #define SDIDATSTA_NO_BUSY (1 << 11)
350 1.2.6.2 yamt #define SDI_DAT_FSTA 0x38
351 1.2.6.2 yamt #define SDIDATFSTA_FFCNT_MASK 0x7F
352 1.2.6.2 yamt #define SDIDATFSTA_FFCNT(reg) (reg & SDIDATFSTA_FFCNT_MASK)
353 1.2.6.2 yamt #define SDIDATFSTA_RF_HALF (1 << 7)
354 1.2.6.2 yamt #define SDIDATFSTA_RF_FULL (1 << 8)
355 1.2.6.2 yamt #define SDIDATFSTA_RF_LAST (1 << 9)
356 1.2.6.2 yamt #define SDIDATFSTA_TF_EMPTY (1 << 10)
357 1.2.6.2 yamt #define SDIDATFSTA_TF_HALF (1 << 11)
358 1.2.6.2 yamt #define SDIDATFSTA_RF_DETECT (1 << 12)
359 1.2.6.2 yamt #define SDIDATFSTA_TX_DETECT (1 << 13)
360 1.2.6.2 yamt #define SDIDATFSTA_FAIL_NO_DETECT (0 << 14)
361 1.2.6.2 yamt #define SDIDATFSTA_FAIL_FIFO (1 << 14)
362 1.2.6.2 yamt #define SDIDATFSTA_FAIL_FIFO_LAST (2 << 14)
363 1.2.6.2 yamt #define SDIDATFSTA_RESET (1 << 16)
364 1.2.6.2 yamt #define SDI_INT_MASK 0x3C
365 1.2.6.2 yamt #define SDIINTMASK_RF_HALF (1<<0)
366 1.2.6.2 yamt #define SDIINTMASK_RF_FULL (1<<1)
367 1.2.6.2 yamt #define SDIINTMASK_RF_LAST (1<<2)
368 1.2.6.2 yamt #define SDIINTMASK_TF_EMPTY (1<<3)
369 1.2.6.2 yamt #define SDIINTMASK_TF_HALF (1<<4)
370 1.2.6.2 yamt #define SDIINTMASK_BUSY_FIN (1<<6)
371 1.2.6.2 yamt #define SDIINTMASK_DATA_FIN (1<<7)
372 1.2.6.2 yamt #define SDIINTMASK_DATA_TIMEOUT (1<<8)
373 1.2.6.2 yamt #define SDIINTMASK_DATA_CRC (1<<9)
374 1.2.6.2 yamt #define SDIINTMASK_STATUS_CRC (1<<10)
375 1.2.6.2 yamt #define SDIINTMASK_FIFO_FAIL (1<<11)
376 1.2.6.2 yamt #define SDIINTMASK_IO (1<<12)
377 1.2.6.2 yamt #define SDIINTMASK_READ_WAIT (1<<13)
378 1.2.6.2 yamt #define SDIINTMASK_RESP (1<<14)
379 1.2.6.2 yamt #define SDIINTMASK_CMD_TIMEOUT (1<<15)
380 1.2.6.2 yamt #define SDIINTMASK_CMD_SENT (1<<16)
381 1.2.6.2 yamt #define SDIINTMASK_RESP_CRC (1<<17)
382 1.2.6.2 yamt #define SDIINTMASK_NO_BUSY (1<<18)
383 1.2.6.2 yamt #define SDI_DAT_LI_W 0x40 /* Word access in Little Endian mode */
384 1.2.6.2 yamt #define SDI_DAT_LI_HW 0x44 /* Half-Word access in Little Endian mode */
385 1.2.6.2 yamt #define SDI_DAT_LI_B 0x48 /* Byte access in Little Endian mode */
386 1.2.6.2 yamt #define SDI_DAT_BI_W 0x4C /* Word access in Big Endian mode */
387 1.2.6.2 yamt #define SDI_DAT_BI_HW 0x41 /* Half-Word access in Big Endian mode */
388 1.2.6.2 yamt #define SDI_DAT_BI_B 0x43 /* Byte access in Big Endian mode */
389 1.2.6.2 yamt
390 1.2.6.2 yamt /* ADC */
391 1.2.6.2 yamt /* XXX: ADCCON register is common to both S3C2410 and S3C2400,
392 1.2.6.2 yamt * but other registers are different.
393 1.2.6.2 yamt */
394 1.2.6.2 yamt #define ADC_ADCCON 0x00
395 1.2.6.2 yamt #define ADCCON_ENABLE_START (1<<0)
396 1.2.6.2 yamt #define ADCCON_READ_START (1<<1)
397 1.2.6.2 yamt #define ADCCON_STDBM (1<<2)
398 1.2.6.2 yamt #define ADCCON_SEL_MUX_SHIFT 3
399 1.2.6.2 yamt #define ADCCON_SEL_MUX_MASK (0x7<<ADCCON_SEL_MUX_SHIFT)
400 1.2.6.2 yamt #define ADCCON_PRSCVL_SHIFT 6
401 1.2.6.2 yamt #define ADCCON_PRSCVL_MASK (0xff<<ADCCON_PRSCVL_SHIFT)
402 1.2.6.2 yamt #define ADCCON_PRSCEN (1<<14)
403 1.2.6.2 yamt #define ADCCON_ECFLG (1<<15)
404 1.2.6.2 yamt
405 1.2.6.2 yamt #define ADC_ADCTSC 0x04
406 1.2.6.2 yamt #define ADCTSC_XY_PST 0x03
407 1.2.6.2 yamt #define ADCTSC_AUTO_PST (1<<2)
408 1.2.6.2 yamt #define ADCTSC_PULL_UP (1<<3)
409 1.2.6.2 yamt #define ADCTSC_XP_SEN (1<<4)
410 1.2.6.2 yamt #define ADCTSC_XM_SEN (1<<5)
411 1.2.6.2 yamt #define ADCTSC_YP_SEN (1<<6)
412 1.2.6.2 yamt #define ADCTSC_YM_SEN (1<<7)
413 1.2.6.2 yamt #define ADCTSC_UD_SEN (1<<8)
414 1.2.6.2 yamt #define ADC_ADCDLY 0x08
415 1.2.6.2 yamt #define ADC_ADCDAT0 0x0c
416 1.2.6.2 yamt #define ADC_ADCDAT1 0x10
417 1.2.6.2 yamt #define ADC_ADCUPDN 0x14
418 1.2.6.2 yamt #define ADCUPDN_TSC_DN (1<<0)
419 1.2.6.2 yamt #define ADCUPDN_TSC_UP (1<<1)
420 1.2.6.2 yamt
421 1.2.6.2 yamt
422 1.2.6.2 yamt #define ADCDAT_DATAMASK 0x3ff
423 1.2.6.2 yamt
424 1.2.6.2 yamt /* DMA */
425 1.2.6.2 yamt #define S3C2440_DMA_CHANNELS 4
426 1.2.6.2 yamt #define S3C2440_DMA_SIZE 0x40
427 1.2.6.2 yamt #define DMA_OFFSET(ch) ch*S3C2440_DMA_SIZE
428 1.2.6.2 yamt #define DMA_DISRC_BASE 0x000000
429 1.2.6.2 yamt #define DMA_DISRC(ch) (DMA_DISRC_BASE+DMA_OFFSET(ch))
430 1.2.6.2 yamt #define DISRC_MASK 0x7FFFFFFF /* Only 31 bits are used */
431 1.2.6.2 yamt #define DMA_DISRCC_BASE 0x000004
432 1.2.6.2 yamt #define DMA_DISRCC(ch) (DMA_DISRCC_BASE+DMA_OFFSET(ch))
433 1.2.6.2 yamt #define DISRCC_INC_INC (0<<0)
434 1.2.6.2 yamt #define DISRCC_INC_FIXED (1<<0)
435 1.2.6.2 yamt #define DISRCC_LOC_AHB (0<<1)
436 1.2.6.2 yamt #define DISRCC_LOC_APB (1<<1)
437 1.2.6.2 yamt #define DMA_DIDST_BASE 0x000008
438 1.2.6.2 yamt #define DMA_DIDST(ch) (DMA_DIDST_BASE+DMA_OFFSET(ch))
439 1.2.6.2 yamt #define DIDST_MASK 0x7FFFFFFF /* Only 31 bits are used */
440 1.2.6.2 yamt #define DMA_DIDSTC_BASE 0x00000C
441 1.2.6.2 yamt #define DMA_DIDSTC(ch) (DMA_DIDSTC_BASE+DMA_OFFSET(ch))
442 1.2.6.2 yamt #define DIDSTC_INC_INC (0<<0)
443 1.2.6.2 yamt #define DIDSTC_INC_FIXED (1<<0)
444 1.2.6.2 yamt #define DIDSTC_LOC_AHB (0<<1)
445 1.2.6.2 yamt #define DIDSTC_LOC_APB (1<<1)
446 1.2.6.2 yamt #define DIDSTC_INT_TC (0<<2)
447 1.2.6.2 yamt #define DIDSTC_INT_AUTO_RELOAD (1<<2)
448 1.2.6.2 yamt #define DMA_CON_BASE 0x000010
449 1.2.6.2 yamt #define DMA_CON(ch) (DMA_CON_BASE+DMA_OFFSET(ch))
450 1.2.6.2 yamt #define DMACON_TC_MASK 0xFFFFF
451 1.2.6.2 yamt #define DMACON_TC(val) (val & DMACON_TC_MASK)
452 1.2.6.2 yamt #define DMACON_DSZ_B (0<<20)
453 1.2.6.2 yamt #define DMACON_DSZ_HW (1<<20)
454 1.2.6.2 yamt #define DMACON_DSZ_W (2<<20)
455 1.2.6.2 yamt #define DMACON_RELOAD_AUTO (0<<22)
456 1.2.6.2 yamt #define DMACON_RELOAD_NO_AUTO (1<<22)
457 1.2.6.2 yamt #define DMACON_SW_REQ (0<<23)
458 1.2.6.2 yamt #define DMACON_HW_REQ (1<<23)
459 1.2.6.2 yamt #define DMACON_HW_SRCSEL_MASK (0x7)
460 1.2.6.2 yamt #define DMACON_HW_SRCSEL_SHIFT 24
461 1.2.6.2 yamt #define DMACON_HW_SRCSEL(v) ( (v & DMACON_HW_SRCSEL_MASK) << DMACON_HW_SRCSEL_SHIFT)
462 1.2.6.2 yamt #define DMACON_SERVMODE_SINGLE (0<<27)
463 1.2.6.2 yamt #define DMACON_SERVMODE_WHOLE (1<<27)
464 1.2.6.2 yamt #define DMACON_TSZ_UNIT (0<<28)
465 1.2.6.2 yamt #define DMACON_TSZ_BURST (1<<28)
466 1.2.6.2 yamt #define DMACON_INT_POLL (0<<29)
467 1.2.6.2 yamt #define DMACON_INT_INT (1<<29)
468 1.2.6.2 yamt #define DMACON_SYNC_APB (0<<30)
469 1.2.6.2 yamt #define DMACON_SYNC_AHB (1<<30)
470 1.2.6.2 yamt #define DMACON_DEMAND (0<<31)
471 1.2.6.2 yamt #define DMACON_HANDSHAKE (1<<31)
472 1.2.6.2 yamt #define DMA_STAT_BASE 0x000014
473 1.2.6.2 yamt #define DMA_STAT(ch) (DMA_STAT_BASE + DMA_OFFSET(ch))
474 1.2.6.2 yamt #define DMASTAT_CURR_TC_MASK 0xFFFFF
475 1.2.6.2 yamt #define DMASTAT_CURR_TC(v) (DMASTAT_CURR_TC_MASK & v)
476 1.2.6.2 yamt #define DMASTAT_BUSY (1<<20)
477 1.2.6.2 yamt #define DMA_CSRC_BASE 0x000018
478 1.2.6.2 yamt #define DMA_CSRC(ch) (DMA_CSRC_BASE + DMA_OFFSET(ch))
479 1.2.6.2 yamt #define DMA_CDST_BASE 0x00001C
480 1.2.6.2 yamt #define DMA_CDST(ch) (DMA_CDST_BASE + DMA_OFFSET(ch))
481 1.2.6.2 yamt #define DMA_MASKTRIG_BASE 0x000020
482 1.2.6.2 yamt #define DMA_MASKTRIG(ch) (DMA_MASKTRIG_BASE + DMA_OFFSET(ch))
483 1.2.6.2 yamt #define DMAMASKTRIG_SW_TRIG (1<<0)
484 1.2.6.2 yamt #define DMAMASKTRIG_HW_TRIG (0<<0)
485 1.2.6.2 yamt #define DMAMASKTRIG_OFF (0<<1)
486 1.2.6.2 yamt #define DMAMASKTRIG_ON (1<<1)
487 1.2.6.2 yamt #define DMAMASKTRIG_STOP (1<<2)
488 1.2.6.2 yamt
489 1.2.6.2 yamt #define IISCON 0x0
490 1.2.6.2 yamt #define IISCON_IFACE_EN (1<<0)
491 1.2.6.2 yamt #define IISCON_PRESCALER_EN (1<<1)
492 1.2.6.2 yamt #define IISCON_RX_IDLE (1<<2)
493 1.2.6.2 yamt #define IISCON_TX_IDLE (1<<3)
494 1.2.6.2 yamt #define IISCON_RX_DMA_EN (1<<4)
495 1.2.6.2 yamt #define IISCON_TX_DMA_EN (1<<5)
496 1.2.6.2 yamt #define IISCON_RX_FIFO_RDY (1<<6)
497 1.2.6.2 yamt #define IISCON_TX_FIFO_RDY (1<<7)
498 1.2.6.2 yamt #define IISCON_CHANNEL_RIGHT (1<<8)
499 1.2.6.2 yamt #define IISMOD 0x04
500 1.2.6.2 yamt #define IISMOD_SERIAL_FREQ_MASK (0x03)
501 1.2.6.2 yamt #define IISMOD_SERIAL_FREQ_SHIFT (0)
502 1.2.6.2 yamt #define IISMOD_SERIAL_FREQ(val) ((val << IISMOD_SERIAL_FREQ_SHIFT) & IISMOD_SERIAL_FREQ_MASK)
503 1.2.6.2 yamt #define IISMOD_SERIAL_FREQ16 IISMOD_SERIAL_FREQ(0)
504 1.2.6.2 yamt #define IISMOD_SERIAL_FREQ32 IISMOD_SERIAL_FREQ(1)
505 1.2.6.2 yamt #define IISMOD_SERIAL_FREQ48 IISMOD_SERIAL_FREQ(2)
506 1.2.6.2 yamt #define IISMOD_MASTER_FREQ256 (0<<2)
507 1.2.6.2 yamt #define IISMOD_MASTER_FREQ384 (1<<2)
508 1.2.6.2 yamt #define IISMOD_16BIT (1<<3)
509 1.2.6.2 yamt #define IISMOD_IFACE_MSB (1<<4)
510 1.2.6.2 yamt #define IISMOD_LEFT_HIGH (1<<5)
511 1.2.6.2 yamt #define IISMOD_MODE_MASK (0xC0)
512 1.2.6.2 yamt #define IISMOD_MODE_SHIFT (6)
513 1.2.6.2 yamt
514 1.2.6.2 yamt #if 0
515 1.2.6.2 yamt #define IISMOD_MODE(val) ((val << IISMOD_MODE_SHIFT) & IISMOD_MODE_MASK)
516 1.2.6.2 yamt #define IISMOD_MODE_NO_XFER IISMOD_MODE(0)
517 1.2.6.2 yamt #define IISMOD_MODE_RECEIVE IISMOD_MODE(1)
518 1.2.6.2 yamt #define IISMOD_MODE_TRANSMIT IISMOD_MODE(2)
519 1.2.6.2 yamt #define IISMOD_MODE_BOTH IISMOD_MODE(3)
520 1.2.6.2 yamt #endif
521 1.2.6.2 yamt #define IISMOD_MODE_RECEIVE (1<<6)
522 1.2.6.2 yamt #define IISMOD_MODE_TRANSMIT (1<<7)
523 1.2.6.2 yamt #define IISMOD_SLAVE (1<<8)
524 1.2.6.2 yamt #define IISMOD_CLOCK_MPLL (1<<9)
525 1.2.6.2 yamt #define IISPSR 0x08
526 1.2.6.2 yamt #define IISPSR_PRESCALER_A_MASK (0x3E0)
527 1.2.6.2 yamt #define IISPSR_PRESCALER_A_SHIFT (5)
528 1.2.6.2 yamt #define IISPSR_PRESCALER_A(val) (((val) << IISPSR_PRESCALER_A_SHIFT) & IISPSR_PRESCALER_A_MASK)
529 1.2.6.2 yamt #define IISPSR_PRESCALER_B_MASK (0x1F)
530 1.2.6.2 yamt #define IISPSR_PRESCALER_B_SHIFT (0)
531 1.2.6.2 yamt #define IISPSR_PRESCALER_B(val) (((val) << IISPSR_PRESCALER_B_SHIFT) & IISPSR_PRESCALER_B_MASK)
532 1.2.6.2 yamt #define IISFCON 0x0C
533 1.2.6.2 yamt #define IISFCON_RX_COUNT_MASK (0x3F)
534 1.2.6.2 yamt #define IISFCON_RX_COUNT_SHIFT 0
535 1.2.6.2 yamt #define IISFCON_TX_COUNT_MASK (0xFC0)
536 1.2.6.2 yamt #define IISFCON_TX_COUNT_SHIFT 6
537 1.2.6.2 yamt #define IISFCON_RX_FIFO_EN (1<<12)
538 1.2.6.2 yamt #define IISFCON_TX_FIFO_EN (1<<13)
539 1.2.6.2 yamt #define IISFCON_RX_DMA_EN (1<<14)
540 1.2.6.2 yamt #define IISFCON_TX_DMA_EN (1<<15)
541 1.2.6.2 yamt #define IISFIFO 0x10
542 1.2.6.2 yamt #define IISFIFO_FENTRY_MASK (0xFFFF)
543 1.2.6.2 yamt
544 1.2.6.2 yamt
545 1.2.6.2 yamt #endif /* _ARM_S3C2XX0_S3C2440REG_H_ */
546