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