diff options
Diffstat (limited to 'include')
| -rw-r--r-- | include/asm-ppc/status_led.h | 77 | ||||
| -rw-r--r-- | include/configs/MPC8260ADS.h | 41 | ||||
| -rw-r--r-- | include/configs/VCMA9.h | 75 | ||||
| -rw-r--r-- | include/configs/smdk2400.h | 8 | ||||
| -rw-r--r-- | include/configs/smdk2410.h | 23 | ||||
| -rw-r--r-- | include/configs/trab.h | 5 | ||||
| -rw-r--r-- | include/s3c2400.h | 130 | ||||
| -rw-r--r-- | include/s3c2410.h | 602 | ||||
| -rw-r--r-- | include/s3c24x0.h | 1135 | ||||
| -rw-r--r-- | include/status_led.h | 4 | 
10 files changed, 1602 insertions, 498 deletions
| diff --git a/include/asm-ppc/status_led.h b/include/asm-ppc/status_led.h new file mode 100644 index 000000000..eb81f371c --- /dev/null +++ b/include/asm-ppc/status_led.h @@ -0,0 +1,77 @@ +/* + * asm/status_led.h + * + * MPC8xx/MPC8260/MPC5xx based status led support functions + */ + +#ifndef __ASM_STATUS_LED_H__ +#define __ASM_STATUS_LED_H__ + +/* if not overriden */ +#ifndef CONFIG_BOARD_SPECIFIC_LED +# if defined(CONFIG_8xx) +#  include <mpc8xx.h> +# elif defined(CONFIG_8260) +#  include <mpc8260.h> +# elif defined(CONFIG_5xx) +#  include <mpc5xx.h> +# else +#  error CPU specific Status LED header file missing. +#endif + +/* led_id_t is unsigned long mask */ +typedef unsigned long led_id_t; + +static inline void __led_init (led_id_t mask, int state) +{ +	volatile immap_t *immr = (immap_t *) CFG_IMMR; + +#ifdef STATUS_LED_PAR +	immr->STATUS_LED_PAR &= ~mask; +#endif +#ifdef STATUS_LED_ODR +	immr->STATUS_LED_ODR &= ~mask; +#endif + +#if (STATUS_LED_ACTIVE == 0) +	if (state == STATUS_LED_ON) +		immr->STATUS_LED_DAT &= ~mask; +	else +		immr->STATUS_LED_DAT |= mask; +#else +	if (state == STATUS_LED_ON) +		immr->STATUS_LED_DAT |= mask; +	else +		immr->STATUS_LED_DAT &= ~mask; +#endif +#ifdef STATUS_LED_DIR +	immr->STATUS_LED_DIR |= mask; +#endif +} + +static inline void __led_toggle (led_id_t mask) +{ +	((immap_t *) CFG_IMMR)->STATUS_LED_DAT ^= mask; +} + +static inline void __led_set (led_id_t mask, int state) +{ +	volatile immap_t *immr = (immap_t *) CFG_IMMR; + +#if (STATUS_LED_ACTIVE == 0) +	if (state == STATUS_LED_ON) +		immr->STATUS_LED_DAT &= ~mask; +	else +		immr->STATUS_LED_DAT |= mask; +#else +	if (state == STATUS_LED_ON) +		immr->STATUS_LED_DAT |= mask; +	else +		immr->STATUS_LED_DAT &= ~mask; +#endif + +} + +#endif + +#endif	/* __ASM_STATUS_LED_H__ */ diff --git a/include/configs/MPC8260ADS.h b/include/configs/MPC8260ADS.h index 30b72076e..dc2c31319 100644 --- a/include/configs/MPC8260ADS.h +++ b/include/configs/MPC8260ADS.h @@ -26,10 +26,6 @@   * MA 02111-1307 USA   */ -/* - * Config header file for a MPC8260ADS Pilot 16M Ram Simm, 8Mbytes Flash Simm - */ -  #ifndef __CONFIG_H  #define __CONFIG_H @@ -77,23 +73,45 @@  #undef	CONFIG_ETHER_ON_SCC		/* define if ether on SCC   */  #define CONFIG_ETHER_ON_FCC		/* define if ether on FCC   */  #undef	CONFIG_ETHER_NONE		/* define if ether on something else */ -#define CONFIG_ETHER_INDEX	2	/* which channel for ether  */ -#if (CONFIG_ETHER_INDEX == 2) +#ifdef CONFIG_ETHER_ON_FCC +#define CONFIG_ETHER_INDEX	2	/* which SCC/FCC channel for ethernet */ + +#if (CONFIG_ETHER_INDEX == 2)  /*   * - Rx-CLK is CLK13   * - Tx-CLK is CLK14   * - Select bus for bd/buffers (see 28-13) - * - Half duplex + * - Full duplex   */  # define CFG_CMXFCR_MASK	(CMXFCR_FC2 | CMXFCR_RF2CS_MSK | CMXFCR_TF2CS_MSK)  # define CFG_CMXFCR_VALUE	(CMXFCR_RF2CS_CLK13 | CMXFCR_TF2CS_CLK14)  # define CFG_CPMFCR_RAMTYPE	0 -# define CFG_FCC_PSMR		0 +# define CFG_FCC_PSMR		(FCC_PSMR_FDE | FCC_PSMR_LPB)  #endif	/* CONFIG_ETHER_INDEX */ +#define CONFIG_MII			/* MII PHY management		*/ +#define CONFIG_BITBANGMII		/* bit-bang MII PHY management	*/ +/* + * GPIO pins used for bit-banged MII communications + */ +#define MDIO_PORT	2		/* Port C */ +#define MDIO_ACTIVE	(iop->pdir |=  0x00400000) +#define MDIO_TRISTATE	(iop->pdir &= ~0x00400000) +#define MDIO_READ	((iop->pdat &  0x00400000) != 0) + +#define MDIO(bit)	if(bit) iop->pdat |=  0x00400000; \ +			else	iop->pdat &= ~0x00400000 + +#define MDC(bit)	if(bit) iop->pdat |=  0x00200000; \ +			else	iop->pdat &= ~0x00200000 + +#define MIIDELAY	udelay(1) + +#endif /* CONFIG_ETHER_ON_FCC */ +  /* other options */  #define CONFIG_HARD_I2C		1	/* To enable I2C support	*/  #define CFG_I2C_SPEED		400000	/* I2C speed and slave address	*/ @@ -172,9 +190,6 @@  #define CFG_MEMTEST_START	0x00100000	/* memtest works on */  #define CFG_MEMTEST_END		0x00f00000	/* 1 ... 15 MB in DRAM	*/ -#define CONFIG_CLOCKS_IN_MHZ	1	/* clocks passsed to Linux in MHz */ -					/* for versions < 2.4.5-pre5	*/ -  #define CFG_LOAD_ADDR		0x100000	/* default load address */  #define CFG_HZ			1000	/* decrementer freq: 1 ms ticks */ @@ -239,8 +254,8 @@  #ifndef CFG_RAMBOOT  #  define CFG_ENV_IS_IN_FLASH	1 -#    define CFG_ENV_ADDR	(CFG_MONITOR_BASE + 0x40000) -#    define CFG_ENV_SECT_SIZE	0x40000 +#  define CFG_ENV_SECT_SIZE	0x40000 +#  define CFG_ENV_ADDR		(CFG_MONITOR_BASE + CFG_ENV_SECT_SIZE)  #else  #  define CFG_ENV_IS_IN_NVRAM	1  #  define CFG_ENV_ADDR		(CFG_MONITOR_BASE - 0x1000) diff --git a/include/configs/VCMA9.h b/include/configs/VCMA9.h index a73281c02..c0103fc33 100644 --- a/include/configs/VCMA9.h +++ b/include/configs/VCMA9.h @@ -59,9 +59,13 @@  #define CONFIG_COMMANDS \  			(CONFIG_CMD_DFL	 | \  			CFG_CMD_CACHE	 | \ +			/*CFG_CMD_JFFS2	 |*/ \ +			/*CFG_CMD_NAND	 |*/ \  			CFG_CMD_EEPROM	 | \  			CFG_CMD_I2C	 | \ +			/*CFG_CMD_USB	 |*/ \  			CFG_CMD_REGINFO  | \ +			CFG_CMD_DATE	 | \  			CFG_CMD_ELF	 | \  			CFG_CMD_BSP) @@ -111,6 +115,24 @@   */  #define CONFIG_SERIAL1          1	/* we use SERIAL 1 on VCMA9 */ +/************************************************************ + * USB support + ************************************************************/ +#if 0 +#define CONFIG_USB_OHCI +#define CONFIG_USB_KEYBOARD +#define CONFIG_USB_STORAGE + +/* Enable needed helper functions */ +#define CFG_DEVICE_DEREGISTER		/* needs device_deregister */ +#endif + +/************************************************************ + * RTC + ************************************************************/ +#define	CONFIG_RTC_S3C24X0	1 + +  /* allow to overwrite serial and ethaddr */  #define CONFIG_ENV_OVERWRITE @@ -138,7 +160,7 @@  #define CFG_BARGSIZE		CFG_CBSIZE	/* Boot Argument Buffer Size	*/  #define CFG_MEMTEST_START	0x30000000	/* memtest works on	*/ -#define CFG_MEMTEST_END		0x33F00000	/* 63 MB in DRAM	*/ +#define CFG_MEMTEST_END		0x33F80000	/* 63.5 MB in DRAM	*/  #define CFG_ALT_MEMTEST  #define	CFG_LOAD_ADDR		0x33000000	/* default load address	*/ @@ -152,6 +174,13 @@  /* valid baudrates */  #define CFG_BAUDRATE_TABLE	{ 9600, 19200, 38400, 57600, 115200 } +/************************************************************ + * Ident + ************************************************************/ +/*#define VERSION_TAG "released"*/ +#define VERSION_TAG "unstable" +#define CONFIG_IDENT_STRING "\n(c) 2003 by MPL AG Switzerland, MEV-10080-001 " VERSION_TAG +  /*-----------------------------------------------------------------------   * Stack sizes   * @@ -204,6 +233,48 @@  #define CFG_ENV_SIZE		0x10000	/* Total Size of Environment Sector */  #endif -#define MULTI_PURPOSE_SOCKET_ADDR 0 + +#define CFG_JFFS2_FIRST_BANK	0 +#define CFG_JFFS2_NUM_BANKS	1 + +#define MULTI_PURPOSE_SOCKET_ADDR 0x08000000 + +/*----------------------------------------------------------------------- + * NAND flash settings + */ +#if (CONFIG_COMMANDS & CFG_CMD_NAND) + +#define CFG_MAX_NAND_DEVICE	1	/* Max number of NAND devices		*/ +#define SECTORSIZE 512 + +#define ADDR_COLUMN 1 +#define ADDR_PAGE 2 +#define ADDR_COLUMN_PAGE 3 + +#define NAND_ChipID_UNKNOWN 	0x00 +#define NAND_MAX_FLOORS 1 +#define NAND_MAX_CHIPS 1 + +#define NAND_WAIT_READY(nand)	NF_WaitRB() + +#define NAND_DISABLE_CE(nand)	NF_SetCE(NFCE_HIGH) +#define NAND_ENABLE_CE(nand)	NF_SetCE(NFCE_LOW) + + +#define WRITE_NAND_COMMAND(d, adr)	NF_Cmd(d) +#define WRITE_NAND_COMMANDW(d, adr)	NF_CmdW(d) +#define WRITE_NAND_ADDRESS(d, adr)	NF_Addr(d) +#define WRITE_NAND(d, adr)		NF_Write(d) +#define READ_NAND(adr)			NF_Read() +/* the following functions are NOP's because S3C24X0 handles this in hardware */ +#define NAND_CTL_CLRALE(nandptr) +#define NAND_CTL_SETALE(nandptr) +#define NAND_CTL_CLRCLE(nandptr) +#define NAND_CTL_SETCLE(nandptr) + +#define CONFIG_MTD_NAND_VERIFY_WRITE	1 +#define CONFIG_MTD_NAND_ECC_JFFS2	1 + +#endif	/* CONFIG_COMMANDS & CFG_CMD_NAND */  #endif	/* __CONFIG_H */ diff --git a/include/configs/smdk2400.h b/include/configs/smdk2400.h index d0ad65ef2..a557bc6cf 100644 --- a/include/configs/smdk2400.h +++ b/include/configs/smdk2400.h @@ -86,10 +86,14 @@  #define	CONFIG_TIMESTAMP	1	/* Print timestamp info for images */ +/* Use s3c2400's RTC */ +#define CONFIG_RTC_S3C24X0	1 +  #ifndef USE_920T_MMU -#define CONFIG_COMMANDS_tmp	(CONFIG_CMD_DFL & ~CFG_CMD_CACHE) +#define CONFIG_COMMANDS_tmp	((CONFIG_CMD_DFL & ~CFG_CMD_CACHE) | \ +				 CFG_CMD_DATE)  #else -#define CONFIG_COMMANDS_tmp	(CONFIG_CMD_DFL) +#define CONFIG_COMMANDS_tmp	(CONFIG_CMD_DFL | CFG_CMD_DATE)  #endif  #ifdef CONFIG_HWFLOW diff --git a/include/configs/smdk2410.h b/include/configs/smdk2410.h index 65dd3fec2..0dcbbb063 100644 --- a/include/configs/smdk2410.h +++ b/include/configs/smdk2410.h @@ -67,16 +67,29 @@   */  #define CONFIG_SERIAL1          1	/* we use SERIAL 1 on SMDK2410 */ +/************************************************************ + * RTC + ************************************************************/ +#define	CONFIG_RTC_S3C24X0	1 +  /* allow to overwrite serial and ethaddr */  #define CONFIG_ENV_OVERWRITE  #define CONFIG_BAUDRATE		115200 -#ifndef USE_920T_MMU -#define CONFIG_COMMANDS		(CONFIG_CMD_DFL & ~CFG_CMD_CACHE) -#else -#define CONFIG_COMMANDS		(CONFIG_CMD_DFL) -#endif +/*********************************************************** + * Command definition + ***********************************************************/ +#define CONFIG_COMMANDS \ +			(CONFIG_CMD_DFL	 | \ +			CFG_CMD_CACHE	 | \ +			/*CFG_CMD_NAND	 |*/ \ +			/*CFG_CMD_EEPROM |*/ \ +			/*CFG_CMD_I2C	 |*/ \ +			/*CFG_CMD_USB	 |*/ \ +			CFG_CMD_REGINFO  | \ +			CFG_CMD_DATE	 | \ +			CFG_CMD_ELF)  /* this must be included AFTER the definition of CONFIG_COMMANDS (if any) */  #include <cmd_confdefs.h> diff --git a/include/configs/trab.h b/include/configs/trab.h index 2466189a8..15b6b1925 100644 --- a/include/configs/trab.h +++ b/include/configs/trab.h @@ -90,6 +90,9 @@  #define	CONFIG_TIMESTAMP	1	/* Print timestamp info for images */ +/* Use s3c2400's RTC */ +#define CONFIG_RTC_S3C24X0	1 +  #ifdef CONFIG_HWFLOW  #define CONFIG_COMMANDS_ADD_HWFLOW	CFG_CMD_HWFLOW  #else @@ -105,11 +108,13 @@  #ifndef USE_920T_MMU  #define CONFIG_COMMANDS		((CONFIG_CMD_DFL & ~CFG_CMD_CACHE) | \  				 CFG_CMD_BSP			| \ +				 CFG_CMD_DATE			| \  				 CONFIG_COMMANDS_ADD_HWFLOW	| \  				 CONFIG_COMMANDS_ADD_VFD	)  #else  #define CONFIG_COMMANDS		(CONFIG_CMD_DFL			| \  				 CFG_CMD_BSP			| \ +				 CFG_CMD_DATE			| \  				 CONFIG_COMMANDS_ADD_HWFLOW	| \  				 CONFIG_COMMANDS_ADD_VFD	)  #endif diff --git a/include/s3c2400.h b/include/s3c2400.h index 08eb3bc44..6269117b0 100644 --- a/include/s3c2400.h +++ b/include/s3c2400.h @@ -1,13 +1,138 @@ +/* + * (C) Copyright 2003 + * David Müller ELSOFT AG Switzerland. d.mueller@elsoft.ch + * + * See file CREDITS for list of people who contributed to this + * project. + * + * This program is free software; you can redistribute it and/or + * modify it under the terms of the GNU General Public License as + * published by the Free Software Foundation; either version 2 of + * the License, or (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program; if not, write to the Free Software + * Foundation, Inc., 59 Temple Place, Suite 330, Boston, + * MA 02111-1307 USA + */ +  /************************************************   * NAME	    : s3c2400.h - * Version  : 3.7.2002 + * Version  : 31.3.2003   * - * Based on 24x.h for the Samsung Development Board + * Based on S3C2400X User's manual Rev 1.1   ************************************************/  #ifndef __S3C2400_H__  #define __S3C2400_H__ +#define S3C24X0_UART_CHANNELS	2 +#define S3C24X0_SPI_CHANNELS	1 +#define PALETTE			(0x14A00400)	/* SJS */ + +typedef enum { +	S3C24X0_UART0, +	S3C24X0_UART1, +} S3C24X0_UARTS_NR; + +/* S3C2400 device base addresses */ +#define S3C24X0_MEMCTL_BASE		0x14000000 +#define S3C24X0_USB_HOST_BASE		0x14200000 +#define S3C24X0_INTERRUPT_BASE		0x14400000 +#define S3C24X0_DMA_BASE		0x14600000 +#define S3C24X0_CLOCK_POWER_BASE	0x14800000 +#define S3C24X0_LCD_BASE		0x14A00000 +#define S3C24X0_UART_BASE		0x15000000 +#define S3C24X0_TIMER_BASE		0x15100000 +#define S3C24X0_USB_DEVICE_BASE		0x15200140 +#define S3C24X0_WATCHDOG_BASE		0x15300000 +#define S3C24X0_I2C_BASE		0x15400000 +#define S3C24X0_I2S_BASE		0x15508000 +#define S3C24X0_GPIO_BASE		0x15600000 +#define S3C24X0_RTC_BASE		0x15700000 +#define S3C24X0_ADC_BASE		0x15800000 +#define S3C24X0_SPI_BASE		0x15900000 +#define S3C2400_MMC_BASE		0x15A00000 + +/* include common stuff */ +#include <s3c24x0.h> + + +static inline S3C24X0_MEMCTL * const S3C24X0_GetBase_MEMCTL(void) +{ +	return (S3C24X0_MEMCTL * const)S3C24X0_MEMCTL_BASE; +} +static inline S3C24X0_USB_HOST * const S3C24X0_GetBase_USB_HOST(void) +{ +	return (S3C24X0_USB_HOST * const)S3C24X0_USB_HOST_BASE; +} +static inline S3C24X0_INTERRUPT * const S3C24X0_GetBase_INTERRUPT(void) +{ +	return (S3C24X0_INTERRUPT * const)S3C24X0_INTERRUPT_BASE; +} +static inline S3C24X0_DMAS * const S3C24X0_GetBase_DMAS(void) +{ +	return (S3C24X0_DMAS * const)S3C24X0_DMA_BASE; +} +static inline S3C24X0_CLOCK_POWER * const S3C24X0_GetBase_CLOCK_POWER(void) +{ +	return (S3C24X0_CLOCK_POWER * const)S3C24X0_CLOCK_POWER_BASE; +} +static inline S3C24X0_LCD * const S3C24X0_GetBase_LCD(void) +{ +	return (S3C24X0_LCD * const)S3C24X0_LCD_BASE; +} +static inline S3C24X0_UART * const S3C24X0_GetBase_UART(S3C24X0_UARTS_NR nr) +{ +	return (S3C24X0_UART * const)(S3C24X0_UART_BASE + (nr * 0x4000)); +} +static inline S3C24X0_TIMERS * const S3C24X0_GetBase_TIMERS(void) +{ +	return (S3C24X0_TIMERS * const)S3C24X0_TIMER_BASE; +} +static inline S3C24X0_USB_DEVICE * const S3C24X0_GetBase_USB_DEVICE(void) +{ +	return (S3C24X0_USB_DEVICE * const)S3C24X0_USB_DEVICE_BASE; +} +static inline S3C24X0_WATCHDOG * const S3C24X0_GetBase_WATCHDOG(void) +{ +	return (S3C24X0_WATCHDOG * const)S3C24X0_WATCHDOG_BASE; +} +static inline S3C24X0_I2C * const S3C24X0_GetBase_I2C(void) +{ +	return (S3C24X0_I2C * const)S3C24X0_I2C_BASE; +} +static inline S3C24X0_I2S * const S3C24X0_GetBase_I2S(void) +{ +	return (S3C24X0_I2S * const)S3C24X0_I2S_BASE; +} +static inline S3C24X0_GPIO * const S3C24X0_GetBase_GPIO(void) +{ +	return (S3C24X0_GPIO * const)S3C24X0_GPIO_BASE; +} +static inline S3C24X0_RTC * const S3C24X0_GetBase_RTC(void) +{ +	return (S3C24X0_RTC * const)S3C24X0_RTC_BASE; +} +static inline S3C2400_ADC * const S3C2400_GetBase_ADC(void) +{ +	return (S3C2400_ADC * const)S3C24X0_ADC_BASE; +} +static inline S3C24X0_SPI * const S3C24X0_GetBase_SPI(void) +{ +	return (S3C24X0_SPI * const)S3C24X0_SPI_BASE; +} +static inline S3C2400_MMC * const S3C2400_GetBase_MMC(void) +{ +	return (S3C2400_MMC * const)S3C2400_MMC_BASE; +} + +#if 0  /* Memory control */  #define rBWSCON		(*(volatile unsigned *)0x14000000)  #define rBANKCON0	(*(volatile unsigned *)0x14000004) @@ -426,4 +551,5 @@  		 rINTPND;\  		 }  /* Wait until rINTPND is changed for the case that the ISR is very short. */ +#endif  #endif /*__S3C2400_H__*/ diff --git a/include/s3c2410.h b/include/s3c2410.h index abdebc12f..86495f628 100644 --- a/include/s3c2410.h +++ b/include/s3c2410.h @@ -1,493 +1,147 @@ +/* + * (C) Copyright 2003 + * David Müller ELSOFT AG Switzerland. d.mueller@elsoft.ch + * + * See file CREDITS for list of people who contributed to this + * project. + * + * This program is free software; you can redistribute it and/or + * modify it under the terms of the GNU General Public License as + * published by the Free Software Foundation; either version 2 of + * the License, or (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program; if not, write to the Free Software + * Foundation, Inc., 59 Temple Place, Suite 330, Boston, + * MA 02111-1307 USA + */ +  /************************************************   * NAME	    : s3c2410.h - * Version  : 3.7.2002 + * Version  : 31.3.2003   * - * Based on S3C2410X User's manual Rev 0.1 + * Based on S3C2410X User's manual Rev 1.1   ************************************************/  #ifndef __S3C2410_H__  #define __S3C2410_H__ +#define S3C24X0_UART_CHANNELS	3 +#define S3C24X0_SPI_CHANNELS	2 -/* Memory control */ -#define rBWSCON			(*(volatile unsigned *)0x48000000) -#define rBANKCON0		(*(volatile unsigned *)0x48000004) -#define rBANKCON1		(*(volatile unsigned *)0x48000008) -#define rBANKCON2		(*(volatile unsigned *)0x4800000C) -#define rBANKCON3		(*(volatile unsigned *)0x48000010) -#define rBANKCON4		(*(volatile unsigned *)0x48000014) -#define rBANKCON5		(*(volatile unsigned *)0x48000018) -#define rBANKCON6		(*(volatile unsigned *)0x4800001C) -#define rBANKCON7		(*(volatile unsigned *)0x48000020) -#define rREFRESH		(*(volatile unsigned *)0x48000024) -#define rBANKSIZE		(*(volatile unsigned *)0x48000028) -#define rMRSRB6			(*(volatile unsigned *)0x4800002C) -#define rMRSRB7			(*(volatile unsigned *)0x48000030) - - -/* USB HOST */ -#define rHcRevision		(*(volatile unsigned *)0x49000000) -#define rHcControl		(*(volatile unsigned *)0x49000004) -#define rHcCommonStatus		(*(volatile unsigned *)0x49000008) -#define rHcInterruptStatus	(*(volatile unsigned *)0x4900000C) -#define rHcInterruptEnable	(*(volatile unsigned *)0x49000010) -#define rHcInterruptDisable	(*(volatile unsigned *)0x49000014) -#define rHcHCCA			(*(volatile unsigned *)0x49000018) -#define rHcPeriodCuttendED	(*(volatile unsigned *)0x4900001C) -#define rHcControlHeadED	(*(volatile unsigned *)0x49000020) -#define rHcControlCurrentED	(*(volatile unsigned *)0x49000024) -#define rHcBulkHeadED		(*(volatile unsigned *)0x49000028) -#define rHcBuldCurrentED	(*(volatile unsigned *)0x4900002C) -#define rHcDoneHead		(*(volatile unsigned *)0x49000030) -#define rHcRmInterval		(*(volatile unsigned *)0x49000034) -#define rHcFmRemaining		(*(volatile unsigned *)0x49000038) -#define rHcFmNumber		(*(volatile unsigned *)0x4900003C) -#define rHcPeriodicStart	(*(volatile unsigned *)0x49000040) -#define rHcLSThreshold		(*(volatile unsigned *)0x49000044) -#define rHcRhDescriptorA	(*(volatile unsigned *)0x49000048) -#define rHcRhDescriptorB	(*(volatile unsigned *)0x4900004C) -#define rHcRhStatus		(*(volatile unsigned *)0x49000050) -#define rHcRhPortStatus1	(*(volatile unsigned *)0x49000054) -#define rHcRhPortStatus2	(*(volatile unsigned *)0x49000058) - - -/* INTERRUPT */ -#define rSRCPND			(*(volatile unsigned *)0x4A000000) -#define rINTMOD			(*(volatile unsigned *)0x4A000004) -#define rINTMSK			(*(volatile unsigned *)0x4A000008) -#define rPRIORITY		(*(volatile unsigned *)0x4A00000C) -#define rINTPND			(*(volatile unsigned *)0x4A000010) -#define rINTOFFSET		(*(volatile unsigned *)0x4A000014) -#define rSUBSRCPND		(*(volatile unsigned *)0x4A000018) -#define rINTSUBMSK		(*(volatile unsigned *)0x4A00001C) - - -/* DMA */ -#define rDISRC0			(*(volatile unsigned *)0x4B000000) -#define rDISRCC0		(*(volatile unsigned *)0x4B000004) -#define rDIDST0			(*(volatile unsigned *)0x4B000008) -#define rDIDSTC0		(*(volatile unsigned *)0x4B00000C) -#define rDCON0			(*(volatile unsigned *)0x4B000010) -#define rDSTAT0			(*(volatile unsigned *)0x4B000014) -#define rDCSRC0			(*(volatile unsigned *)0x4B000018) -#define rDCDST0			(*(volatile unsigned *)0x4B00001C) -#define rDMASKTRIG0		(*(volatile unsigned *)0x4B000020) -#define rDISRC1			(*(volatile unsigned *)0x4B000040) -#define rDISRCC1		(*(volatile unsigned *)0x4B000044) -#define rDIDST1			(*(volatile unsigned *)0x4B000048) -#define rDIDSTC1		(*(volatile unsigned *)0x4B00004C) -#define rDCON1			(*(volatile unsigned *)0x4B000050) -#define rDSTAT1			(*(volatile unsigned *)0x4B000054) -#define rDCSRC1			(*(volatile unsigned *)0x4B000058) -#define rDCDST1			(*(volatile unsigned *)0x4B00005C) -#define rDMASKTRIG1		(*(volatile unsigned *)0x4B000060) -#define rDISRC2			(*(volatile unsigned *)0x4B000080) -#define rDISRCC2		(*(volatile unsigned *)0x4B000084) -#define rDIDST2			(*(volatile unsigned *)0x4B000088) -#define rDIDSTC2		(*(volatile unsigned *)0x4B00008C) -#define rDCON2			(*(volatile unsigned *)0x4B000090) -#define rDSTAT2			(*(volatile unsigned *)0x4B000094) -#define rDCSRC2			(*(volatile unsigned *)0x4B000098) -#define rDCDST2			(*(volatile unsigned *)0x4B00009C) -#define rDMASKTRIG2		(*(volatile unsigned *)0x4B0000A0) -#define rDISRC3			(*(volatile unsigned *)0x4B0000C0) -#define rDISRCC3		(*(volatile unsigned *)0x4B0000C4) -#define rDIDST3			(*(volatile unsigned *)0x4B0000C8) -#define rDIDSTC3		(*(volatile unsigned *)0x4B0000CC) -#define rDCON3			(*(volatile unsigned *)0x4B0000D0) -#define rDSTAT3			(*(volatile unsigned *)0x4B0000D4) -#define rDCSRC3			(*(volatile unsigned *)0x4B0000D8) -#define rDCDST3			(*(volatile unsigned *)0x4B0000DC) -#define rDMASKTRIG3		(*(volatile unsigned *)0x4B0000E0) - - -/* CLOCK & POWER MANAGEMENT */ -#define rLOCKTIME		(*(volatile unsigned *)0x4C000000) -#define rMPLLCON		(*(volatile unsigned *)0x4C000004) -#define rUPLLCON		(*(volatile unsigned *)0x4C000008) -#define rCLKCON			(*(volatile unsigned *)0x4C00000C) -#define rCLKSLOW		(*(volatile unsigned *)0x4C000010) -#define rCLKDIVN		(*(volatile unsigned *)0x4C000014) - - -/* LCD CONTROLLER */ -#define rLCDCON1		(*(volatile unsigned *)0x4D000000) -#define rLCDCON2		(*(volatile unsigned *)0x4D000004) -#define rLCDCON3		(*(volatile unsigned *)0x4D000008) -#define rLCDCON4		(*(volatile unsigned *)0x4D00000C) -#define rLCDCON5		(*(volatile unsigned *)0x4D000010) -#define rLCDSADDR1		(*(volatile unsigned *)0x4D000014) -#define rLCDSADDR2		(*(volatile unsigned *)0x4D000018) -#define rLCDSADDR3		(*(volatile unsigned *)0x4D00001C) -#define rREDLUT			(*(volatile unsigned *)0x4D000020) -#define rGREENLUT		(*(volatile unsigned *)0x4D000024) -#define rBLUELUT		(*(volatile unsigned *)0x4D000028) -#define rDITHMODE		(*(volatile unsigned *)0x4D00004C) -#define rTPAL			(*(volatile unsigned *)0x4D000050) -#define rLCDINTPND		(*(volatile unsigned *)0x4D000054) -#define rLCDSRCPND		(*(volatile unsigned *)0x4D000058) -#define rLCDINTMSK		(*(volatile unsigned *)0x4D00005C) - - -/* NAND FLASH */ -#define rNFCONF			(*(volatile unsigned *)0x4E000000) -#define rNFCMD			(*(volatile unsigned *)0x4E000004) -#define rNFADDR			(*(volatile unsigned *)0x4E000008) -#define rNFDATA			(*(volatile unsigned *)0x4E00000C) -#define rNFSTAT			(*(volatile unsigned *)0x4E000010) -#define rNFECC			(*(volatile unsigned *)0x4E000014) - - -/* UART */ -#define rULCON0			(*(volatile unsigned *)0x50000000) -#define rUCON0			(*(volatile unsigned *)0x50000004) -#define rUFCON0			(*(volatile unsigned *)0x50000008) -#define rUMCON0			(*(volatile unsigned *)0x5000000C) -#define rUTRSTAT0		(*(volatile unsigned *)0x50000010) -#define rUERSTAT0		(*(volatile unsigned *)0x50000014) -#define rUFSTAT0		(*(volatile unsigned *)0x50000018) -#define rUMSTAT0		(*(volatile unsigned *)0x5000001C) -#define rUBRDIV0		(*(volatile unsigned *)0x50000028) - -#define rULCON1			(*(volatile unsigned *)0x50004000) -#define rUCON1			(*(volatile unsigned *)0x50004004) -#define rUFCON1			(*(volatile unsigned *)0x50004008) -#define rUMCON1			(*(volatile unsigned *)0x5000400C) -#define rUTRSTAT1		(*(volatile unsigned *)0x50004010) -#define rUERSTAT1		(*(volatile unsigned *)0x50004014) -#define rUFSTAT1		(*(volatile unsigned *)0x50004018) -#define rUMSTAT1		(*(volatile unsigned *)0x5000401C) -#define rUBRDIV1		(*(volatile unsigned *)0x50004028) - -#define rULCON2			(*(volatile unsigned *)0x50008000) -#define rUCON2			(*(volatile unsigned *)0x50008004) -#define rUFCON2			(*(volatile unsigned *)0x50008008) -#define rUTRSTAT2		(*(volatile unsigned *)0x50008010) -#define rUERSTAT2		(*(volatile unsigned *)0x50008014) -#define rUFSTAT2		(*(volatile unsigned *)0x50008018) -#define rUBRDIV2		(*(volatile unsigned *)0x50008028) - -#ifdef __BIG_ENDIAN -#define rUTXH0			(*(volatile unsigned char *)0x50000023) -#define rURXH0			(*(volatile unsigned char *)0x50000027) -#define rUTXH1			(*(volatile unsigned char *)0x50004023) -#define rURXH1			(*(volatile unsigned char *)0x50004027) -#define rUTXH2			(*(volatile unsigned char *)0x50008023) -#define rURXH2			(*(volatile unsigned char *)0x50008027) - -#define WrUTXH0(ch)		(*(volatile unsigned char *)0x50000023)=(unsigned char)(ch) -#define RdURXH0()		(*(volatile unsigned char *)0x50000027) -#define WrUTXH1(ch)		(*(volatile unsigned char *)0x50004023)=(unsigned char)(ch) -#define RdURXH1()		(*(volatile unsigned char *)0x50004027) -#define WrUTXH2(ch)		(*(volatile unsigned char *)0x50008023)=(unsigned char)(ch) -#define RdURXH2()		(*(volatile unsigned char *)0x50008027) - -#define UTXH0			(0x50000020+3)  /* byte_access address by DMA */ -#define URXH0			(0x50000024+3) -#define UTXH1			(0x50004020+3) -#define URXH1			(0x50004024+3) -#define UTXH2			(0x50008020+3) -#define URXH2			(0x50008024+3) - -#else /* Little Endian */ -#define rUTXH0			(*(volatile unsigned char *)0x50000020) -#define rURXH0			(*(volatile unsigned char *)0x50000024) -#define rUTXH1			(*(volatile unsigned char *)0x50004020) -#define rURXH1			(*(volatile unsigned char *)0x50004024) -#define rUTXH2			(*(volatile unsigned char *)0x50008020) -#define rURXH2			(*(volatile unsigned char *)0x50008024) - -#define WrUTXH0(ch)		(*(volatile unsigned char *)0x50000020)=(unsigned char)(ch) -#define RdURXH0()		(*(volatile unsigned char *)0x50000024) -#define WrUTXH1(ch)		(*(volatile unsigned char *)0x50004020)=(unsigned char)(ch) -#define RdURXH1()		(*(volatile unsigned char *)0x50004024) -#define WrUTXH2(ch)		(*(volatile unsigned char *)0x50008020)=(unsigned char)(ch) -#define RdURXH2()		(*(volatile unsigned char *)0x50008024) - -#define UTXH0			(0x50000020)    /* byte_access address by DMA */ -#define URXH0			(0x50000024) -#define UTXH1			(0x50004020) -#define URXH1			(0x50004024) -#define UTXH2			(0x50008020) -#define URXH2			(0x50008024) -#endif - - -/* PWM TIMER */ -#define rTCFG0			(*(volatile unsigned *)0x51000000) -#define rTCFG1			(*(volatile unsigned *)0x51000004) -#define rTCON			(*(volatile unsigned *)0x51000008) -#define rTCNTB0			(*(volatile unsigned *)0x5100000C) -#define rTCMPB0			(*(volatile unsigned *)0x51000010) -#define rTCNTO0			(*(volatile unsigned *)0x51000014) -#define rTCNTB1			(*(volatile unsigned *)0x51000018) -#define rTCMPB1			(*(volatile unsigned *)0x5100001C) -#define rTCNTO1			(*(volatile unsigned *)0x51000020) -#define rTCNTB2			(*(volatile unsigned *)0x51000024) -#define rTCMPB2			(*(volatile unsigned *)0x51000028) -#define rTCNTO2			(*(volatile unsigned *)0x5100002C) -#define rTCNTB3			(*(volatile unsigned *)0x51000030) -#define rTCMPB3			(*(volatile unsigned *)0x51000034) -#define rTCNTO3			(*(volatile unsigned *)0x51000038) -#define rTCNTB4			(*(volatile unsigned *)0x5100003C) -#define rTCNTO4			(*(volatile unsigned *)0x51000040) - - -/* USB DEVICE */ -#ifdef __BIG_ENDIAN -#define rFUNC_ADDR_REG		(*(volatile unsigned char *)0x52000143) -#define rPWR_REG		(*(volatile unsigned char *)0x52000147) -#define rEP_INT_REG		(*(volatile unsigned char *)0x5200014B) -#define rUSB_INT_REG		(*(volatile unsigned char *)0x5200015B) -#define rEP_INT_EN_REG		(*(volatile unsigned char *)0x5200015F) -#define rUSB_INT_EN_REG		(*(volatile unsigned char *)0x5200016F) -#define rFRAME_NUM1_REG		(*(volatile unsigned char *)0x52000173) -#define rFRAME_NUM2_REG		(*(volatile unsigned char *)0x52000177) -#define rINDEX_REG		(*(volatile unsigned char *)0x5200017B) -#define rMAXP_REG		(*(volatile unsigned char *)0x52000183) -#define rEP0_CSR		(*(volatile unsigned char *)0x52000187) -#define rIN_CSR1_REG		(*(volatile unsigned char *)0x52000187) -#define rIN_CSR2_REG		(*(volatile unsigned char *)0x5200018B) -#define rOUT_CSR1_REG		(*(volatile unsigned char *)0x52000193) -#define rOUT_CSR2_REG		(*(volatile unsigned char *)0x52000197) -#define rOUT_FIFO_CNT1_REG	(*(volatile unsigned char *)0x5200019B) -#define rOUT_FIFO_CNT2_REG	(*(volatile unsigned char *)0x5200019F) -#define rEP0_FIFO		(*(volatile unsigned char *)0x520001C3) -#define rEP1_FIFO		(*(volatile unsigned char *)0x520001C7) -#define rEP2_FIFO		(*(volatile unsigned char *)0x520001CB) -#define rEP3_FIFO		(*(volatile unsigned char *)0x520001CF) -#define rEP4_FIFO		(*(volatile unsigned char *)0x520001D3) -#define rEP1_DMA_CON		(*(volatile unsigned char *)0x52000203) -#define rEP1_DMA_UNIT		(*(volatile unsigned char *)0x52000207) -#define rEP1_DMA_FIFO		(*(volatile unsigned char *)0x5200020B) -#define rEP1_DMA_TX_LO		(*(volatile unsigned char *)0x5200020F) -#define rEP1_DMA_TX_MD		(*(volatile unsigned char *)0x52000213) -#define rEP1_DMA_TX_HI		(*(volatile unsigned char *)0x52000217) -#define rEP2_DMA_CON		(*(volatile unsigned char *)0x5200021B) -#define rEP2_DMA_UNIT		(*(volatile unsigned char *)0x5200021F) -#define rEP2_DMA_FIFO		(*(volatile unsigned char *)0x52000223) -#define rEP2_DMA_TX_LO		(*(volatile unsigned char *)0x52000227) -#define rEP2_DMA_TX_MD		(*(volatile unsigned char *)0x5200022B) -#define rEP2_DMA_TX_HI		(*(volatile unsigned char *)0x5200022F) -#define rEP3_DMA_CON		(*(volatile unsigned char *)0x52000243) -#define rEP3_DMA_UNIT		(*(volatile unsigned char *)0x52000247) -#define rEP3_DMA_FIFO		(*(volatile unsigned char *)0x5200024B) -#define rEP3_DMA_TX_LO		(*(volatile unsigned char *)0x5200024F) -#define rEP3_DMA_TX_MD		(*(volatile unsigned char *)0x52000253) -#define rEP3_DMA_TX_HI		(*(volatile unsigned char *)0x52000257) -#define rEP4_DMA_CON		(*(volatile unsigned char *)0x5200025B) -#define rEP4_DMA_UNIT		(*(volatile unsigned char *)0x5200025F) -#define rEP4_DMA_FIFO		(*(volatile unsigned char *)0x52000263) -#define rEP4_DMA_TX_LO		(*(volatile unsigned char *)0x52000267) -#define rEP4_DMA_TX_MD		(*(volatile unsigned char *)0x5200026B) -#define rEP4_DMA_TX_HI		(*(volatile unsigned char *)0x5200026F) -#else /*  little endian */ -#define rFUNC_ADDR_REG		(*(volatile unsigned char *)0x52000140) -#define rPWR_REG		(*(volatile unsigned char *)0x52000144) -#define rEP_INT_REG		(*(volatile unsigned char *)0x52000148) -#define rUSB_INT_REG		(*(volatile unsigned char *)0x52000158) -#define rEP_INT_EN_REG		(*(volatile unsigned char *)0x5200015C) -#define rUSB_INT_EN_REG		(*(volatile unsigned char *)0x5200016C) -#define rFRAME_NUM1_REG		(*(volatile unsigned char *)0x52000170) -#define rFRAME_NUM2_REG		(*(volatile unsigned char *)0x52000174) -#define rINDEX_REG		(*(volatile unsigned char *)0x52000178) -#define rMAXP_REG		(*(volatile unsigned char *)0x52000180) -#define rEP0_CSR		(*(volatile unsigned char *)0x52000184) -#define rIN_CSR1_REG		(*(volatile unsigned char *)0x52000184) -#define rIN_CSR2_REG		(*(volatile unsigned char *)0x52000188) -#define rOUT_CSR1_REG		(*(volatile unsigned char *)0x52000190) -#define rOUT_CSR2_REG		(*(volatile unsigned char *)0x52000194) -#define rOUT_FIFO_CNT1_REG	(*(volatile unsigned char *)0x52000198) -#define rOUT_FIFO_CNT2_REG	(*(volatile unsigned char *)0x5200019C) -#define rEP0_FIFO		(*(volatile unsigned char *)0x520001C0) -#define rEP1_FIFO		(*(volatile unsigned char *)0x520001C4) -#define rEP2_FIFO		(*(volatile unsigned char *)0x520001C8) -#define rEP3_FIFO		(*(volatile unsigned char *)0x520001CC) -#define rEP4_FIFO		(*(volatile unsigned char *)0x520001D0) -#define rEP1_DMA_CON		(*(volatile unsigned char *)0x52000200) -#define rEP1_DMA_UNIT		(*(volatile unsigned char *)0x52000204) -#define rEP1_DMA_FIFO		(*(volatile unsigned char *)0x52000208) -#define rEP1_DMA_TX_LO		(*(volatile unsigned char *)0x5200020C) -#define rEP1_DMA_TX_MD		(*(volatile unsigned char *)0x52000210) -#define rEP1_DMA_TX_HI		(*(volatile unsigned char *)0x52000214) -#define rEP2_DMA_CON		(*(volatile unsigned char *)0x52000218) -#define rEP2_DMA_UNIT		(*(volatile unsigned char *)0x5200021C) -#define rEP2_DMA_FIFO		(*(volatile unsigned char *)0x52000220) -#define rEP2_DMA_TX_LO		(*(volatile unsigned char *)0x52000224) -#define rEP2_DMA_TX_MD		(*(volatile unsigned char *)0x52000228) -#define rEP2_DMA_TX_HI		(*(volatile unsigned char *)0x5200022C) -#define rEP3_DMA_CON		(*(volatile unsigned char *)0x52000240) -#define rEP3_DMA_UNIT		(*(volatile unsigned char *)0x52000244) -#define rEP3_DMA_FIFO		(*(volatile unsigned char *)0x52000248) -#define rEP3_DMA_TX_LO		(*(volatile unsigned char *)0x5200024C) -#define rEP3_DMA_TX_MD		(*(volatile unsigned char *)0x52000250) -#define rEP3_DMA_TX_HI		(*(volatile unsigned char *)0x52000254) -#define rEP4_DMA_CON		(*(volatile unsigned char *)0x52000258) -#define rEP4_DMA_UNIT		(*(volatile unsigned char *)0x5200025C) -#define rEP4_DMA_FIFO		(*(volatile unsigned char *)0x52000260) -#define rEP4_DMA_TX_LO		(*(volatile unsigned char *)0x52000264) -#define rEP4_DMA_TX_MD		(*(volatile unsigned char *)0x52000268) -#define rEP4_DMA_TX_HI		(*(volatile unsigned char *)0x5200026C) -#endif /*  __BIG_ENDIAN */ - -/* WATCH DOG TIMER */ -#define rWTCON			(*(volatile unsigned *)0x53000000) -#define rWTDAT			(*(volatile unsigned *)0x53000004) -#define rWTCNT			(*(volatile unsigned *)0x53000008) - - -/* IIC */ -#define rIICCON			(*(volatile unsigned *)0x54000000) -#define rIICSTAT		(*(volatile unsigned *)0x54000004) -#define rIICADD			(*(volatile unsigned *)0x54000008) -#define rIICDS			(*(volatile unsigned *)0x5400000C) - - -/* IIS */ -#define rIISCON			(*(volatile unsigned *)0x55000000) -#define rIISMOD			(*(volatile unsigned *)0x55000004) -#define rIISPSR			(*(volatile unsigned *)0x55000008) -#define rIISFCON		(*(volatile unsigned *)0x5500000C) - -#ifdef __BIG_ENDIAN -#define IISFIF			((volatile unsigned short *)0x55000012) -#else /*  little endian */ -#define IISFIF			((volatile unsigned short *)0x55000010) -#endif - - -/* I/O PORT */ -#define rGPACON			(*(volatile unsigned *)0x56000000) -#define rGPADAT			(*(volatile unsigned *)0x56000004) - -#define rGPBCON			(*(volatile unsigned *)0x56000010) -#define rGPBDAT			(*(volatile unsigned *)0x56000014) -#define rGPBUP			(*(volatile unsigned *)0x56000018) - -#define rGPCCON			(*(volatile unsigned *)0x56000020) -#define rGPCDAT			(*(volatile unsigned *)0x56000024) -#define rGPCUP			(*(volatile unsigned *)0x56000028) - -#define rGPDCON			(*(volatile unsigned *)0x56000030) -#define rGPDDAT			(*(volatile unsigned *)0x56000034) -#define rGPDUP			(*(volatile unsigned *)0x56000038) - -#define rGPECON			(*(volatile unsigned *)0x56000040) -#define rGPEDAT			(*(volatile unsigned *)0x56000044) -#define rGPEUP			(*(volatile unsigned *)0x56000048) - -#define rGPFCON			(*(volatile unsigned *)0x56000050) -#define rGPFDAT			(*(volatile unsigned *)0x56000054) -#define rGPFUP			(*(volatile unsigned *)0x56000058) - -#define rGPGCON			(*(volatile unsigned *)0x56000060) -#define rGPGDAT			(*(volatile unsigned *)0x56000064) -#define rGPGUP			(*(volatile unsigned *)0x56000068) - -#define rGPHCON			(*(volatile unsigned *)0x56000070) -#define rGPHDAT			(*(volatile unsigned *)0x56000074) -#define rGPHUP			(*(volatile unsigned *)0x56000078) - -#define rMISCCR			(*(volatile unsigned *)0x56000080) -#define rDCLKCON		(*(volatile unsigned *)0x56000084) -#define rEXTINT0		(*(volatile unsigned *)0x56000088) -#define rEXTINT1		(*(volatile unsigned *)0x5600008C) -#define rEXTINT2		(*(volatile unsigned *)0x56000090) -#define rEINTFLT0		(*(volatile unsigned *)0x56000094) -#define rEINTFLT1		(*(volatile unsigned *)0x56000098) -#define rEINTFLT2		(*(volatile unsigned *)0x5600009C) -#define rEINTFLT3		(*(volatile unsigned *)0x560000A0) -#define rEINTMASK		(*(volatile unsigned *)0x560000A4) -#define rEINTPEND		(*(volatile unsigned *)0x560000A8) -#define rGSTATUS0		(*(volatile unsigned *)0x560000AC) -#define rGSTATUS1		(*(volatile unsigned *)0x560000B0) - +/* S3C2410 only supports 512 Byte HW ECC */ +#define S3C2410_ECCSIZE		512 +#define S3C2410_ECCBYTES	3 -/* RTC */ -#ifdef __BIG_ENDIAN -#define rRTCCON			(*(volatile unsigned char *)0x57000043) -#define rTICNT			(*(volatile unsigned char *)0x57000047) -#define rRTCALM			(*(volatile unsigned char *)0x57000053) -#define rALMSEC			(*(volatile unsigned char *)0x57000057) -#define rALMMIN			(*(volatile unsigned char *)0x5700005B) -#define rALMHOUR		(*(volatile unsigned char *)0x5700005F) -#define rALMDATE		(*(volatile unsigned char *)0x57000063) -#define rALMMON			(*(volatile unsigned char *)0x57000067) -#define rALMYEAR		(*(volatile unsigned char *)0x5700006B) -#define rRTCRST			(*(volatile unsigned char *)0x5700006F) -#define rBCDSEC			(*(volatile unsigned char *)0x57000073) -#define rBCDMIN			(*(volatile unsigned char *)0x57000077) -#define rBCDHOUR		(*(volatile unsigned char *)0x5700007B) -#define rBCDDATE		(*(volatile unsigned char *)0x5700007F) -#define rBCDDAY			(*(volatile unsigned char *)0x57000083) -#define rBCDMON			(*(volatile unsigned char *)0x57000087) -#define rBCDYEAR		(*(volatile unsigned char *)0x5700008B) -#else /*  little endian */ -#define rRTCCON			(*(volatile unsigned char *)0x57000040) -#define rTICNT			(*(volatile unsigned char *)0x57000044) -#define rRTCALM			(*(volatile unsigned char *)0x57000050) -#define rALMSEC			(*(volatile unsigned char *)0x57000054) -#define rALMMIN			(*(volatile unsigned char *)0x57000058) -#define rALMHOUR		(*(volatile unsigned char *)0x5700005C) -#define rALMDATE		(*(volatile unsigned char *)0x57000060) -#define rALMMON			(*(volatile unsigned char *)0x57000064) -#define rALMYEAR		(*(volatile unsigned char *)0x57000068) -#define rRTCRST			(*(volatile unsigned char *)0x5700006C) -#define rBCDSEC			(*(volatile unsigned char *)0x57000070) -#define rBCDMIN			(*(volatile unsigned char *)0x57000074) -#define rBCDHOUR		(*(volatile unsigned char *)0x57000078) -#define rBCDDATE		(*(volatile unsigned char *)0x5700007C) -#define rBCDDAY			(*(volatile unsigned char *)0x57000080) -#define rBCDMON			(*(volatile unsigned char *)0x57000084) -#define rBCDYEAR		(*(volatile unsigned char *)0x57000088) -#endif +typedef enum { +	S3C24X0_UART0, +	S3C24X0_UART1, +	S3C24X0_UART2 +} S3C24X0_UARTS_NR; +/* S3C2410 device base addresses */ +#define S3C24X0_MEMCTL_BASE		0x48000000 +#define S3C24X0_USB_HOST_BASE		0x49000000 +#define S3C24X0_INTERRUPT_BASE		0x4A000000 +#define S3C24X0_DMA_BASE		0x4B000000 +#define S3C24X0_CLOCK_POWER_BASE	0x4C000000 +#define S3C24X0_LCD_BASE		0x4D000000 +#define S3C2410_NAND_BASE		0x4E000000 +#define S3C24X0_UART_BASE		0x50000000 +#define S3C24X0_TIMER_BASE		0x51000000 +#define S3C24X0_USB_DEVICE_BASE		0x52000140 +#define S3C24X0_WATCHDOG_BASE		0x53000000 +#define S3C24X0_I2C_BASE		0x54000000 +#define S3C24X0_I2S_BASE		0x55000000 +#define S3C24X0_GPIO_BASE		0x56000000 +#define S3C24X0_RTC_BASE		0x57000000 +#define S3C2410_ADC_BASE		0x58000000 +#define S3C24X0_SPI_BASE		0x59000000 +#define S3C2410_SDI_BASE		0x5A000000 -/* ADC */ -#define rADCCON			(*(volatile unsigned *)0x58000000) -#define rADCTSC			(*(volatile unsigned *)0x58000004) -#define rADCDLY			(*(volatile unsigned *)0x58000008) -#define rADCDAT0		(*(volatile unsigned *)0x5800000C) -#define rADCDAT1		(*(volatile unsigned *)0x58000010) +/* include common stuff */ +#include <s3c24x0.h> -/* SPI */ -#define rSPCON0			(*(volatile unsigned *)0x59000000) -#define rSPSTA0			(*(volatile unsigned *)0x59000004) -#define rSPPIN0			(*(volatile unsigned *)0x59000008) -#define rSPPRE0			(*(volatile unsigned *)0x5900000C) -#define rSPTDAT0		(*(volatile unsigned *)0x59000010) -#define rSPRDAT0		(*(volatile unsigned *)0x59000014) -#define rSPCON1			(*(volatile unsigned *)0x59000020) -#define rSPSTA1			(*(volatile unsigned *)0x59000024) -#define rSPPIN1			(*(volatile unsigned *)0x59000028) -#define rSPPRE1			(*(volatile unsigned *)0x5900002C) -#define rSPTDAT1		(*(volatile unsigned *)0x59000030) -#define rSPRDAT1		(*(volatile unsigned *)0x59000034) +static inline S3C24X0_MEMCTL * const S3C24X0_GetBase_MEMCTL(void) +{ +	return (S3C24X0_MEMCTL * const)S3C24X0_MEMCTL_BASE; +} +static inline S3C24X0_USB_HOST * const S3C24X0_GetBase_USB_HOST(void) +{ +	return (S3C24X0_USB_HOST * const)S3C24X0_USB_HOST_BASE; +} +static inline S3C24X0_INTERRUPT * const S3C24X0_GetBase_INTERRUPT(void) +{ +	return (S3C24X0_INTERRUPT * const)S3C24X0_INTERRUPT_BASE; +} +static inline S3C24X0_DMAS * const S3C24X0_GetBase_DMAS(void) +{ +	return (S3C24X0_DMAS * const)S3C24X0_DMA_BASE; +} +static inline S3C24X0_CLOCK_POWER * const S3C24X0_GetBase_CLOCK_POWER(void) +{ +	return (S3C24X0_CLOCK_POWER * const)S3C24X0_CLOCK_POWER_BASE; +} +static inline S3C24X0_LCD * const S3C24X0_GetBase_LCD(void) +{ +	return (S3C24X0_LCD * const)S3C24X0_LCD_BASE; +} +static inline S3C2410_NAND * const S3C2410_GetBase_NAND(void) +{ +	return (S3C2410_NAND * const)S3C2410_NAND_BASE; +} +static inline S3C24X0_UART * const S3C24X0_GetBase_UART(S3C24X0_UARTS_NR nr) +{ +	return (S3C24X0_UART * const)(S3C24X0_UART_BASE + (nr * 0x4000)); +} +static inline S3C24X0_TIMERS * const S3C24X0_GetBase_TIMERS(void) +{ +	return (S3C24X0_TIMERS * const)S3C24X0_TIMER_BASE; +} +static inline S3C24X0_USB_DEVICE * const S3C24X0_GetBase_USB_DEVICE(void) +{ +	return (S3C24X0_USB_DEVICE * const)S3C24X0_USB_DEVICE_BASE; +} +static inline S3C24X0_WATCHDOG * const S3C24X0_GetBase_WATCHDOG(void) +{ +	return (S3C24X0_WATCHDOG * const)S3C24X0_WATCHDOG_BASE; +} +static inline S3C24X0_I2C * const S3C24X0_GetBase_I2C(void) +{ +	return (S3C24X0_I2C * const)S3C24X0_I2C_BASE; +} +static inline S3C24X0_I2S * const S3C24X0_GetBase_I2S(void) +{ +	return (S3C24X0_I2S * const)S3C24X0_I2S_BASE; +} +static inline S3C24X0_GPIO * const S3C24X0_GetBase_GPIO(void) +{ +	return (S3C24X0_GPIO * const)S3C24X0_GPIO_BASE; +} +static inline S3C24X0_RTC * const S3C24X0_GetBase_RTC(void) +{ +	return (S3C24X0_RTC * const)S3C24X0_RTC_BASE; +} +static inline S3C2410_ADC * const S3C2410_GetBase_ADC(void) +{ +	return (S3C2410_ADC * const)S3C2410_ADC_BASE; +} +static inline S3C24X0_SPI * const S3C24X0_GetBase_SPI(void) +{ +	return (S3C24X0_SPI * const)S3C24X0_SPI_BASE; +} +static inline S3C2410_SDI * const S3C2410_GetBase_SDI(void) +{ +	return (S3C2410_SDI * const)S3C2410_SDI_BASE; +} -/* SD INTERFACE */ -#define rSDICON			(*(volatile unsigned *)0x5A000000) -#define rSDIPRE			(*(volatile unsigned *)0x5A000004) -#define rSDICmdArg		(*(volatile unsigned *)0x5A000008) -#define rSDICmdCon		(*(volatile unsigned *)0x5A00000C) -#define rSDICmdSta		(*(volatile unsigned *)0x5A000010) -#define rSDIRSP0		(*(volatile unsigned *)0x5A000014) -#define rSDIRSP1		(*(volatile unsigned *)0x5A000018) -#define rSDIRSP2		(*(volatile unsigned *)0x5A00001C) -#define rSDIRSP3		(*(volatile unsigned *)0x5A000020) -#define rSDIDTimer		(*(volatile unsigned *)0x5A000024) -#define rSDIBSize		(*(volatile unsigned *)0x5A000028) -#define rSDIDatCon		(*(volatile unsigned *)0x5A00002C) -#define rSDIDatCnt		(*(volatile unsigned *)0x5A000030) -#define rSDIDatSta		(*(volatile unsigned *)0x5A000034) -#define rSDIFSTA		(*(volatile unsigned *)0x5A000038) -#ifdef __BIG_ENDIAN -#define rSDIDAT			(*(volatile unsigned char *)0x5A00003F) -#else -#define rSDIDAT			(*(volatile unsigned char *)0x5A00003C) -#endif -#define rSDIIntMsk		(*(volatile unsigned *)0x5A000040)  /* ISR */  #define pISR_RESET		(*(unsigned *)(_ISR_STARTADDRESS+0x0)) diff --git a/include/s3c24x0.h b/include/s3c24x0.h new file mode 100644 index 000000000..78a79811f --- /dev/null +++ b/include/s3c24x0.h @@ -0,0 +1,1135 @@ +/* + * (C) Copyright 2003 + * David Müller ELSOFT AG Switzerland. d.mueller@elsoft.ch + * + * See file CREDITS for list of people who contributed to this + * project. + * + * This program is free software; you can redistribute it and/or + * modify it under the terms of the GNU General Public License as + * published by the Free Software Foundation; either version 2 of + * the License, or (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program; if not, write to the Free Software + * Foundation, Inc., 59 Temple Place, Suite 330, Boston, + * MA 02111-1307 USA + */ + +/************************************************ + * NAME	    : s3c24x0.h + * Version  : 31.3.2003 + * + * common stuff for SAMSUNG S3C24X0 SoC + ************************************************/ + +#ifndef __S3C24X0_H__ +#define __S3C24X0_H__ + +typedef volatile u8	S3C24X0_REG8; +typedef volatile u16	S3C24X0_REG16; +typedef volatile u32	S3C24X0_REG32; + +/* Memory controller (see manual chapter 5) */ +typedef struct { +	S3C24X0_REG32	BWSCON; +	S3C24X0_REG32	BANKCON[8]; +	S3C24X0_REG32	REFRESH; +	S3C24X0_REG32	BANKSIZE; +	S3C24X0_REG32	MRSRB6; +	S3C24X0_REG32	MRSRB7; +} /*__attribute__((__packed__))*/ S3C24X0_MEMCTL; + + +/* USB HOST (see manual chapter 12) */ +typedef struct { +	S3C24X0_REG32	HcRevision; +	S3C24X0_REG32	HcControl; +	S3C24X0_REG32	HcCommonStatus; +	S3C24X0_REG32	HcInterruptStatus; +	S3C24X0_REG32	HcInterruptEnable; +	S3C24X0_REG32	HcInterruptDisable; +	S3C24X0_REG32	HcHCCA; +	S3C24X0_REG32	HcPeriodCuttendED; +	S3C24X0_REG32	HcControlHeadED; +	S3C24X0_REG32	HcControlCurrentED; +	S3C24X0_REG32	HcBulkHeadED; +	S3C24X0_REG32	HcBuldCurrentED; +	S3C24X0_REG32	HcDoneHead; +	S3C24X0_REG32	HcRmInterval; +	S3C24X0_REG32	HcFmRemaining; +	S3C24X0_REG32	HcFmNumber; +	S3C24X0_REG32	HcPeriodicStart; +	S3C24X0_REG32	HcLSThreshold; +	S3C24X0_REG32	HcRhDescriptorA; +	S3C24X0_REG32	HcRhDescriptorB; +	S3C24X0_REG32	HcRhStatus; +	S3C24X0_REG32	HcRhPortStatus1; +	S3C24X0_REG32	HcRhPortStatus2; +} /*__attribute__((__packed__))*/ S3C24X0_USB_HOST; + + +/* INTERRUPT (see manual chapter 14) */ +typedef struct { +	S3C24X0_REG32	SRCPND; +	S3C24X0_REG32	INTMOD; +	S3C24X0_REG32	INTMSK; +	S3C24X0_REG32	PRIORITY; +	S3C24X0_REG32	INTPND; +	S3C24X0_REG32	INTOFFSET; +#ifdef CONFIG_S3C2410 +	S3C24X0_REG32	SUBSRCPND; +	S3C24X0_REG32	INTSUBMSK; +#endif +} /*__attribute__((__packed__))*/ S3C24X0_INTERRUPT; + + +/* DMAS (see manual chapter 8) */ +typedef struct { +	S3C24X0_REG32	DISRC; +#ifdef CONFIG_S3C2410 +	S3C24X0_REG32	DISRCC; +#endif +	S3C24X0_REG32	DIDST; +#ifdef CONFIG_S3C2410 +	S3C24X0_REG32	DIDSTC; +#endif +	S3C24X0_REG32	DCON; +	S3C24X0_REG32	DSTAT; +	S3C24X0_REG32	DCSRC; +	S3C24X0_REG32	DCDST; +	S3C24X0_REG32	DMASKTRIG; +#ifdef CONFIG_S3C2400 +	S3C24X0_REG32	res[1]; +#endif +#ifdef CONFIG_S3C2410 +	S3C24X0_REG32	res[7]; +#endif +} /*__attribute__((__packed__))*/ S3C24X0_DMA; + +typedef struct { +	S3C24X0_DMA	dma[4]; +} /*__attribute__((__packed__))*/ S3C24X0_DMAS; + + +/* CLOCK & POWER MANAGEMENT (see S3C2400 manual chapter 6) */ +/*                          (see S3C2410 manual chapter 7) */ +typedef struct { +	S3C24X0_REG32	LOCKTIME; +	S3C24X0_REG32	MPLLCON; +	S3C24X0_REG32	UPLLCON; +	S3C24X0_REG32	CLKCON; +	S3C24X0_REG32	CLKSLOW; +	S3C24X0_REG32	CLKDIVN; +} /*__attribute__((__packed__))*/ S3C24X0_CLOCK_POWER; + + +/* LCD CONTROLLER (see manual chapter 15) */ +typedef struct { +	S3C24X0_REG32	LCDCON1; +	S3C24X0_REG32	LCDCON2; +	S3C24X0_REG32	LCDCON3; +	S3C24X0_REG32	LCDCON4; +	S3C24X0_REG32	LCDCON5; +	S3C24X0_REG32	LCDSADDR1; +	S3C24X0_REG32	LCDSADDR2; +	S3C24X0_REG32	LCDSADDR3; +	S3C24X0_REG32	REDLUT; +	S3C24X0_REG32	GREENLUT; +	S3C24X0_REG32	BLUELUT; +	S3C24X0_REG32	res[8]; +	S3C24X0_REG32	DITHMODE; +	S3C24X0_REG32	TPAL; +#ifdef CONFIG_S3C2410 +	S3C24X0_REG32	LCDINTPND; +	S3C24X0_REG32	LCDSRCPND; +	S3C24X0_REG32	LCDINTMSK; +	S3C24X0_REG32	LPCSEL; +#endif +} /*__attribute__((__packed__))*/ S3C24X0_LCD; + + +/* NAND FLASH (see S3C2410 manual chapter 6) */ +typedef struct { +	S3C24X0_REG32	NFCONF; +	S3C24X0_REG32	NFCMD; +	S3C24X0_REG32	NFADDR; +	S3C24X0_REG32	NFDATA; +	S3C24X0_REG32	NFSTAT; +	S3C24X0_REG32	NFECC; +} /*__attribute__((__packed__))*/ S3C2410_NAND; + + +/* UART (see manual chapter 11) */ +typedef struct { +	S3C24X0_REG32	ULCON; +	S3C24X0_REG32	UCON; +	S3C24X0_REG32	UFCON; +	S3C24X0_REG32	UMCON; +	S3C24X0_REG32	UTRSTAT; +	S3C24X0_REG32	UERSTAT; +	S3C24X0_REG32	UFSTAT; +	S3C24X0_REG32	UMSTAT; +#ifdef __BIG_ENDIAN +	S3C24X0_REG8	res1[3]; +	S3C24X0_REG8	UTXH; +	S3C24X0_REG8	res2[3]; +	S3C24X0_REG8	URXH; +#else /* Little Endian */ +	S3C24X0_REG8	UTXH; +	S3C24X0_REG8	res1[3]; +	S3C24X0_REG8	URXH; +	S3C24X0_REG8	res2[3]; +#endif +	S3C24X0_REG32	UBRDIV; +} /*__attribute__((__packed__))*/ S3C24X0_UART; + + +/* PWM TIMER (see manual chapter 10) */ +typedef struct { +	S3C24X0_REG32	TCNTB; +	S3C24X0_REG32	TCMPB; +	S3C24X0_REG32	TCNTO; +} /*__attribute__((__packed__))*/ S3C24X0_TIMER; + +typedef struct { +	S3C24X0_REG32	TCFG0; +	S3C24X0_REG32	TCFG1; +	S3C24X0_REG32	TCON; +	S3C24X0_TIMER	ch[4]; +	S3C24X0_REG32	TCNTB4; +	S3C24X0_REG32	TCNTO4; +} /*__attribute__((__packed__))*/ S3C24X0_TIMERS; + + +/* USB DEVICE (see manual chapter 13) */ +typedef struct { +#ifdef __BIG_ENDIAN +	S3C24X0_REG8	res[3]; +	S3C24X0_REG8	EP_FIFO_REG; +#else /*  little endian */ +	S3C24X0_REG8	EP_FIFO_REG; +	S3C24X0_REG8	res[3]; +#endif +} /*__attribute__((__packed__))*/ S3C24X0_USB_DEV_FIFOS; + +typedef struct { +#ifdef __BIG_ENDIAN +	S3C24X0_REG8	res1[3]; +	S3C24X0_REG8	EP_DMA_CON; +	S3C24X0_REG8	res2[3]; +	S3C24X0_REG8	EP_DMA_UNIT; +	S3C24X0_REG8	res3[3]; +	S3C24X0_REG8	EP_DMA_FIFO; +	S3C24X0_REG8	res4[3]; +	S3C24X0_REG8	EP_DMA_TTC_L; +	S3C24X0_REG8	res5[3]; +	S3C24X0_REG8	EP_DMA_TTC_M; +	S3C24X0_REG8	res6[3]; +	S3C24X0_REG8	EP_DMA_TTC_H; +#else /*  little endian */ +	S3C24X0_REG8	EP_DMA_CON; +	S3C24X0_REG8	res1[3]; +	S3C24X0_REG8	EP_DMA_UNIT; +	S3C24X0_REG8	res2[3]; +	S3C24X0_REG8	EP_DMA_FIFO; +	S3C24X0_REG8	res3[3]; +	S3C24X0_REG8	EP_DMA_TTC_L; +	S3C24X0_REG8	res4[3]; +	S3C24X0_REG8	EP_DMA_TTC_M; +	S3C24X0_REG8	res5[3]; +	S3C24X0_REG8	EP_DMA_TTC_H; +	S3C24X0_REG8	res6[3]; +#endif +} /*__attribute__((__packed__))*/ S3C24X0_USB_DEV_DMAS; + +typedef struct { +#ifdef __BIG_ENDIAN +	S3C24X0_REG8	res1[3]; +	S3C24X0_REG8	FUNC_ADDR_REG; +	S3C24X0_REG8	res2[3]; +	S3C24X0_REG8	PWR_REG; +	S3C24X0_REG8	res3[3]; +	S3C24X0_REG8	EP_INT_REG; +	S3C24X0_REG8	res4[15]; +	S3C24X0_REG8	USB_INT_REG; +	S3C24X0_REG8	res5[3]; +	S3C24X0_REG8	EP_INT_EN_REG; +	S3C24X0_REG8	res6[15]; +	S3C24X0_REG8	USB_INT_EN_REG; +	S3C24X0_REG8	res7[3]; +	S3C24X0_REG8	FRAME_NUM1_REG; +	S3C24X0_REG8	res8[3]; +	S3C24X0_REG8	FRAME_NUM2_REG; +	S3C24X0_REG8	res9[3]; +	S3C24X0_REG8	INDEX_REG; +	S3C24X0_REG8	res10[7]; +	S3C24X0_REG8	MAXP_REG; +	S3C24X0_REG8	res11[3]; +	S3C24X0_REG8	EP0_CSR_IN_CSR1_REG; +	S3C24X0_REG8	res12[3]; +	S3C24X0_REG8	IN_CSR2_REG; +	S3C24X0_REG8	res13[7]; +	S3C24X0_REG8	OUT_CSR1_REG; +	S3C24X0_REG8	res14[3]; +	S3C24X0_REG8	OUT_CSR2_REG; +	S3C24X0_REG8	res15[3]; +	S3C24X0_REG8	OUT_FIFO_CNT1_REG; +	S3C24X0_REG8	res16[3]; +	S3C24X0_REG8	OUT_FIFO_CNT2_REG; +#else /*  little endian */ +	S3C24X0_REG8	FUNC_ADDR_REG; +	S3C24X0_REG8	res1[3]; +	S3C24X0_REG8	PWR_REG; +	S3C24X0_REG8	res2[3]; +	S3C24X0_REG8	EP_INT_REG; +	S3C24X0_REG8	res3[15]; +	S3C24X0_REG8	USB_INT_REG; +	S3C24X0_REG8	res4[3]; +	S3C24X0_REG8	EP_INT_EN_REG; +	S3C24X0_REG8	res5[15]; +	S3C24X0_REG8	USB_INT_EN_REG; +	S3C24X0_REG8	res6[3]; +	S3C24X0_REG8	FRAME_NUM1_REG; +	S3C24X0_REG8	res7[3]; +	S3C24X0_REG8	FRAME_NUM2_REG; +	S3C24X0_REG8	res8[3]; +	S3C24X0_REG8	INDEX_REG; +	S3C24X0_REG8	res9[7]; +	S3C24X0_REG8	MAXP_REG; +	S3C24X0_REG8	res10[7]; +	S3C24X0_REG8	EP0_CSR_IN_CSR1_REG; +	S3C24X0_REG8	res11[3]; +	S3C24X0_REG8	IN_CSR2_REG; +	S3C24X0_REG8	res12[3]; +	S3C24X0_REG8	OUT_CSR1_REG; +	S3C24X0_REG8	res13[7]; +	S3C24X0_REG8	OUT_CSR2_REG; +	S3C24X0_REG8	res14[3]; +	S3C24X0_REG8	OUT_FIFO_CNT1_REG; +	S3C24X0_REG8	res15[3]; +	S3C24X0_REG8	OUT_FIFO_CNT2_REG; +	S3C24X0_REG8	res16[3]; +#endif /*  __BIG_ENDIAN */ +	S3C24X0_USB_DEV_FIFOS	fifo[5]; +	S3C24X0_USB_DEV_DMAS	dma[5]; +} /*__attribute__((__packed__))*/ S3C24X0_USB_DEVICE; + + +/* WATCH DOG TIMER (see manual chapter 18) */ +typedef struct { +	S3C24X0_REG32	WTCON; +	S3C24X0_REG32	WTDAT; +	S3C24X0_REG32	WTCNT; +} /*__attribute__((__packed__))*/ S3C24X0_WATCHDOG; + + +/* IIC (see manual chapter 20) */ +typedef struct { +	S3C24X0_REG32	IICCON; +	S3C24X0_REG32	IICSTAT; +	S3C24X0_REG32	IICADD; +	S3C24X0_REG32	IICDS; +} /*__attribute__((__packed__))*/ S3C24X0_I2C; + + +/* IIS (see manual chapter 21) */ +typedef struct { +#ifdef __BIG_ENDIAN +	S3C24X0_REG16	res1; +	S3C24X0_REG16	IISCON; +	S3C24X0_REG16	res2; +	S3C24X0_REG16	IISMOD; +	S3C24X0_REG16	res3; +	S3C24X0_REG16	IISPSR; +	S3C24X0_REG16	res4; +	S3C24X0_REG16	IISFCON; +	S3C24X0_REG16	res5; +	S3C24X0_REG16	IISFIFO; +#else /*  little endian */ +	S3C24X0_REG16	IISCON; +	S3C24X0_REG16	res1; +	S3C24X0_REG16	IISMOD; +	S3C24X0_REG16	res2; +	S3C24X0_REG16	IISPSR; +	S3C24X0_REG16	res3; +	S3C24X0_REG16	IISFCON; +	S3C24X0_REG16	res4; +	S3C24X0_REG16	IISFIFO; +	S3C24X0_REG16	res5; +#endif +} /*__attribute__((__packed__))*/ S3C24X0_I2S; + + +/* I/O PORT (see manual chapter 9) */ +typedef struct { +#ifdef CONFIG_S3C2400 +	S3C24X0_REG32	PACON; +	S3C24X0_REG32	PADAT; +	 +	S3C24X0_REG32	PBCON; +	S3C24X0_REG32	PBDAT; +	S3C24X0_REG32	PBUP; + +	S3C24X0_REG32	PCCON; +	S3C24X0_REG32	PCDAT; +	S3C24X0_REG32	PCUP; + +	S3C24X0_REG32	PDCON; +	S3C24X0_REG32	PDDAT; +	S3C24X0_REG32	PDUP; + +	S3C24X0_REG32	PECON; +	S3C24X0_REG32	PEDAT; +	S3C24X0_REG32	PEUP; + +	S3C24X0_REG32	PFCON; +	S3C24X0_REG32	PFDAT; +	S3C24X0_REG32	PFUP; + +	S3C24X0_REG32	PGCON; +	S3C24X0_REG32	PGDAT; +	S3C24X0_REG32	PGUP; + +	S3C24X0_REG32	OPENCR; + +	S3C24X0_REG32	MISCCR; +	S3C24X0_REG32	EXTINT; +#endif +#ifdef CONFIG_S3C2410 +	S3C24X0_REG32	GPACON; +	S3C24X0_REG32	GPADAT; +	S3C24X0_REG32	res1[2]; +	S3C24X0_REG32	GPBCON; +	S3C24X0_REG32	GPBDAT; +	S3C24X0_REG32	GPBUP; +	S3C24X0_REG32	res2; +	S3C24X0_REG32	GPCCON; +	S3C24X0_REG32	GPCDAT; +	S3C24X0_REG32	GPCUP; +	S3C24X0_REG32	res3; +	S3C24X0_REG32	GPDCON; +	S3C24X0_REG32	GPDDAT; +	S3C24X0_REG32	GPDUP; +	S3C24X0_REG32	res4; +	S3C24X0_REG32	GPECON; +	S3C24X0_REG32	GPEDAT; +	S3C24X0_REG32	GPEUP; +	S3C24X0_REG32	res5; +	S3C24X0_REG32	GPFCON; +	S3C24X0_REG32	GPFDAT; +	S3C24X0_REG32	GPFUP; +	S3C24X0_REG32	res6; +	S3C24X0_REG32	GPGCON; +	S3C24X0_REG32	GPGDAT; +	S3C24X0_REG32	GPGUP; +	S3C24X0_REG32	res7; +	S3C24X0_REG32	GPHCON; +	S3C24X0_REG32	GPHDAT; +	S3C24X0_REG32	GPHUP; +	S3C24X0_REG32	res8; + +	S3C24X0_REG32	MISCCR; +	S3C24X0_REG32	DCLKCON; +	S3C24X0_REG32	EXTINT0; +	S3C24X0_REG32	EXTINT1; +	S3C24X0_REG32	EXTINT2; +	S3C24X0_REG32	EINTFLT0; +	S3C24X0_REG32	EINTFLT1; +	S3C24X0_REG32	EINTFLT2; +	S3C24X0_REG32	EINTFLT3; +	S3C24X0_REG32	EINTMASK; +	S3C24X0_REG32	EINTPEND; +	S3C24X0_REG32	GSTATUS0; +	S3C24X0_REG32	GSTATUS1; +	S3C24X0_REG32	GSTATUS2; +	S3C24X0_REG32	GSTATUS3; +	S3C24X0_REG32	GSTATUS4; +#endif +} /*__attribute__((__packed__))*/ S3C24X0_GPIO; + + +/* RTC (see manual chapter 17) */ +typedef struct { +#ifdef __BIG_ENDIAN +	S3C24X0_REG8	res1[67]; +	S3C24X0_REG8	RTCCON; +	S3C24X0_REG8	res2[3]; +	S3C24X0_REG8	TICNT; +	S3C24X0_REG8	res3[11]; +	S3C24X0_REG8	RTCALM; +	S3C24X0_REG8	res4[3]; +	S3C24X0_REG8	ALMSEC; +	S3C24X0_REG8	res5[3]; +	S3C24X0_REG8	ALMMIN; +	S3C24X0_REG8	res6[3]; +	S3C24X0_REG8	ALMHOUR; +	S3C24X0_REG8	res7[3]; +	S3C24X0_REG8	ALMDATE; +	S3C24X0_REG8	res8[3]; +	S3C24X0_REG8	ALMMON; +	S3C24X0_REG8	res9[3]; +	S3C24X0_REG8	ALMYEAR; +	S3C24X0_REG8	res10[3]; +	S3C24X0_REG8	RTCRST; +	S3C24X0_REG8	res11[3]; +	S3C24X0_REG8	BCDSEC; +	S3C24X0_REG8	res12[3]; +	S3C24X0_REG8	BCDMIN; +	S3C24X0_REG8	res13[3]; +	S3C24X0_REG8	BCDHOUR; +	S3C24X0_REG8	res14[3]; +	S3C24X0_REG8	BCDDATE; +	S3C24X0_REG8	res15[3]; +	S3C24X0_REG8	BCDDAY; +	S3C24X0_REG8	res16[3]; +	S3C24X0_REG8	BCDMON; +	S3C24X0_REG8	res17[3]; +	S3C24X0_REG8	BCDYEAR; +#else /*  little endian */ +	S3C24X0_REG8	res0[64]; +	S3C24X0_REG8	RTCCON; +	S3C24X0_REG8	res1[3]; +	S3C24X0_REG8	TICNT; +	S3C24X0_REG8	res2[11]; +	S3C24X0_REG8	RTCALM; +	S3C24X0_REG8	res3[3]; +	S3C24X0_REG8	ALMSEC; +	S3C24X0_REG8	res4[3]; +	S3C24X0_REG8	ALMMIN; +	S3C24X0_REG8	res5[3]; +	S3C24X0_REG8	ALMHOUR; +	S3C24X0_REG8	res6[3]; +	S3C24X0_REG8	ALMDATE; +	S3C24X0_REG8	res7[3]; +	S3C24X0_REG8	ALMMON; +	S3C24X0_REG8	res8[3]; +	S3C24X0_REG8	ALMYEAR; +	S3C24X0_REG8	res9[3]; +	S3C24X0_REG8	RTCRST; +	S3C24X0_REG8	res10[3]; +	S3C24X0_REG8	BCDSEC; +	S3C24X0_REG8	res11[3]; +	S3C24X0_REG8	BCDMIN; +	S3C24X0_REG8	res12[3]; +	S3C24X0_REG8	BCDHOUR; +	S3C24X0_REG8	res13[3]; +	S3C24X0_REG8	BCDDATE; +	S3C24X0_REG8	res14[3]; +	S3C24X0_REG8	BCDDAY; +	S3C24X0_REG8	res15[3]; +	S3C24X0_REG8	BCDMON; +	S3C24X0_REG8	res16[3]; +	S3C24X0_REG8	BCDYEAR; +	S3C24X0_REG8	res17[3]; +#endif +} /*__attribute__((__packed__))*/ S3C24X0_RTC; + + +/* ADC (see manual chapter 16) */ +typedef struct { +	S3C24X0_REG32	ADCCON; +	S3C24X0_REG32	ADCDAT; +} /*__attribute__((__packed__))*/ S3C2400_ADC; + + +/* ADC (see manual chapter 16) */ +typedef struct { +	S3C24X0_REG32	ADCCON; +	S3C24X0_REG32	ADCTSC; +	S3C24X0_REG32	ADCDLY; +	S3C24X0_REG32	ADCDAT0; +	S3C24X0_REG32	ADCDAT1; +} /*__attribute__((__packed__))*/ S3C2410_ADC; + + +/* SPI (see manual chapter 22) */ +typedef struct { +	S3C24X0_REG32	SPCON; +	S3C24X0_REG32	SPSTA; +	S3C24X0_REG32	SPPIN; +	S3C24X0_REG32	SPPRE; +	S3C24X0_REG32	SPTDAT; +	S3C24X0_REG32	SPRDAT; +	S3C24X0_REG32	res[2]; +} __attribute__((__packed__)) S3C24X0_SPI_CHANNEL; + +typedef struct { +	S3C24X0_SPI_CHANNEL	ch[S3C24X0_SPI_CHANNELS]; +} /*__attribute__((__packed__))*/ S3C24X0_SPI; + + +/* MMC INTERFACE (see S3C2400 manual chapter 19) */ +typedef struct { +#ifdef __BIG_ENDIAN +	S3C24X0_REG8	res1[3]; +	S3C24X0_REG8	MMCON; +	S3C24X0_REG8	res2[3]; +	S3C24X0_REG8	MMCRR; +	S3C24X0_REG8	res3[3]; +	S3C24X0_REG8	MMFCON; +	S3C24X0_REG8	res4[3]; +	S3C24X0_REG8	MMSTA; +	S3C24X0_REG16	res5; +	S3C24X0_REG16	MMFSTA; +	S3C24X0_REG8	res6[3]; +	S3C24X0_REG8	MMPRE; +	S3C24X0_REG16	res7; +	S3C24X0_REG16	MMLEN; +	S3C24X0_REG8	res8[3]; +	S3C24X0_REG8	MMCR7; +	S3C24X0_REG32	MMRSP[4]; +	S3C24X0_REG8	res9[3]; +	S3C24X0_REG8	MMCMD0; +	S3C24X0_REG32	MMCMD1; +	S3C24X0_REG16	res10; +	S3C24X0_REG16	MMCR16; +	S3C24X0_REG8	res11[3]; +	S3C24X0_REG8	MMDAT; +#else +	S3C24X0_REG8	MMCON; +	S3C24X0_REG8	res1[3]; +	S3C24X0_REG8	MMCRR; +	S3C24X0_REG8	res2[3]; +	S3C24X0_REG8	MMFCON; +	S3C24X0_REG8	res3[3]; +	S3C24X0_REG8	MMSTA; +	S3C24X0_REG8	res4[3]; +	S3C24X0_REG16	MMFSTA; +	S3C24X0_REG16	res5; +	S3C24X0_REG8	MMPRE; +	S3C24X0_REG8	res6[3]; +	S3C24X0_REG16	MMLEN; +	S3C24X0_REG16	res7; +	S3C24X0_REG8	MMCR7; +	S3C24X0_REG8	res8[3]; +	S3C24X0_REG32	MMRSP[4]; +	S3C24X0_REG8	MMCMD0; +	S3C24X0_REG8	res9[3]; +	S3C24X0_REG32	MMCMD1; +	S3C24X0_REG16	MMCR16; +	S3C24X0_REG16	res10; +	S3C24X0_REG8	MMDAT; +	S3C24X0_REG8	res11[3]; +#endif +} /*__attribute__((__packed__))*/ S3C2400_MMC; + + +/* SD INTERFACE (see S3C2410 manual chapter 19) */ +typedef struct { +	S3C24X0_REG32	SDICON; +	S3C24X0_REG32	SDIPRE; +	S3C24X0_REG32	SDICARG; +	S3C24X0_REG32	SDICCON; +	S3C24X0_REG32	SDICSTA; +	S3C24X0_REG32	SDIRSP0; +	S3C24X0_REG32	SDIRSP1; +	S3C24X0_REG32	SDIRSP2; +	S3C24X0_REG32	SDIRSP3; +	S3C24X0_REG32	SDIDTIMER; +	S3C24X0_REG32	SDIBSIZE; +	S3C24X0_REG32	SDIDCON; +	S3C24X0_REG32	SDIDCNT; +	S3C24X0_REG32	SDIDSTA; +	S3C24X0_REG32	SDIFSTA; +#ifdef __BIG_ENDIAN +	S3C24X0_REG8	res[3]; +	S3C24X0_REG8	SDIDAT; +#else +	S3C24X0_REG8	SDIDAT; +	S3C24X0_REG8	res[3]; +#endif +	S3C24X0_REG32	SDIIMSK; +} /*__attribute__((__packed__))*/ S3C2410_SDI; + + +#if 0 +/* Memory control */ +#define rBWSCON			(*(volatile unsigned *)0x48000000) +#define rBANKCON0		(*(volatile unsigned *)0x48000004) +#define rBANKCON1		(*(volatile unsigned *)0x48000008) +#define rBANKCON2		(*(volatile unsigned *)0x4800000C) +#define rBANKCON3		(*(volatile unsigned *)0x48000010) +#define rBANKCON4		(*(volatile unsigned *)0x48000014) +#define rBANKCON5		(*(volatile unsigned *)0x48000018) +#define rBANKCON6		(*(volatile unsigned *)0x4800001C) +#define rBANKCON7		(*(volatile unsigned *)0x48000020) +#define rREFRESH		(*(volatile unsigned *)0x48000024) +#define rBANKSIZE		(*(volatile unsigned *)0x48000028) +#define rMRSRB6			(*(volatile unsigned *)0x4800002C) +#define rMRSRB7			(*(volatile unsigned *)0x48000030) + + +/* USB HOST */ +#define rHcRevision		(*(volatile unsigned *)0x49000000) +#define rHcControl		(*(volatile unsigned *)0x49000004) +#define rHcCommonStatus		(*(volatile unsigned *)0x49000008) +#define rHcInterruptStatus	(*(volatile unsigned *)0x4900000C) +#define rHcInterruptEnable	(*(volatile unsigned *)0x49000010) +#define rHcInterruptDisable	(*(volatile unsigned *)0x49000014) +#define rHcHCCA			(*(volatile unsigned *)0x49000018) +#define rHcPeriodCuttendED	(*(volatile unsigned *)0x4900001C) +#define rHcControlHeadED	(*(volatile unsigned *)0x49000020) +#define rHcControlCurrentED	(*(volatile unsigned *)0x49000024) +#define rHcBulkHeadED		(*(volatile unsigned *)0x49000028) +#define rHcBuldCurrentED	(*(volatile unsigned *)0x4900002C) +#define rHcDoneHead		(*(volatile unsigned *)0x49000030) +#define rHcRmInterval		(*(volatile unsigned *)0x49000034) +#define rHcFmRemaining		(*(volatile unsigned *)0x49000038) +#define rHcFmNumber		(*(volatile unsigned *)0x4900003C) +#define rHcPeriodicStart	(*(volatile unsigned *)0x49000040) +#define rHcLSThreshold		(*(volatile unsigned *)0x49000044) +#define rHcRhDescriptorA	(*(volatile unsigned *)0x49000048) +#define rHcRhDescriptorB	(*(volatile unsigned *)0x4900004C) +#define rHcRhStatus		(*(volatile unsigned *)0x49000050) +#define rHcRhPortStatus1	(*(volatile unsigned *)0x49000054) +#define rHcRhPortStatus2	(*(volatile unsigned *)0x49000058) + + +/* INTERRUPT */ +#define rSRCPND			(*(volatile unsigned *)0x4A000000) +#define rINTMOD			(*(volatile unsigned *)0x4A000004) +#define rINTMSK			(*(volatile unsigned *)0x4A000008) +#define rPRIORITY		(*(volatile unsigned *)0x4A00000C) +#define rINTPND			(*(volatile unsigned *)0x4A000010) +#define rINTOFFSET		(*(volatile unsigned *)0x4A000014) +#define rSUBSRCPND		(*(volatile unsigned *)0x4A000018) +#define rINTSUBMSK		(*(volatile unsigned *)0x4A00001C) + + +/* DMA */ +#define rDISRC0			(*(volatile unsigned *)0x4B000000) +#define rDISRCC0		(*(volatile unsigned *)0x4B000004) +#define rDIDST0			(*(volatile unsigned *)0x4B000008) +#define rDIDSTC0		(*(volatile unsigned *)0x4B00000C) +#define rDCON0			(*(volatile unsigned *)0x4B000010) +#define rDSTAT0			(*(volatile unsigned *)0x4B000014) +#define rDCSRC0			(*(volatile unsigned *)0x4B000018) +#define rDCDST0			(*(volatile unsigned *)0x4B00001C) +#define rDMASKTRIG0		(*(volatile unsigned *)0x4B000020) +#define rDISRC1			(*(volatile unsigned *)0x4B000040) +#define rDISRCC1		(*(volatile unsigned *)0x4B000044) +#define rDIDST1			(*(volatile unsigned *)0x4B000048) +#define rDIDSTC1		(*(volatile unsigned *)0x4B00004C) +#define rDCON1			(*(volatile unsigned *)0x4B000050) +#define rDSTAT1			(*(volatile unsigned *)0x4B000054) +#define rDCSRC1			(*(volatile unsigned *)0x4B000058) +#define rDCDST1			(*(volatile unsigned *)0x4B00005C) +#define rDMASKTRIG1		(*(volatile unsigned *)0x4B000060) +#define rDISRC2			(*(volatile unsigned *)0x4B000080) +#define rDISRCC2		(*(volatile unsigned *)0x4B000084) +#define rDIDST2			(*(volatile unsigned *)0x4B000088) +#define rDIDSTC2		(*(volatile unsigned *)0x4B00008C) +#define rDCON2			(*(volatile unsigned *)0x4B000090) +#define rDSTAT2			(*(volatile unsigned *)0x4B000094) +#define rDCSRC2			(*(volatile unsigned *)0x4B000098) +#define rDCDST2			(*(volatile unsigned *)0x4B00009C) +#define rDMASKTRIG2		(*(volatile unsigned *)0x4B0000A0) +#define rDISRC3			(*(volatile unsigned *)0x4B0000C0) +#define rDISRCC3		(*(volatile unsigned *)0x4B0000C4) +#define rDIDST3			(*(volatile unsigned *)0x4B0000C8) +#define rDIDSTC3		(*(volatile unsigned *)0x4B0000CC) +#define rDCON3			(*(volatile unsigned *)0x4B0000D0) +#define rDSTAT3			(*(volatile unsigned *)0x4B0000D4) +#define rDCSRC3			(*(volatile unsigned *)0x4B0000D8) +#define rDCDST3			(*(volatile unsigned *)0x4B0000DC) +#define rDMASKTRIG3		(*(volatile unsigned *)0x4B0000E0) + + +/* CLOCK & POWER MANAGEMENT */ +#define rLOCKTIME		(*(volatile unsigned *)0x4C000000) +#define rMPLLCON		(*(volatile unsigned *)0x4C000004) +#define rUPLLCON		(*(volatile unsigned *)0x4C000008) +#define rCLKCON			(*(volatile unsigned *)0x4C00000C) +#define rCLKSLOW		(*(volatile unsigned *)0x4C000010) +#define rCLKDIVN		(*(volatile unsigned *)0x4C000014) + + +/* LCD CONTROLLER */ +#define rLCDCON1		(*(volatile unsigned *)0x4D000000) +#define rLCDCON2		(*(volatile unsigned *)0x4D000004) +#define rLCDCON3		(*(volatile unsigned *)0x4D000008) +#define rLCDCON4		(*(volatile unsigned *)0x4D00000C) +#define rLCDCON5		(*(volatile unsigned *)0x4D000010) +#define rLCDSADDR1		(*(volatile unsigned *)0x4D000014) +#define rLCDSADDR2		(*(volatile unsigned *)0x4D000018) +#define rLCDSADDR3		(*(volatile unsigned *)0x4D00001C) +#define rREDLUT			(*(volatile unsigned *)0x4D000020) +#define rGREENLUT		(*(volatile unsigned *)0x4D000024) +#define rBLUELUT		(*(volatile unsigned *)0x4D000028) +#define rDITHMODE		(*(volatile unsigned *)0x4D00004C) +#define rTPAL			(*(volatile unsigned *)0x4D000050) +#define rLCDINTPND		(*(volatile unsigned *)0x4D000054) +#define rLCDSRCPND		(*(volatile unsigned *)0x4D000058) +#define rLCDINTMSK		(*(volatile unsigned *)0x4D00005C) + + +/* NAND FLASH */ +#define rNFCONF			(*(volatile unsigned *)0x4E000000) +#define rNFCMD			(*(volatile unsigned *)0x4E000004) +#define rNFADDR			(*(volatile unsigned *)0x4E000008) +#define rNFDATA			(*(volatile unsigned *)0x4E00000C) +#define rNFSTAT			(*(volatile unsigned *)0x4E000010) +#define rNFECC			(*(volatile unsigned *)0x4E000014) + + +/* UART */ +#define rULCON0			(*(volatile unsigned *)0x50000000) +#define rUCON0			(*(volatile unsigned *)0x50000004) +#define rUFCON0			(*(volatile unsigned *)0x50000008) +#define rUMCON0			(*(volatile unsigned *)0x5000000C) +#define rUTRSTAT0		(*(volatile unsigned *)0x50000010) +#define rUERSTAT0		(*(volatile unsigned *)0x50000014) +#define rUFSTAT0		(*(volatile unsigned *)0x50000018) +#define rUMSTAT0		(*(volatile unsigned *)0x5000001C) +#define rUBRDIV0		(*(volatile unsigned *)0x50000028) + +#define rULCON1			(*(volatile unsigned *)0x50004000) +#define rUCON1			(*(volatile unsigned *)0x50004004) +#define rUFCON1			(*(volatile unsigned *)0x50004008) +#define rUMCON1			(*(volatile unsigned *)0x5000400C) +#define rUTRSTAT1		(*(volatile unsigned *)0x50004010) +#define rUERSTAT1		(*(volatile unsigned *)0x50004014) +#define rUFSTAT1		(*(volatile unsigned *)0x50004018) +#define rUMSTAT1		(*(volatile unsigned *)0x5000401C) +#define rUBRDIV1		(*(volatile unsigned *)0x50004028) + +#define rULCON2			(*(volatile unsigned *)0x50008000) +#define rUCON2			(*(volatile unsigned *)0x50008004) +#define rUFCON2			(*(volatile unsigned *)0x50008008) +#define rUTRSTAT2		(*(volatile unsigned *)0x50008010) +#define rUERSTAT2		(*(volatile unsigned *)0x50008014) +#define rUFSTAT2		(*(volatile unsigned *)0x50008018) +#define rUBRDIV2		(*(volatile unsigned *)0x50008028) + +#ifdef __BIG_ENDIAN +#define rUTXH0			(*(volatile unsigned char *)0x50000023) +#define rURXH0			(*(volatile unsigned char *)0x50000027) +#define rUTXH1			(*(volatile unsigned char *)0x50004023) +#define rURXH1			(*(volatile unsigned char *)0x50004027) +#define rUTXH2			(*(volatile unsigned char *)0x50008023) +#define rURXH2			(*(volatile unsigned char *)0x50008027) + +#define WrUTXH0(ch)		(*(volatile unsigned char *)0x50000023)=(unsigned char)(ch) +#define RdURXH0()		(*(volatile unsigned char *)0x50000027) +#define WrUTXH1(ch)		(*(volatile unsigned char *)0x50004023)=(unsigned char)(ch) +#define RdURXH1()		(*(volatile unsigned char *)0x50004027) +#define WrUTXH2(ch)		(*(volatile unsigned char *)0x50008023)=(unsigned char)(ch) +#define RdURXH2()		(*(volatile unsigned char *)0x50008027) + +#define UTXH0			(0x50000020+3)  /* byte_access address by DMA */ +#define URXH0			(0x50000024+3) +#define UTXH1			(0x50004020+3) +#define URXH1			(0x50004024+3) +#define UTXH2			(0x50008020+3) +#define URXH2			(0x50008024+3) + +#else /* Little Endian */ +#define rUTXH0			(*(volatile unsigned char *)0x50000020) +#define rURXH0			(*(volatile unsigned char *)0x50000024) +#define rUTXH1			(*(volatile unsigned char *)0x50004020) +#define rURXH1			(*(volatile unsigned char *)0x50004024) +#define rUTXH2			(*(volatile unsigned char *)0x50008020) +#define rURXH2			(*(volatile unsigned char *)0x50008024) + +#define WrUTXH0(ch)		(*(volatile unsigned char *)0x50000020)=(unsigned char)(ch) +#define RdURXH0()		(*(volatile unsigned char *)0x50000024) +#define WrUTXH1(ch)		(*(volatile unsigned char *)0x50004020)=(unsigned char)(ch) +#define RdURXH1()		(*(volatile unsigned char *)0x50004024) +#define WrUTXH2(ch)		(*(volatile unsigned char *)0x50008020)=(unsigned char)(ch) +#define RdURXH2()		(*(volatile unsigned char *)0x50008024) + +#define UTXH0			(0x50000020)    /* byte_access address by DMA */ +#define URXH0			(0x50000024) +#define UTXH1			(0x50004020) +#define URXH1			(0x50004024) +#define UTXH2			(0x50008020) +#define URXH2			(0x50008024) +#endif + + +/* PWM TIMER */ +#define rTCFG0			(*(volatile unsigned *)0x51000000) +#define rTCFG1			(*(volatile unsigned *)0x51000004) +#define rTCON			(*(volatile unsigned *)0x51000008) +#define rTCNTB0			(*(volatile unsigned *)0x5100000C) +#define rTCMPB0			(*(volatile unsigned *)0x51000010) +#define rTCNTO0			(*(volatile unsigned *)0x51000014) +#define rTCNTB1			(*(volatile unsigned *)0x51000018) +#define rTCMPB1			(*(volatile unsigned *)0x5100001C) +#define rTCNTO1			(*(volatile unsigned *)0x51000020) +#define rTCNTB2			(*(volatile unsigned *)0x51000024) +#define rTCMPB2			(*(volatile unsigned *)0x51000028) +#define rTCNTO2			(*(volatile unsigned *)0x5100002C) +#define rTCNTB3			(*(volatile unsigned *)0x51000030) +#define rTCMPB3			(*(volatile unsigned *)0x51000034) +#define rTCNTO3			(*(volatile unsigned *)0x51000038) +#define rTCNTB4			(*(volatile unsigned *)0x5100003C) +#define rTCNTO4			(*(volatile unsigned *)0x51000040) + + +/* USB DEVICE */ +#ifdef __BIG_ENDIAN +#define rFUNC_ADDR_REG		(*(volatile unsigned char *)0x52000143) +#define rPWR_REG		(*(volatile unsigned char *)0x52000147) +#define rEP_INT_REG		(*(volatile unsigned char *)0x5200014B) +#define rUSB_INT_REG		(*(volatile unsigned char *)0x5200015B) +#define rEP_INT_EN_REG		(*(volatile unsigned char *)0x5200015F) +#define rUSB_INT_EN_REG		(*(volatile unsigned char *)0x5200016F) +#define rFRAME_NUM1_REG		(*(volatile unsigned char *)0x52000173) +#define rFRAME_NUM2_REG		(*(volatile unsigned char *)0x52000177) +#define rINDEX_REG		(*(volatile unsigned char *)0x5200017B) +#define rMAXP_REG		(*(volatile unsigned char *)0x52000183) +#define rEP0_CSR		(*(volatile unsigned char *)0x52000187) +#define rIN_CSR1_REG		(*(volatile unsigned char *)0x52000187) +#define rIN_CSR2_REG		(*(volatile unsigned char *)0x5200018B) +#define rOUT_CSR1_REG		(*(volatile unsigned char *)0x52000193) +#define rOUT_CSR2_REG		(*(volatile unsigned char *)0x52000197) +#define rOUT_FIFO_CNT1_REG	(*(volatile unsigned char *)0x5200019B) +#define rOUT_FIFO_CNT2_REG	(*(volatile unsigned char *)0x5200019F) +#define rEP0_FIFO		(*(volatile unsigned char *)0x520001C3) +#define rEP1_FIFO		(*(volatile unsigned char *)0x520001C7) +#define rEP2_FIFO		(*(volatile unsigned char *)0x520001CB) +#define rEP3_FIFO		(*(volatile unsigned char *)0x520001CF) +#define rEP4_FIFO		(*(volatile unsigned char *)0x520001D3) +#define rEP1_DMA_CON		(*(volatile unsigned char *)0x52000203) +#define rEP1_DMA_UNIT		(*(volatile unsigned char *)0x52000207) +#define rEP1_DMA_FIFO		(*(volatile unsigned char *)0x5200020B) +#define rEP1_DMA_TX_LO		(*(volatile unsigned char *)0x5200020F) +#define rEP1_DMA_TX_MD		(*(volatile unsigned char *)0x52000213) +#define rEP1_DMA_TX_HI		(*(volatile unsigned char *)0x52000217) +#define rEP2_DMA_CON		(*(volatile unsigned char *)0x5200021B) +#define rEP2_DMA_UNIT		(*(volatile unsigned char *)0x5200021F) +#define rEP2_DMA_FIFO		(*(volatile unsigned char *)0x52000223) +#define rEP2_DMA_TX_LO		(*(volatile unsigned char *)0x52000227) +#define rEP2_DMA_TX_MD		(*(volatile unsigned char *)0x5200022B) +#define rEP2_DMA_TX_HI		(*(volatile unsigned char *)0x5200022F) +#define rEP3_DMA_CON		(*(volatile unsigned char *)0x52000243) +#define rEP3_DMA_UNIT		(*(volatile unsigned char *)0x52000247) +#define rEP3_DMA_FIFO		(*(volatile unsigned char *)0x5200024B) +#define rEP3_DMA_TX_LO		(*(volatile unsigned char *)0x5200024F) +#define rEP3_DMA_TX_MD		(*(volatile unsigned char *)0x52000253) +#define rEP3_DMA_TX_HI		(*(volatile unsigned char *)0x52000257) +#define rEP4_DMA_CON		(*(volatile unsigned char *)0x5200025B) +#define rEP4_DMA_UNIT		(*(volatile unsigned char *)0x5200025F) +#define rEP4_DMA_FIFO		(*(volatile unsigned char *)0x52000263) +#define rEP4_DMA_TX_LO		(*(volatile unsigned char *)0x52000267) +#define rEP4_DMA_TX_MD		(*(volatile unsigned char *)0x5200026B) +#define rEP4_DMA_TX_HI		(*(volatile unsigned char *)0x5200026F) +#else /*  little endian */ +#define rFUNC_ADDR_REG		(*(volatile unsigned char *)0x52000140) +#define rPWR_REG		(*(volatile unsigned char *)0x52000144) +#define rEP_INT_REG		(*(volatile unsigned char *)0x52000148) +#define rUSB_INT_REG		(*(volatile unsigned char *)0x52000158) +#define rEP_INT_EN_REG		(*(volatile unsigned char *)0x5200015C) +#define rUSB_INT_EN_REG		(*(volatile unsigned char *)0x5200016C) +#define rFRAME_NUM1_REG		(*(volatile unsigned char *)0x52000170) +#define rFRAME_NUM2_REG		(*(volatile unsigned char *)0x52000174) +#define rINDEX_REG		(*(volatile unsigned char *)0x52000178) +#define rMAXP_REG		(*(volatile unsigned char *)0x52000180) +#define rEP0_CSR		(*(volatile unsigned char *)0x52000184) +#define rIN_CSR1_REG		(*(volatile unsigned char *)0x52000184) +#define rIN_CSR2_REG		(*(volatile unsigned char *)0x52000188) +#define rOUT_CSR1_REG		(*(volatile unsigned char *)0x52000190) +#define rOUT_CSR2_REG		(*(volatile unsigned char *)0x52000194) +#define rOUT_FIFO_CNT1_REG	(*(volatile unsigned char *)0x52000198) +#define rOUT_FIFO_CNT2_REG	(*(volatile unsigned char *)0x5200019C) +#define rEP0_FIFO		(*(volatile unsigned char *)0x520001C0) +#define rEP1_FIFO		(*(volatile unsigned char *)0x520001C4) +#define rEP2_FIFO		(*(volatile unsigned char *)0x520001C8) +#define rEP3_FIFO		(*(volatile unsigned char *)0x520001CC) +#define rEP4_FIFO		(*(volatile unsigned char *)0x520001D0) +#define rEP1_DMA_CON		(*(volatile unsigned char *)0x52000200) +#define rEP1_DMA_UNIT		(*(volatile unsigned char *)0x52000204) +#define rEP1_DMA_FIFO		(*(volatile unsigned char *)0x52000208) +#define rEP1_DMA_TX_LO		(*(volatile unsigned char *)0x5200020C) +#define rEP1_DMA_TX_MD		(*(volatile unsigned char *)0x52000210) +#define rEP1_DMA_TX_HI		(*(volatile unsigned char *)0x52000214) +#define rEP2_DMA_CON		(*(volatile unsigned char *)0x52000218) +#define rEP2_DMA_UNIT		(*(volatile unsigned char *)0x5200021C) +#define rEP2_DMA_FIFO		(*(volatile unsigned char *)0x52000220) +#define rEP2_DMA_TX_LO		(*(volatile unsigned char *)0x52000224) +#define rEP2_DMA_TX_MD		(*(volatile unsigned char *)0x52000228) +#define rEP2_DMA_TX_HI		(*(volatile unsigned char *)0x5200022C) +#define rEP3_DMA_CON		(*(volatile unsigned char *)0x52000240) +#define rEP3_DMA_UNIT		(*(volatile unsigned char *)0x52000244) +#define rEP3_DMA_FIFO		(*(volatile unsigned char *)0x52000248) +#define rEP3_DMA_TX_LO		(*(volatile unsigned char *)0x5200024C) +#define rEP3_DMA_TX_MD		(*(volatile unsigned char *)0x52000250) +#define rEP3_DMA_TX_HI		(*(volatile unsigned char *)0x52000254) +#define rEP4_DMA_CON		(*(volatile unsigned char *)0x52000258) +#define rEP4_DMA_UNIT		(*(volatile unsigned char *)0x5200025C) +#define rEP4_DMA_FIFO		(*(volatile unsigned char *)0x52000260) +#define rEP4_DMA_TX_LO		(*(volatile unsigned char *)0x52000264) +#define rEP4_DMA_TX_MD		(*(volatile unsigned char *)0x52000268) +#define rEP4_DMA_TX_HI		(*(volatile unsigned char *)0x5200026C) +#endif /*  __BIG_ENDIAN */ + + +/* WATCH DOG TIMER */ +#define rWTCON			(*(volatile unsigned *)0x53000000) +#define rWTDAT			(*(volatile unsigned *)0x53000004) +#define rWTCNT			(*(volatile unsigned *)0x53000008) + + +/* IIC */ +#define rIICCON			(*(volatile unsigned *)0x54000000) +#define rIICSTAT		(*(volatile unsigned *)0x54000004) +#define rIICADD			(*(volatile unsigned *)0x54000008) +#define rIICDS			(*(volatile unsigned *)0x5400000C) + + +/* IIS */ +#define rIISCON			(*(volatile unsigned *)0x55000000) +#define rIISMOD			(*(volatile unsigned *)0x55000004) +#define rIISPSR			(*(volatile unsigned *)0x55000008) +#define rIISFCON		(*(volatile unsigned *)0x5500000C) + +#ifdef __BIG_ENDIAN +#define IISFIF			((volatile unsigned short *)0x55000012) +#else /*  little endian */ +#define IISFIF			((volatile unsigned short *)0x55000010) +#endif + + +/* I/O PORT */ +#define rGPACON			(*(volatile unsigned *)0x56000000) +#define rGPADAT			(*(volatile unsigned *)0x56000004) + +#define rGPBCON			(*(volatile unsigned *)0x56000010) +#define rGPBDAT			(*(volatile unsigned *)0x56000014) +#define rGPBUP			(*(volatile unsigned *)0x56000018) + +#define rGPCCON			(*(volatile unsigned *)0x56000020) +#define rGPCDAT			(*(volatile unsigned *)0x56000024) +#define rGPCUP			(*(volatile unsigned *)0x56000028) + +#define rGPDCON			(*(volatile unsigned *)0x56000030) +#define rGPDDAT			(*(volatile unsigned *)0x56000034) +#define rGPDUP			(*(volatile unsigned *)0x56000038) + +#define rGPECON			(*(volatile unsigned *)0x56000040) +#define rGPEDAT			(*(volatile unsigned *)0x56000044) +#define rGPEUP			(*(volatile unsigned *)0x56000048) + +#define rGPFCON			(*(volatile unsigned *)0x56000050) +#define rGPFDAT			(*(volatile unsigned *)0x56000054) +#define rGPFUP			(*(volatile unsigned *)0x56000058) + +#define rGPGCON			(*(volatile unsigned *)0x56000060) +#define rGPGDAT			(*(volatile unsigned *)0x56000064) +#define rGPGUP			(*(volatile unsigned *)0x56000068) + +#define rGPHCON			(*(volatile unsigned *)0x56000070) +#define rGPHDAT			(*(volatile unsigned *)0x56000074) +#define rGPHUP			(*(volatile unsigned *)0x56000078) + +#define rMISCCR			(*(volatile unsigned *)0x56000080) +#define rDCLKCON		(*(volatile unsigned *)0x56000084) +#define rEXTINT0		(*(volatile unsigned *)0x56000088) +#define rEXTINT1		(*(volatile unsigned *)0x5600008C) +#define rEXTINT2		(*(volatile unsigned *)0x56000090) +#define rEINTFLT0		(*(volatile unsigned *)0x56000094) +#define rEINTFLT1		(*(volatile unsigned *)0x56000098) +#define rEINTFLT2		(*(volatile unsigned *)0x5600009C) +#define rEINTFLT3		(*(volatile unsigned *)0x560000A0) +#define rEINTMASK		(*(volatile unsigned *)0x560000A4) +#define rEINTPEND		(*(volatile unsigned *)0x560000A8) +#define rGSTATUS0		(*(volatile unsigned *)0x560000AC) +#define rGSTATUS1		(*(volatile unsigned *)0x560000B0) + + +/* RTC */ +#ifdef __BIG_ENDIAN +#define rRTCCON			(*(volatile unsigned char *)0x57000043) +#define rTICNT			(*(volatile unsigned char *)0x57000047) +#define rRTCALM			(*(volatile unsigned char *)0x57000053) +#define rALMSEC			(*(volatile unsigned char *)0x57000057) +#define rALMMIN			(*(volatile unsigned char *)0x5700005B) +#define rALMHOUR		(*(volatile unsigned char *)0x5700005F) +#define rALMDATE		(*(volatile unsigned char *)0x57000063) +#define rALMMON			(*(volatile unsigned char *)0x57000067) +#define rALMYEAR		(*(volatile unsigned char *)0x5700006B) +#define rRTCRST			(*(volatile unsigned char *)0x5700006F) +#define rBCDSEC			(*(volatile unsigned char *)0x57000073) +#define rBCDMIN			(*(volatile unsigned char *)0x57000077) +#define rBCDHOUR		(*(volatile unsigned char *)0x5700007B) +#define rBCDDATE		(*(volatile unsigned char *)0x5700007F) +#define rBCDDAY			(*(volatile unsigned char *)0x57000083) +#define rBCDMON			(*(volatile unsigned char *)0x57000087) +#define rBCDYEAR		(*(volatile unsigned char *)0x5700008B) +#else /*  little endian */ +#define rRTCCON			(*(volatile unsigned char *)0x57000040) +#define rTICNT			(*(volatile unsigned char *)0x57000044) +#define rRTCALM			(*(volatile unsigned char *)0x57000050) +#define rALMSEC			(*(volatile unsigned char *)0x57000054) +#define rALMMIN			(*(volatile unsigned char *)0x57000058) +#define rALMHOUR		(*(volatile unsigned char *)0x5700005C) +#define rALMDATE		(*(volatile unsigned char *)0x57000060) +#define rALMMON			(*(volatile unsigned char *)0x57000064) +#define rALMYEAR		(*(volatile unsigned char *)0x57000068) +#define rRTCRST			(*(volatile unsigned char *)0x5700006C) +#define rBCDSEC			(*(volatile unsigned char *)0x57000070) +#define rBCDMIN			(*(volatile unsigned char *)0x57000074) +#define rBCDHOUR		(*(volatile unsigned char *)0x57000078) +#define rBCDDATE		(*(volatile unsigned char *)0x5700007C) +#define rBCDDAY			(*(volatile unsigned char *)0x57000080) +#define rBCDMON			(*(volatile unsigned char *)0x57000084) +#define rBCDYEAR		(*(volatile unsigned char *)0x57000088) +#endif + + +/* ADC */ +#define rADCCON			(*(volatile unsigned *)0x58000000) +#define rADCTSC			(*(volatile unsigned *)0x58000004) +#define rADCDLY			(*(volatile unsigned *)0x58000008) +#define rADCDAT0		(*(volatile unsigned *)0x5800000C) +#define rADCDAT1		(*(volatile unsigned *)0x58000010) + + +/* SPI */ +#define rSPCON0			(*(volatile unsigned *)0x59000000) +#define rSPSTA0			(*(volatile unsigned *)0x59000004) +#define rSPPIN0			(*(volatile unsigned *)0x59000008) +#define rSPPRE0			(*(volatile unsigned *)0x5900000C) +#define rSPTDAT0		(*(volatile unsigned *)0x59000010) +#define rSPRDAT0		(*(volatile unsigned *)0x59000014) +#define rSPCON1			(*(volatile unsigned *)0x59000020) +#define rSPSTA1			(*(volatile unsigned *)0x59000024) +#define rSPPIN1			(*(volatile unsigned *)0x59000028) +#define rSPPRE1			(*(volatile unsigned *)0x5900002C) +#define rSPTDAT1		(*(volatile unsigned *)0x59000030) +#define rSPRDAT1		(*(volatile unsigned *)0x59000034) + + +/* SD INTERFACE */ +#define rSDICON			(*(volatile unsigned *)0x5A000000) +#define rSDIPRE			(*(volatile unsigned *)0x5A000004) +#define rSDICmdArg		(*(volatile unsigned *)0x5A000008) +#define rSDICmdCon		(*(volatile unsigned *)0x5A00000C) +#define rSDICmdSta		(*(volatile unsigned *)0x5A000010) +#define rSDIRSP0		(*(volatile unsigned *)0x5A000014) +#define rSDIRSP1		(*(volatile unsigned *)0x5A000018) +#define rSDIRSP2		(*(volatile unsigned *)0x5A00001C) +#define rSDIRSP3		(*(volatile unsigned *)0x5A000020) +#define rSDIDTimer		(*(volatile unsigned *)0x5A000024) +#define rSDIBSize		(*(volatile unsigned *)0x5A000028) +#define rSDIDatCon		(*(volatile unsigned *)0x5A00002C) +#define rSDIDatCnt		(*(volatile unsigned *)0x5A000030) +#define rSDIDatSta		(*(volatile unsigned *)0x5A000034) +#define rSDIFSTA		(*(volatile unsigned *)0x5A000038) +#ifdef __BIG_ENDIAN +#define rSDIDAT			(*(volatile unsigned char *)0x5A00003F) +#else +#define rSDIDAT			(*(volatile unsigned char *)0x5A00003C) +#endif +#define rSDIIntMsk		(*(volatile unsigned *)0x5A000040) + +#endif + +#endif /*__S3C24X0_H__*/ diff --git a/include/status_led.h b/include/status_led.h index c1fb7f3f2..5a33e31e9 100644 --- a/include/status_led.h +++ b/include/status_led.h @@ -321,6 +321,10 @@ void status_led_set  (int led, int state);  #endif  /************************************************************************/ +#ifndef CONFIG_BOARD_SPECIFIC_LED +# include <asm/status_led.h> +#endif +  #endif	/* CONFIG_STATUS_LED	*/  #endif	/* _STATUS_LED_H_	*/ |