Home | History | Annotate | Line # | Download | only in s3c2xx0
s3c2440reg.h revision 1.2
      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