magicoe@163.com eb5e940df5 added bsp/lpc122x & libcpu/arm/lpc122x
git-svn-id: https://rt-thread.googlecode.com/svn/trunk@1234 bbd45198-f89e-11dd-88c7-29a3b14d5316
2011-01-05 06:23:40 +00:00

669 lines
23 KiB
C

/****************************************************************************
* $Id:: LPC122x.h 5637 2010-11-18 00:02:05Z nxp28433 $
* Project: NXP LPC122x software example
*
* Description:
* CMSIS Cortex-M0 Core Peripheral Access Layer Header File for
* NXP LPC122x Device Series
*
****************************************************************************
* Software that is described herein is for illustrative purposes only
* which provides customers with programming information regarding the
* products. This software is supplied "AS IS" without any warranties.
* NXP Semiconductors assumes no responsibility or liability for the
* use of the software, conveys no license or title under any patent,
* copyright, or mask work right to the product. NXP Semiconductors
* reserves the right to make changes in the software without
* notification. NXP Semiconductors also make no representation or
* warranty that such application will be suitable for the specified
* use without further testing or modification.
****************************************************************************/
#ifndef __LPC122x_H__
#define __LPC122x_H__
#ifdef __cplusplus
extern "C" {
#endif
/** @addtogroup LPC122x_Definitions LPC122x Definitions
This file defines all structures and symbols for LPC122x:
- Registers and bitfields
- peripheral base address
- peripheral ID
- PIO definitions
@{
*/
/******************************************************************************/
/* Processor and Core Peripherals */
/******************************************************************************/
/** @addtogroup LPC122x_CMSIS LPC122x CMSIS Definitions
Configuration of the Cortex-M0 Processor and Core Peripherals
@{
*/
/*
* ==========================================================================
* ---------- Interrupt Number Definition -----------------------------------
* ==========================================================================
*/
typedef enum IRQn
{
/****** Cortex-M0 Processor Exceptions Numbers ***************************************************/
NonMaskableInt_IRQn = -14, /*!< 2 Non Maskable Interrupt */
MemoryManagement_IRQn = -12, /*!< 4 Cortex-M0 Memory Management Interrupt */
BusFault_IRQn = -11, /*!< 5 Cortex-M0 Bus Fault Interrupt */
UsageFault_IRQn = -10, /*!< 6 Cortex-M0 Usage Fault Interrupt */
SVCall_IRQn = -5, /*!< 11 Cortex-M0 SV Call Interrupt */
DebugMonitor_IRQn = -4, /*!< 12 Cortex-M0 Debug Monitor Interrupt */
PendSV_IRQn = -2, /*!< 14 Cortex-M0 Pend SV Interrupt */
SysTick_IRQn = -1, /*!< 15 Cortex-M0 System Tick Interrupt */
/****** LPC122x Specific Interrupt Numbers *******************************************************/
WAKEUP0_IRQn = 0, /*!< The I/O pins can be used as wakeup source. */
WAKEUP1_IRQn = 1,
WAKEUP2_IRQn = 2,
WAKEUP3_IRQn = 3,
WAKEUP4_IRQn = 4,
WAKEUP5_IRQn = 5,
WAKEUP6_IRQn = 6,
WAKEUP7_IRQn = 7,
WAKEUP8_IRQn = 8,
WAKEUP9_IRQn = 9,
WAKEUP10_IRQn = 10,
WAKEUP11_IRQn = 11, /*!< 0 through 11 are WAKEUP interrupts */
I2C_IRQn = 12, /*!< I2C Interrupt */
TIMER_16_0_IRQn = 13, /*!< 16-bit Timer0 Interrupt */
TIMER_16_1_IRQn = 14, /*!< 16-bit Timer1 Interrupt */
TIMER_32_0_IRQn = 15, /*!< 32-bit Timer0 Interrupt */
TIMER_32_1_IRQn = 16, /*!< 32-bit Timer1 Interrupt */
SSP_IRQn = 17, /*!< SSP Interrupt */
UART0_IRQn = 18, /*!< UART0 Interrupt */
UART1_IRQn = 19, /*!< UART1 Interrupt */
CMP_IRQn = 20, /*!< Comparator Interrupt */
ADC_IRQn = 21, /*!< A/D Converter Interrupt */
WDT_IRQn = 22, /*!< Watchdog timer Interrupt */
BOD_IRQn = 23, /*!< Brown Out Detect(BOD) Interrupt */
FLASH_IRQn = 24, /*!< Flash Interrupt */
EINT0_IRQn = 25, /*!< External Interrupt 0 Interrupt */
EINT1_IRQn = 26, /*!< External Interrupt 1 Interrupt */
EINT2_IRQn = 27, /*!< External Interrupt 2 Interrupt */
PMU_IRQn = 28, /*!< PMU Interrupt */
DMA_IRQn = 29, /*!< DMA Interrupt */
RTC_IRQn = 30, /*!< RTC Interrupt */
EDM_IRQn = 31, /*!< EDT Interrupt */
} IRQn_Type;
/*
* ==========================================================================
* ----------- Processor and Core Peripheral Section ------------------------
* ==========================================================================
*/
/* Configuration of the Cortex-M3 Processor and Core Peripherals */
#define __MPU_PRESENT 1 /*!< MPU present or not */
#define __NVIC_PRIO_BITS 2 /*!< Number of Bits used for Priority Levels */
#define __Vendor_SysTickConfig 0 /*!< Set to 1 if different SysTick Config is used */
/*@}*/ /* end of group LPC122x_CMSIS */
#include "core_cm0.h" /* Cortex-M0 processor and core peripherals */
#include "system_LPC122x.h" /* System Header */
/******************************************************************************/
/* Device Specific Peripheral Registers structures */
/******************************************************************************/
#if defined ( __CC_ARM )
#pragma anon_unions
#endif
/*------------- System Control (SYSCON) --------------------------------------*/
/** @addtogroup LPC122x_SYSCON LPC122x System Control Block
@{
*/
typedef struct
{
__IO uint32_t SYSMEMREMAP; /* Sys mem. Remap, Offset 0x0 */
__IO uint32_t PRESETCTRL;
__IO uint32_t SYSPLLCTRL; /* Sys PLL control */
__IO uint32_t SYSPLLSTAT;
uint32_t RESERVED0[4];
__IO uint32_t SYSOSCCTRL; /* Offset 0x20 */
__IO uint32_t WDTOSCCTRL;
__IO uint32_t IRCCTRL;
uint32_t RESERVED0b;
__IO uint32_t SYSRESSTAT; /* Offset 0x30 */
uint32_t RESERVED1[3];
__IO uint32_t SYSPLLCLKSEL; /* Offset 0x40 */
__IO uint32_t SYSPLLCLKUEN;
uint32_t RESERVED2[10];
__IO uint32_t MAINCLKSEL; /* Offset 0x70 */
__IO uint32_t MAINCLKUEN;
__IO uint32_t SYSAHBCLKDIV;
uint32_t RESERVED3[1];
__IO uint32_t SYSAHBCLKCTRL; /* Offset 0x80 */
uint32_t RESERVED4[4];
__IO uint32_t SSPCLKDIV;
__IO uint32_t UART0CLKDIV;
__IO uint32_t UART1CLKDIV;
__IO uint32_t RTCCLKDIV;
uint32_t RESERVED5[2];
__IO uint32_t TRACECLKDIV;
__IO uint32_t SYSTICKCLKDIV; /* Offset 0xB0 */
__IO uint32_t I2CCLKDIV;
uint32_t RESERVED6[10];
__IO uint32_t CLKOUTCLKSEL; /* Offset 0xE0 */
__IO uint32_t CLKOUTUEN;
__IO uint32_t CLKOUTDIV;
uint32_t RESERVED7[5];
__IO uint32_t PIOPORCAP0; /* Offset 0x100 */
__IO uint32_t PIOPORCAP1;
uint32_t RESERVED8[11];
__IO uint32_t FILTERCLKCFG6;
__IO uint32_t FILTERCLKCFG5;
__IO uint32_t FILTERCLKCFG4;
__IO uint32_t FILTERCLKCFG3; /* Offset 0x140 */
__IO uint32_t FILTERCLKCFG2;
__IO uint32_t FILTERCLKCFG1;
__IO uint32_t FILTERCLKCFG0;
__IO uint32_t BODCTRL; /* Offset 0x150 */
uint32_t RESERVED9[1];
__IO uint32_t SYSTCKCAL;
uint32_t RESERVED10[5];
__IO uint32_t INT_IRQ_LATENCY; /* Offset 0x170 */
__IO uint32_t INTNMI;
uint32_t RESERVED11[34];
__IO uint32_t STARTAPRP0; /* Offset 0x200 */
__IO uint32_t STARTERP0;
__IO uint32_t STARTRSRP0CLR;
__IO uint32_t STARTSRP0;
__IO uint32_t STARTAPRP1;
__IO uint32_t STARTERP1;
__IO uint32_t STARTRSRP1CLR;
__IO uint32_t STARTSRP1;
uint32_t RESERVED12[4];
__IO uint32_t PDSLEEPCFG; /* Offset 0x230 */
__IO uint32_t PDAWAKECFG;
__IO uint32_t PDRUNCFG;
uint32_t RESERVED13;
__IO uint32_t EZHBOOT;
__IO uint32_t EZHCTRL;
__IO uint32_t EZHMUXSEL;
__IO uint32_t EZHARM2EZH;
__IO uint32_t EZHEZH2ARM;
__IO uint32_t EZHEZHPC;
__IO uint32_t EZHEZHSP;
__IO uint32_t EZHINTERRUPT;
uint32_t RESERVED14[101];
__I uint32_t DEVICE_ID;
} LPC_SYSCON_TypeDef;
/*------------- Pin Connect Block (IOCON) --------------------------------*/
/** @addtogroup LPC122x_IOCON LPC122x I/O Configuration Block
@{
*/
typedef struct
{
__IO uint32_t PIO2_28; /* 0x00 */
__IO uint32_t PIO2_29;
__IO uint32_t PIO0_19;
__IO uint32_t PIO0_20;
__IO uint32_t PIO0_21;
__IO uint32_t PIO0_22;
__IO uint32_t PIO0_23;
__IO uint32_t PIO0_24;
__IO uint32_t SWDIO_PIO0_25; /* 0x20 */
__IO uint32_t SWCLK_PIO0_26;
__IO uint32_t PIO0_27;
__IO uint32_t PIO2_12;
__IO uint32_t PIO2_13;
__IO uint32_t PIO2_14;
__IO uint32_t PIO2_15;
__IO uint32_t PIO0_28;
__IO uint32_t PIO0_29; /* 0x40 */
__IO uint32_t PIO0_0;
__IO uint32_t PIO0_1;
__IO uint32_t PIO0_2;
uint32_t RESERVED0;
__IO uint32_t PIO0_3;
__IO uint32_t PIO0_4;
__IO uint32_t PIO0_5;
__IO uint32_t PIO0_6; /* 0x60 */
__IO uint32_t PIO0_7;
__IO uint32_t PIO0_8;
__IO uint32_t PIO0_9;
__IO uint32_t PIO2_0;
__IO uint32_t PIO2_1;
__IO uint32_t PIO2_2;
__IO uint32_t PIO2_3;
__IO uint32_t PIO2_4; /* 0x80 */
__IO uint32_t PIO2_5;
__IO uint32_t PIO2_6;
__IO uint32_t PIO2_7;
__IO uint32_t PIO0_10;
__IO uint32_t PIO0_11;
__IO uint32_t PIO0_12;
__IO uint32_t RESET_P0_13;
__IO uint32_t PIO0_14; /* 0xA0 */
__IO uint32_t PIO0_15;
__IO uint32_t PIO0_16;
__IO uint32_t PIO0_17;
__IO uint32_t PIO0_18;
__IO uint32_t PIO0_30;
__IO uint32_t PIO0_31;
__IO uint32_t PIO1_0;
__IO uint32_t PIO1_1; /* 0xC0 */
__IO uint32_t PIO1_2;
__IO uint32_t PIO1_3;
__IO uint32_t PIO1_4;
__IO uint32_t PIO1_5;
__IO uint32_t PIO1_6;
uint32_t RESERVED1[2];
__IO uint32_t PIO2_8; /* 0xE0 */
__IO uint32_t PIO2_9;
__IO uint32_t PIO2_10;
__IO uint32_t PIO2_11;
#if 0
/* LOC registers are no longer needed on LPC122x V1. */
__IO uint32_t EZH0_LOC;
__IO uint32_t EZH1_LOC;
__IO uint32_t CT32B0_0_LOC;
__IO uint32_t EZH2_LOC;
__IO uint32_t CT32B0_1_LOC; /* 0x100 */
__IO uint32_t EZH3_LOC;
__IO uint32_t CT32B0_2_LOC;
__IO uint32_t EZH4_LOC;
__IO uint32_t CT32B0_3_LOC;
__IO uint32_t EZH5_LOC;
__IO uint32_t EZH6_LOC;
__IO uint32_t CT32B1_0_LOC;
__IO uint32_t EZH7_LOC; /* 0x120 */
__IO uint32_t CT32B1_1_LOC;
__IO uint32_t EZH8_LOC;
__IO uint32_t CT32B1_2_LOC;
__IO uint32_t EZH9_LOC;
__IO uint32_t CT32B1_3_LOC;
__IO uint32_t EZH10_LOC;
__IO uint32_t EZH11_LOC;
__IO uint32_t CT16B0_0_LOC; /* 0x140 */
__IO uint32_t EZH12_LOC;
__IO uint32_t CT16B0_1_LOC;
__IO uint32_t EZH13_LOC;
__IO uint32_t EZH14_LOC;
__IO uint32_t EZH15_LOC;
__IO uint32_t CT16B1_0_LOC;
__IO uint32_t CT16B1_1_LOC;
#endif
} LPC_IOCON_TypeDef;
/*------------- microDMA (DMA) --------------------------*/
/** @addtogroup LPC122x_DMA LPC122x microDMA
@{
*/
typedef struct
{
__I uint32_t STATUS;
__O uint32_t CFG;
__IO uint32_t CTRL_BASE_PTR;
__I uint32_t ALT_CTRL_BASE_PTR;
__I uint32_t WAITONREQ_STATUS;
__O uint32_t CHNL_SW_REQUEST;
__IO uint32_t CHNL_USEBURST_SET;
__O uint32_t CHNL_USEBURST_CLR;
__IO uint32_t CHNL_REQ_MASK_SET;
__O uint32_t CHNL_REQ_MASK_CLR;
__IO uint32_t CHNL_ENABLE_SET;
__O uint32_t CHNL_ENABLE_CLR;
__IO uint32_t CHNL_PRI_ALT_SET;
__O uint32_t CHNL_PRI_ALT_CLR;
__IO uint32_t CHNL_PRIORITY_SET;
__O uint32_t CHNL_PRIORITY_CLR;
uint32_t RESERVE0[3];
__IO uint32_t ERR_CLR; /* 0x4C */
uint32_t RESERVE1[12];
__IO uint32_t CHNL_IRQ_STATUS; /* 0x80 */
__IO uint32_t IRQ_ERR_ENABLE;
__IO uint32_t CHNL_IRQ_ENABLE;
} LPC_DMA_TypeDef;
/*@}*/ /* end of group LPC122x_DMA */
/*------------- Comparator (CMP) --------------------------------*/
/** @addtogroup LPC122x_CMD LPC122x Comparator
@{
*/
typedef struct
{
__IO uint32_t CMP;
__IO uint32_t VLAD;
} LPC_COMP_TypeDef;
/*@}*/ /* end of group LPC122x_CMD */
/*------------- Real Timer Clock (RTC) --------------------------*/
/** @addtogroup LPC122x_RTC LPC122x Real-time Clock
@{
*/
typedef struct
{
__I uint32_t DR;
__IO uint32_t MR;
__IO uint32_t LR;
__IO uint32_t CR;
__IO uint32_t IMSC;
__I uint32_t IRS;
__I uint32_t MIS;
__IO uint32_t ICR;
} LPC_RTC_TypeDef;
/*@}*/ /* end of group LPC122x_RTC */
/*------------- Power Management Unit (PMU) --------------------------*/
/** @addtogroup LPC122x_PMU LPC122x Power Management Unit
@{
*/
typedef struct
{
__IO uint32_t PCON;
__IO uint32_t GPREG0;
__IO uint32_t GPREG1;
__IO uint32_t GPREG2;
__IO uint32_t GPREG3;
__IO uint32_t GPREG4;
} LPC_PMU_TypeDef;
/*@}*/ /* end of group LPC122x_PMU */
/*------------- General Purpose Input/Output (GPIO) --------------------------*/
/** @addtogroup LPC122x_GPIO LPC122x General Purpose Input/Output
@{
*/
typedef struct
{
__IO uint32_t MASK;
__I uint32_t PIN;
__IO uint32_t OUT;
__O uint32_t SET;
__O uint32_t CLR;
__O uint32_t NOT;
uint32_t RESERVE[2];
__IO uint32_t DIR;
__IO uint32_t IS;
__IO uint32_t IBE;
__IO uint32_t IEV;
__IO uint32_t IE;
__I uint32_t RIS;
__I uint32_t MIS;
__O uint32_t IC;
} LPC_GPIO_TypeDef;
/*@}*/ /* end of group LPC122x_GPIO */
/*------------- Timer (TMR) --------------------------------------------------*/
/** @addtogroup LPC122x_TMR LPC122x 16/32-bit Counter/Timer
@{
*/
typedef struct
{
__IO uint32_t IR;
__IO uint32_t TCR;
__IO uint32_t TC;
__IO uint32_t PR;
__IO uint32_t PC;
__IO uint32_t MCR;
__IO uint32_t MR0;
__IO uint32_t MR1;
__IO uint32_t MR2;
__IO uint32_t MR3;
__IO uint32_t CCR;
__I uint32_t CR0;
__I uint32_t CR1;
__I uint32_t CR2;
__I uint32_t CR3;
__IO uint32_t EMR;
uint32_t RESERVED2[12];
__IO uint32_t CTCR;
__IO uint32_t PWMC;
} LPC_TMR_TypeDef;
/*@}*/ /* end of group LPC122x_TMR */
/*------------- Universal Asynchronous Receiver Transmitter (UART) -----------*/
/** @addtogroup LPC122x_UART LPC122x Universal Asynchronous Receiver/Transmitter
@{
*/
typedef struct
{
union {
__I uint32_t RBR;
__O uint32_t THR;
__IO uint32_t DLL;
};
union {
__IO uint32_t DLM;
__IO uint32_t IER;
};
union {
__I uint32_t IIR;
__O uint32_t FCR;
};
__IO uint32_t LCR;
__IO uint32_t MCR;
__I uint32_t LSR;
__I uint32_t MSR;
__IO uint32_t SCR;
__IO uint32_t ACR;
__IO uint32_t ICR;
__IO uint32_t FDR;
uint32_t RESERVED0;
__IO uint32_t TER;
uint32_t RESERVED1[6];
__IO uint32_t RS485CTRL;
__IO uint32_t ADRMATCH;
__IO uint32_t RS485DLY;
__I uint32_t FIFOLVL;
} LPC_UART_TypeDef;
/*@}*/ /* end of group LPC122x_UART */
/*------------- Synchronous Serial Communication (SSP) -----------------------*/
/** @addtogroup LPC122x_SSP LPC122x Synchronous Serial Port
@{
*/
typedef struct
{
__IO uint32_t CR0;
__IO uint32_t CR1;
__IO uint32_t DR;
__I uint32_t SR;
__IO uint32_t CPSR;
__IO uint32_t IMSC;
__IO uint32_t RIS;
__IO uint32_t MIS;
__IO uint32_t ICR;
} LPC_SSP_TypeDef;
/*@}*/ /* end of group LPC122x_SSP */
/*------------- Inter-Integrated Circuit (I2C) -------------------------------*/
/** @addtogroup LPC122x_I2C LPC122x I2C-Bus Interface
@{
*/
typedef struct
{
__IO uint32_t CONSET;
__I uint32_t STAT;
__IO uint32_t DAT;
__IO uint32_t ADR0;
__IO uint32_t SCLH;
__IO uint32_t SCLL;
__O uint32_t CONCLR;
__IO uint32_t MMCTRL;
__IO uint32_t ADR1;
__IO uint32_t ADR2;
__IO uint32_t ADR3;
__I uint32_t DATA_BUFFER;
__IO uint32_t MASK0;
__IO uint32_t MASK1;
__IO uint32_t MASK2;
__IO uint32_t MASK3;
} LPC_I2C_TypeDef;
/*@}*/ /* end of group LPC122x_I2C */
/*------------- Watchdog Timer (WDT) -----------------------------------------*/
/** @addtogroup LPC122x_WDT LPC122x WatchDog Timer
@{
*/
typedef struct
{
__IO uint32_t MOD;
__IO uint32_t TC;
__O uint32_t FEED;
__I uint32_t TV;
__IO uint32_t CLKSEL;
__IO uint32_t WARNINT;
__IO uint32_t WINDOW;
} LPC_WDT_TypeDef;
/*@}*/ /* end of group LPC122x_WDT */
/*------------- Analog-to-Digital Converter (ADC) ----------------------------*/
/** @addtogroup LPC122x_ADC LPC122x Analog-to-Digital Converter
@{
*/
typedef struct
{
__IO uint32_t CR;
__IO uint32_t GDR;
uint32_t RESERVED0;
__IO uint32_t INTEN;
__IO uint32_t DR[8];
__I uint32_t STAT;
} LPC_ADC_TypeDef;
/*@}*/ /* end of group LPC122x_ADC */
/*------------- Flash Memory Controller (FMC) -----------------------------------*/
typedef struct
{
__IO uint32_t TBCFG; /* Time Base Config register */
__IO uint32_t FINSTR; /* Flash Instruction register */
__I uint32_t INSSTA; /* Raw Instruction Status register */
__IO uint32_t INSSCLR; /* Raw Instruction Clear register */
__IO uint32_t INT_EN; /* Interrupt Enable register */
__I uint32_t INT_STA; /* Interrupt Status register */
uint32_t RESERVED0;
__IO uint32_t ADDRLAT; /* Address Latch registers */
__IO uint32_t DATALAT; /* Data Latch register */
__IO uint32_t FIMC; /* Flash Manaul Operation register */
__IO uint32_t RDCFG; /* Read Configuration register */
__IO uint32_t EPPCFG; /* Flash Programming Permission Cofig register */
__IO uint32_t EPPAA; /* Flash Programming Permission Address A register */
__IO uint32_t EPPAB; /* Flash Programming Permission Address B register */
} LPC_FMC_TypeDef;
/*------------- CRC Engine (CRC) -----------------------------------------*/
typedef struct
{
__IO uint32_t MODE;
__IO uint32_t SEED;
union {
__I uint32_t SUM;
__O uint32_t WR_DATA_DWORD;
__O uint16_t WR_DATA_WORD;
uint16_t RESERVED_WORD;
__O uint8_t WR_DATA_BYTE;
uint8_t RESERVED_BYTE[3];
};
__I uint32_t ID;
} LPC_CRC_TypeDef;
#if defined ( __CC_ARM )
#pragma no_anon_unions
#endif
/******************************************************************************/
/* Peripheral memory map */
/******************************************************************************/
/* Base addresses */
#define LPC_FLASH_BASE (0x00000000)
#define LPC_RAM_BASE (0x10000000)
#define LPC_APB0_BASE (0x40000000)
#define LPC_AHB_BASE (0x50000000)
/* APB0 peripherals */
#define LPC_I2C_BASE (LPC_APB0_BASE + 0x00000)
#define LPC_WDT_BASE (LPC_APB0_BASE + 0x04000)
#define LPC_UART0_BASE (LPC_APB0_BASE + 0x08000)
#define LPC_UART1_BASE (LPC_APB0_BASE + 0x0C000)
#define LPC_CT16B0_BASE (LPC_APB0_BASE + 0x10000)
#define LPC_CT16B1_BASE (LPC_APB0_BASE + 0x14000)
#define LPC_CT32B0_BASE (LPC_APB0_BASE + 0x18000)
#define LPC_CT32B1_BASE (LPC_APB0_BASE + 0x1C000)
#define LPC_ADC_BASE (LPC_APB0_BASE + 0x20000)
#define LPC_PMU_BASE (LPC_APB0_BASE + 0x38000)
#define LPC_SSP_BASE (LPC_APB0_BASE + 0x40000)
#define LPC_IOCON_BASE (LPC_APB0_BASE + 0x44000)
#define LPC_SYSCON_BASE (LPC_APB0_BASE + 0x48000)
#define LPC_DMA_BASE (LPC_APB0_BASE + 0x4C000)
#define LPC_RTC_BASE (LPC_APB0_BASE + 0x50000)
#define LPC_COMP_BASE (LPC_APB0_BASE + 0x54000)
/* AHB peripherals */
#define LPC_GPIO_BASE (LPC_AHB_BASE + 0x00000)
#define LPC_GPIO0_BASE (LPC_AHB_BASE + 0x00000)
#define LPC_GPIO1_BASE (LPC_AHB_BASE + 0x10000)
#define LPC_GPIO2_BASE (LPC_AHB_BASE + 0x20000)
#define LPC_FMC_BASE (LPC_AHB_BASE + 0x60000)
#define LPC_CRC_BASE (LPC_AHB_BASE + 0x70000)
/******************************************************************************/
/* Peripheral declaration */
/******************************************************************************/
#define LPC_I2C ((LPC_I2C_TypeDef *) LPC_I2C_BASE )
#define LPC_WDT ((LPC_WDT_TypeDef *) LPC_WDT_BASE )
#define LPC_UART0 ((LPC_UART_TypeDef *) LPC_UART0_BASE )
#define LPC_UART1 ((LPC_UART_TypeDef *) LPC_UART1_BASE )
#define LPC_TMR16B0 ((LPC_TMR_TypeDef *) LPC_CT16B0_BASE)
#define LPC_TMR16B1 ((LPC_TMR_TypeDef *) LPC_CT16B1_BASE)
#define LPC_TMR32B0 ((LPC_TMR_TypeDef *) LPC_CT32B0_BASE)
#define LPC_TMR32B1 ((LPC_TMR_TypeDef *) LPC_CT32B1_BASE)
#define LPC_ADC ((LPC_ADC_TypeDef *) LPC_ADC_BASE )
#define LPC_PMU ((LPC_PMU_TypeDef *) LPC_PMU_BASE )
#define LPC_SSP ((LPC_SSP_TypeDef *) LPC_SSP_BASE )
#define LPC_IOCON ((LPC_IOCON_TypeDef *) LPC_IOCON_BASE )
#define LPC_SYSCON ((LPC_SYSCON_TypeDef *) LPC_SYSCON_BASE)
#define LPC_DMA ((LPC_DMA_TypeDef *) LPC_DMA_BASE )
#define LPC_RTC ((LPC_RTC_TypeDef *) LPC_RTC_BASE )
#define LPC_COMP ((LPC_COMP_TypeDef *) LPC_COMP_BASE )
#define LPC_GPIO0 ((LPC_GPIO_TypeDef *) LPC_GPIO0_BASE )
#define LPC_GPIO1 ((LPC_GPIO_TypeDef *) LPC_GPIO1_BASE )
#define LPC_GPIO2 ((LPC_GPIO_TypeDef *) LPC_GPIO2_BASE )
#define LPC_FMC ((LPC_FMC_TypeDef *) LPC_FMC_BASE )
#define LPC_CRC ((LPC_CRC_TypeDef *) LPC_CRC_BASE )
#ifdef __cplusplus
}
#endif
#endif // __LPC122x_H__