/*
 * Copyright (c) 2006-2021, RT-Thread Development Team
 *
 * SPDX-License-Identifier: Apache-2.0
 *
 * Change Logs:
 * Date           Author       Notes
 * 2013-7-17      Peng Fan     sep6200 implementation
 */

#ifndef __SEP6200_H
#define __SEP6200_H

#include <rtthread.h>

/*Core definations*/
#define PRIVMODE  0x13
#define Mode_USR    0x10
#define Mode_REAL   0x11
#define Mode_IRQ    0x12
#define Mode_PRIV   0x13
#define Mode_TRAP   0x17
#define Mode_EXT    0x1B
#define Mode_SUSR   0x1F

/*
 *  Address
 */

#define  SEP6200_VIC_BASE   0xb0000000
#define  SEP6200_PMU_BASE   0xb0001000
#define  SEP6200_RTC_BASE   0xb0002000
#define  SEP6200_TIMER_BASE 0xb0003000
#define  SEP6200_PWM_BASE   0xb0004000
#define  SEP6200_GPIO_BASE  0xb0006000
#define  SEP6200_TOUCH_ADC  0xb0007000
#define  SEP6200_SYSCTL_BASE    0xb0008000
#define  SEP6200_UART0_BASE 0xb1000000
#define  SEP6200_UART1_BASE 0xb1001000
#define  SEP6200_UART2_BASE 0xb1002000
#define  SEP6200_UART3_BASE 0xb1003000
#define  SEP6200_SSI1_BASE  0xb1004000
#define  SEP6200_SSI2_BASE  0xb1005000
#define  SEP6200_SSI3_BASE  0xb1006000
#define  SEP6200_I2C_BASE   0xb1007000
#define  SEP6200_I2S_BASE   0xb1008000
#define  SEP6200_USB_BASE    0xb1010000
#define  SEP6200_DMAC2_BASE  0xb1011000
#define  SEP6200_ESRAM_BASE  0xb2000000
#define  SEP6200_NORREG_BASE0xb2020000
#define  SEP6200_SDIO1_BASE 0xb2022000
#define  SEP6200_SDIO2_BASE 0xb2023000
#define  SEP6200_LCDC_BASE  0xb2025000
#define  SEP6200_VPU_BASE   0xb2026000
#define  SEP6200_DMAC1_BASE 0xb2027000
#define  SEP6200_DDR2_REG   0xb3000000
#define  SEP6200_DDR_MEM    0x40000000

#define SEP6200_UART0_DLBL  (SEP6200_UART0_BASE+0x00)
#define SEP6200_UART0_RXFIFO    (SEP6200_UART0_BASE+0x00)
#define SEP6200_UART0_TXFIFO    (SEP6200_UART0_BASE+0x00)
#define SEP6200_UART0_DLBH  (SEP6200_UART0_BASE+0x04)
#define SEP6200_UART0_IER   (SEP6200_UART0_BASE+0x04)
#define SEP6200_UART0_IIR   (SEP6200_UART0_BASE+0x08)
#define SEP6200_UART0_FCR   (SEP6200_UART0_BASE+0x08)
#define SEP6200_UART0_LCR   (SEP6200_UART0_BASE+0x0c)
#define SEP6200_UART0_MCR   (SEP6200_UART0_BASE+0x10)
#define SEP6200_UART0_LSR   (SEP6200_UART0_BASE+0x14)
#define SEP6200_UART0_MSR   (SEP6200_UART0_BASE+0x18)


#define    SEP6200_TIMER_T1LCR              (SEP6200_TIMER_BASE + 0X000)
#define    SEP6200_TIMER_T1CCR              (SEP6200_TIMER_BASE + 0X004)
#define    SEP6200_TIMER_T1CR               (SEP6200_TIMER_BASE + 0X008)
#define    SEP6200_TIMER_T1ISCR             (SEP6200_TIMER_BASE + 0X00C)
#define    SEP6200_TIMER_T1IMSR             (SEP6200_TIMER_BASE + 0X010)
#define    SEP6200_TIMER_T2LCR              (SEP6200_TIMER_BASE + 0X020)
#define    SEP6200_TIMER_T2CCR              (SEP6200_TIMER_BASE + 0X024)
#define    SEP6200_TIMER_T2CR               (SEP6200_TIMER_BASE + 0X028)
#define    SEP6200_TIMER_T2ISCR             (SEP6200_TIMER_BASE + 0X02C)
#define    SEP6200_TIMER_T2IMSR             (SEP6200_TIMER_BASE + 0X030)
#define    SEP6200_TIMER_T3LCR              (SEP6200_TIMER_BASE + 0X040)
#define    SEP6200_TIMER_T3CCR              (SEP6200_TIMER_BASE + 0X044)
#define    SEP6200_TIMER_T3CR               (SEP6200_TIMER_BASE + 0X048)
#define    SEP6200_TIMER_T3ISCR             (SEP6200_TIMER_BASE + 0X04C)
#define    SEP6200_TIMER_T3IMSR             (SEP6200_TIMER_BASE + 0X050)
#define    SEP6200_TIMER_T3CAPR             (SEP6200_TIMER_BASE + 0X054)
#define    SEP6200_TIMER_T4LCR              (SEP6200_TIMER_BASE + 0X060)
#define    SEP6200_TIMER_T4CCR              (SEP6200_TIMER_BASE + 0X064)
#define    SEP6200_TIMER_T4CR               (SEP6200_TIMER_BASE + 0X068)
#define    SEP6200_TIMER_T4ISCR             (SEP6200_TIMER_BASE + 0X06C)
#define    SEP6200_TIMER_T4IMSR             (SEP6200_TIMER_BASE + 0X070)
#define    SEP6200_TIMER_T4CAPR             (SEP6200_TIMER_BASE + 0X074)
#define    SEP6200_TIMER_T5LCR              (SEP6200_TIMER_BASE + 0X080)
#define    SEP6200_TIMER_T5CCR              (SEP6200_TIMER_BASE + 0X084)
#define    SEP6200_TIMER_T5CR               (SEP6200_TIMER_BASE + 0X088)
#define    SEP6200_TIMER_T5ISCR             (SEP6200_TIMER_BASE + 0X08C)
#define    SEP6200_TIMER_T5IMSR             (SEP6200_TIMER_BASE + 0X090)
#define    SEP6200_TIMER_T5CAPR             (SEP6200_TIMER_BASE + 0X094)
#define    SEP6200_TIMER_T6LCR              (SEP6200_TIMER_BASE + 0X0A0)
#define    SEP6200_TIMER_T6CCR              (SEP6200_TIMER_BASE + 0X0A4)
#define    SEP6200_TIMER_T6CR               (SEP6200_TIMER_BASE + 0X0A8)
#define    SEP6200_TIMER_T6ISCR             (SEP6200_TIMER_BASE + 0X0AC)
#define    SEP6200_TIMER_T6IMSR             (SEP6200_TIMER_BASE + 0X0B0)
#define    SEP6200_TIMER_T6CAPR             (SEP6200_TIMER_BASE + 0X0B4)
#define    SEP6200_TIMER_T7LCR              (SEP6200_TIMER_BASE + 0X0C0)
#define    SEP6200_TIMER_T7CCR              (SEP6200_TIMER_BASE + 0X0C4)
#define    SEP6200_TIMER_T7CR               (SEP6200_TIMER_BASE + 0X0C8)
#define    SEP6200_TIMER_T7ISCR             (SEP6200_TIMER_BASE + 0X0CC)
#define    SEP6200_TIMER_T7IMSR             (SEP6200_TIMER_BASE + 0X0D0)
#define    SEP6200_TIMER_T8LCR              (SEP6200_TIMER_BASE + 0X0E0)
#define    SEP6200_TIMER_T8CCR              (SEP6200_TIMER_BASE + 0X0E4)
#define    SEP6200_TIMER_T8CR               (SEP6200_TIMER_BASE + 0X0E8)
#define    SEP6200_TIMER_T8ISCR             (SEP6200_TIMER_BASE + 0X0EC)
#define    SEP6200_TIMER_T8IMSR             (SEP6200_TIMER_BASE + 0X0F0)
#define    SEP6200_TIMER_T9LCR              (SEP6200_TIMER_BASE + 0X100)
#define    SEP6200_TIMER_T9CCR              (SEP6200_TIMER_BASE + 0X104)
#define    SEP6200_TIMER_T9CR               (SEP6200_TIMER_BASE + 0X108)
#define    SEP6200_TIMER_T9ISCR             (SEP6200_TIMER_BASE + 0X10C)
#define    SEP6200_TIMER_T9IMSR             (SEP6200_TIMER_BASE + 0X110)
#define    SEP6200_TIMER_T10LCR             (SEP6200_TIMER_BASE + 0X120)
#define    SEP6200_TIMER_T10CCR             (SEP6200_TIMER_BASE + 0X124)
#define    SEP6200_TIMER_T10CR              (SEP6200_TIMER_BASE + 0X128)
#define    SEP6200_TIMER_T10ISCR            (SEP6200_TIMER_BASE + 0X12C)
#define    SEP6200_TIMER_T10IMSR            (SEP6200_TIMER_BASE + 0X130)
#define    SEP6200_TIMER_TIMSR              (SEP6200_TIMER_BASE + 0X140)
#define    SEP6200_TIMER_TISCR              (SEP6200_TIMER_BASE + 0X144)
#define    SEP6200_TIMER_TISR               (SEP6200_TIMER_BASE + 0X148)

#define    SEP6200_VIC_INT_SLT_L            (SEP6200_VIC_BASE + 0x000)
#define    SEP6200_VIC_INT_SLT_H            (SEP6200_VIC_BASE + 0x004)
#define    SEP6200_VIC_INT_EN_L             (SEP6200_VIC_BASE + 0x008)
#define    SEP6200_VIC_INT_EN_H             (SEP6200_VIC_BASE + 0x00C)
#define    SEP6200_VIC_INT_EN_CLR_L         (SEP6200_VIC_BASE + 0x010)
#define    SEP6200_VIC_INT_EN_CLR_H         (SEP6200_VIC_BASE + 0x014)
#define    SEP6200_VIC_SFT_INT_L            (SEP6200_VIC_BASE + 0x018)
#define    SEP6200_VIC_SFT_INT_H            (SEP6200_VIC_BASE + 0x01C)
#define    SEP6200_VIC_SFT_INT_CLR_L        (SEP6200_VIC_BASE + 0x020)
#define    SEP6200_VIC_SFT_INT_CLR_H        (SEP6200_VIC_BASE + 0x024)
#define    SEP6200_VIC_INT_MSK_ALL          (SEP6200_VIC_BASE + 0x028)
#define    SEP6200_VIC_RAW_INT_SRC_L        (SEP6200_VIC_BASE + 0x030)
#define    SEP6200_VIC_RAW_INT_SRC_H        (SEP6200_VIC_BASE + 0x034)
#define    SEP6200_VIC_RAW_IRQ_STS_L        (SEP6200_VIC_BASE + 0x038)
#define    SEP6200_VIC_RAW_IRQ_STS_H        (SEP6200_VIC_BASE + 0x03C)
#define    SEP6200_VIC_RAW_FIQ_STS_L        (SEP6200_VIC_BASE + 0x040)
#define    SEP6200_VIC_RAW_FIQ_STS_H        (SEP6200_VIC_BASE + 0x044)
#define    SEP6200_VIC_MSK_IRQ_STS_L        (SEP6200_VIC_BASE + 0x048)
#define    SEP6200_VIC_MSK_IRQ_STS_H        (SEP6200_VIC_BASE + 0x04C)
#define    SEP6200_VIC_MSK_FIQ_STS_L        (SEP6200_VIC_BASE + 0x050)
#define    SEP6200_VIC_MSK_FIQ_STS_H        (SEP6200_VIC_BASE + 0x054)
#define    SEP6200_VIC_IRQ_PENDING_L        (SEP6200_VIC_BASE + 0x058)
#define    SEP6200_VIC_IRQ_PENDING_H        (SEP6200_VIC_BASE + 0x05C)
#define    SEP6200_VIC_FIQ_PENDING_L        (SEP6200_VIC_BASE + 0x060)
#define    SEP6200_VIC_FIQ_PENDING_H        (SEP6200_VIC_BASE + 0x064)
#define    SEP6200_VIC_IRQ_VECTOR_BASE      (SEP6200_VIC_BASE + 0x070)
#define    SEP6200_VIC_FIQ_VECTOR_BASE      (SEP6200_VIC_BASE + 0x074)
#define    SEP6200_VIC_IRQ_VECTOR_NUM       (SEP6200_VIC_BASE + 0x078)
#define    SEP6200_VIC_FIQ_VECTOR_NUM       (SEP6200_VIC_BASE + 0x07C)
#define    SEP6200_VIC_IRQ_VECTOR_ADDR      (SEP6200_VIC_BASE + 0x080)
#define    SEP6200_VIC_FIQ_VECTOR_ADDR      (SEP6200_VIC_BASE + 0x084)
#define    SEP6200_VIC_PROIRTY_MASK         (SEP6200_VIC_BASE + 0x090)
#define    SEP6200_VIC_VECTOR_PROIRTY00     (SEP6200_VIC_BASE + 0x100)
#define    SEP6200_VIC_VECTOR_PROIRTY01     (SEP6200_VIC_BASE + 0x104)
#define    SEP6200_VIC_VECTOR_PROIRTY02     (SEP6200_VIC_BASE + 0x108)
#define    SEP6200_VIC_VECTOR_PROIRTY03     (SEP6200_VIC_BASE + 0x10C)
#define    SEP6200_VIC_VECTOR_PROIRTY04     (SEP6200_VIC_BASE + 0x110)
#define    SEP6200_VIC_VECTOR_PROIRTY05     (SEP6200_VIC_BASE + 0x114)
#define    SEP6200_VIC_VECTOR_PROIRTY06     (SEP6200_VIC_BASE + 0x118)
#define    SEP6200_VIC_VECTOR_PROIRTY07     (SEP6200_VIC_BASE + 0x11C)
#define    SEP6200_VIC_VECTOR_PROIRTY08     (SEP6200_VIC_BASE + 0x120)
#define    SEP6200_VIC_VECTOR_PROIRTY09     (SEP6200_VIC_BASE + 0x124)
#define    SEP6200_VIC_VECTOR_PROIRTY10     (SEP6200_VIC_BASE + 0x128)
#define    SEP6200_VIC_VECTOR_PROIRTY11     (SEP6200_VIC_BASE + 0x12C)
#define    SEP6200_VIC_VECTOR_PROIRTY12     (SEP6200_VIC_BASE + 0x130)
#define    SEP6200_VIC_VECTOR_PROIRTY13     (SEP6200_VIC_BASE + 0x134)
#define    SEP6200_VIC_VECTOR_PROIRTY14     (SEP6200_VIC_BASE + 0x138)
#define    SEP6200_VIC_VECTOR_PROIRTY15     (SEP6200_VIC_BASE + 0x13C)
#define    SEP6200_VIC_VECTOR_PROIRTY16     (SEP6200_VIC_BASE + 0x140)
#define    SEP6200_VIC_VECTOR_PROIRTY17     (SEP6200_VIC_BASE + 0x144)
#define    SEP6200_VIC_VECTOR_PROIRTY18     (SEP6200_VIC_BASE + 0x148)
#define    SEP6200_VIC_VECTOR_PROIRTY19     (SEP6200_VIC_BASE + 0x14C)
#define    SEP6200_VIC_VECTOR_PROIRTY20     (SEP6200_VIC_BASE + 0x150)
#define    SEP6200_VIC_VECTOR_PROIRTY21     (SEP6200_VIC_BASE + 0x154)
#define    SEP6200_VIC_VECTOR_PROIRTY22     (SEP6200_VIC_BASE + 0x158)
#define    SEP6200_VIC_VECTOR_PROIRTY23     (SEP6200_VIC_BASE + 0x15C)
#define    SEP6200_VIC_VECTOR_PROIRTY24     (SEP6200_VIC_BASE + 0x160)
#define    SEP6200_VIC_VECTOR_PROIRTY25     (SEP6200_VIC_BASE + 0x164)
#define    SEP6200_VIC_VECTOR_PROIRTY26     (SEP6200_VIC_BASE + 0x168)
#define    SEP6200_VIC_VECTOR_PROIRTY27     (SEP6200_VIC_BASE + 0x16C)
#define    SEP6200_VIC_VECTOR_PROIRTY28     (SEP6200_VIC_BASE + 0x170)
#define    SEP6200_VIC_VECTOR_PROIRTY29     (SEP6200_VIC_BASE + 0x174)
#define    SEP6200_VIC_VECTOR_PROIRTY30     (SEP6200_VIC_BASE + 0x178)
#define    SEP6200_VIC_VECTOR_PROIRTY31     (SEP6200_VIC_BASE + 0x17C)
#define    SEP6200_VIC_VECTOR_PROIRTY32     (SEP6200_VIC_BASE + 0x180)
#define    SEP6200_VIC_VECTOR_PROIRTY33     (SEP6200_VIC_BASE + 0x184)
#define    SEP6200_VIC_VECTOR_PROIRTY34     (SEP6200_VIC_BASE + 0x188)
#define    SEP6200_VIC_VECTOR_PROIRTY35     (SEP6200_VIC_BASE + 0x18C)
#define    SEP6200_VIC_VECTOR_PROIRTY36     (SEP6200_VIC_BASE + 0x190)
#define    SEP6200_VIC_VECTOR_PROIRTY37     (SEP6200_VIC_BASE + 0x194)
#define    SEP6200_VIC_VECTOR_PROIRTY38     (SEP6200_VIC_BASE + 0x198)
#define    SEP6200_VIC_VECTOR_PROIRTY39     (SEP6200_VIC_BASE + 0x19C)
#define    SEP6200_VIC_VECTOR_PROIRTY40     (SEP6200_VIC_BASE + 0x1A0)
#define    SEP6200_VIC_VECTOR_PROIRTY41     (SEP6200_VIC_BASE + 0x1A4)
#define    SEP6200_VIC_VECTOR_PROIRTY42     (SEP6200_VIC_BASE + 0x1A8)
#define    SEP6200_VIC_VECTOR_PROIRTY43     (SEP6200_VIC_BASE + 0x1AC)
#define    SEP6200_VIC_VECTOR_PROIRTY44     (SEP6200_VIC_BASE + 0x1B0)
#define    SEP6200_VIC_VECTOR_PROIRTY45     (SEP6200_VIC_BASE + 0x1B4)
#define    SEP6200_VIC_VECTOR_PROIRTY46     (SEP6200_VIC_BASE + 0x1B8)
#define    SEP6200_VIC_VECTOR_PROIRTY47     (SEP6200_VIC_BASE + 0x1BC)
#define    SEP6200_VIC_VECTOR_PROIRTY48     (SEP6200_VIC_BASE + 0x1C0)
#define    SEP6200_VIC_VECTOR_PROIRTY49     (SEP6200_VIC_BASE + 0x1C4)
#define    SEP6200_VIC_VECTOR_PROIRTY50     (SEP6200_VIC_BASE + 0x1C8)
#define    SEP6200_VIC_VECTOR_PROIRTY51     (SEP6200_VIC_BASE + 0x1CC)
#define    SEP6200_VIC_VECTOR_PROIRTY52     (SEP6200_VIC_BASE + 0x1D0)
#define    SEP6200_VIC_VECTOR_PROIRTY53     (SEP6200_VIC_BASE + 0x1D4)
#define    SEP6200_VIC_VECTOR_PROIRTY54     (SEP6200_VIC_BASE + 0x1D8)
#define    SEP6200_VIC_VECTOR_PROIRTY55     (SEP6200_VIC_BASE + 0x1DC)
#define    SEP6200_VIC_VECTOR_PROIRTY56     (SEP6200_VIC_BASE + 0x1E0)
#define    SEP6200_VIC_VECTOR_PROIRTY57     (SEP6200_VIC_BASE + 0x1E4)
#define    SEP6200_VIC_VECTOR_PROIRTY58     (SEP6200_VIC_BASE + 0x1E8)
#define    SEP6200_VIC_VECTOR_PROIRTY59     (SEP6200_VIC_BASE + 0x1EC)
#define    SEP6200_VIC_VECTOR_PROIRTY60     (SEP6200_VIC_BASE + 0x1F0)
#define    SEP6200_VIC_VECTOR_PROIRTY61     (SEP6200_VIC_BASE + 0x1F4)
#define    SEP6200_VIC_VECTOR_PROIRTY62     (SEP6200_VIC_BASE + 0x1F8)
#define    SEP6200_VIC_VECTOR_PROIRTY63     (SEP6200_VIC_BASE + 0x1FC)

#define    SEP6200_PMU_PLL_SET              (SEP6200_PMU_BASE + 0x000)
#define    SEP6200_PMU_APLL_CFG             (SEP6200_PMU_BASE + 0x004)
#define    SEP6200_PMU_MPLL_GFG             (SEP6200_PMU_BASE + 0x008)
#define    SEP6200_PMU_DPLL_CFG             (SEP6200_PMU_BASE + 0x00C)
#define    SEP6200_PMU_PMDR                 (SEP6200_PMU_BASE + 0x010)
#define    SEP6200_PMU_CLK_GT_CFG1          (SEP6200_PMU_BASE + 0x014)
#define    SEP6200_PMU_CLK_GT_CFG2          (SEP6200_PMU_BASE + 0x018)
#define    SEP6200_PMU_PWR_GT_CFG           (SEP6200_PMU_BASE + 0x01C)
#define    SEP6200_PMU_AHB_CLK_CFG          (SEP6200_PMU_BASE + 0x020)
#define    SEP6200_PMU_ARM_CLK_CFG          (SEP6200_PMU_BASE + 0x024)
#define    SEP6200_PMU_DDR_CLK_CFG          (SEP6200_PMU_BASE + 0x028)
#define    SEP6200_PMU_PIX_CLK_CFG          (SEP6200_PMU_BASE + 0x02C)
#define    SEP6200_PMU_GPU_CLK2X_CFG        (SEP6200_PMU_BASE + 0x030)
#define    SEP6200_PMU_DIV_SET              (SEP6200_PMU_BASE + 0x034)
#define    SEP6200_PMU_CRYSTAL_CFG          (SEP6200_PMU_BASE + 0x038)
#define    SEP6200_PMU_MSK_WAKEUP           (SEP6200_PMU_BASE + 0x03C)
#define    SEP6200_PMU_RTCR                 (SEP6200_PMU_BASE + 0x040)
#define    SEP6200_PMU_CLR_WAKEUP           (SEP6200_PMU_BASE + 0x044)
#define    SEP6200_PMU_WAKEUP_TIME          (SEP6200_PMU_BASE + 0x048)
#define    SEP6200_PMU_SLEEP_FLAG           (SEP6200_PMU_BASE + 0x04C)
#define    SEP6200_PMU_WAIT_PWR_SWITCH      (SEP6200_PMU_BASE + 0x050)
#define    SEP6200_PMU_PWR_STATE            (SEP6200_PMU_BASE + 0x054)
#define    SEP6200_PMU_INT_POL_SEL          (SEP6200_PMU_BASE + 0x058)
#define    SEP6200_PMU_PLLLD                (SEP6200_PMU_BASE + 0x05C)
#define    SEP6200_PMU_IC_ENABLE            (SEP6200_PMU_BASE + 0x060)
#define    SEP6200_PMU_IC_TAR               (SEP6200_PMU_BASE + 0x064)
#define    SEP6200_PMU_IC_SCL_LCNT          (SEP6200_PMU_BASE + 0x068)
#define    SEP6200_PMU_IC_SCL_HCNT          (SEP6200_PMU_BASE + 0x06C)
#define    SEP6200_PMU_IC_DATA_CMD          (SEP6200_PMU_BASE + 0x070)
#define    SEP6200_PMU_IC_STATE             (SEP6200_PMU_BASE + 0x074)
#define    SEP6200_PMU_IC_SET               (SEP6200_PMU_BASE + 0x078)
#define    SEP6200_PMU_HA_PWR_OFF_DAT       (SEP6200_PMU_BASE + 0x07C)
#define    SEP6200_PMU_HA_PWR_ON_DAT        (SEP6200_PMU_BASE + 0x080)
#define    SEP6200_PMU_HA_PWR_OFF_DAT_CNT   (SEP6200_PMU_BASE + 0x084)
#define    SEP6200_PMU_HA_PWR_ON_DAT_CNT    (SEP6200_PMU_BASE + 0x088)
#define    SEP6200_PMU_PWR_OFF_TIME         (SEP6200_PMU_BASE + 0x08C)
#define    SEP6200_PMU_PWR_ON_TIME          (SEP6200_PMU_BASE + 0x090)
#define    SEP6200_PMU_PWR_ON_POL_SEL       (SEP6200_PMU_BASE + 0x094)
#define    SEP6200_PMU_RETURN_ADDR          (SEP6200_PMU_BASE + 0x098)
#define    SEP6200_PMU_INT                  (SEP6200_PMU_BASE + 0x09C)

/* define the interrupt source number */
#define    INTSRC_RESERVE2      63
#define    INTSRC_RESERVE1      62
#define    INTSRC_LCDC          61
#define    INTSRC_GPU           60
#define    INTSRC_VPU           59
#define    INTSRC_TIMER3        58
#define    INTSRC_TIMER2        57
#define    INTSRC_TIMER1        56
#define    INTSRC_NAND          55
#define    INTSRC_I2S           54
#define    INTSRC_I2C3          53
#define    INTSRC_I2C2          52
#define    INTSRC_I2C1          51
#define    INTSRC_SSI3          50
#define    INTSRC_SSI2          49
#define    INTSRC_SSI1          48
#define    INTSRC_SDIO2         47
#define    INTSRC_SDIO1         46
#define    INTSRC_UART3         45
#define    INTSRC_UART2         44
#define    INTSRC_UART1         43
#define    INTSRC_UART0         42
#define    INTSRC_PWM           41
#define    INTSRC_USB           40
#define    INTSRC_USBDMA        39
#define    INTSRC_DMAC2         38
#define    INTSRC_DMAC1         37
#define    INTSRC_PMUIRQ_A11    36
#define    INTSRC_DMAIRQ_A11    35
#define    INTSRC_GPS           34
#define    INTSRC_RTC           33
#define    INTSRC_RESERVED16    32
#define    INTSRC_PORTE12       31
#define    INTSRC_PORTE11       30
#define    INTSRC_PORTE10       29
#define    INTSRC_PORTE9        28
#define    INTSRC_PORTE5        27
#define    INTSRC_PORTE4        26
#define    INTSRC_PORTD9        25
#define    INTSRC_PORTD8        24
#define    INTSRC_PORTD3        23
#define    INTSRC_PORTD2        22
#define    INTSRC_PORTD1        21
#define    INTSRC_PORTD0        20
#define    INTSRC_PORTC3        19
#define    INTSRC_PORTC2        18
#define    INTSRC_PORTC1        17
#define    INTSRC_PORTC0        16
#define    INTSRC_EXT15         15
#define    INTSRC_EXT14         14
#define    INTSRC_EXT13         13
#define    INTSRC_EXT12         12
#define    INTSRC_EXT11         11
#define    INTSRC_EXT10         10
#define    INTSRC_EXT9          9
#define    INTSRC_EXT8          8
#define    INTSRC_EXT7          7
#define    INTSRC_EXT6          6
#define    INTSRC_EXT5          5
#define    INTSRC_EXT4          4
#define    INTSRC_AO_EXT3       3
#define    INTSRC_AO_EXT2       2
#define    INTSRC_AO_EXT1       1
#define    INTSRC_AO_EXT0       0


typedef    char                 S8;        /* signed 8-bit integer */
typedef    short                S16;       /* signed 16-bit integer */
typedef    long                 S32;       /* signed 32-bit integer */
typedef    unsigned char        U8;        /* unsigned 8-bit integer */
typedef    unsigned short       U16;       /* unsigned 16-bit integer */
typedef    unsigned long        U32;       /* unsigned 32-bit integer */

typedef    volatile U32 *       RP;
typedef    volatile U16 *       RP16;
typedef    volatile U8  *       RP8;

typedef    void                 *VP;       /* pointer to an unpredictable data type */
typedef    void                 (*FP)();   /* program start address */

#ifndef    _BOOL_TYPE_
#define    _BOOL_TYPE_
typedef    int                  BOOL;        /* Boolean value.  TRUE (1) or FALSE (0). */
#endif

typedef    int                  ER;         /* Error code.  A signed integer. */

/**
 * IO definitions
 *
 * define access restrictions to peripheral registers
 */

#define     __I     volatile const            /*!< defines 'read only' permissions      */
#define     __O     volatile                  /*!< defines 'write only' permissions     */
#define     __IO    volatile                  /*!< defines 'read / write' permissions   */
#define     __iomem volatile


/*Macros for debug*/

#define EOUT(fmt,...) \
    do \
    {   \
        rt_kprintf("EOUT:(%s:%i)  ",__FILE__,__LINE__); \
        rt_kprintf(fmt,##__VA_ARGS__); \
    }while(0)

#define RT_USING_DEBUG
#ifdef RT_USING_DEBUG
    #define DBOUT(fmt,...) \
    do \
    {   \
        rt_kprintf("DBOUT:(%s:%i)  ",__FILE__,__LINE__); \
        rt_kprintf(fmt,##__VA_ARGS__); \
    }while(0)
#else
    #define DBOUT(fmt,...) \
    do{}while(0)
#endif

#ifdef  RT_USING_DEBUG
    #define ASSERT(arg) \
    if((arg) == 0) \
    {       \
        while(1) \
        {         \
            rt_kprintf("have a assert failure\n"); \
        }                                        \
    }
#else
    #define ASSERT(arg) \
    do      \
    {        \
    }while(0)
#endif


#define write_reg(reg,value) \
    do \
    { \
        *(RP)(reg) = value; \
    }while(0)

#define read_reg(reg) (*(RP)reg)


struct rt_hw_register
{
    rt_uint32_t r0;
    rt_uint32_t r1;
    rt_uint32_t r2;
    rt_uint32_t r3;
    rt_uint32_t r4;
    rt_uint32_t r5;
    rt_uint32_t r6;
    rt_uint32_t r7;
    rt_uint32_t r8;
    rt_uint32_t r9;
    rt_uint32_t r10;
    rt_uint32_t r11;
    rt_uint32_t r12;
    rt_uint32_t r13;
    rt_uint32_t r14;
    rt_uint32_t r15;
    rt_uint32_t r16;
    rt_uint32_t r17;
    rt_uint32_t r18;
    rt_uint32_t r19;
    rt_uint32_t r20;
    rt_uint32_t r21;
    rt_uint32_t r22;
    rt_uint32_t r23;
    rt_uint32_t r24;
    rt_uint32_t sb;
    rt_uint32_t sl;
    rt_uint32_t fp;
    rt_uint32_t ip;
    rt_uint32_t sp;
    rt_uint32_t lr;
    rt_uint32_t pc;
    rt_uint32_t asr;
    rt_uint32_t bsr;
    rt_uint32_t ORIG_r0;
};

/*@}*/

#endif