1144 lines
51 KiB
C
1144 lines
51 KiB
C
/*-------------------------------------------------------------------*/
|
|
/* 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 */
|