/*-------------------------------------------------------------------*/
/* LPC176x Register Definitions and Cortex-M3 Supplement Definitions */
/*       This file is a non-copyrighted public domain software       */
/*-------------------------------------------------------------------*/

#ifndef __LPC176x
#define __LPC176x
#include <stdint.h>

#define	USE_SV_SERVICE	0	/* Enable supervisor service for user mode task */


/* System Controls */
#define	EXTINT		(*(volatile uint32_t*)0x400FC140)
#define	EXTMODE		(*(volatile uint32_t*)0x400FC148)
#define	EXTPOLAR	(*(volatile uint32_t*)0x400FC14C)
#define	RSID		(*(volatile uint32_t*)0x400FC180)
#define	SCS			(*(volatile uint32_t*)0x400FC1A0)

/* Clocking and Power Controls */
#define	CLKSRCSEL	(*(volatile uint32_t*)0x400FC10C)
#define	PLL0CON		(*(volatile uint32_t*)0x400FC080)
#define	PLL0CFG		(*(volatile uint32_t*)0x400FC084)
#define	PLL0STAT	(*(volatile uint32_t*)0x400FC088)
#define	PLL0FEED	(*(volatile uint32_t*)0x400FC08C)
#define	PLL1CON		(*(volatile uint32_t*)0x400FC0A0)
#define	PLL1CFG		(*(volatile uint32_t*)0x400FC0A4)
#define	PLL1STAT	(*(volatile uint32_t*)0x400FC0A8)
#define	PLL1FEED	(*(volatile uint32_t*)0x400FC0AC)
#define	CCLKCFG		(*(volatile uint32_t*)0x400FC104)
#define	USBCLKCFG	(*(volatile uint32_t*)0x400FC108)
#define	PCLKSEL		( (volatile uint32_t*)0x400FC1A8)
#define	PCLKSEL0	(*(volatile uint32_t*)0x400FC1A8)
#define	PCLKSEL1	(*(volatile uint32_t*)0x400FC1AC)
#define	PCON		(*(volatile uint32_t*)0x400FC0C0)
#define	PCONP		(*(volatile uint32_t*)0x400FC0C4)
#define	CLKOUTCFG	(*(volatile uint32_t*)0x400FC1C8)

/* Flash Accelerator */
#define	FLASHCFG	(*(volatile uint32_t*)0x400FC000)

/* Pin Configurations */
#define	PINSEL		( (volatile uint32_t*)0x4002C000)
#define	PINSEL0		(*(volatile uint32_t*)0x4002C000)
#define	PINSEL1		(*(volatile uint32_t*)0x4002C004)
#define	PINSEL2		(*(volatile uint32_t*)0x4002C008)
#define	PINSEL3		(*(volatile uint32_t*)0x4002C00C)
#define	PINSEL4		(*(volatile uint32_t*)0x4002C010)
#define	PINSEL7		(*(volatile uint32_t*)0x4002C01C)
#define	PINSEL8		(*(volatile uint32_t*)0x4002C020)
#define	PINSEL9		(*(volatile uint32_t*)0x4002C024)
#define	PINSEL10	(*(volatile uint32_t*)0x4002C028)
#define	PINMODE		( (volatile uint32_t*)0x4002C040)
#define	PINMODE0	(*(volatile uint32_t*)0x4002C040)
#define	PINMODE1	(*(volatile uint32_t*)0x4002C044)
#define	PINMODE2	(*(volatile uint32_t*)0x4002C048)
#define	PINMODE3	(*(volatile uint32_t*)0x4002C04C)
#define	PINMODE4	(*(volatile uint32_t*)0x4002C050)
#define	PINMODE5	(*(volatile uint32_t*)0x4002C054)
#define	PINMODE6	(*(volatile uint32_t*)0x4002C058)
#define	PINMODE7	(*(volatile uint32_t*)0x4002C05C)
#define	PINMODE9	(*(volatile uint32_t*)0x4002C064)
#define	PINMODE_OD	( (volatile uint32_t*)0x4002C068)
#define	PINMODE_OD0	(*(volatile uint32_t*)0x4002C068)
#define	PINMODE_OD1	(*(volatile uint32_t*)0x4002C06C)
#define	PINMODE_OD2	(*(volatile uint32_t*)0x4002C070)
#define	PINMODE_OD3	(*(volatile uint32_t*)0x4002C074)
#define	PINMODE_OD4	(*(volatile uint32_t*)0x4002C078)
#define	I2CPADCFG	(*(volatile uint32_t*)0x4002C07C)

/* GPIO */
#define	FIO0DIR		(*(volatile uint32_t*)0x2009C000)
#define	FIO0DIRL	(*(volatile uint16_t*)0x2009C000)
#define	FIO0DIRH	(*(volatile uint16_t*)0x2009C002)
#define	FIO0DIR0	(*(volatile uint8_t*)0x2009C000)
#define	FIO0DIR1	(*(volatile uint8_t*)0x2009C001)
#define	FIO0DIR2	(*(volatile uint8_t*)0x2009C002)
#define	FIO0DIR3	(*(volatile uint8_t*)0x2009C003)

#define	FIO1DIR		(*(volatile uint32_t*)0x2009C020)
#define	FIO1DIRL	(*(volatile uint16_t*)0x2009C020)
#define	FIO1DIRH	(*(volatile uint16_t*)0x2009C022)
#define	FIO1DIR0	(*(volatile uint8_t*)0x2009C020)
#define	FIO1DIR1	(*(volatile uint8_t*)0x2009C021)
#define	FIO1DIR2	(*(volatile uint8_t*)0x2009C022)
#define	FIO1DIR3	(*(volatile uint8_t*)0x2009C023)

#define	FIO2DIR		(*(volatile uint32_t*)0x2009C040)
#define	FIO2DIRL	(*(volatile uint16_t*)0x2009C040)
#define	FIO2DIRH	(*(volatile uint16_t*)0x2009C042)
#define	FIO2DIR0	(*(volatile uint8_t*)0x2009C040)
#define	FIO2DIR1	(*(volatile uint8_t*)0x2009C041)
#define	FIO2DIR2	(*(volatile uint8_t*)0x2009C042)
#define	FIO2DIR3	(*(volatile uint8_t*)0x2009C043)

#define	FIO3DIR		(*(volatile uint32_t*)0x2009C060)
#define	FIO3DIRL	(*(volatile uint16_t*)0x2009C060)
#define	FIO3DIRH	(*(volatile uint16_t*)0x2009C062)
#define	FIO3DIR0	(*(volatile uint8_t*)0x2009C060)
#define	FIO3DIR1	(*(volatile uint8_t*)0x2009C061)
#define	FIO3DIR2	(*(volatile uint8_t*)0x2009C062)
#define	FIO3DIR3	(*(volatile uint8_t*)0x2009C063)

#define	FIO4DIR		(*(volatile uint32_t*)0x2009C080)
#define	FIO4DIRL	(*(volatile uint16_t*)0x2009C080)
#define	FIO4DIRH	(*(volatile uint16_t*)0x2009C082)
#define	FIO4DIR0	(*(volatile uint8_t*)0x2009C080)
#define	FIO4DIR1	(*(volatile uint8_t*)0x2009C081)
#define	FIO4DIR2	(*(volatile uint8_t*)0x2009C082)
#define	FIO4DIR3	(*(volatile uint8_t*)0x2009C083)

#define	FIO0MASK	(*(volatile uint32_t*)0x2009C010)
#define	FIO0MASKL	(*(volatile uint16_t*)0x2009C010)
#define	FIO0MASKH	(*(volatile uint16_t*)0x2009C012)
#define	FIO0MASK0	(*(volatile uint8_t*)0x2009C010)
#define	FIO0MASK1	(*(volatile uint8_t*)0x2009C011)
#define	FIO0MASK2	(*(volatile uint8_t*)0x2009C012)
#define	FIO0MASK3	(*(volatile uint8_t*)0x2009C013)

#define	FIO1MASK	(*(volatile uint32_t*)0x2009C030)
#define	FIO1MASKL	(*(volatile uint16_t*)0x2009C030)
#define	FIO1MASKH	(*(volatile uint16_t*)0x2009C032)
#define	FIO1MASK0	(*(volatile uint8_t*)0x2009C030)
#define	FIO1MASK1	(*(volatile uint8_t*)0x2009C031)
#define	FIO1MASK2	(*(volatile uint8_t*)0x2009C032)
#define	FIO1MASK3	(*(volatile uint8_t*)0x2009C033)

#define	FIO2MASK	(*(volatile uint32_t*)0x2009C050)
#define	FIO2MASKL	(*(volatile uint16_t*)0x2009C050)
#define	FIO2MASKH	(*(volatile uint16_t*)0x2009C052)
#define	FIO2MASK0	(*(volatile uint8_t*)0x2009C050)
#define	FIO2MASK1	(*(volatile uint8_t*)0x2009C051)
#define	FIO2MASK2	(*(volatile uint8_t*)0x2009C052)
#define	FIO2MASK3	(*(volatile uint8_t*)0x2009C053)

#define	FIO3MASK	(*(volatile uint32_t*)0x2009C070)
#define	FIO3MASKL	(*(volatile uint16_t*)0x2009C070)
#define	FIO3MASKH	(*(volatile uint16_t*)0x2009C072)
#define	FIO3MASK0	(*(volatile uint8_t*)0x2009C070)
#define	FIO3MASK1	(*(volatile uint8_t*)0x2009C071)
#define	FIO3MASK2	(*(volatile uint8_t*)0x2009C072)
#define	FIO3MASK3	(*(volatile uint8_t*)0x2009C073)

#define	FIO4MASK	(*(volatile uint32_t*)0x2009C090)
#define	FIO4MASKL	(*(volatile uint16_t*)0x2009C090)
#define	FIO4MASKH	(*(volatile uint16_t*)0x2009C092)
#define	FIO4MASK0	(*(volatile uint8_t*)0x2009C090)
#define	FIO4MASK1	(*(volatile uint8_t*)0x2009C091)
#define	FIO4MASK2	(*(volatile uint8_t*)0x2009C092)
#define	FIO4MASK3	(*(volatile uint8_t*)0x2009C093)

#define	FIO0PIN		(*(volatile uint32_t*)0x2009C014)
#define	FIO0PINL	(*(volatile uint16_t*)0x2009C014)
#define	FIO0PINH	(*(volatile uint16_t*)0x2009C016)
#define	FIO0PIN0	(*(volatile uint8_t*)0x2009C014)
#define	FIO0PIN1	(*(volatile uint8_t*)0x2009C015)
#define	FIO0PIN2	(*(volatile uint8_t*)0x2009C016)
#define	FIO0PIN3	(*(volatile uint8_t*)0x2009C017)

#define	FIO1PIN		(*(volatile uint32_t*)0x2009C034)
#define	FIO1PINL	(*(volatile uint16_t*)0x2009C034)
#define	FIO1PINH	(*(volatile uint16_t*)0x2009C036)
#define	FIO1PIN0	(*(volatile uint8_t*)0x2009C034)
#define	FIO1PIN1	(*(volatile uint8_t*)0x2009C035)
#define	FIO1PIN2	(*(volatile uint8_t*)0x2009C036)
#define	FIO1PIN3	(*(volatile uint8_t*)0x2009C037)

#define	FIO2PIN		(*(volatile uint32_t*)0x2009C054)
#define	FIO2PINL	(*(volatile uint16_t*)0x2009C054)
#define	FIO2PINH	(*(volatile uint16_t*)0x2009C056)
#define	FIO2PIN0	(*(volatile uint8_t*)0x2009C054)
#define	FIO2PIN1	(*(volatile uint8_t*)0x2009C055)
#define	FIO2PIN2	(*(volatile uint8_t*)0x2009C056)
#define	FIO2PIN3	(*(volatile uint8_t*)0x2009C057)

#define	FIO3PIN		(*(volatile uint32_t*)0x2009C074)
#define	FIO3PINL	(*(volatile uint16_t*)0x2009C074)
#define	FIO3PINH	(*(volatile uint16_t*)0x2009C076)
#define	FIO3PIN0	(*(volatile uint8_t*)0x2009C074)
#define	FIO3PIN1	(*(volatile uint8_t*)0x2009C075)
#define	FIO3PIN2	(*(volatile uint8_t*)0x2009C076)
#define	FIO3PIN3	(*(volatile uint8_t*)0x2009C077)

#define	FIO4PIN		(*(volatile uint32_t*)0x2009C094)
#define	FIO4PINL	(*(volatile uint16_t*)0x2009C094)
#define	FIO4PINH	(*(volatile uint16_t*)0x2009C096)
#define	FIO4PIN0	(*(volatile uint8_t*)0x2009C094)
#define	FIO4PIN1	(*(volatile uint8_t*)0x2009C095)
#define	FIO4PIN2	(*(volatile uint8_t*)0x2009C096)
#define	FIO4PIN3	(*(volatile uint8_t*)0x2009C097)

#define	FIO0SET		(*(volatile uint32_t*)0x2009C018)
#define	FIO0SETL	(*(volatile uint16_t*)0x2009C018)
#define	FIO0SETH	(*(volatile uint16_t*)0x2009C01A)
#define	FIO0SET0	(*(volatile uint8_t*)0x2009C018)
#define	FIO0SET1	(*(volatile uint8_t*)0x2009C019)
#define	FIO0SET2	(*(volatile uint8_t*)0x2009C01A)
#define	FIO0SET3	(*(volatile uint8_t*)0x2009C01B)

#define	FIO1SET		(*(volatile uint32_t*)0x2009C038)
#define	FIO1SETL	(*(volatile uint16_t*)0x2009C038)
#define	FIO1SETH	(*(volatile uint16_t*)0x2009C03A)
#define	FIO1SET0	(*(volatile uint8_t*)0x2009C038)
#define	FIO1SET1	(*(volatile uint8_t*)0x2009C039)
#define	FIO1SET2	(*(volatile uint8_t*)0x2009C03A)
#define	FIO1SET3	(*(volatile uint8_t*)0x2009C03B)

#define	FIO2SET		(*(volatile uint32_t*)0x2009C058)
#define	FIO2SETL	(*(volatile uint16_t*)0x2009C058)
#define	FIO2SETH	(*(volatile uint16_t*)0x2009C05A)
#define	FIO2SET0	(*(volatile uint8_t*)0x2009C058)
#define	FIO2SET1	(*(volatile uint8_t*)0x2009C059)
#define	FIO2SET2	(*(volatile uint8_t*)0x2009C05A)
#define	FIO2SET3	(*(volatile uint8_t*)0x2009C05B)

#define	FIO3SET		(*(volatile uint32_t*)0x2009C078)
#define	FIO3SETL	(*(volatile uint16_t*)0x2009C078)
#define	FIO3SETH	(*(volatile uint16_t*)0x2009C07A)
#define	FIO3SET0	(*(volatile uint8_t*)0x2009C078)
#define	FIO3SET1	(*(volatile uint8_t*)0x2009C079)
#define	FIO3SET2	(*(volatile uint8_t*)0x2009C07A)
#define	FIO3SET3	(*(volatile uint8_t*)0x2009C07B)

#define	FIO4SET		(*(volatile uint32_t*)0x2009C098)
#define	FIO4SETL	(*(volatile uint16_t*)0x2009C098)
#define	FIO4SETH	(*(volatile uint16_t*)0x2009C09A)
#define	FIO4SET0	(*(volatile uint8_t*)0x2009C098)
#define	FIO4SET1	(*(volatile uint8_t*)0x2009C099)
#define	FIO4SET2	(*(volatile uint8_t*)0x2009C09A)
#define	FIO4SET3	(*(volatile uint8_t*)0x2009C09B)

#define	FIO0CLR		(*(volatile uint32_t*)0x2009C01C)
#define	FIO0CLRL	(*(volatile uint16_t*)0x2009C01C)
#define	FIO0CLRH	(*(volatile uint16_t*)0x2009C01E)
#define	FIO0CLR0	(*(volatile uint8_t*)0x2009C01C)
#define	FIO0CLR1	(*(volatile uint8_t*)0x2009C01D)
#define	FIO0CLR2	(*(volatile uint8_t*)0x2009C01E)
#define	FIO0CLR3	(*(volatile uint8_t*)0x2009C01F)

#define	FIO1CLR		(*(volatile uint32_t*)0x2009C03C)
#define	FIO1CLRL	(*(volatile uint16_t*)0x2009C03C)
#define	FIO1CLRH	(*(volatile uint16_t*)0x2009C03E)
#define	FIO1CLR0	(*(volatile uint8_t*)0x2009C03C)
#define	FIO1CLR1	(*(volatile uint8_t*)0x2009C03D)
#define	FIO1CLR2	(*(volatile uint8_t*)0x2009C03E)
#define	FIO1CLR3	(*(volatile uint8_t*)0x2009C03F)

#define	FIO2CLR		(*(volatile uint32_t*)0x2009C05C)
#define	FIO2CLRL	(*(volatile uint16_t*)0x2009C05C)
#define	FIO2CLRH	(*(volatile uint16_t*)0x2009C05E)
#define	FIO2CLR0	(*(volatile uint8_t*)0x2009C05C)
#define	FIO2CLR1	(*(volatile uint8_t*)0x2009C05D)
#define	FIO2CLR2	(*(volatile uint8_t*)0x2009C05E)
#define	FIO2CLR3	(*(volatile uint8_t*)0x2009C05F)

#define	FIO3CLR		(*(volatile uint32_t*)0x2009C07C)
#define	FIO3CLRL	(*(volatile uint16_t*)0x2009C07C)
#define	FIO3CLRH	(*(volatile uint16_t*)0x2009C07E)
#define	FIO3CLR0	(*(volatile uint8_t*)0x2009C07C)
#define	FIO3CLR1	(*(volatile uint8_t*)0x2009C07D)
#define	FIO3CLR2	(*(volatile uint8_t*)0x2009C07E)
#define	FIO3CLR3	(*(volatile uint8_t*)0x2009C07F)

#define	FIO4CLR		(*(volatile uint32_t*)0x2009C09C)
#define	FIO4CLRL	(*(volatile uint16_t*)0x2009C09C)
#define	FIO4CLRH	(*(volatile uint16_t*)0x2009C09E)
#define	FIO4CLR0	(*(volatile uint8_t*)0x2009C09C)
#define	FIO4CLR1	(*(volatile uint8_t*)0x2009C09D)
#define	FIO4CLR2	(*(volatile uint8_t*)0x2009C09E)
#define	FIO4CLR3	(*(volatile uint8_t*)0x2009C09F)

#define	IOIntStatus	(*(volatile uint32_t*)0x40028080)
#define	IO0IntStatR	(*(volatile uint32_t*)0x40028084)
#define	IO0IntStatF	(*(volatile uint32_t*)0x40028088)
#define	IO0IntClr	(*(volatile uint32_t*)0x4002808C)
#define	IO0IntEnR	(*(volatile uint32_t*)0x40028090)
#define	IO0IntEnF	(*(volatile uint32_t*)0x40028094)
#define	IO2IntStatR	(*(volatile uint32_t*)0x400280A4)
#define	IO2IntStatF	(*(volatile uint32_t*)0x400280A8)
#define	IO2IntClr	(*(volatile uint32_t*)0x400280AC)
#define	IO2IntEnR	(*(volatile uint32_t*)0x400280B0)
#define	IO2IntEnF	(*(volatile uint32_t*)0x400280B4)

/* Ethernet MAC */
#define	MAC1			(*(volatile uint32_t*)0x50000000)
#define	MAC2			(*(volatile uint32_t*)0x50000004)
#define	IPGT			(*(volatile uint32_t*)0x50000008)
#define	IPGR			(*(volatile uint32_t*)0x5000000C)
#define	CLRT			(*(volatile uint32_t*)0x50000010)
#define	MAXF			(*(volatile uint32_t*)0x50000014)
#define	SUPP			(*(volatile uint32_t*)0x50000018)
#define	TEST			(*(volatile uint32_t*)0x5000001C)
#define	MCFG			(*(volatile uint32_t*)0x50000020)
#define	MCMD			(*(volatile uint32_t*)0x50000024)
#define	MADR			(*(volatile uint32_t*)0x50000028)
#define	MWTD			(*(volatile uint32_t*)0x5000002C)
#define	MRDD			(*(volatile uint32_t*)0x50000030)
#define	MIND			(*(volatile uint32_t*)0x50000034)
#define	SA0				(*(volatile uint32_t*)0x50000040)
#define	SA1				(*(volatile uint32_t*)0x50000044)
#define	SA2				(*(volatile uint32_t*)0x50000048)
#define	Command			(*(volatile uint32_t*)0x50000100)
#define	Status			(*(volatile uint32_t*)0x50000104)
#define	RxDescriptor	(*(volatile uint32_t*)0x50000108)
#define	RxStatus		(*(volatile uint32_t*)0x5000010C)
#define	RxDescriptorNumber	(*(volatile uint32_t*)0x50000110)
#define	RxProduceIndex	(*(volatile uint32_t*)0x50000114)
#define	RxConsumeIndex	(*(volatile uint32_t*)0x50000118)
#define	TxDescriptor	(*(volatile uint32_t*)0x5000011C)
#define	TxStatus		(*(volatile uint32_t*)0x50000120)
#define	TxDescriptorNumber	(*(volatile uint32_t*)0x50000124)
#define	TxProduceIndex	(*(volatile uint32_t*)0x50000128)
#define	TxConsumeIndex	(*(volatile uint32_t*)0x5000012C)
#define	TSV0			(*(volatile uint32_t*)0x50000158)
#define	TSV1			(*(volatile uint32_t*)0x5000015C)
#define	RSV				(*(volatile uint32_t*)0x50000160)
#define	FlowControlCounter	(*(volatile uint32_t*)0x50000170)
#define	FlowControlStatus	(*(volatile uint32_t*)0x50000174)
#define	RxFliterCtrl		(*(volatile uint32_t*)0x50000200)
#define	RxFilterWoLStatus	(*(volatile uint32_t*)0x50000204)
#define	RxFilterWoLClear	(*(volatile uint32_t*)0x50000208)
#define	HashFilterL		(*(volatile uint32_t*)0x50000210)
#define	HashFilterH		(*(volatile uint32_t*)0x50000214)
#define	IntStatus		(*(volatile uint32_t*)0x50000FE0)
#define	IntEnable		(*(volatile uint32_t*)0x50000FE4)
#define	IntClear		(*(volatile uint32_t*)0x50000FE8)
#define	IntSet			(*(volatile uint32_t*)0x50000FEC)
#define	PowerDown		(*(volatile uint32_t*)0x50000FF4)

/* USB Device */
#define	USBClkCtrl		(*(volatile uint32_t*)0x5000CFF4)
#define	USBClkSt		(*(volatile uint32_t*)0x5000CFF8)
#define	USBIntSt		(*(volatile uint32_t*)0x400FC1C0)
#define	USBDevIntSt		(*(volatile uint32_t*)0x5000C200)
#define	USBDevIntEn		(*(volatile uint32_t*)0x5000C204)
#define	USBDevIntClr	(*(volatile uint32_t*)0x5000C208)
#define	USBDevIntSet	(*(volatile uint32_t*)0x5000C20C)
#define	USBDevIntPri	(*(volatile uint32_t*)0x5000C22C)
#define	USBEpIntSt		(*(volatile uint32_t*)0x5000C230)
#define	USBEpIntEn		(*(volatile uint32_t*)0x5000C234)
#define	USBEpIntClr		(*(volatile uint32_t*)0x5000C238)
#define	USBEpIntSet		(*(volatile uint32_t*)0x5000C23C)
#define	USBEpIntPri		(*(volatile uint32_t*)0x5000C240)
#define	USBReEp			(*(volatile uint32_t*)0x5000C244)
#define	USBEpIn			(*(volatile uint32_t*)0x5000C248)
#define	USBMaxPSize		(*(volatile uint32_t*)0x5000C24C)
#define	USBRxData		(*(volatile uint32_t*)0x5000C218)
#define	USBRxPLen		(*(volatile uint32_t*)0x5000C220)
#define	USBTxData		(*(volatile uint32_t*)0x5000C21C)
#define	USBTxPLen		(*(volatile uint32_t*)0x5000C224)
#define	USBCtrl			(*(volatile uint32_t*)0x5000C228)
#define	USBCmdCode		(*(volatile uint32_t*)0x5000C210)
#define	USBCmdData		(*(volatile uint32_t*)0x5000C214)
#define	USBDMARSt		(*(volatile uint32_t*)0x5000C250)
#define	USBDMARClr		(*(volatile uint32_t*)0x5000C254)
#define	USBDMARSet		(*(volatile uint32_t*)0x5000C258)
#define	USBUDCAH		(*(volatile uint32_t*)0x5000C280)
#define	USBEpDMASt		(*(volatile uint32_t*)0x5000C284)
#define	USBEpDMAEn		(*(volatile uint32_t*)0x5000C288)
#define	USBEpDMADis		(*(volatile uint32_t*)0x5000C28C)
#define	USBDMAIntSt		(*(volatile uint32_t*)0x5000C290)
#define	USBDMAIntEn		(*(volatile uint32_t*)0x5000C294)
#define	USBEoTIntSt		(*(volatile uint32_t*)0x5000C2A0)
#define	USBEoTIntClr	(*(volatile uint32_t*)0x5000C2A4)
#define	USBEoTIntSet	(*(volatile uint32_t*)0x5000C2A8)
#define	USBNDDRIntSt	(*(volatile uint32_t*)0x5000C2AC)
#define	USBNDDRIntClr	(*(volatile uint32_t*)0x5000C2B0)
#define	USBNDDRIntSet	(*(volatile uint32_t*)0x5000C2B4)
#define	USBSysErrIntSt	(*(volatile uint32_t*)0x5000C2B8)
#define	USBSysErrIntClr	(*(volatile uint32_t*)0x5000C2BC)
#define	USBSysErrIntSet	(*(volatile uint32_t*)0x5000C2C0)

/* USB OTG */
#define	USBIntSt	(*(volatile uint32_t*)0x400FC1C0)
#define	OTGIntSt	(*(volatile uint32_t*)0x5000C100)
#define	OTGIntEn	(*(volatile uint32_t*)0x5000C104)
#define	OTGIntSet	(*(volatile uint32_t*)0x5000C108)
#define	OTGIntClr	(*(volatile uint32_t*)0x5000C10C)
#define	OTGStCtrl	(*(volatile uint32_t*)0x5000C110)
#define	OTGTmr		(*(volatile uint32_t*)0x5000C114)
#define	I2C_RX		(*(volatile uint32_t*)0x5000C300)
#define	I2C_TX		(*(volatile uint32_t*)0x5000C300)
#define	I2C_STS		(*(volatile uint32_t*)0x5000C304)
#define	I2C_CTL		(*(volatile uint32_t*)0x5000C308)
#define	I2C_CLKHI	(*(volatile uint32_t*)0x5000C30C)
#define	I2C_CLKLO	(*(volatile uint32_t*)0x5000C310)
#define	OTGClkCtrl	(*(volatile uint32_t*)0x5000CFF4)
#define	OTGClkSt	(*(volatile uint32_t*)0x5000CFF8)

/* UART0,UART1,UART2,UART3 */
#define	U0RBR		(*(volatile uint32_t*)0x4000C000)
#define	U0THR		(*(volatile uint32_t*)0x4000C000)
#define	U0DLL		(*(volatile uint32_t*)0x4000C000)
#define	U0DLM		(*(volatile uint32_t*)0x4000C004)
#define	U0IER		(*(volatile uint32_t*)0x4000C004)
#define	U0IIR		(*(volatile uint32_t*)0x4000C008)
#define	U0FCR		(*(volatile uint32_t*)0x4000C008)
#define	U0LCR		(*(volatile uint32_t*)0x4000C00C)
#define	U0LSR		(*(volatile uint32_t*)0x4000C014)
#define	U0SCR		(*(volatile uint32_t*)0x4000C01C)
#define	U0ACR		(*(volatile uint32_t*)0x4000C020)
#define	U0ICR		(*(volatile uint32_t*)0x4000C024)
#define	U0FDR		(*(volatile uint32_t*)0x4000C028)
#define	U0TER		(*(volatile uint32_t*)0x4000C030)

#define	U1RBR		(*(volatile uint32_t*)0x40010000)
#define	U1THR		(*(volatile uint32_t*)0x40010000)
#define	U1DLL		(*(volatile uint32_t*)0x40010000)
#define	U1DLM		(*(volatile uint32_t*)0x40010004)
#define	U1IER		(*(volatile uint32_t*)0x40010004)
#define	U1IIR		(*(volatile uint32_t*)0x40010008)
#define	U1FCR		(*(volatile uint32_t*)0x40010008)
#define	U1LCR		(*(volatile uint32_t*)0x4001000C)
#define	U1MCR		(*(volatile uint32_t*)0x40010010)
#define	U1LSR		(*(volatile uint32_t*)0x40010014)
#define	U1MSR		(*(volatile uint32_t*)0x40010018)
#define	U1SCR		(*(volatile uint32_t*)0x4001001C)
#define	U1ACR		(*(volatile uint32_t*)0x40010020)
#define	U1FDR		(*(volatile uint32_t*)0x40010028)
#define	U1TER		(*(volatile uint32_t*)0x40010030)
#define	U1RS485CTRL	(*(volatile uint32_t*)0x4001004C)
#define	U1ADRMATCH	(*(volatile uint32_t*)0x40010050)
#define	U1RS485DLY	(*(volatile uint32_t*)0x40010054)

#define	U2RBR		(*(volatile uint32_t*)0x40098000)
#define	U2THR		(*(volatile uint32_t*)0x40098000)
#define	U2DLL		(*(volatile uint32_t*)0x40098000)
#define	U2DLM		(*(volatile uint32_t*)0x40098004)
#define	U2IER		(*(volatile uint32_t*)0x40098004)
#define	U2IIR		(*(volatile uint32_t*)0x40098008)
#define	U2FCR		(*(volatile uint32_t*)0x40098008)
#define	U2LCR		(*(volatile uint32_t*)0x4009800C)
#define	U2LSR		(*(volatile uint32_t*)0x40098014)
#define	U2SCR		(*(volatile uint32_t*)0x4009801C)
#define	U2ACR		(*(volatile uint32_t*)0x40098020)
#define	U2ICR		(*(volatile uint32_t*)0x40098024)
#define	U2FDR		(*(volatile uint32_t*)0x40098028)
#define	U2TER		(*(volatile uint32_t*)0x40098030)

#define	U3RBR		(*(volatile uint32_t*)0x4009C000)
#define	U3THR		(*(volatile uint32_t*)0x4009C000)
#define	U3DLL		(*(volatile uint32_t*)0x4009C000)
#define	U3DLM		(*(volatile uint32_t*)0x4009C004)
#define	U3IER		(*(volatile uint32_t*)0x4009C004)
#define	U3IIR		(*(volatile uint32_t*)0x4009C008)
#define	U3FCR		(*(volatile uint32_t*)0x4009C008)
#define	U3LCR		(*(volatile uint32_t*)0x4009C00C)
#define	U3LSR		(*(volatile uint32_t*)0x4009C014)
#define	U3SCR		(*(volatile uint32_t*)0x4009C01C)
#define	U3ACR		(*(volatile uint32_t*)0x4009C020)
#define	U3ICR		(*(volatile uint32_t*)0x4009C024)
#define	U3FDR		(*(volatile uint32_t*)0x4009C028)
#define	U3TER		(*(volatile uint32_t*)0x4009C030)

/* CAN1,CAN2 */
#define	AFMR		(*(volatile uint32_t*)0x4003C000)
#define	SFF_sa		(*(volatile uint32_t*)0x4003C004)
#define	SFF_GRP_sa	(*(volatile uint32_t*)0x4003C008)
#define	EFF_sa		(*(volatile uint32_t*)0x4003C00C)
#define	EFF_GRP_sa	(*(volatile uint32_t*)0x4003C010)
#define	ENDofTable	(*(volatile uint32_t*)0x4003C014)
#define	LUTerrAd	(*(volatile uint32_t*)0x4003C018)
#define	LUTerr		(*(volatile uint32_t*)0x4003C01C)

#define	CANTxSR		(*(volatile uint32_t*)0x40040000)
#define	CANRxSR		(*(volatile uint32_t*)0x40040004)
#define	CANMSR		(*(volatile uint32_t*)0x40040008)
#define	CAN1MOD		(*(volatile uint32_t*)0x40044000)
#define	CAN1CMR		(*(volatile uint32_t*)0x40044004)
#define	CAN1GSR		(*(volatile uint32_t*)0x40044008)
#define	CAN1ICR		(*(volatile uint32_t*)0x4004400C)
#define	CAN1IER		(*(volatile uint32_t*)0x40044010)
#define	CAN1BTR		(*(volatile uint32_t*)0x40044014)
#define	CAN1EWL		(*(volatile uint32_t*)0x40044018)
#define	CAN1SR		(*(volatile uint32_t*)0x4004401C)
#define	CAN1RFS		(*(volatile uint32_t*)0x40044020)
#define	CAN1RID		(*(volatile uint32_t*)0x40044024)
#define	CAN1RDA		(*(volatile uint32_t*)0x40044028)
#define	CAN1RDB		(*(volatile uint32_t*)0x4004402C)
#define	CAN1TFI1	(*(volatile uint32_t*)0x40044030)
#define	CAN1TID1	(*(volatile uint32_t*)0x40044034)
#define	CAN1TDA1	(*(volatile uint32_t*)0x40044038)
#define	CAN1TDB1	(*(volatile uint32_t*)0x4004403C)
#define	CAN1TFI2	(*(volatile uint32_t*)0x40044040)
#define	CAN1TID2	(*(volatile uint32_t*)0x40044044)
#define	CAN1TDA2	(*(volatile uint32_t*)0x40044048)
#define	CAN1TDB2	(*(volatile uint32_t*)0x4004404C)
#define	CAN1TFI3	(*(volatile uint32_t*)0x40044050)
#define	CAN1TID3	(*(volatile uint32_t*)0x40044054)
#define	CAN1TDA3	(*(volatile uint32_t*)0x40044058)
#define	CAN1TDB3	(*(volatile uint32_t*)0x4004405C)

#define	CAN2MOD		(*(volatile uint32_t*)0x40048000)
#define	CAN2CMR		(*(volatile uint32_t*)0x40048004)
#define	CAN2GSR		(*(volatile uint32_t*)0x40048008)
#define	CAN2ICR		(*(volatile uint32_t*)0x4004800C)
#define	CAN2IER		(*(volatile uint32_t*)0x40048010)
#define	CAN2BTR		(*(volatile uint32_t*)0x40048014)
#define	CAN2EWL		(*(volatile uint32_t*)0x40048018)
#define	CAN2SR		(*(volatile uint32_t*)0x4004801C)
#define	CAN2RFS		(*(volatile uint32_t*)0x40048020)
#define	CAN2RID		(*(volatile uint32_t*)0x40048024)
#define	CAN2RDA		(*(volatile uint32_t*)0x40048028)
#define	CAN2RDB		(*(volatile uint32_t*)0x4004802C)
#define	CAN2TFI1	(*(volatile uint32_t*)0x40048030)
#define	CAN2TID1	(*(volatile uint32_t*)0x40048034)
#define	CAN2TDA1	(*(volatile uint32_t*)0x40048038)
#define	CAN2TDB1	(*(volatile uint32_t*)0x4004803C)
#define	CAN2TFI2	(*(volatile uint32_t*)0x40048040)
#define	CAN2TID2	(*(volatile uint32_t*)0x40048044)
#define	CAN2TDA2	(*(volatile uint32_t*)0x40048048)
#define	CAN2TDB2	(*(volatile uint32_t*)0x4004804C)
#define	CAN2TFI3	(*(volatile uint32_t*)0x40048050)
#define	CAN2TID3	(*(volatile uint32_t*)0x40048054)
#define	CAN2TDA3	(*(volatile uint32_t*)0x40048058)
#define	CAN2TDB3	(*(volatile uint32_t*)0x4004805C)

/* SPI0 */
#define	S0SPCR		(*(volatile uint32_t*)0x40020000)
#define	S0SPSR		(*(volatile uint32_t*)0x40020004)
#define	S0SPDR		(*(volatile uint32_t*)0x40020008)
#define	S0SPCCR		(*(volatile uint32_t*)0x4002000C)
#define	S0SPINT		(*(volatile uint32_t*)0x4002001C)

/* SSP0,SSP1 */
#define	SSP0CR0		(*(volatile uint32_t*)0x40088000)
#define	SSP0CR1		(*(volatile uint32_t*)0x40088004)
#define	SSP0DR		(*(volatile uint32_t*)0x40088008)
#define	SSP0SR		(*(volatile uint32_t*)0x4008800C)
#define	SSP0CPSR	(*(volatile uint32_t*)0x40088010)
#define	SSP0IMSC	(*(volatile uint32_t*)0x40088014)
#define	SSP0RIS		(*(volatile uint32_t*)0x40088018)
#define	SSP0MIS		(*(volatile uint32_t*)0x4008801C)
#define	SSP0ICR		(*(volatile uint32_t*)0x40088020)
#define	SSP0DMACR	(*(volatile uint32_t*)0x40088024)
#define	SSP1CR0		(*(volatile uint32_t*)0x40030000)
#define	SSP1CR1		(*(volatile uint32_t*)0x40030004)
#define	SSP1DR		(*(volatile uint32_t*)0x40030008)
#define	SSP1SR		(*(volatile uint32_t*)0x4003000C)
#define	SSP1CPSR	(*(volatile uint32_t*)0x40030010)
#define	SSP1IMSC	(*(volatile uint32_t*)0x40030014)
#define	SSP1RIS		(*(volatile uint32_t*)0x40030018)
#define	SSP1MIS		(*(volatile uint32_t*)0x4003001C)
#define	SSP1ICR		(*(volatile uint32_t*)0x40030020)
#define	SSP1DMACR	(*(volatile uint32_t*)0x40030024)

/* I2C0,I2C1,I2C2 */
#define	I2C0CONSET		(*(volatile uint32_t*)0x4001C000)
#define	I2C0STAT		(*(volatile uint32_t*)0x4001C004)
#define	I2C0DAT			(*(volatile uint32_t*)0x4001C008)
#define	I2C0ADR0		(*(volatile uint32_t*)0x4001C00C)
#define	I2C0SCLH		(*(volatile uint32_t*)0x4001C010)
#define	I2C0SCLL		(*(volatile uint32_t*)0x4001C014)
#define	I2C0CONCLR		(*(volatile uint32_t*)0x4001C018)
#define	I2C0MMCTRL		(*(volatile uint32_t*)0x4001C01C)
#define	I2C0ADR1		(*(volatile uint32_t*)0x4001C020)
#define	I2C0ADR2		(*(volatile uint32_t*)0x4001C024)
#define	I2C0ADR3		(*(volatile uint32_t*)0x4001C028)
#define	I2C0DATA_BUFFER	(*(volatile uint32_t*)0x4001C02C)
#define	I2C0MASK		( (volatile uint32_t*)0x4001C030)
#define	I2C0MASK0		(*(volatile uint32_t*)0x4001C030)
#define	I2C0MASK1		(*(volatile uint32_t*)0x4001C034)
#define	I2C0MASK2		(*(volatile uint32_t*)0x4001C038)
#define	I2C0MASK3		(*(volatile uint32_t*)0x4001C03C)
#define	I2C1CONSET		(*(volatile uint32_t*)0x4005C000)
#define	I2C1STAT		(*(volatile uint32_t*)0x4005C004)
#define	I2C1DAT			(*(volatile uint32_t*)0x4005C008)
#define	I2C1ADR0		(*(volatile uint32_t*)0x4005C00C)
#define	I2C1SCLH		(*(volatile uint32_t*)0x4005C010)
#define	I2C1SCLL		(*(volatile uint32_t*)0x4005C014)
#define	I2C1CONCLR		(*(volatile uint32_t*)0x4005C018)
#define	I2C1MMCTRL		(*(volatile uint32_t*)0x4005C01C)
#define	I2C1ADR1		(*(volatile uint32_t*)0x4005C020)
#define	I2C1ADR2		(*(volatile uint32_t*)0x4005C024)
#define	I2C1ADR3		(*(volatile uint32_t*)0x4005C028)
#define	I2C1DATA_BUFFER	(*(volatile uint32_t*)0x4005C02C)
#define	I2C1MASK		( (volatile uint32_t*)0x4005C030)
#define	I2C1MASK0		(*(volatile uint32_t*)0x4005C030)
#define	I2C1MASK1		(*(volatile uint32_t*)0x4005C034)
#define	I2C1MASK2		(*(volatile uint32_t*)0x4005C038)
#define	I2C1MASK3		(*(volatile uint32_t*)0x4005C03C)
#define	I2C2CONSET		(*(volatile uint32_t*)0x400A0000)
#define	I2C2STAT		(*(volatile uint32_t*)0x400A0004)
#define	I2C2DAT			(*(volatile uint32_t*)0x400A0008)
#define	I2C2ADR0		(*(volatile uint32_t*)0x400A000C)
#define	I2C2SCLH		(*(volatile uint32_t*)0x400A0010)
#define	I2C2SCLL		(*(volatile uint32_t*)0x400A0014)
#define	I2C2CONCLR		(*(volatile uint32_t*)0x400A0018)
#define	I2C2MMCTRL		(*(volatile uint32_t*)0x400A001C)
#define	I2C2ADR1		(*(volatile uint32_t*)0x400A0020)
#define	I2C2ADR2		(*(volatile uint32_t*)0x400A0024)
#define	I2C2ADR3		(*(volatile uint32_t*)0x400A0028)
#define	I2C2DATA_BUFFER	(*(volatile uint32_t*)0x400A002C)
#define	I2C2MASK		( (volatile uint32_t*)0x400A0030)
#define	I2C2MASK0		(*(volatile uint32_t*)0x400A0030)
#define	I2C2MASK1		(*(volatile uint32_t*)0x400A0034)
#define	I2C2MASK2		(*(volatile uint32_t*)0x400A0038)
#define	I2C2MASK3		(*(volatile uint32_t*)0x400A003C)

/* I2S */
#define	I2SDAO		(*(volatile uint32_t*)0x400A8000)
#define	I2SDAI		(*(volatile uint32_t*)0x400A8004)
#define	I2STXFIFO	(*(volatile uint32_t*)0x400A8008)
#define	I2SRXFIFO	(*(volatile uint32_t*)0x400A800C)
#define	I2SSTATE	(*(volatile uint32_t*)0x400A8010)
#define	I2SDMA1		(*(volatile uint32_t*)0x400A8014)
#define	I2SDMA2		(*(volatile uint32_t*)0x400A8018)
#define	I2SIRQ		(*(volatile uint32_t*)0x400A801C)
#define	I2STXRATE	(*(volatile uint32_t*)0x400A8020)
#define	I2SRXRATE	(*(volatile uint32_t*)0x400A8024)
#define	I2STXBITRATE	(*(volatile uint32_t*)0x400A8028)
#define	I2SRXBITRATE	(*(volatile uint32_t*)0x400A802C)
#define	I2STXMODE	(*(volatile uint32_t*)0x400A8030)
#define	I2SRXMODE	(*(volatile uint32_t*)0x400A8034)

/* Timer0,Timer1,Timer2,Timer3 */
#define	T0IR		(*(volatile uint32_t*)0x40004000)
#define	T0TCR		(*(volatile uint32_t*)0x40004004)
#define	T0TC		(*(volatile uint32_t*)0x40004008)
#define	T0PR		(*(volatile uint32_t*)0x4000400C)
#define	T0PC		(*(volatile uint32_t*)0x40004010)
#define	T0MCR		(*(volatile uint32_t*)0x40004014)
#define	T0MR		( (volatile uint32_t*)0x40004018)
#define	T0MR0		(*(volatile uint32_t*)0x40004018)
#define	T0MR1		(*(volatile uint32_t*)0x4000401C)
#define	T0MR2		(*(volatile uint32_t*)0x40004020)
#define	T0MR3		(*(volatile uint32_t*)0x40004024)
#define	T0CCR		(*(volatile uint32_t*)0x40004028)
#define	T0CR0		(*(volatile uint32_t*)0x4000402C)
#define	T0CR1		(*(volatile uint32_t*)0x40004030)
#define	T0EMR		(*(volatile uint32_t*)0x4000403C)
#define	T0CTCR		(*(volatile uint32_t*)0x40004070)

#define	T1IR		(*(volatile uint32_t*)0x40008000)
#define	T1TCR		(*(volatile uint32_t*)0x40008004)
#define	T1TC		(*(volatile uint32_t*)0x40008008)
#define	T1PR		(*(volatile uint32_t*)0x4000800C)
#define	T1PC		(*(volatile uint32_t*)0x40008010)
#define	T1MCR		(*(volatile uint32_t*)0x40008014)
#define	T1MR		( (volatile uint32_t*)0x40008018)
#define	T1MR0		(*(volatile uint32_t*)0x40008018)
#define	T1MR1		(*(volatile uint32_t*)0x4000801C)
#define	T1MR2		(*(volatile uint32_t*)0x40008020)
#define	T1MR3		(*(volatile uint32_t*)0x40008024)
#define	T1CCR		(*(volatile uint32_t*)0x40008028)
#define	T1CR0		(*(volatile uint32_t*)0x4000802C)
#define	T1CR1		(*(volatile uint32_t*)0x40008030)
#define	T1EMR		(*(volatile uint32_t*)0x4000803C)
#define	T1CTCR		(*(volatile uint32_t*)0x40008070)

#define	T2IR		(*(volatile uint32_t*)0x40090000)
#define	T2TCR		(*(volatile uint32_t*)0x40090004)
#define	T2TC		(*(volatile uint32_t*)0x40090008)
#define	T2PR		(*(volatile uint32_t*)0x4009000C)
#define	T2PC		(*(volatile uint32_t*)0x40090010)
#define	T2MCR		(*(volatile uint32_t*)0x40090014)
#define	T2MR		( (volatile uint32_t*)0x40090018)
#define	T2MR0		(*(volatile uint32_t*)0x40090018)
#define	T2MR1		(*(volatile uint32_t*)0x4009001C)
#define	T2MR2		(*(volatile uint32_t*)0x40090020)
#define	T2MR3		(*(volatile uint32_t*)0x40090024)
#define	T2CCR		(*(volatile uint32_t*)0x40090028)
#define	T2CR0		(*(volatile uint32_t*)0x4009002C)
#define	T2CR1		(*(volatile uint32_t*)0x40090030)
#define	T2EMR		(*(volatile uint32_t*)0x4009003C)
#define	T2CTCR		(*(volatile uint32_t*)0x40090070)

#define	T3IR		(*(volatile uint32_t*)0x40094000)
#define	T3TCR		(*(volatile uint32_t*)0x40094004)
#define	T3TC		(*(volatile uint32_t*)0x40094008)
#define	T3PR		(*(volatile uint32_t*)0x4009400C)
#define	T3PC		(*(volatile uint32_t*)0x40094010)
#define	T3MCR		(*(volatile uint32_t*)0x40094014)
#define	T3MR		( (volatile uint32_t*)0x40094018)
#define	T3MR0		(*(volatile uint32_t*)0x40094018)
#define	T3MR1		(*(volatile uint32_t*)0x4009401C)
#define	T3MR2		(*(volatile uint32_t*)0x40094020)
#define	T3MR3		(*(volatile uint32_t*)0x40094024)
#define	T3CCR		(*(volatile uint32_t*)0x40094028)
#define	T3CR0		(*(volatile uint32_t*)0x4009402C)
#define	T3CR1		(*(volatile uint32_t*)0x40094030)
#define	T3EMR		(*(volatile uint32_t*)0x4009403C)
#define	T3CTCR		(*(volatile uint32_t*)0x40094070)

/* Repeative Interrupt Timer */
#define	RICOMPVAL	(*(volatile uint32_t*)0x400B0000)
#define	RIMASK		(*(volatile uint32_t*)0x400B0004)
#define	RICTRL		(*(volatile uint32_t*)0x400B0008)
#define	RICOUNTER	(*(volatile uint32_t*)0x400B000C)

/* PWM1 */
#define	PWM1IR		(*(volatile uint32_t*)0x40018000)
#define	PWM1TCR		(*(volatile uint32_t*)0x40018004)
#define	PWM1TC		(*(volatile uint32_t*)0x40018008)
#define	PWM1PR		(*(volatile uint32_t*)0x4001800C)
#define	PWM1PC		(*(volatile uint32_t*)0x40018010)
#define	PWM1MCR		(*(volatile uint32_t*)0x40018014)
#define	PWM1MR0		(*(volatile uint32_t*)0x40018018)
#define	PWM1MR1		(*(volatile uint32_t*)0x4001801C)
#define	PWM1MR2		(*(volatile uint32_t*)0x40018020)
#define	PWM1MR3		(*(volatile uint32_t*)0x40018024)
#define	PWM1CCR		(*(volatile uint32_t*)0x40018028)
#define	PWM1CR0		(*(volatile uint32_t*)0x4001802C)
#define	PWM1CR1		(*(volatile uint32_t*)0x40018030)
#define	PWM1CR2		(*(volatile uint32_t*)0x40018034)
#define	PWM1CR3		(*(volatile uint32_t*)0x40018038)
#define	PWM1MR4		(*(volatile uint32_t*)0x40018040)
#define	PWM1MR5		(*(volatile uint32_t*)0x40018044)
#define	PWM1MR6		(*(volatile uint32_t*)0x40018048)
#define	PWM1PCR		(*(volatile uint32_t*)0x4001804C)
#define	PWM1LER		(*(volatile uint32_t*)0x40018050)
#define	PWM1CTCR	(*(volatile uint32_t*)0x40018070)

/* Motor Control PWM */
#define	MCCON		(*(volatile uint32_t*)0x400B8000)
#define	MCCON_SET	(*(volatile uint32_t*)0x400B8004)
#define	MCCON_CLR	(*(volatile uint32_t*)0x400B8008)
#define	MCCAPCON	(*(volatile uint32_t*)0x400B800C)
#define	MCCAPCON_SET	(*(volatile uint32_t*)0x400B8010)
#define	MCCAPCON_CLR	(*(volatile uint32_t*)0x400B8014)
#define	MCTC		( (volatile uint32_t*)0x400B8018)
#define	MCTC0		(*(volatile uint32_t*)0x400B8018)
#define	MCTC1		(*(volatile uint32_t*)0x400B801C)
#define	MCTC2		(*(volatile uint32_t*)0x400B8020)
#define	MCLIM		( (volatile uint32_t*)0x400B8024)
#define	MCLIM0		(*(volatile uint32_t*)0x400B8024)
#define	MCLIM1		(*(volatile uint32_t*)0x400B8028)
#define	MCLIM2		(*(volatile uint32_t*)0x400B802C)
#define	MCMAT		( (volatile uint32_t*)0x400B8030)
#define	MCMAT0		(*(volatile uint32_t*)0x400B8030)
#define	MCMAT1		(*(volatile uint32_t*)0x400B8034)
#define	MCMAT2		(*(volatile uint32_t*)0x400B8038)
#define	MCDT		(*(volatile uint32_t*)0x400B803C)
#define	MCCP		(*(volatile uint32_t*)0x400B8040)
#define	MCCAP		( (volatile uint32_t*)0x400B8044)
#define	MCCAP0		(*(volatile uint32_t*)0x400B8044)
#define	MCCAP1		(*(volatile uint32_t*)0x400B8048)
#define	MCCAP2		(*(volatile uint32_t*)0x400B804C)
#define	MCINTEN		(*(volatile uint32_t*)0x400B8050)
#define	MCINTEN_SET	(*(volatile uint32_t*)0x400B8054)
#define	MCINTEN_CLR	(*(volatile uint32_t*)0x400B8058)
#define	MCCNTCON	(*(volatile uint32_t*)0x400B805C)
#define	MCCNTCON_SET	(*(volatile uint32_t*)0x400B8060)
#define	MCCNTCON_CLR	(*(volatile uint32_t*)0x400B8064)
#define	MCINTF		(*(volatile uint32_t*)0x400B8068)
#define	MCINTF_SET	(*(volatile uint32_t*)0x400B806C)
#define	MCINTF_CLR	(*(volatile uint32_t*)0x400B8070)
#define	MCCAP_CLR	(*(volatile uint32_t*)0x400B8074)

/* Quadrature Encoder Interface */
#define	QEICON		(*(volatile uint32_t*)0x400BC000)
#define	QEICONF		(*(volatile uint32_t*)0x400BC008)
#define	QEISTAT		(*(volatile uint32_t*)0x400BC004)
#define	QEIPOS		(*(volatile uint32_t*)0x400BC00C)
#define	QEIMAXPOS	(*(volatile uint32_t*)0x400BC010)
#define	CMPOS0		(*(volatile uint32_t*)0x400BC014)
#define	CMPOS1		(*(volatile uint32_t*)0x400BC018)
#define	CMPOS2		(*(volatile uint32_t*)0x400BC01C)
#define	INXCNT		(*(volatile uint32_t*)0x400BC020)
#define	INXCMP		(*(volatile uint32_t*)0x400BC024)
#define	QEILOAD		(*(volatile uint32_t*)0x400BC028)
#define	QEITIME		(*(volatile uint32_t*)0x400BC02C)
#define	QEIVEL		(*(volatile uint32_t*)0x400BC030)
#define	QEICAP		(*(volatile uint32_t*)0x400BC034)
#define	VELCOMP		(*(volatile uint32_t*)0x400BC038)
#define	FILTER		(*(volatile uint32_t*)0x400BC03C)
#define	QEIINTSTAT	(*(volatile uint32_t*)0x400BCFE0)
#define	QEISET		(*(volatile uint32_t*)0x400BCFEC)
#define	QEICLR		(*(volatile uint32_t*)0x400BCFE8)
#define	QEIIE		(*(volatile uint32_t*)0x400BCFE4)
#define	QEIIES		(*(volatile uint32_t*)0x400BCFDC)
#define	QEIIEC		(*(volatile uint32_t*)0x400BCFD8)

/* RTC */
#define	RTC_ILR		(*(volatile uint32_t*)0x40024000)
#define	RTC_CCR		(*(volatile uint32_t*)0x40024008)
#define	RTC_CIIR	(*(volatile uint32_t*)0x4002400C)
#define	RTC_AMR		(*(volatile uint32_t*)0x40024010)
#define	RTC_AUX		(*(volatile uint32_t*)0x4002405C)
#define	RTC_AUXEN	(*(volatile uint32_t*)0x40024058)
#define	RTC_CTIME0	(*(volatile uint32_t*)0x40024014)
#define	RTC_CTIME1	(*(volatile uint32_t*)0x40024018)
#define	RTC_CTIME2	(*(volatile uint32_t*)0x4002401C)
#define	RTC_SEC		(*(volatile uint32_t*)0x40024020)
#define	RTC_MIN		(*(volatile uint32_t*)0x40024024)
#define	RTC_HOUR	(*(volatile uint32_t*)0x40024028)
#define	RTC_DOM		(*(volatile uint32_t*)0x4002402C)
#define	RTC_DOW		(*(volatile uint32_t*)0x40024030)
#define	RTC_DOY		(*(volatile uint32_t*)0x40024034)
#define	RTC_MONTH	(*(volatile uint32_t*)0x40024038)
#define	RTC_YEAR	(*(volatile uint32_t*)0x4002403C)
#define	RTC_CALIBRATION	(*(volatile uint32_t*)0x40024040)
#define	RTC_GPREG	( (volatile uint32_t*)0x40024044)
#define	RTC_GPREG0	(*(volatile uint32_t*)0x40024044)
#define	RTC_GPREG1	(*(volatile uint32_t*)0x40024048)
#define	RTC_GPREG2	(*(volatile uint32_t*)0x4002404C)
#define	RTC_GPREG3	(*(volatile uint32_t*)0x40024050)
#define	RTC_GPREG4	(*(volatile uint32_t*)0x40024054)
#define	RTC_ALSEC	(*(volatile uint32_t*)0x40024060)
#define	RTC_ALMIN	(*(volatile uint32_t*)0x40024064)
#define	RTC_ALHOUR	(*(volatile uint32_t*)0x40024068)
#define	RTC_ALDOM	(*(volatile uint32_t*)0x4002406C)
#define	RTC_ALDOW	(*(volatile uint32_t*)0x40024070)
#define	RTC_ALDOY	(*(volatile uint32_t*)0x40024074)
#define	RTC_ALMON	(*(volatile uint32_t*)0x40024078)
#define	RTC_ALYEAR	(*(volatile uint32_t*)0x4002407C)

/* WDT */
#define	WDMOD		(*(volatile uint32_t*)0x40000000)
#define	WDTC		(*(volatile uint32_t*)0x40000004)
#define	WDFEED		(*(volatile uint32_t*)0x40000008)
#define	WDTV		(*(volatile uint32_t*)0x4000000C)
#define	WDCLKSEL	(*(volatile uint32_t*)0x40000010)

/* ADC0 */
#define	AD0CR		(*(volatile uint32_t*)0x40034000)
#define	AD0GDR		(*(volatile uint32_t*)0x40034004)
#define	AD0INTEN	(*(volatile uint32_t*)0x4003400C)
#define	AD0DR		( (volatile uint32_t*)0x40034010)
#define	AD0DR0		(*(volatile uint32_t*)0x40034010)
#define	AD0DR1		(*(volatile uint32_t*)0x40034014)
#define	AD0DR2		(*(volatile uint32_t*)0x40034018)
#define	AD0DR3		(*(volatile uint32_t*)0x4003401C)
#define	AD0DR4		(*(volatile uint32_t*)0x40034020)
#define	AD0DR5		(*(volatile uint32_t*)0x40034024)
#define	AD0DR6		(*(volatile uint32_t*)0x40034028)
#define	AD0DR7		(*(volatile uint32_t*)0x4003402C)
#define	AD0STAT		(*(volatile uint32_t*)0x40034030)
#define	AD0TRM		(*(volatile uint32_t*)0x40034034)

/* DAC */
#define	DACR		(*(volatile uint32_t*)0x4008C000)
#define	DACCTRL		(*(volatile uint32_t*)0x4008C004)
#define	DACCNTVAL	(*(volatile uint32_t*)0x4008C008)

/* GPDMA */
#define	DMACIntStat		(*(volatile uint32_t*)0x50004000)
#define	DMACIntTCStat	(*(volatile uint32_t*)0x50004004)
#define	DMACIntTCClear	(*(volatile uint32_t*)0x50004008)
#define	DMACIntErrStat	(*(volatile uint32_t*)0x5000400C)
#define	DMACIntErrClr	(*(volatile uint32_t*)0x50004010)
#define	DMACRawIntTCStat	(*(volatile uint32_t*)0x50004014)
#define	DMACRawIntErrStat	(*(volatile uint32_t*)0x50004018)
#define	DMACEnbldChns	(*(volatile uint32_t*)0x5000401C)
#define	DMACSoftBReq	(*(volatile uint32_t*)0x50004020)
#define	DMACSoftSReq	(*(volatile uint32_t*)0x50004024)
#define	DMACSoftLBReq	(*(volatile uint32_t*)0x50004028)
#define	DMACSoftLSReq	(*(volatile uint32_t*)0x5000402C)
#define	DMACConfig		(*(volatile uint32_t*)0x50004030)
#define	DMACSync		(*(volatile uint32_t*)0x50004034)
#define	DMAREQSEL		(*(volatile uint32_t*)0x400FC1C4)
#define	DMACC0SrcAddr	(*(volatile uint32_t*)0x50004100)
#define	DMACC0DestAddr	(*(volatile uint32_t*)0x50004104)
#define	DMACC0LLI		(*(volatile uint32_t*)0x50004108)
#define	DMACC0Control	(*(volatile uint32_t*)0x5000410C)
#define	DMACC0Config	(*(volatile uint32_t*)0x50004110)
#define	DMACC1SrcAddr	(*(volatile uint32_t*)0x50004120)
#define	DMACC1DestAddr	(*(volatile uint32_t*)0x50004124)
#define	DMACC1LLI		(*(volatile uint32_t*)0x50004128)
#define	DMACC1Control	(*(volatile uint32_t*)0x5000412C)
#define	DMACC1Config	(*(volatile uint32_t*)0x50004130)
#define	DMACC2SrcAddr	(*(volatile uint32_t*)0x50004140)
#define	DMACC2DestAddr	(*(volatile uint32_t*)0x50004144)
#define	DMACC2LLI		(*(volatile uint32_t*)0x50004148)
#define	DMACC2Control	(*(volatile uint32_t*)0x5000414C)
#define	DMACC2Config	(*(volatile uint32_t*)0x50004150)
#define	DMACC3SrcAddr	(*(volatile uint32_t*)0x50004160)
#define	DMACC3DestAddr	(*(volatile uint32_t*)0x50004164)
#define	DMACC3LLI		(*(volatile uint32_t*)0x50004168)
#define	DMACC3Control	(*(volatile uint32_t*)0x5000416C)
#define	DMACC3Config	(*(volatile uint32_t*)0x50004170)
#define	DMACC4SrcAddr	(*(volatile uint32_t*)0x50004180)
#define	DMACC4DestAddr	(*(volatile uint32_t*)0x50004184)
#define	DMACC4LLI		(*(volatile uint32_t*)0x50004188)
#define	DMACC4Control	(*(volatile uint32_t*)0x5000418C)
#define	DMACC4Config	(*(volatile uint32_t*)0x50004190)
#define	DMACC5SrcAddr	(*(volatile uint32_t*)0x500041A0)
#define	DMACC5DestAddr	(*(volatile uint32_t*)0x500041A4)
#define	DMACC5LLI		(*(volatile uint32_t*)0x500041A8)
#define	DMACC5Control	(*(volatile uint32_t*)0x500041AC)
#define	DMACC5Config	(*(volatile uint32_t*)0x500041B0)
#define	DMACC6SrcAddr	(*(volatile uint32_t*)0x500041C0)
#define	DMACC6DestAddr	(*(volatile uint32_t*)0x500041C4)
#define	DMACC6LLI		(*(volatile uint32_t*)0x500041C8)
#define	DMACC6Control	(*(volatile uint32_t*)0x500041CC)
#define	DMACC6Config	(*(volatile uint32_t*)0x500041D0)
#define	DMACC7SrcAddr	(*(volatile uint32_t*)0x500041E0)
#define	DMACC7DestAddr	(*(volatile uint32_t*)0x500041E4)
#define	DMACC7LLI		(*(volatile uint32_t*)0x500041E8)
#define	DMACC7Control	(*(volatile uint32_t*)0x500041EC)
#define	DMACC7Config	(*(volatile uint32_t*)0x500041F0)


/* Cortex-M3 System timer */
#define	SYST_CSR	(*(volatile uint32_t*)0xE000E010)
#define	SYST_RVR	(*(volatile uint32_t*)0xE000E014)
#define	SYST_CVR	(*(volatile uint32_t*)0xE000E018)
#define	SYST_CALIB	(*(volatile uint32_t*)0xE000E01C)

/* Cortex-M3 NVIC */
#define	ISER		( (volatile uint32_t*)0xE000E100)
#define	ICER		( (volatile uint32_t*)0xE000E180)
#define	ISPR		( (volatile uint32_t*)0xE000E200)
#define	ICPR		( (volatile uint32_t*)0xE000E280)
#define	IABR		( (volatile uint32_t*)0xE000E300)
#define	IPR			( (volatile uint8_t *)0xE000E400)
#define	STIR		(*(volatile uint32_t*)0xE000EF00)

/* Cortex-M3 SCB */
#define	ACTLR		(*(volatile uint32_t*)0xE000E008)
#define	CPUID		(*(volatile uint32_t*)0xE000ED00)
#define	ICSR		(*(volatile uint32_t*)0xE000ED04)
#define	VTOR		(*(volatile uint32_t*)0xE000ED08)
#define	AIRCR		(*(volatile uint32_t*)0xE000ED0C)
#define	SCR			(*(volatile uint32_t*)0xE000ED10)
#define	CCR			(*(volatile uint32_t*)0xE000ED14)
#define	SHPR		( (volatile uint8_t *)0xE000ED14)
#define	CFSR		(*(volatile uint32_t*)0xE000ED28)
#define	MMSR		(*(volatile uint32_t*)0xE000ED28)
#define	BFSR		(*(volatile uint32_t*)0xE000ED29)
#define	UFSR		(*(volatile uint32_t*)0xE000ED2A)
#define	HFSR		(*(volatile uint32_t*)0xE000ED2C)
#define	MMFAR		(*(volatile uint32_t*)0xE000ED34)
#define	BFAR		(*(volatile uint32_t*)0xE000ED38)



/*--------------------------------------------------------------*/
/* Cortex-M3 core/peripheral access macros                      */
/*--------------------------------------------------------------*/

/* These are for only privileged mode */
#define __enable_irq() asm volatile ("CPSIE i\n")
#define __disable_irq() asm volatile ("CPSID i\n")
#define __enable_irqn(n) ISER[(n) / 32] = 1 << ((n) % 32)
#define __disable_irqn(n) ICER[(n) / 32] = 1 << ((n) % 32)
#define __test_irqn_enabled(n) (ISER[(n) / 32] & (1 << ((n) % 32)))
#define __set_irqn(n) ISPR[(n) / 32] = 1 << ((n) % 32)
#define __clear_irqn(n) ICPR[(n) / 32] = 1 << ((n) % 32)
#define __test_irqn(n) (ICPR[(n) / 32] & (1 << ((n) % 32)))
#define __test_irqn_active(n) (IABR[n / 32] & (1 << ((n) % 32)))
#define __set_irqn_priority(n,v) IPR[n] = (v)
#define __set_faultn_priority(n,v) SHPR[(n) + 16] = (v)
#define __get_MSP()			({uint32_t __rv; asm ("MRS %0, MSP\n"		: "=r" (__rv)); __rv;})
#define __get_PSP()			({uint32_t __rv; asm ("MRS %0, PSP\n"		: "=r" (__rv)); __rv;})
#define __get_PRIMASK() 	({uint32_t __rv; asm ("MRS %0, PRIMASK\n"	: "=r" (__rv)); __rv;})
#define __get_FAULTMASK()	({uint32_t __rv; asm ("MRS %0, FAULTMASK\n"	: "=r" (__rv)); __rv;})
#define __get_BASEPRI() 	({uint32_t __rv; asm ("MRS %0, BASEPRI\n"	: "=r" (__rv)); __rv;})
#define __get_CONTROL()		({uint32_t __rv; asm ("MRS %0, CONTROL\n"	: "=r" (__rv)); __rv;})
#define __set_MSP(arg)		{uint32_t __v=arg; asm ("MSR MSP, %0\n" 		:: "r" (__v));}
#define __set_PSP(arg)		{uint32_t __v=arg; asm ("MSR PSP, %0\n" 		:: "r" (__v));}
#define __set_PRIMASK(arg)	{uint32_t __v=arg; asm ("MSR PRIMASK, %0\n" 	:: "r" (__v));}
#define __set_FAULTMASK(arg) {uint32_t __v=arg; asm ("MSR FAULTMASK, %0\n" 	:: "r" (__v));}
#define __set_BASEPRI(arg)	{uint32_t __v=arg; asm ("MSR BASEPRI, %0\n" 	:: "r" (__v));}
#define __set_CONTORL(arg)	{uint32_t __v=arg; asm ("MSR CONTROL, %0\nISB\n" :: "r" (__v));}

/* These functions and macros are alternative of above for user mode */
#if USE_SV_SERVICE
#define __enable_irq_user()		asm volatile ("SVC #0\n")	/* CPSIE i */
#define __disable_irq_user()	asm volatile ("SVC #1\n")	/* CPSID i */
#define __enable_irq_user()		asm volatile ("SVC #2\n")	/* CPSIE f */
#define __disable_irq_user()	asm volatile ("SVC #3\n")	/* CPSID f */
uint32_t __get_scs_reg (volatile uint32_t* reg);			/* Read a register in SCS */
void __set_scs_reg (volatile uint32_t* reg, uint32_t val);	/* Write a register in SCS */
#define __enable_irqn_user(n) __set_scs_reg(&ISER[((n) / 32)], 1 << ((n) % 32))
#define __disable_irqn_user(n) __set_scs_reg(&ISCR[((n) / 32)], 1 << ((n) % 32))
#define __test_irqn_enabled_user(n) (__get_scs_reg(&ISCR[(n) / 32]) & (1 << ((n) % 32)))
#define __set_irqn_user(n) __set_scs_reg(&ISPR[((n) / 32)], 1 << ((n) % 32))
#define __clear_irqn_user(n) __set_scs_reg(&ICPR[((n) / 32)], 1 << ((n) % 32))
#define __test_irqn_user(n) (__get_scs_reg(&ICPR[(n) / 32]) & (1 << ((n) % 32)))
#define __test_active_irqn_user(n) (__get_scs_reg(&IABR[(n) / 32]) & (1 << ((n) % 32)))
#define __set_irqn_priority_user(n,v) __set_scs_reg(&IPR[n], (v))
#define __set_faultn_priority_user(n,v) __set_scs_reg(&SHPR[(n) + 16], (v))
#endif

/* These functions/macros can be used at user/privileged mode */
#define __REV(arg)		({uint32_t __r, __v=arg; asm ("REV %0,%1\n"   : "=r" (__r) : "r" (__v) ); __r;})
#define __REV16(arg)	({uint32_t __r, __v=arg; asm ("REV16 %0,%1\n" : "=r" (__r) : "r" (__v) ); __r;})
#define __REVSH(arg)	({uint32_t __r, __v=arg; asm ("REVSH %0,%1\n" : "=r" (__r) : "r" (__v) ); __r;})
#define __RBIT(arg)		({uint32_t __r, __v=arg; asm ("RBIT %0,%1\n"  : "=r" (__r) : "r" (__v) ); __r;})
#define __LDREXB(p)		({uint8_t __r;	asm ("LDREXB %0,[%1]\n" : "=r" (__r) : "r" (p)); __r;})
#define __LDREXH(p)		({uint16_t __r;	asm ("LDREXH %0,[%1]\n" : "=r" (__r) : "r" (p)); __r;})
#define __LDREXW(p)		({uint32_t __r;	asm ("LDREX  %0,[%1]\n" : "=r" (__r) : "r" (p)); __r;})
#define __STREXB(d,p)	({register uint32_t __r asm("r2"); register uint8_t __d asm("r1") = d; register volatile uint8_t *__p asm("r0") = p; asm ("STREXB %0,%2,[%1]\n" : "=r" (__r) : "r" (__p), "r" (__d)); __r;})
#define __STREXH(d,p)	({register uint32_t __r asm("r2"); register uint16_t __d asm("r1") = d; register volatile uint16_t *__p asm("r0") = p; asm ("STREXH %0,%2,[%1]\n" : "=r" (__r) : "r" (p), "r" (__d)); __r;})
#define __STREXW(d,p)	({register uint32_t __r asm("r2"); register uint32_t __d asm("r1") = d; register volatile uint32_t *__p asm("r0") = p; asm ("STREX  %0,%2,[%1]\n" : "=r" (__r) : "r" (p), "r" (__d)); __r;})
#define __CLREX() asm volatile ("CLREX\n")
#define __SEV() asm volatile ("SEV\n")
#define __WFE() asm volatile ("WFE\n")
#define __WFI() asm volatile ("WFI\n")

/* LPC176x IRQ number */
#define	MemManage_IRQn	(-12)
#define	BusFault_IRQn	(-11)
#define	UsageFault_IRQn	(-10)
#define	SVC_IRQn		(-5)
#define	DebugMon_IRQn	(-4)
#define	PendSV_IRQn		(-2)
#define	SysTick_IRQn	(-1)
#define	WDT_IRQn		0
#define	TIMER0_IRQn		1
#define	TIMER1_IRQn		2
#define	TIMER2_IRQn		3
#define	TIMER3_IRQn		4
#define	UART0_IRQn		5
#define	UART1_IRQn		6
#define	UART2_IRQn		7
#define	UART3_IRQn		8
#define	PWM1_IRQn		9
#define	I2C0_IRQn		10
#define	I2C1_IRQn		11
#define	I2C2_IRQn		12
#define	SPI_IRQn		13
#define	SSP0_IRQn		14
#define	SSP1_IRQn		15
#define	PLL0_IRQn		16
#define	RTC_IRQn		17
#define	EINT0_IRQn		18
#define	EINT1_IRQn		19
#define	EINT2_IRQn		20
#define	EINT3_IRQn		21
#define	ADC_IRQn		22
#define	BOD_IRQn		23
#define	USB_IRQn		24
#define	CAN_IRQn		25
#define	GPDMA_IRQn		26
#define	I2S_IRQn		27
#define	ETHER_IRQn		28
#define	RIT_IRQn		29
#define	MCPWM_IRQn		30
#define	QEI_IRQn		31
#define	PLL1_IRQn		32
#define	USBACT_IRQn		33
#define	CANACT_IRQn		34

/* LPC176x Peripheral Divider */
#define	__set_PCLKSEL(p,v)	PCLKSEL[(p) / 16] = (PCLKSEL[(p) / 16] & ~(3 << ((p) * 2 % 32))) | (v << ((p) * 2 % 32))
#define PCLKDIV_4	0
#define PCLKDIV_1	1
#define PCLKDIV_2	2
#define PCLKDIV_8	3
#define	PCLK_WDT	0
#define	PCLK_TIMER0	1
#define	PCLK_TIMER1	2
#define	PCLK_UART0	3
#define	PCLK_UART1	4
#define	PCLK_PWM1	6
#define	PCLK_I2C0	7
#define	PCLK_SPI	8
#define	PCLK_SSP1	10
#define	PCLK_DAC	11
#define	PCLK_ADC	12
#define	PCLK_CAN1	13
#define	PCLK_CAN2	14
#define	PCLK_ACF	15
#define	PCLK_QEI	16
#define	PCLK_GPIOINT	17
#define	PCLK_PCB	18
#define	PCLK_I2C1	19
#define	PCLK_SSP0	21
#define	PCLK_TIMER2	22
#define	PCLK_TIMER3	23
#define	PCLK_UART2	24
#define	PCLK_UART3	25
#define	PCLK_I2C2	26
#define	PCLK_I2S	27
#define	PCLK_RIT	28
#define	PCLK_SYSCON	29
#define	PCLK_MC		30

/* LPC176x Pin Configuration */
#define __set_PINSEL(p,b,v)		PINSEL[(p) * 2 + (b) / 16] = (PINSEL[(p) * 2 + (b) / 16] & ~(3 << ((b) * 2 % 32))) | (v << ((b) * 2 % 32))
#define __set_PINMODE(p,b,v)	PINMODE[(p) * 2 + (b) / 16] = (PINMODE[(p) * 2 + (b) / 16] & ~(3 << ((b) * 2 % 32))) | (v << ((b) * 2 % 32))
#define __set_PINOD(p,b,v)		PINOD[p] = (PINOD[p] & ~(1 << (b))) | ((v) << (b))

/* LPC176x Power Control */
#define	__set_PCONP(p,v)	PCONP = (PCONP & ~(1 << (p))) | (1 << (p))
#define	PCTIM0	1
#define	PCTIM1	2
#define	PCUART0	3
#define	PCUART1	4
#define	PCPWM1	6
#define	PCIIC0	7
#define	PCSPI	8
#define	PCRTC	9
#define	PCSSP1	10
#define	PCADC	12
#define	PCCAN1	13
#define	PCCAN2	14
#define	PCGPIO	15
#define	PCRIT	16
#define	PCMCPWM	17
#define	PCQEI	18
#define	PCI2C1	19
#define	PCSSP0	21
#define	PCTIM2	22
#define	PCTIM3	23
#define	PCUART2	24
#define	PCUART3	25
#define	PCI2C2	26
#define	PCI2S	27
#define	PCGPDMA	29
#define	PCENET	30
#define	PCUSB	31


/*--------------------------------------------------------------*/
/* Misc Macros                                                  */
/*--------------------------------------------------------------*/


#define	_BV(bit) (1<<(bit))

#define	IMPORT_BIN(sect, file, sym) asm (\
		".section " #sect "\n"\
		".balign 4\n"\
		".global " #sym "\n"\
		#sym ":\n"\
		".incbin \"" file "\"\n"\
		".global _sizeof_" #sym "\n"\
		".set _sizeof_" #sym ", . - " #sym "\n"\
		".balign 4\n"\
		".section \".text\"\n")

#define	IMPORT_BIN_PART(sect, file, ofs, siz, sym) asm (\
		".section " #sect "\n"\
		".balign 4\n"\
		".global " #sym "\n"\
		#sym ":\n"\
		".incbin \"" file "\"," #ofs "," #siz "\n"\
		".global _sizeof_" #sym "\n"\
		".set _sizeof_" #sym ", . - " #sym "\n"\
		".balign 4\n"\
		".section \".text\"\n")

/* Jump to secondary application */
#define JUMP_APP(appvt) asm (\
		"LDR SP, [%0]\n"          /* Initialize SP */\
		"LDR PC, [%0, #4]\n"      /* Go to reset vector */\
        : : "r" (appvt))


#endif /* __LPC176x */