[BACK]Return to s3c2410reg.h CVS log [TXT][DIR] Up to [local] / sys / arch / arm / s3c2xx0

Annotation of sys/arch/arm/s3c2xx0/s3c2410reg.h, Revision 1.1.1.1

1.1       nbrk        1: /* $NetBSD: s3c2410reg.h,v 1.7 2005/12/11 12:16:51 christos Exp $ */
                      2:
                      3: /*
                      4:  * Copyright (c) 2003, 2004  Genetec corporation.  All rights reserved.
                      5:  * Written by Hiroyuki Bessho for Genetec corporation.
                      6:  *
                      7:  * Redistribution and use in source and binary forms, with or without
                      8:  * modification, are permitted provided that the following conditions
                      9:  * are met:
                     10:  * 1. Redistributions of source code must retain the above copyright
                     11:  *    notice, this list of conditions and the following disclaimer.
                     12:  * 2. Redistributions in binary form must reproduce the above copyright
                     13:  *    notice, this list of conditions and the following disclaimer in the
                     14:  *    documentation and/or other materials provided with the distribution.
                     15:  * 3. The name of Genetec corporation may not be used to endorse
                     16:  *    or promote products derived from this software without specific prior
                     17:  *    written permission.
                     18:  *
                     19:  * THIS SOFTWARE IS PROVIDED BY GENETEC CORP. ``AS IS'' AND
                     20:  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
                     21:  * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
                     22:  * PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL GENETEC CORP.
                     23:  * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
                     24:  * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
                     25:  * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
                     26:  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
                     27:  * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
                     28:  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
                     29:  * POSSIBILITY OF SUCH DAMAGE.
                     30:  */
                     31:
                     32:
                     33: /*
                     34:  * Samsung S3C2410X processor is ARM920T based integrated CPU
                     35:  *
                     36:  * Reference:
                     37:  *  S3C2410X User's Manual
                     38:  */
                     39: #ifndef _ARM_S3C2XX0_S3C2410REG_H_
                     40: #define        _ARM_S3C2XX0_S3C2410REG_H_
                     41:
                     42: /* common definitions for S3C2800, S3C2400 and S3C2410 */
                     43: #include <arm/s3c2xx0/s3c2xx0reg.h>
                     44: /* common definitions for S3C2400 and S3C2410 */
                     45: #include <arm/s3c2xx0/s3c24x0reg.h>
                     46:
                     47: /*
                     48:  * Memory Map
                     49:  */
                     50: #define        S3C2410_BANK_SIZE       0x08000000
                     51: #define        S3C2410_BANK_START(n)   (S3C2410_BANK_SIZE*(n))
                     52: #define        S3C2410_SDRAM_START     S3C2410_BANK_START(6)
                     53:
                     54: /*
                     55:  * Physical address of integrated peripherals
                     56:  */
                     57: #define        S3C2410_MEMCTL_BASE     0x48000000 /* memory controller */
                     58: #define        S3C2410_USBHC_BASE      0x49000000 /* USB Host controller */
                     59: #define        S3C2410_INTCTL_BASE     0x4a000000 /* Interrupt controller */
                     60: #define        S3C2410_DMAC_BASE       0x4b000000
                     61: #define        S3C2410_DMAC_SIZE       0xe4
                     62: #define        S3C2410_CLKMAN_BASE     0x4c000000 /* clock & power management */
                     63: #define        S3C2410_LCDC_BASE       0x4d000000 /* LCD controller */
                     64: #define        S3C2410_NANDFC_BASE     0x4e000000 /* NAND Flash controller */
                     65: #define        S3C2410_NANDFC_SIZE     0x18
                     66: #define        S3C2410_UART0_BASE      0x50000000
                     67: #define        S3C2410_UART_BASE(n)    (S3C2410_UART0_BASE+0x4000*(n))
                     68: #define        S3C2410_TIMER_BASE      0x51000000
                     69: #define        S3C2410_USBDC_BASE      0x5200140
                     70: #define        S3C2410_USBDC_SIZE      0x130
                     71: #define        S3C2410_WDT_BASE        0x53000000
                     72: #define        S3C2410_IIC_BASE        0x54000000
                     73: #define        S3C2410_IIS_BASE        0x55000000
                     74: #define        S3C2410_GPIO_BASE       0x56000000
                     75: #define        S3C2410_GPIO_SIZE       0xb4
                     76: #define        S3C2410_ADC_BASE        0x58000000
                     77: #define        S3C2410_ADC_SIZE        0x14
                     78: #define        S3C2410_SPI0_BASE       0x59000000
                     79: #define        S3C2410_SPI1_BASE       0x59000020
                     80: #define        S3C2410_SDI_BASE        0x5a000000 /* SD Interface */
                     81: #define        S3C2410_SDI_SIZE        0x44
                     82:
                     83: /* interrupt control (additional defs for 2410) */
                     84: #define        ICU_LEN (32+11)
                     85:
                     86: #define        INTCTL_SUBSRCPND        0x18    /* sub source pending (2410 only) */
                     87: #define        INTCTL_INTSUBMSK        0x1c    /* sub mask (2410 only) */
                     88:
                     89: /* 2410 has more than 32 interrupt sources.  These are sub-sources
                     90:  * that are OR-ed into main interrupt sources, and controlled via
                     91:  * SUBSRCPND and  SUBSRCMSK registers */
                     92:
                     93: #define        S3C2410_SUBIRQ_MIN      32
                     94: #define        S3C2410_SUBIRQ_MAX      (32+10)
                     95:
                     96: /* cascaded to INT_ADCTC */
                     97: #define        S3C2410_INT_ADC         (S3C2410_SUBIRQ_MIN+10) /* AD converter */
                     98: #define        S3C2410_INT_TC          (S3C2410_SUBIRQ_MIN+9)  /* Touch screen */
                     99: /* cascaded to INT_UART2 */
                    100: #define        S3C2410_INT_ERR2        (S3C2410_SUBIRQ_MIN+8)  /* UART2 Error interrupt */
                    101: #define        S3C2410_INT_TXD2        (S3C2410_SUBIRQ_MIN+7)  /* UART2 Tx interrupt */
                    102: #define        S3C2410_INT_RXD2        (S3C2410_SUBIRQ_MIN+6)  /* UART2 Rx interrupt */
                    103: /* cascaded to INT_UART1 */
                    104: #define        S3C2410_INT_ERR1        (S3C2410_SUBIRQ_MIN+5)  /* UART1 Error interrupt */
                    105: #define        S3C2410_INT_TXD1        (S3C2410_SUBIRQ_MIN+4)  /* UART1 Tx interrupt */
                    106: #define        S3C2410_INT_RXD1        (S3C2410_SUBIRQ_MIN+3)  /* UART1 Rx interrupt */
                    107: /* cascaded to INT_UART0 */
                    108: #define        S3C2410_INT_ERR0        (S3C2410_SUBIRQ_MIN+2)  /* UART0 Error interrupt */
                    109: #define        S3C2410_INT_TXD0        (S3C2410_SUBIRQ_MIN+1)  /* UART0 Tx interrupt */
                    110: #define        S3C2410_INT_RXD0        (S3C2410_SUBIRQ_MIN+0)  /* UART0 Rx interrupt */
                    111:
                    112: #define        S3C2410_INTCTL_SIZE     0x20
                    113:
                    114:
                    115: /* Clock control */
                    116: #define        CLKMAN_LOCKTIME 0x00
                    117: #define        CLKMAN_MPLLCON  0x04
                    118: #define        CLKMAN_UPLLCON  0x08
                    119: #define        CLKMAN_CLKCON   0x0c
                    120: #define         CLKCON_SPI     (1<<18)
                    121: #define         CLKCON_IIS     (1<<17)
                    122: #define         CLKCON_IIC     (1<<16)
                    123: #define         CLKCON_ADC     (1<<15)
                    124: #define         CLKCON_RTC     (1<<14)
                    125: #define         CLKCON_GPIO    (1<<13)
                    126: #define         CLKCON_UART2   (1<<12)
                    127: #define         CLKCON_UART1   (1<<11)
                    128: #define         CLKCON_UART0   (1<<10) /* PCLK to UART0 */
                    129: #define         CLKCON_SDI     (1<<9)
                    130: #define         CLKCON_TIMER   (1<<8)  /* PCLK to TIMER */
                    131: #define         CLKCON_USBD    (1<<7)  /* PCLK to USB device controller */
                    132: #define         CLKCON_USBH    (1<<6)  /* PCLK to USB host controller */
                    133: #define         CLKCON_LCDC    (1<<5)  /* PCLK to LCD controller */
                    134: #define         CLKCON_NANDFC  (1<<4)  /* PCLK to NAND Flash controller */
                    135: #define         CLKCON_IDLE    (1<<2)  /* 1=transition to IDLE mode */
                    136: #define         CLKCON_STOP    (1<<0)  /* 1=transition to STOP mode */
                    137: #define        CLKMAN_CLKSLOW  0x10
                    138: #define        CLKMAN_CLKDIVN  0x14
                    139: #define         CLKDIVN_HDIVN  (1<<1)  /* hclk=fclk/2 */
                    140: #define         CLKDIVN_PDIVN  (1<<0)  /* pclk=hclk/2 */
                    141:
                    142: /* NAND Flash controller */
                    143: #define        NANDFC_NFCONF   0x00    /* Configuration */
                    144: #define        NANDFC_NFCMD    0x04    /* command */
                    145: #define        NANDFC_NFADDR   0x08    /* address */
                    146: #define        NANDFC_NFDATA   0x0c    /* data */
                    147: #define        NANDFC_NFSTAT   0x10    /* operation status */
                    148: #define        NANDFC_NFECC    0x14    /* ecc */
                    149:
                    150: /* GPIO */
                    151: #define        GPIO_PACON      0x00    /* port A configuration */
                    152: #define         PCON_INPUT     0       /* Input port */
                    153: #define         PCON_OUTPUT    1       /* Output port */
                    154: #define         PCON_ALTFUN    2       /* Alternate function */
                    155: #define         PCON_ALTFUN2   3       /* Alternate function */
                    156: #define        GPIO_PADAT      0x04    /* port A data */
                    157: #define        GPIO_PBCON      0x10
                    158: #define        GPIO_PBDAT      0x14
                    159: #define        GPIO_PBUP       0x18
                    160: #define        GPIO_PCCON      0x20
                    161: #define        GPIO_PCDAT      0x24
                    162: #define        GPIO_PCUP       0x28
                    163: #define        GPIO_PDCON      0x30
                    164: #define        GPIO_PDDAT      0x34
                    165: #define        GPIO_PDUP       0x38
                    166: #define        GPIO_PECON      0x40
                    167: #define        GPIO_PEDAT      0x44
                    168: #define        GPIO_PEUP       0x48
                    169: #define        GPIO_PFCON      0x50
                    170: #define        GPIO_PFDAT      0x54
                    171: #define        GPIO_PFUP       0x58
                    172: #define        GPIO_PGCON      0x60
                    173: #define        GPIO_PGDAT      0x64
                    174: #define        GPIO_PGUP       0x68
                    175: #define        GPIO_PHCON      0x70
                    176: #define        GPIO_PHDAT      0x74
                    177: #define        GPIO_PHUP       0x78
                    178: #define        GPIO_MISCCR     0x80    /* miscellaneous control */
                    179: #define        GPIO_DCLKCON    0x84    /* DCLK 0/1 */
                    180: #define        GPIO_EXTINT(n)  (0x88+4*(n))    /* external int control 0/1/2 */
                    181: #define        GPIO_EINTFLT(n) (0x94+4*(n))    /* external int filter control 0..3 */
                    182: #define        GPIO_EINTMASK   0xa4
                    183: #define        GPIO_EINTPEND   0xa8
                    184: #define        GPIO_GSTATUS0   0xac    /* external pin status */
                    185: #define        GPIO_GSTATUS1   0xb0    /* external pin status */
                    186:
                    187: #define        GPIO_SET_FUNC(v,port,func)      \
                    188:                (((v) & ~(3<<(2*(port))))|((func)<<(2*(port))))
                    189:
                    190: #define         EXTINTR_LOW     0x00
                    191: #define         EXTINTR_HIGH    0x01
                    192: #define         EXTINTR_FALLING 0x02
                    193: #define         EXTINTR_RISING  0x04
                    194: #define         EXTINTR_BOTH    0x06
                    195:
                    196: /* SD interface */
                    197: /* XXX */
                    198:
                    199: /* ADC */
                    200: /* XXX: ADCCON register is common to both S3C2410 and S3C2400,
                    201:  *      but other registers are different.
                    202:  */
                    203: #define        ADC_ADCCON      0x00
                    204: #define         ADCCON_ENABLE_START    (1<<0)
                    205: #define         ADCCON_READ_START      (1<<1)
                    206: #define         ADCCON_STDBM           (1<<2)
                    207: #define         ADCCON_SEL_MUX_SHIFT   3
                    208: #define         ADCCON_SEL_MUX_MASK    (0x7<<ADCCON_SEL_MUX_SHIFT)
                    209: #define         ADCCON_PRSCVL_SHIFT    6
                    210: #define         ADCCON_PRSCVL_MASK     (0xff<<ADCCON_PRSCVL_SHIFT)
                    211: #define         ADCCON_PRSCEN          (1<<14)
                    212: #define         ADCCON_ECFLG           (1<<15)
                    213:
                    214: #define        ADC_ADCTSC      0x04
                    215: #define         ADCTSC_XY_PST          0x03
                    216: #define         ADCTSC_AUTO_PST        (1<<2)
                    217: #define         ADCTSC_PULL_UP         (1<<3)
                    218: #define         ADCTSC_XP_SEN          (1<<4)
                    219: #define         ADCTSC_XM_SEN          (1<<5)
                    220: #define         ADCTSC_YP_SEN          (1<<6)
                    221: #define         ADCTSC_YM_SEN          (1<<7)
                    222: #define         ADCTSC_UD_SEN          (1<<8)
                    223: #define        ADC_ADCDLY      0x08
                    224: #define        ADC_ADCDAT0     0x0c
                    225: #define        ADC_ADCDAT1     0x10
                    226:
                    227: #define        ADCDAT_DATAMASK         0x3ff
                    228:
                    229: #endif /* _ARM_S3C2XX0_S3C2410REG_H_ */

CVSweb