#define S3C24X0_SPI_CHANNELS   1
 #define PALETTE                        (0x14A00400)    /* SJS */
 
-typedef enum {
+enum s3c24x0_uarts_nr {
        S3C24X0_UART0,
        S3C24X0_UART1,
-} S3C24X0_UARTS_NR;
+};
 
-/* S3C2400 device base addresses */
+/*S3C2400 device base addresses */
 #define S3C24X0_MEMCTL_BASE            0x14000000
 #define S3C24X0_USB_HOST_BASE          0x14200000
 #define S3C24X0_INTERRUPT_BASE         0x14400000
 #include <s3c24x0.h>
 
 
-static inline S3C24X0_MEMCTL * S3C24X0_GetBase_MEMCTL(void)
+static inline struct s3c24x0_memctl *s3c24x0_get_base_memctl(void)
 {
-       return (S3C24X0_MEMCTL * const)S3C24X0_MEMCTL_BASE;
+       return (struct s3c24x0_memctl *)S3C24X0_MEMCTL_BASE;
 }
-static inline S3C24X0_USB_HOST * S3C24X0_GetBase_USB_HOST(void)
+static inline struct s3c24x0_usb_host *s3c24x0_get_base_usb_host(void)
 {
-       return (S3C24X0_USB_HOST * const)S3C24X0_USB_HOST_BASE;
+       return (struct s3c24x0_usb_host *)S3C24X0_USB_HOST_BASE;
 }
-static inline S3C24X0_INTERRUPT * S3C24X0_GetBase_INTERRUPT(void)
+static inline struct s3c24x0_interrupt *s3c24x0_get_base_interrupt(void)
 {
-       return (S3C24X0_INTERRUPT * const)S3C24X0_INTERRUPT_BASE;
+       return (struct s3c24x0_interrupt *)S3C24X0_INTERRUPT_BASE;
 }
-static inline S3C24X0_DMAS * S3C24X0_GetBase_DMAS(void)
+static inline struct s3c24x0_dmas *s3c24x0_get_base_dmas(void)
 {
-       return (S3C24X0_DMAS * const)S3C24X0_DMA_BASE;
+       return (struct s3c24x0_dmas *)S3C24X0_DMA_BASE;
 }
-static inline S3C24X0_CLOCK_POWER * S3C24X0_GetBase_CLOCK_POWER(void)
+static inline struct s3c24x0_clock_power *s3c24x0_get_base_clock_power(void)
 {
-       return (S3C24X0_CLOCK_POWER * const)S3C24X0_CLOCK_POWER_BASE;
+       return (struct s3c24x0_clock_power *)S3C24X0_CLOCK_POWER_BASE;
 }
-static inline S3C24X0_LCD * S3C24X0_GetBase_LCD(void)
+static inline struct s3c24x0_lcd *s3c24x0_get_base_lcd(void)
 {
-       return (S3C24X0_LCD * const)S3C24X0_LCD_BASE;
+       return (struct s3c24x0_lcd *)S3C24X0_LCD_BASE;
 }
-static inline S3C24X0_UART * S3C24X0_GetBase_UART(S3C24X0_UARTS_NR nr)
+static inline struct s3c24x0_uart
+       *s3c24x0_get_base_uart(enum s3c24x0_uarts_nr n)
 {
-       return (S3C24X0_UART * const)(S3C24X0_UART_BASE + (nr * 0x4000));
+       return (struct s3c24x0_uart *)(S3C24X0_UART_BASE + (n * 0x4000));
 }
-static inline S3C24X0_TIMERS * S3C24X0_GetBase_TIMERS(void)
+static inline struct s3c24x0_timers *s3c24x0_get_base_timers(void)
 {
-       return (S3C24X0_TIMERS * const)S3C24X0_TIMER_BASE;
+       return (struct s3c24x0_timers *)S3C24X0_TIMER_BASE;
 }
-static inline S3C24X0_USB_DEVICE * S3C24X0_GetBase_USB_DEVICE(void)
+static inline struct s3c24x0_usb_device *s3c24x0_get_base_usb_device(void)
 {
-       return (S3C24X0_USB_DEVICE * const)S3C24X0_USB_DEVICE_BASE;
+       return (struct s3c24x0_usb_device *)S3C24X0_USB_DEVICE_BASE;
 }
-static inline S3C24X0_WATCHDOG * S3C24X0_GetBase_WATCHDOG(void)
+static inline struct s3c24x0_watchdog *s3c24x0_get_base_watchdog(void)
 {
-       return (S3C24X0_WATCHDOG * const)S3C24X0_WATCHDOG_BASE;
+       return (struct s3c24x0_watchdog *)S3C24X0_WATCHDOG_BASE;
 }
-static inline S3C24X0_I2C * S3C24X0_GetBase_I2C(void)
+static inline struct s3c24x0_i2c *s3c24x0_get_base_i2c(void)
 {
-       return (S3C24X0_I2C * const)S3C24X0_I2C_BASE;
+       return (struct s3c24x0_i2c *)S3C24X0_I2C_BASE;
 }
-static inline S3C24X0_I2S * S3C24X0_GetBase_I2S(void)
+static inline struct s3c24x0_i2s *s3c24x0_get_base_i2s(void)
 {
-       return (S3C24X0_I2S * const)S3C24X0_I2S_BASE;
+       return (struct s3c24x0_i2s *)S3C24X0_I2S_BASE;
 }
-static inline S3C24X0_GPIO * S3C24X0_GetBase_GPIO(void)
+static inline struct s3c24x0_gpio *s3c24x0_get_base_gpio(void)
 {
-       return (S3C24X0_GPIO * const)S3C24X0_GPIO_BASE;
+       return (struct s3c24x0_gpio *)S3C24X0_GPIO_BASE;
 }
-static inline S3C24X0_RTC * S3C24X0_GetBase_RTC(void)
+static inline struct s3c24x0_rtc *s3c24x0_get_base_rtc(void)
 {
-       return (S3C24X0_RTC * const)S3C24X0_RTC_BASE;
+       return (struct s3c24x0_rtc *)S3C24X0_RTC_BASE;
 }
-static inline S3C2400_ADC * S3C2400_GetBase_ADC(void)
+static inline struct s3c2400_adc *s3c2400_get_base_adc(void)
 {
-       return (S3C2400_ADC * const)S3C24X0_ADC_BASE;
+       return (struct s3c2400_adc *)S3C24X0_ADC_BASE;
 }
-static inline S3C24X0_SPI * S3C24X0_GetBase_SPI(void)
+static inline struct s3c24x0_spi *s3c24x0_get_base_spi(void)
 {
-       return (S3C24X0_SPI * const)S3C24X0_SPI_BASE;
+       return (struct s3c24x0_spi *)S3C24X0_SPI_BASE;
 }
-static inline S3C2400_MMC * S3C2400_GetBase_MMC(void)
+static inline struct s3c2400_mmc *s3c2400_get_base_mmc(void)
 {
-       return (S3C2400_MMC * const)S3C2400_MMC_BASE;
+       return (struct s3c2400_mmc *)S3C2400_MMC_BASE;
 }
 
-#if 0
-/* Memory control */
-#define rBWSCON                (*(volatile unsigned *)0x14000000)
-#define rBANKCON0      (*(volatile unsigned *)0x14000004)
-#define rBANKCON1      (*(volatile unsigned *)0x14000008)
-#define rBANKCON2      (*(volatile unsigned *)0x1400000C)
-#define rBANKCON3      (*(volatile unsigned *)0x14000010)
-#define rBANKCON4      (*(volatile unsigned *)0x14000014)
-#define rBANKCON5      (*(volatile unsigned *)0x14000018)
-#define rBANKCON6      (*(volatile unsigned *)0x1400001C)
-#define rBANKCON7      (*(volatile unsigned *)0x14000020)
-#define rREFRESH       (*(volatile unsigned *)0x14000024)
-#define rBANKSIZE      (*(volatile unsigned *)0x14000028)
-#define rMRSRB6                (*(volatile unsigned *)0x1400002C)
-#define rMRSRB7                (*(volatile unsigned *)0x14000030)
-
-
-/* INTERRUPT */
-#define rSRCPND                (*(volatile unsigned *)0x14400000)
-#define rINTMOD                (*(volatile unsigned *)0x14400004)
-#define rINTMSK                (*(volatile unsigned *)0x14400008)
-#define rPRIORITY      (*(volatile unsigned *)0x1440000C)
-#define rINTPND                (*(volatile unsigned *)0x14400010)
-#define rINTOFFSET     (*(volatile unsigned *)0x14400014)
-
-
-/* DMA */
-#define rDISRC0                (*(volatile unsigned *)0x14600000)
-#define rDIDST0                (*(volatile unsigned *)0x14600004)
-#define rDCON0         (*(volatile unsigned *)0x14600008)
-#define rDSTAT0                (*(volatile unsigned *)0x1460000C)
-#define rDCSRC0                (*(volatile unsigned *)0x14600010)
-#define rDCDST0                (*(volatile unsigned *)0x14600014)
-#define rDMASKTRIG0    (*(volatile unsigned *)0x14600018)
-#define rDISRC1                (*(volatile unsigned *)0x14600020)
-#define rDIDST1                (*(volatile unsigned *)0x14600024)
-#define rDCON1         (*(volatile unsigned *)0x14600028)
-#define rDSTAT1                (*(volatile unsigned *)0x1460002C)
-#define rDCSRC1                (*(volatile unsigned *)0x14600030)
-#define rDCDST1                (*(volatile unsigned *)0x14600034)
-#define rDMASKTRIG1    (*(volatile unsigned *)0x14600038)
-#define rDISRC2                (*(volatile unsigned *)0x14600040)
-#define rDIDST2                (*(volatile unsigned *)0x14600044)
-#define rDCON2         (*(volatile unsigned *)0x14600048)
-#define rDSTAT2                (*(volatile unsigned *)0x1460004C)
-#define rDCSRC2                (*(volatile unsigned *)0x14600050)
-#define rDCDST2                (*(volatile unsigned *)0x14600054)
-#define rDMASKTRIG2    (*(volatile unsigned *)0x14600058)
-#define rDISRC3                (*(volatile unsigned *)0x14600060)
-#define rDIDST3                (*(volatile unsigned *)0x14600064)
-#define rDCON3         (*(volatile unsigned *)0x14600068)
-#define rDSTAT3                (*(volatile unsigned *)0x1460006C)
-#define rDCSRC3                (*(volatile unsigned *)0x14600070)
-#define rDCDST3                (*(volatile unsigned *)0x14600074)
-#define rDMASKTRIG3    (*(volatile unsigned *)0x14600078)
-
-
-/* CLOCK & POWER MANAGEMENT */
-#define rLOCKTIME      (*(volatile unsigned *)0x14800000)
-#define rMPLLCON       (*(volatile unsigned *)0x14800004)
-#define rUPLLCON       (*(volatile unsigned *)0x14800008)
-#define rCLKCON                (*(volatile unsigned *)0x1480000C)
-#define rCLKSLOW       (*(volatile unsigned *)0x14800010)
-#define rCLKDIVN       (*(volatile unsigned *)0x14800014)
-
-
-/* LCD CONTROLLER */
-#define rLCDCON1       (*(volatile unsigned *)0x14A00000)
-#define rLCDCON2       (*(volatile unsigned *)0x14A00004)
-#define rLCDCON3       (*(volatile unsigned *)0x14A00008)
-#define rLCDCON4       (*(volatile unsigned *)0x14A0000C)
-#define rLCDCON5       (*(volatile unsigned *)0x14A00010)
-#define rLCDSADDR1     (*(volatile unsigned *)0x14A00014)
-#define rLCDSADDR2     (*(volatile unsigned *)0x14A00018)
-#define rLCDSADDR3     (*(volatile unsigned *)0x14A0001C)
-#define rREDLUT                (*(volatile unsigned *)0x14A00020)
-#define rGREENLUT      (*(volatile unsigned *)0x14A00024)
-#define rBLUELUT       (*(volatile unsigned *)0x14A00028)
-#define rDP1_2         (*(volatile unsigned *)0x14A0002C)
-#define rDP4_7         (*(volatile unsigned *)0x14A00030)
-#define rDP3_5         (*(volatile unsigned *)0x14A00034)
-#define rDP2_3         (*(volatile unsigned *)0x14A00038)
-#define rDP5_7         (*(volatile unsigned *)0x14A0003c)
-#define rDP3_4         (*(volatile unsigned *)0x14A00040)
-#define rDP4_5         (*(volatile unsigned *)0x14A00044)
-#define rDP6_7         (*(volatile unsigned *)0x14A00048)
-#define rDITHMODE      (*(volatile unsigned *)0x14A0004C)
-#define rTPAL          (*(volatile unsigned *)0x14A00050)
-#define PALETTE                (0x14A00400)    /* SJS */
-
-
-/* UART */
-#define rULCON0                (*(volatile unsigned char *)0x15000000)
-#define rUCON0         (*(volatile unsigned short *)0x15000004)
-#define rUFCON0                (*(volatile unsigned char *)0x15000008)
-#define rUMCON0                (*(volatile unsigned char *)0x1500000C)
-#define rUTRSTAT0      (*(volatile unsigned char *)0x15000010)
-#define rUERSTAT0      (*(volatile unsigned char *)0x15000014)
-#define rUFSTAT0       (*(volatile unsigned short *)0x15000018)
-#define rUMSTAT0       (*(volatile unsigned char *)0x1500001C)
-#define rUBRDIV0       (*(volatile unsigned short *)0x15000028)
-
-#define rULCON1                (*(volatile unsigned char *)0x15004000)
-#define rUCON1         (*(volatile unsigned short *)0x15004004)
-#define rUFCON1                (*(volatile unsigned char *)0x15004008)
-#define rUMCON1                (*(volatile unsigned char *)0x1500400C)
-#define rUTRSTAT1      (*(volatile unsigned char *)0x15004010)
-#define rUERSTAT1      (*(volatile unsigned char *)0x15004014)
-#define rUFSTAT1       (*(volatile unsigned short *)0x15004018)
-#define rUMSTAT1       (*(volatile unsigned char *)0x1500401C)
-#define rUBRDIV1       (*(volatile unsigned short *)0x15004028)
-
-#ifdef __BIG_ENDIAN
-#define rUTXH0         (*(volatile unsigned char *)0x15000023)
-#define rURXH0         (*(volatile unsigned char *)0x15000027)
-#define rUTXH1         (*(volatile unsigned char *)0x15004023)
-#define rURXH1         (*(volatile unsigned char *)0x15004027)
-
-#define WrUTXH0(ch)    (*(volatile unsigned char *)0x15000023)=(unsigned char)(ch)
-#define RdURXH0()      (*(volatile unsigned char *)0x15000027)
-#define WrUTXH1(ch)    (*(volatile unsigned char *)0x15004023)=(unsigned char)(ch)
-#define RdURXH1()      (*(volatile unsigned char *)0x15004027)
-
-#define UTXH0          (0x15000020+3)  /* byte_access address by DMA */
-#define URXH0          (0x15000024+3)
-#define UTXH1          (0x15004020+3)
-#define URXH1          (0x15004024+3)
-
-#else /* Little Endian */
-#define rUTXH0         (*(volatile unsigned char *)0x15000020)
-#define rURXH0         (*(volatile unsigned char *)0x15000024)
-#define rUTXH1         (*(volatile unsigned char *)0x15004020)
-#define rURXH1         (*(volatile unsigned char *)0x15004024)
-
-#define WrUTXH0(ch)    (*(volatile unsigned char *)0x15000020)=(unsigned char)(ch)
-#define RdURXH0()      (*(volatile unsigned char *)0x15000024)
-#define WrUTXH1(ch)    (*(volatile unsigned char *)0x15004020)=(unsigned char)(ch)
-#define RdURXH1()      (*(volatile unsigned char *)0x15004024)
-
-#define UTXH0          (0x15000020)    /* byte_access address by DMA */
-#define URXH0          (0x15000024)
-#define UTXH1          (0x15004020)
-#define URXH1          (0x15004024)
-#endif
-
-
-/* PWM TIMER */
-#define rTCFG0         (*(volatile unsigned *)0x15100000)
-#define rTCFG1         (*(volatile unsigned *)0x15100004)
-#define rTCON          (*(volatile unsigned *)0x15100008)
-#define rTCNTB0                (*(volatile unsigned *)0x1510000C)
-#define rTCMPB0                (*(volatile unsigned *)0x15100010)
-#define rTCNTO0                (*(volatile unsigned *)0x15100014)
-#define rTCNTB1                (*(volatile unsigned *)0x15100018)
-#define rTCMPB1                (*(volatile unsigned *)0x1510001C)
-#define rTCNTO1                (*(volatile unsigned *)0x15100020)
-#define rTCNTB2                (*(volatile unsigned *)0x15100024)
-#define rTCMPB2                (*(volatile unsigned *)0x15100028)
-#define rTCNTO2                (*(volatile unsigned *)0x1510002C)
-#define rTCNTB3                (*(volatile unsigned *)0x15100030)
-#define rTCMPB3                (*(volatile unsigned *)0x15100034)
-#define rTCNTO3                (*(volatile unsigned *)0x15100038)
-#define rTCNTB4                (*(volatile unsigned *)0x1510003C)
-#define rTCNTO4                (*(volatile unsigned *)0x15100040)
-
-
-/* USB DEVICE */
-#define rFUNC_ADDR_REG (*(volatile unsigned *)0x15200140)
-#define rPWR_REG       (*(volatile unsigned *)0x15200144)
-#define rINT_REG       (*(volatile unsigned *)0x15200148)
-#define rINT_MASK_REG  (*(volatile unsigned *)0x1520014C)
-#define rFRAME_NUM_REG (*(volatile unsigned *)0x15200150)
-#define rRESUME_CON_REG        (*(volatile unsigned *)0x15200154)
-#define rEP0_CSR       (*(volatile unsigned *)0x15200160)
-#define rEP0_MAXP      (*(volatile unsigned *)0x15200164)
-#define rEP0_OUT_CNT   (*(volatile unsigned *)0x15200168)
-#define rEP0_FIFO      (*(volatile unsigned *)0x1520016C)
-#define rEP1_IN_CSR    (*(volatile unsigned *)0x15200180)
-#define rEP1_IN_MAXP   (*(volatile unsigned *)0x15200184)
-#define rEP1_FIFO      (*(volatile unsigned *)0x15200188)
-#define rEP2_IN_CSR    (*(volatile unsigned *)0x15200190)
-#define rEP2_IN_MAXP   (*(volatile unsigned *)0x15200194)
-#define rEP2_FIFO      (*(volatile unsigned *)0x15200198)
-#define rEP3_OUT_CSR   (*(volatile unsigned *)0x152001A0)
-#define rEP3_OUT_MAXP  (*(volatile unsigned *)0x152001A4)
-#define rEP3_OUT_CNT   (*(volatile unsigned *)0x152001A8)
-#define rEP3_FIFO      (*(volatile unsigned *)0x152001AC)
-#define rEP4_OUT_CSR   (*(volatile unsigned *)0x152001B0)
-#define rEP4_OUT_MAXP  (*(volatile unsigned *)0x152001B4)
-#define rEP4_OUT_CNT   (*(volatile unsigned *)0x152001B8)
-#define rEP4_FIFO      (*(volatile unsigned *)0x152001BC)
-#define rDMA_CON       (*(volatile unsigned *)0x152001C0)
-#define rDMA_UNIT      (*(volatile unsigned *)0x152001C4)
-#define rDMA_FIFO      (*(volatile unsigned *)0x152001C8)
-#define rDMA_TX                (*(volatile unsigned *)0x152001CC)
-#define rTEST_MODE     (*(volatile unsigned *)0x152001F4)
-#define rIN_CON_REG    (*(volatile unsigned *)0x152001F8)
-
-
-/* WATCH DOG TIMER */
-#define rWTCON         (*(volatile unsigned *)0x15300000)
-#define rWTDAT         (*(volatile unsigned *)0x15300004)
-#define rWTCNT         (*(volatile unsigned *)0x15300008)
-
-
-/* IIC */
-#define rIICCON                (*(volatile unsigned *)0x15400000)
-#define rIICSTAT       (*(volatile unsigned *)0x15400004)
-#define rIICADD                (*(volatile unsigned *)0x15400008)
-#define rIICDS         (*(volatile unsigned *)0x1540000C)
-
-
-/* IIS */
-#define rIISCON                (*(volatile unsigned *)0x15508000)
-#define rIISMOD                (*(volatile unsigned *)0x15508004)
-#define rIISPSR                (*(volatile unsigned *)0x15508008)
-#define rIISFIFCON     (*(volatile unsigned *)0x1550800C)
-
-#ifdef __BIG_ENDIAN
-#define IISFIF         ((volatile unsigned short *)0x15508012)
-
-#else /* Little Endian */
-#define IISFIF         ((volatile unsigned short *)0x15508010)
-#endif
-
-
-/* I/O PORT */
-#define rPACON         (*(volatile unsigned *)0x15600000)
-#define rPADAT         (*(volatile unsigned *)0x15600004)
-
-#define rPBCON         (*(volatile unsigned *)0x15600008)
-#define rPBDAT         (*(volatile unsigned *)0x1560000C)
-#define rPBUP          (*(volatile unsigned *)0x15600010)
-
-#define rPCCON         (*(volatile unsigned *)0x15600014)
-#define rPCDAT         (*(volatile unsigned *)0x15600018)
-#define rPCUP          (*(volatile unsigned *)0x1560001C)
-
-#define rPDCON         (*(volatile unsigned *)0x15600020)
-#define rPDDAT         (*(volatile unsigned *)0x15600024)
-#define rPDUP          (*(volatile unsigned *)0x15600028)
-
-#define rPECON         (*(volatile unsigned *)0x1560002C)
-#define rPEDAT         (*(volatile unsigned *)0x15600030)
-#define rPEUP          (*(volatile unsigned *)0x15600034)
-
-#define rPFCON         (*(volatile unsigned *)0x15600038)
-#define rPFDAT         (*(volatile unsigned *)0x1560003C)
-#define rPFUP          (*(volatile unsigned *)0x15600040)
-
-#define rPGCON         (*(volatile unsigned *)0x15600044)
-#define rPGDAT         (*(volatile unsigned *)0x15600048)
-#define rPGUP          (*(volatile unsigned *)0x1560004C)
-
-#define rOPENCR                (*(volatile unsigned *)0x15600050)
-#define rMISCCR                (*(volatile unsigned *)0x15600054)
-#define rEXTINT                (*(volatile unsigned *)0x15600058)
-
-
-/* RTC */
-#ifdef __BIG_ENDIAN
-#define rRTCCON                (*(volatile unsigned char *)0x15700043)
-#define rRTCALM                (*(volatile unsigned char *)0x15700053)
-#define rALMSEC                (*(volatile unsigned char *)0x15700057)
-#define rALMMIN                (*(volatile unsigned char *)0x1570005B)
-#define rALMHOUR       (*(volatile unsigned char *)0x1570005F)
-#define rALMDAY                (*(volatile unsigned char *)0x15700063)
-#define rALMMON                (*(volatile unsigned char *)0x15700067)
-#define rALMYEAR       (*(volatile unsigned char *)0x1570006B)
-#define rRTCRST                (*(volatile unsigned char *)0x1570006F)
-#define rBCDSEC                (*(volatile unsigned char *)0x15700073)
-#define rBCDMIN                (*(volatile unsigned char *)0x15700077)
-#define rBCDHOUR       (*(volatile unsigned char *)0x1570007B)
-#define rBCDDAY                (*(volatile unsigned char *)0x1570007F)
-#define rBCDDATE       (*(volatile unsigned char *)0x15700083)
-#define rBCDMON                (*(volatile unsigned char *)0x15700087)
-#define rBCDYEAR       (*(volatile unsigned char *)0x1570008B)
-#define rTICINT                (*(volatile unsigned char *)0x15700047)
-
-#else /* Little Endian */
-#define rRTCCON                (*(volatile unsigned char *)0x15700040)
-#define rRTCALM                (*(volatile unsigned char *)0x15700050)
-#define rALMSEC                (*(volatile unsigned char *)0x15700054)
-#define rALMMIN                (*(volatile unsigned char *)0x15700058)
-#define rALMHOUR       (*(volatile unsigned char *)0x1570005C)
-#define rALMDAY                (*(volatile unsigned char *)0x15700060)
-#define rALMMON                (*(volatile unsigned char *)0x15700064)
-#define rALMYEAR       (*(volatile unsigned char *)0x15700068)
-#define rRTCRST                (*(volatile unsigned char *)0x1570006C)
-#define rBCDSEC                (*(volatile unsigned char *)0x15700070)
-#define rBCDMIN                (*(volatile unsigned char *)0x15700074)
-#define rBCDHOUR       (*(volatile unsigned char *)0x15700078)
-#define rBCDDAY                (*(volatile unsigned char *)0x1570007C)
-#define rBCDDATE       (*(volatile unsigned char *)0x15700080)
-#define rBCDMON                (*(volatile unsigned char *)0x15700084)
-#define rBCDYEAR       (*(volatile unsigned char *)0x15700088)
-#define rTICINT                (*(volatile unsigned char *)0x15700044)
-#endif
-
-
-/* ADC */
-#define rADCCON                (*(volatile unsigned *)0x15800000)
-#define rADCDAT                (*(volatile unsigned *)0x15800004)
-
-
-/* SPI */
-#define rSPCON         (*(volatile unsigned *)0x15900000)
-#define rSPSTA         (*(volatile unsigned *)0x15900004)
-#define rSPPIN         (*(volatile unsigned *)0x15900008)
-#define rSPPRE         (*(volatile unsigned *)0x1590000C)
-#define rSPTDAT                (*(volatile unsigned *)0x15900010)
-#define rSPRDAT                (*(volatile unsigned *)0x15900014)
-
-
-/* MMC INTERFACE */
-#define rMMCON         (*(volatile unsigned *)0x15a00000)
-#define rMMCRR         (*(volatile unsigned *)0x15a00004)
-#define rMMFCON                (*(volatile unsigned *)0x15a00008)
-#define rMMSTA         (*(volatile unsigned *)0x15a0000C)
-#define rMMFSTA                (*(volatile unsigned *)0x15a00010)
-#define rMMPRE         (*(volatile unsigned *)0x15a00014)
-#define rMMLEN         (*(volatile unsigned *)0x15a00018)
-#define rMMCR7         (*(volatile unsigned *)0x15a0001C)
-#define rMMRSP0                (*(volatile unsigned *)0x15a00020)
-#define rMMRSP1                (*(volatile unsigned *)0x15a00024)
-#define rMMRSP2                (*(volatile unsigned *)0x15a00028)
-#define rMMRSP3                (*(volatile unsigned *)0x15a0002C)
-#define rMMCMD0                (*(volatile unsigned *)0x15a00030)
-#define rMMCMD1                (*(volatile unsigned *)0x15a00034)
-#define rMMCR16                (*(volatile unsigned *)0x15a00038)
-#define rMMDAT         (*(volatile unsigned *)0x15a0003C)
-
-
-/* ISR */
-#define pISR_RESET     (*(unsigned *)(_ISR_STARTADDRESS+0x0))
-#define pISR_UNDEF     (*(unsigned *)(_ISR_STARTADDRESS+0x4))
-#define pISR_SWI       (*(unsigned *)(_ISR_STARTADDRESS+0x8))
-#define pISR_PABORT    (*(unsigned *)(_ISR_STARTADDRESS+0xC))
-#define pISR_DABORT    (*(unsigned *)(_ISR_STARTADDRESS+0x10))
-#define pISR_RESERVED  (*(unsigned *)(_ISR_STARTADDRESS+0x14))
-#define pISR_IRQ       (*(unsigned *)(_ISR_STARTADDRESS+0x18))
-#define pISR_FIQ       (*(unsigned *)(_ISR_STARTADDRESS+0x1C))
-
-#define pISR_EINT0     (*(unsigned *)(_ISR_STARTADDRESS+0x20))
-#define pISR_EINT1     (*(unsigned *)(_ISR_STARTADDRESS+0x24))
-#define pISR_EINT2     (*(unsigned *)(_ISR_STARTADDRESS+0x28))
-#define pISR_EINT3     (*(unsigned *)(_ISR_STARTADDRESS+0x2C))
-#define pISR_EINT4     (*(unsigned *)(_ISR_STARTADDRESS+0x30))
-#define pISR_EINT5     (*(unsigned *)(_ISR_STARTADDRESS+0x34))
-#define pISR_EINT6     (*(unsigned *)(_ISR_STARTADDRESS+0x38))
-#define pISR_EINT7     (*(unsigned *)(_ISR_STARTADDRESS+0x3C))
-#define pISR_TICK      (*(unsigned *)(_ISR_STARTADDRESS+0x40))
-#define pISR_WDT       (*(unsigned *)(_ISR_STARTADDRESS+0x44))
-#define pISR_TIMER0    (*(unsigned *)(_ISR_STARTADDRESS+0x48))
-#define pISR_TIMER1    (*(unsigned *)(_ISR_STARTADDRESS+0x4C))
-#define pISR_TIMER2    (*(unsigned *)(_ISR_STARTADDRESS+0x50))
-#define pISR_TIMER3    (*(unsigned *)(_ISR_STARTADDRESS+0x54))
-#define pISR_TIMER4    (*(unsigned *)(_ISR_STARTADDRESS+0x58))
-#define pISR_UERR01    (*(unsigned *)(_ISR_STARTADDRESS+0x5C))
-#define pISR_NOTUSED   (*(unsigned *)(_ISR_STARTADDRESS+0x60))
-#define pISR_DMA0      (*(unsigned *)(_ISR_STARTADDRESS+0x64))
-#define pISR_DMA1      (*(unsigned *)(_ISR_STARTADDRESS+0x68))
-#define pISR_DMA2      (*(unsigned *)(_ISR_STARTADDRESS+0x6C))
-#define pISR_DMA3      (*(unsigned *)(_ISR_STARTADDRESS+0x70))
-#define pISR_MMC       (*(unsigned *)(_ISR_STARTADDRESS+0x74))
-#define pISR_SPI       (*(unsigned *)(_ISR_STARTADDRESS+0x78))
-#define pISR_URXD0     (*(unsigned *)(_ISR_STARTADDRESS+0x7C))
-#define pISR_URXD1     (*(unsigned *)(_ISR_STARTADDRESS+0x80))
-#define pISR_USBD      (*(unsigned *)(_ISR_STARTADDRESS+0x84))
-#define pISR_USBH      (*(unsigned *)(_ISR_STARTADDRESS+0x88))
-#define pISR_IIC       (*(unsigned *)(_ISR_STARTADDRESS+0x8C))
-#define pISR_UTXD0     (*(unsigned *)(_ISR_STARTADDRESS+0x90))
-#define pISR_UTXD1     (*(unsigned *)(_ISR_STARTADDRESS+0x94))
-#define pISR_RTC       (*(unsigned *)(_ISR_STARTADDRESS+0x98))
-#define pISR_ADC       (*(unsigned *)(_ISR_STARTADDRESS+0xA0))
-
-
-/* PENDING BIT */
-#define BIT_EINT0      (0x1)
-#define BIT_EINT1      (0x1<<1)
-#define BIT_EINT2      (0x1<<2)
-#define BIT_EINT3      (0x1<<3)
-#define BIT_EINT4      (0x1<<4)
-#define BIT_EINT5      (0x1<<5)
-#define BIT_EINT6      (0x1<<6)
-#define BIT_EINT7      (0x1<<7)
-#define BIT_TICK       (0x1<<8)
-#define BIT_WDT                (0x1<<9)
-#define BIT_TIMER0     (0x1<<10)
-#define BIT_TIMER1     (0x1<<11)
-#define BIT_TIMER2     (0x1<<12)
-#define BIT_TIMER3     (0x1<<13)
-#define BIT_TIMER4     (0x1<<14)
-#define BIT_UERR01     (0x1<<15)
-#define BIT_NOTUSED    (0x1<<16)
-#define BIT_DMA0       (0x1<<17)
-#define BIT_DMA1       (0x1<<18)
-#define BIT_DMA2       (0x1<<19)
-#define BIT_DMA3       (0x1<<20)
-#define BIT_MMC                (0x1<<21)
-#define BIT_SPI                (0x1<<22)
-#define BIT_URXD0      (0x1<<23)
-#define BIT_URXD1      (0x1<<24)
-#define BIT_USBD       (0x1<<25)
-#define BIT_USBH       (0x1<<26)
-#define BIT_IIC                (0x1<<27)
-#define BIT_UTXD0      (0x1<<28)
-#define BIT_UTXD1      (0x1<<29)
-#define BIT_RTC                (0x1<<30)
-#define BIT_ADC                (0x1<<31)
-#define BIT_ALLMSK     (0xFFFFFFFF)
-
-#define ClearPending(bit) {\
-                rSRCPND = bit;\
-                rINTPND = bit;\
-                rINTPND;\
-                }
-/* Wait until rINTPND is changed for the case that the ISR is very short. */
-#endif
 #endif /*__S3C2400_H__*/
 
 #define S3C2410_ECCSIZE                512
 #define S3C2410_ECCBYTES       3
 
-typedef enum {
+enum s3c24x0_uarts_nr {
        S3C24X0_UART0,
        S3C24X0_UART1,
        S3C24X0_UART2
-} S3C24X0_UARTS_NR;
+};
 
 /* S3C2410 device base addresses */
 #define S3C24X0_MEMCTL_BASE            0x48000000
 #include <s3c24x0.h>
 
 
-static inline S3C24X0_MEMCTL * S3C24X0_GetBase_MEMCTL(void)
+static inline struct s3c24x0_memctl *s3c24x0_get_base_memctl(void)
 {
-       return (S3C24X0_MEMCTL * const)S3C24X0_MEMCTL_BASE;
+       return (struct s3c24x0_memctl *)S3C24X0_MEMCTL_BASE;
 }
-static inline S3C24X0_USB_HOST * S3C24X0_GetBase_USB_HOST(void)
+static inline struct s3c24x0_usb_host *s3c24x0_get_base_usb_host(void)
 {
-       return (S3C24X0_USB_HOST * const)S3C24X0_USB_HOST_BASE;
+       return (struct s3c24x0_usb_host *)S3C24X0_USB_HOST_BASE;
 }
-static inline S3C24X0_INTERRUPT * S3C24X0_GetBase_INTERRUPT(void)
+static inline struct s3c24x0_interrupt *s3c24x0_get_base_interrupt(void)
 {
-       return (S3C24X0_INTERRUPT * const)S3C24X0_INTERRUPT_BASE;
+       return (struct s3c24x0_interrupt *)S3C24X0_INTERRUPT_BASE;
 }
-static inline S3C24X0_DMAS * S3C24X0_GetBase_DMAS(void)
+static inline struct s3c24x0_dmas *s3c24x0_get_base_dmas(void)
 {
-       return (S3C24X0_DMAS * const)S3C24X0_DMA_BASE;
+       return (struct s3c24x0_dmas *)S3C24X0_DMA_BASE;
 }
-static inline S3C24X0_CLOCK_POWER * S3C24X0_GetBase_CLOCK_POWER(void)
+static inline struct s3c24x0_clock_power *s3c24x0_get_base_clock_power(void)
 {
-       return (S3C24X0_CLOCK_POWER * const)S3C24X0_CLOCK_POWER_BASE;
+       return (struct s3c24x0_clock_power *)S3C24X0_CLOCK_POWER_BASE;
 }
-static inline S3C24X0_LCD * S3C24X0_GetBase_LCD(void)
+static inline struct s3c24x0_lcd *s3c24x0_get_base_lcd(void)
 {
-       return (S3C24X0_LCD * const)S3C24X0_LCD_BASE;
+       return (struct s3c24x0_lcd *)S3C24X0_LCD_BASE;
 }
-static inline S3C2410_NAND * S3C2410_GetBase_NAND(void)
+static inline struct s3c2410_nand *s3c2410_get_base_nand(void)
 {
-       return (S3C2410_NAND * const)S3C2410_NAND_BASE;
+       return (struct s3c2410_nand *)S3C2410_NAND_BASE;
 }
-static inline S3C24X0_UART * S3C24X0_GetBase_UART(S3C24X0_UARTS_NR nr)
+static inline struct s3c24x0_uart
+       *s3c24x0_get_base_uart(enum s3c24x0_uarts_nr n)
 {
-       return (S3C24X0_UART * const)(S3C24X0_UART_BASE + (nr * 0x4000));
+       return (struct s3c24x0_uart *)(S3C24X0_UART_BASE + (n * 0x4000));
 }
-static inline S3C24X0_TIMERS * S3C24X0_GetBase_TIMERS(void)
+static inline struct s3c24x0_timers *s3c24x0_get_base_timers(void)
 {
-       return (S3C24X0_TIMERS * const)S3C24X0_TIMER_BASE;
+       return (struct s3c24x0_timers *)S3C24X0_TIMER_BASE;
 }
-static inline S3C24X0_USB_DEVICE * S3C24X0_GetBase_USB_DEVICE(void)
+static inline struct s3c24x0_usb_device *s3c24x0_get_base_usb_device(void)
 {
-       return (S3C24X0_USB_DEVICE * const)S3C24X0_USB_DEVICE_BASE;
+       return (struct s3c24x0_usb_device *)S3C24X0_USB_DEVICE_BASE;
 }
-static inline S3C24X0_WATCHDOG * S3C24X0_GetBase_WATCHDOG(void)
+static inline struct s3c24x0_watchdog *s3c24x0_get_base_watchdog(void)
 {
-       return (S3C24X0_WATCHDOG * const)S3C24X0_WATCHDOG_BASE;
+       return (struct s3c24x0_watchdog *)S3C24X0_WATCHDOG_BASE;
 }
-static inline S3C24X0_I2C * S3C24X0_GetBase_I2C(void)
+static inline struct s3c24x0_i2c *s3c24x0_get_base_i2c(void)
 {
-       return (S3C24X0_I2C * const)S3C24X0_I2C_BASE;
+       return (struct s3c24x0_i2c *)S3C24X0_I2C_BASE;
 }
-static inline S3C24X0_I2S * S3C24X0_GetBase_I2S(void)
+static inline struct s3c24x0_i2s *s3c24x0_get_base_i2s(void)
 {
-       return (S3C24X0_I2S * const)S3C24X0_I2S_BASE;
+       return (struct s3c24x0_i2s *)S3C24X0_I2S_BASE;
 }
-static inline S3C24X0_GPIO * S3C24X0_GetBase_GPIO(void)
+static inline struct s3c24x0_gpio *s3c24x0_get_base_gpio(void)
 {
-       return (S3C24X0_GPIO * const)S3C24X0_GPIO_BASE;
+       return (struct s3c24x0_gpio *)S3C24X0_GPIO_BASE;
 }
-static inline S3C24X0_RTC * S3C24X0_GetBase_RTC(void)
+static inline struct s3c24x0_rtc *s3c24x0_get_base_rtc(void)
 {
-       return (S3C24X0_RTC * const)S3C24X0_RTC_BASE;
+       return (struct s3c24x0_rtc *)S3C24X0_RTC_BASE;
 }
-static inline S3C2410_ADC * S3C2410_GetBase_ADC(void)
+static inline struct s3c2410_adc *s3c2410_get_base_adc(void)
 {
-       return (S3C2410_ADC * const)S3C2410_ADC_BASE;
+       return (struct s3c2410_adc *)S3C2410_ADC_BASE;
 }
-static inline S3C24X0_SPI * S3C24X0_GetBase_SPI(void)
+static inline struct s3c24x0_spi *s3c24x0_get_base_spi(void)
 {
-       return (S3C24X0_SPI * const)S3C24X0_SPI_BASE;
+       return (struct s3c24x0_spi *)S3C24X0_SPI_BASE;
 }
-static inline S3C2410_SDI * S3C2410_GetBase_SDI(void)
+static inline struct s3c2410_sdi *s3c2410_get_base_sdi(void)
 {
-       return (S3C2410_SDI * const)S3C2410_SDI_BASE;
+       return (struct s3c2410_sdi *)S3C2410_SDI_BASE;
 }
 
-
-/* ISR */
-#define pISR_RESET             (*(unsigned *)(_ISR_STARTADDRESS+0x0))
-#define pISR_UNDEF             (*(unsigned *)(_ISR_STARTADDRESS+0x4))
-#define pISR_SWI               (*(unsigned *)(_ISR_STARTADDRESS+0x8))
-#define pISR_PABORT            (*(unsigned *)(_ISR_STARTADDRESS+0xC))
-#define pISR_DABORT            (*(unsigned *)(_ISR_STARTADDRESS+0x10))
-#define pISR_RESERVED          (*(unsigned *)(_ISR_STARTADDRESS+0x14))
-#define pISR_IRQ               (*(unsigned *)(_ISR_STARTADDRESS+0x18))
-#define pISR_FIQ               (*(unsigned *)(_ISR_STARTADDRESS+0x1C))
-
-#define pISR_EINT0             (*(unsigned *)(_ISR_STARTADDRESS+0x20))
-#define pISR_EINT1             (*(unsigned *)(_ISR_STARTADDRESS+0x24))
-#define pISR_EINT2             (*(unsigned *)(_ISR_STARTADDRESS+0x28))
-#define pISR_EINT3             (*(unsigned *)(_ISR_STARTADDRESS+0x2C))
-#define pISR_EINT4_7           (*(unsigned *)(_ISR_STARTADDRESS+0x30))
-#define pISR_EINT8_23          (*(unsigned *)(_ISR_STARTADDRESS+0x34))
-#define pISR_BAT_FLT           (*(unsigned *)(_ISR_STARTADDRESS+0x3C))
-#define pISR_TICK              (*(unsigned *)(_ISR_STARTADDRESS+0x40))
-#define pISR_WDT               (*(unsigned *)(_ISR_STARTADDRESS+0x44))
-#define pISR_TIMER0            (*(unsigned *)(_ISR_STARTADDRESS+0x48))
-#define pISR_TIMER1            (*(unsigned *)(_ISR_STARTADDRESS+0x4C))
-#define pISR_TIMER2            (*(unsigned *)(_ISR_STARTADDRESS+0x50))
-#define pISR_TIMER3            (*(unsigned *)(_ISR_STARTADDRESS+0x54))
-#define pISR_TIMER4            (*(unsigned *)(_ISR_STARTADDRESS+0x58))
-#define pISR_UART2             (*(unsigned *)(_ISR_STARTADDRESS+0x5C))
-#define pISR_NOTUSED           (*(unsigned *)(_ISR_STARTADDRESS+0x60))
-#define pISR_DMA0              (*(unsigned *)(_ISR_STARTADDRESS+0x64))
-#define pISR_DMA1              (*(unsigned *)(_ISR_STARTADDRESS+0x68))
-#define pISR_DMA2              (*(unsigned *)(_ISR_STARTADDRESS+0x6C))
-#define pISR_DMA3              (*(unsigned *)(_ISR_STARTADDRESS+0x70))
-#define pISR_SDI               (*(unsigned *)(_ISR_STARTADDRESS+0x74))
-#define pISR_SPI0              (*(unsigned *)(_ISR_STARTADDRESS+0x78))
-#define pISR_UART1             (*(unsigned *)(_ISR_STARTADDRESS+0x7C))
-#define pISR_USBD              (*(unsigned *)(_ISR_STARTADDRESS+0x84))
-#define pISR_USBH              (*(unsigned *)(_ISR_STARTADDRESS+0x88))
-#define pISR_IIC               (*(unsigned *)(_ISR_STARTADDRESS+0x8C))
-#define pISR_UART0             (*(unsigned *)(_ISR_STARTADDRESS+0x90))
-#define pISR_SPI1              (*(unsigned *)(_ISR_STARTADDRESS+0x94))
-#define pISR_RTC               (*(unsigned *)(_ISR_STARTADDRESS+0x98))
-#define pISR_ADC               (*(unsigned *)(_ISR_STARTADDRESS+0xA0))
-
-
-/* PENDING BIT */
-#define BIT_EINT0              (0x1)
-#define BIT_EINT1              (0x1<<1)
-#define BIT_EINT2              (0x1<<2)
-#define BIT_EINT3              (0x1<<3)
-#define BIT_EINT4_7            (0x1<<4)
-#define BIT_EINT8_23           (0x1<<5)
-#define BIT_BAT_FLT            (0x1<<7)
-#define BIT_TICK               (0x1<<8)
-#define BIT_WDT                        (0x1<<9)
-#define BIT_TIMER0             (0x1<<10)
-#define BIT_TIMER1             (0x1<<11)
-#define BIT_TIMER2             (0x1<<12)
-#define BIT_TIMER3             (0x1<<13)
-#define BIT_TIMER4             (0x1<<14)
-#define BIT_UART2              (0x1<<15)
-#define BIT_LCD                        (0x1<<16)
-#define BIT_DMA0               (0x1<<17)
-#define BIT_DMA1               (0x1<<18)
-#define BIT_DMA2               (0x1<<19)
-#define BIT_DMA3               (0x1<<20)
-#define BIT_SDI                        (0x1<<21)
-#define BIT_SPI0               (0x1<<22)
-#define BIT_UART1              (0x1<<23)
-#define BIT_USBD               (0x1<<25)
-#define BIT_USBH               (0x1<<26)
-#define BIT_IIC                        (0x1<<27)
-#define BIT_UART0              (0x1<<28)
-#define BIT_SPI1               (0x1<<29)
-#define BIT_RTC                        (0x1<<30)
-#define BIT_ADC                        (0x1<<31)
-#define BIT_ALLMSK             (0xFFFFFFFF)
-
-#define ClearPending(bit) {\
-                rSRCPND = bit;\
-                rINTPND = bit;\
-                rINTPND;\
-                }
-/* Wait until rINTPND is changed for the case that the ISR is very short. */
 #endif /*__S3C2410_H__*/
 
 typedef volatile u32   S3C24X0_REG32;
 
 /* Memory controller (see manual chapter 5) */
-typedef struct {
+struct s3c24x0_memctl {
        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 {
+struct s3c24x0_usb_host {
        S3C24X0_REG32   HcRevision;
        S3C24X0_REG32   HcControl;
        S3C24X0_REG32   HcCommonStatus;
        S3C24X0_REG32   HcRhStatus;
        S3C24X0_REG32   HcRhPortStatus1;
        S3C24X0_REG32   HcRhPortStatus2;
-} /*__attribute__((__packed__))*/ S3C24X0_USB_HOST;
+};
 
 
 /* INTERRUPT (see manual chapter 14) */
-typedef struct {
+struct s3c24x0_interrupt {
        S3C24X0_REG32   SRCPND;
        S3C24X0_REG32   INTMOD;
        S3C24X0_REG32   INTMSK;
        S3C24X0_REG32   SUBSRCPND;
        S3C24X0_REG32   INTSUBMSK;
 #endif
-} /*__attribute__((__packed__))*/ S3C24X0_INTERRUPT;
+};
 
 
 /* DMAS (see manual chapter 8) */
-typedef struct {
+struct s3c24x0_dma {
        S3C24X0_REG32   DISRC;
 #ifdef CONFIG_S3C2410
        S3C24X0_REG32   DISRCC;
 #ifdef CONFIG_S3C2410
        S3C24X0_REG32   res[7];
 #endif
-} /*__attribute__((__packed__))*/ S3C24X0_DMA;
+};
 
-typedef struct {
-       S3C24X0_DMA     dma[4];
-} /*__attribute__((__packed__))*/ S3C24X0_DMAS;
+struct s3c24x0_dmas {
+       struct s3c24x0_dma      dma[4];
+};
 
 
 /* CLOCK & POWER MANAGEMENT (see S3C2400 manual chapter 6) */
 /*                          (see S3C2410 manual chapter 7) */
-typedef struct {
+struct s3c24x0_clock_power {
        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 {
+struct s3c24x0_lcd {
        S3C24X0_REG32   LCDCON1;
        S3C24X0_REG32   LCDCON2;
        S3C24X0_REG32   LCDCON3;
        S3C24X0_REG32   LCDINTMSK;
        S3C24X0_REG32   LPCSEL;
 #endif
-} /*__attribute__((__packed__))*/ S3C24X0_LCD;
+};
 
 
 /* NAND FLASH (see S3C2410 manual chapter 6) */
-typedef struct {
+struct s3c2410_nand {
        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 {
+struct s3c24x0_uart {
        S3C24X0_REG32   ULCON;
        S3C24X0_REG32   UCON;
        S3C24X0_REG32   UFCON;
        S3C24X0_REG8    res2[3];
 #endif
        S3C24X0_REG32   UBRDIV;
-} /*__attribute__((__packed__))*/ S3C24X0_UART;
+};
 
 
 /* PWM TIMER (see manual chapter 10) */
-typedef struct {
+struct s3c24x0_timer {
        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;
+struct s3c24x0_timers {
+       S3C24X0_REG32           TCFG0;
+       S3C24X0_REG32           TCFG1;
+       S3C24X0_REG32           TCON;
+       struct s3c24x0_timer    ch[4];
+       S3C24X0_REG32           TCNTB4;
+       S3C24X0_REG32           TCNTO4;
+};
 
 
 /* USB DEVICE (see manual chapter 13) */
-typedef struct {
+struct s3c24x0_usb_dev_fifos {
 #ifdef __BIG_ENDIAN
        S3C24X0_REG8    res[3];
        S3C24X0_REG8    EP_FIFO_REG;
        S3C24X0_REG8    EP_FIFO_REG;
        S3C24X0_REG8    res[3];
 #endif
-} /*__attribute__((__packed__))*/ S3C24X0_USB_DEV_FIFOS;
+};
 
-typedef struct {
+struct s3c24x0_usb_dev_dmas {
 #ifdef __BIG_ENDIAN
        S3C24X0_REG8    res1[3];
        S3C24X0_REG8    EP_DMA_CON;
        S3C24X0_REG8    EP_DMA_TTC_H;
        S3C24X0_REG8    res6[3];
 #endif
-} /*__attribute__((__packed__))*/ S3C24X0_USB_DEV_DMAS;
+};
 
-typedef struct {
+struct s3c24x0_usb_device {
 #ifdef __BIG_ENDIAN
        S3C24X0_REG8    res1[3];
        S3C24X0_REG8    FUNC_ADDR_REG;
        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;
+       struct s3c24x0_usb_dev_fifos    fifo[5];
+       struct s3c24x0_usb_dev_dmas     dma[5];
+};
 
 
 /* WATCH DOG TIMER (see manual chapter 18) */
-typedef struct {
+struct s3c24x0_watchdog {
        S3C24X0_REG32   WTCON;
        S3C24X0_REG32   WTDAT;
        S3C24X0_REG32   WTCNT;
-} /*__attribute__((__packed__))*/ S3C24X0_WATCHDOG;
+};
 
 
 /* IIC (see manual chapter 20) */
-typedef struct {
+struct s3c24x0_i2c {
        S3C24X0_REG32   IICCON;
        S3C24X0_REG32   IICSTAT;
        S3C24X0_REG32   IICADD;
        S3C24X0_REG32   IICDS;
-} /*__attribute__((__packed__))*/ S3C24X0_I2C;
+};
 
 
 /* IIS (see manual chapter 21) */
-typedef struct {
+struct s3c24x0_i2s {
 #ifdef __BIG_ENDIAN
        S3C24X0_REG16   res1;
        S3C24X0_REG16   IISCON;
        S3C24X0_REG16   IISFIFO;
        S3C24X0_REG16   res5;
 #endif
-} /*__attribute__((__packed__))*/ S3C24X0_I2S;
+};
 
 
 /* I/O PORT (see manual chapter 9) */
-typedef struct {
+struct s3c24x0_gpio {
 #ifdef CONFIG_S3C2400
        S3C24X0_REG32   PACON;
        S3C24X0_REG32   PADAT;
        S3C24X0_REG32   GSTATUS3;
        S3C24X0_REG32   GSTATUS4;
 #endif
-} /*__attribute__((__packed__))*/ S3C24X0_GPIO;
+};
 
 
 /* RTC (see manual chapter 17) */
-typedef struct {
+struct s3c24x0_rtc {
 #ifdef __BIG_ENDIAN
        S3C24X0_REG8    res1[67];
        S3C24X0_REG8    RTCCON;
        S3C24X0_REG8    BCDYEAR;
        S3C24X0_REG8    res17[3];
 #endif
-} /*__attribute__((__packed__))*/ S3C24X0_RTC;
+};
 
 
 /* ADC (see manual chapter 16) */
-typedef struct {
+struct s3c2400_adc {
        S3C24X0_REG32   ADCCON;
        S3C24X0_REG32   ADCDAT;
-} /*__attribute__((__packed__))*/ S3C2400_ADC;
+};
 
 
 /* ADC (see manual chapter 16) */
-typedef struct {
+struct s3c2410_adc {
        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 {
+struct s3c24x0_spi_channel {
        S3C24X0_REG8    SPCON;
        S3C24X0_REG8    res1[3];
        S3C24X0_REG8    SPSTA;
        S3C24X0_REG8    SPRDAT;
        S3C24X0_REG8    res6[3];
        S3C24X0_REG8    res7[16];
-} /*__attribute__((__packed__))*/ S3C24X0_SPI_CHANNEL;
+};
 
-typedef struct {
-       S3C24X0_SPI_CHANNEL     ch[S3C24X0_SPI_CHANNELS];
-} /*__attribute__((__packed__))*/ S3C24X0_SPI;
+struct s3c24x0_spi {
+       struct s3c24x0_spi_channel      ch[S3C24X0_SPI_CHANNELS];
+};
 
 
 /* MMC INTERFACE (see S3C2400 manual chapter 19) */
-typedef struct {
+struct s3c2400_mmc {
 #ifdef __BIG_ENDIAN
        S3C24X0_REG8    res1[3];
        S3C24X0_REG8    MMCON;
        S3C24X0_REG8    MMDAT;
        S3C24X0_REG8    res11[3];
 #endif
-} /*__attribute__((__packed__))*/ S3C2400_MMC;
+};
 
 
 /* SD INTERFACE (see S3C2410 manual chapter 19) */
-typedef struct {
+struct s3c2410_sdi {
        S3C24X0_REG32   SDICON;
        S3C24X0_REG32   SDIPRE;
        S3C24X0_REG32   SDICARG;
        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__*/