projekty/Source/example1/src/include/lpc2100/lpc21xx.h

Go to the documentation of this file.
00001 /******************************************************************************
00002  *
00003  * $RCSfile: $
00004  * $Revision: $
00005  *
00006  * Header file for Philips LPC21xx ARM Processors 
00007  * Copyright 2004 R O SoftWare
00008  *
00009  * No guarantees, warrantees, or promises, implied or otherwise.
00010  * May be used for hobby or commercial purposes provided copyright
00011  * notice remains intact.
00012  *
00013  *****************************************************************************/
00014 #ifndef INC_LPC21xx_H
00015 #define INC_LPC21xx_H
00016 
00017 #define REG_8           volatile unsigned char
00018 #define REG16           volatile unsigned short
00019 #define REG32           volatile unsigned long
00020 
00021 #include "lpc2100/lpcWD.h"
00022 #include "lpc2100/lpcTMR.h"
00023 #include "lpc2100/lpcUART.h"
00024 #include "lpc2100/lpcI2C.h"
00025 #include "lpc2100/lpcSPI.h"
00026 #include "lpc2100/lpcRTC.h"
00027 #include "lpc2100/lpcGPIO.h"
00028 #include "lpc2100/lpcPIN.h"
00029 #include "lpc2100/lpcADC.h"
00030 #include "lpc2100/lpcSCB.h"
00031 #include "lpc2100/lpcVIC.h"
00032 
00034 // Watchdog
00035 #define WD              ((wdRegs_t *)0xE0000000)
00036 
00037 // Watchdog Registers
00038 #define WDMOD           WD->mod         /* Watchdog Mode Register */
00039 #define WDTC            WD->tc          /* Watchdog Time Constant Register */
00040 #define WDFEED          WD->feed        /* Watchdog Feed Register */
00041 #define WDTV            WD->tv          /* Watchdog Time Value Register */
00042 
00044 // Timer 0
00045 #define TMR0            ((pwmTmrRegs_t *)0xE0004000)
00046 
00047 // Timer 0 Registers
00048 #define T0IR            TMR0->ir        /* Interrupt Register */
00049 #define T0TCR           TMR0->tcr       /* Timer Control Register */
00050 #define T0TC            TMR0->tc        /* Timer Counter */
00051 #define T0PR            TMR0->pr        /* Prescale Register */
00052 #define T0PC            TMR0->pc        /* Prescale Counter Register */
00053 #define T0MCR           TMR0->mcr       /* Match Control Register */
00054 #define T0MR0           TMR0->mr0       /* Match Register 0 */
00055 #define T0MR1           TMR0->mr1       /* Match Register 1 */
00056 #define T0MR2           TMR0->mr2       /* Match Register 2 */
00057 #define T0MR3           TMR0->mr3       /* Match Register 3 */
00058 #define T0CCR           TMR0->ccr       /* Capture Control Register */
00059 #define T0CR0           TMR0->cr0       /* Capture Register 0 */
00060 #define T0CR1           TMR0->cr1       /* Capture Register 1 */
00061 #define T0CR2           TMR0->cr2       /* Capture Register 2 */
00062 #define T0CR3           TMR0->cr3       /* Capture Register 3 */
00063 #define T0EMR           TMR0->emr       /* External Match Register */
00064 
00066 // Timer 1
00067 #define TMR1            ((pwmTmrRegs_t *)0xE0008000)
00068 
00069 // Timer 1 Registers
00070 #define T1IR            TMR1->ir        /* Interrupt Register */
00071 #define T1TCR           TMR1->tcr       /* Timer Control Register */
00072 #define T1TC            TMR1->tc        /* Timer Counter */
00073 #define T1PR            TMR1->pr        /* Prescale Register */
00074 #define T1PC            TMR1->pc        /* Prescale Counter Register */
00075 #define T1MCR           TMR1->mcr       /* Match Control Register */
00076 #define T1MR0           TMR1->mr0       /* Match Register 0 */
00077 #define T1MR1           TMR1->mr1       /* Match Register 1 */
00078 #define T1MR2           TMR1->mr2       /* Match Register 2 */
00079 #define T1MR3           TMR1->mr3       /* Match Register 3 */
00080 #define T1CCR           TMR1->ccr       /* Capture Control Register */
00081 #define T1CR0           TMR1->cr0       /* Capture Register 0 */
00082 #define T1CR1           TMR1->cr1       /* Capture Register 1 */
00083 #define T1CR2           TMR1->cr2       /* Capture Register 2 */
00084 #define T1CR3           TMR1->cr3       /* Capture Register 3 */
00085 #define T1EMR           TMR1->emr       /* External Match Register */
00086 
00088 // Pulse Width Modulator (PWM)
00089 #define PWM             ((pwmTmrRegs_t *)0xE0014000)
00090 
00091 // PWM Registers
00092 #define PWMIR           PWM->ir         /* Interrupt Register */
00093 #define PWMTCR          PWM->tcr        /* Timer Control Register */
00094 #define PWMTC           PWM->tc         /* Timer Counter */
00095 #define PWMPR           PWM->pr         /* Prescale Register */
00096 #define PWMPC           PWM->pc         /* Prescale Counter Register */
00097 #define PWMMCR          PWM->mcr        /* Match Control Register */
00098 #define PWMMR0          PWM->mr0        /* Match Register 0 */
00099 #define PWMMR1          PWM->mr1        /* Match Register 1 */
00100 #define PWMMR2          PWM->mr2        /* Match Register 2 */
00101 #define PWMMR3          PWM->mr3        /* Match Register 3 */
00102 #define PWMMR4          PWM->mr4        /* Match Register 4 */
00103 #define PWMMR5          PWM->mr5        /* Match Register 5 */
00104 #define PWMMR6          PWM->mr6        /* Match Register 6 */
00105 #define PWMPCR          PWM->pcr        /* Control Register */
00106 #define PWMLER          PWM->ler        /* Latch Enable Register */
00107 
00109 // Universal Asynchronous Receiver Transmitter 0 (UART0)
00110 #define UART0           ((uartRegs_t *)0xE000C000)
00111 #define U0_PINSEL       (0x00000005)    /* PINSEL0 Value for UART0 */
00112 #define U0_PINMASK      (0x0000000F)    /* PINSEL0 Mask for UART0 */
00113 
00114 // UART0 Registers
00115 #define U0RBR           UART0->rbr      /* Receive Buffer Register */
00116 #define U0THR           UART0->thr      /* Transmit Holding Register */
00117 #define U0IER           UART0->ier      /* Interrupt Enable Register */
00118 #define U0IIR           UART0->iir      /* Interrupt ID Register */
00119 #define U0FCR           UART0->fcr      /* FIFO Control Register */
00120 #define U0LCR           UART0->lcr      /* Line Control Register */
00121 #define U0LSR           UART0->lsr      /* Line Status Register */
00122 #define U0SCR           UART0->scr      /* Scratch Pad Register */
00123 #define U0DLL           UART0->dll      /* Divisor Latch Register (LSB) */
00124 #define U0DLM           UART0->dlm      /* Divisor Latch Register (MSB) */
00125 
00127 // Universal Asynchronous Receiver Transmitter 1 (UART1)
00128 #define UART1           ((uartRegs_t *)0xE0010000)
00129 #define U1_PINSEL       (0x00050000)    /* PINSEL0 Value for UART1 */
00130 #define U1_PINMASK      (0x000F0000)    /* PINSEL0 Mask for UART1 */
00131 
00132 // UART1 Registers
00133 #define U1RBR           UART1->rbr      /* Receive Buffer Register */
00134 #define U1THR           UART1->thr      /* Transmit Holding Register */
00135 #define U1IER           UART1->ier      /* Interrupt Enable Register */
00136 #define U1IIR           UART1->iir      /* Interrupt ID Register */
00137 #define U1FCR           UART1->fcr      /* FIFO Control Register */
00138 #define U1LCR           UART1->lcr      /* Line Control Register */
00139 #define U1MCR           UART1->mcr      /* MODEM Control Register */
00140 #define U1LSR           UART1->lsr      /* Line Status Register */
00141 #define U1MSR           UART1->msr      /* MODEM Status Register */
00142 #define U1SCR           UART1->scr      /* Scratch Pad Register */
00143 #define U1DLL           UART1->dll      /* Divisor Latch Register (LSB) */
00144 #define U1DLM           UART1->dlm      /* Divisor Latch Register (MSB) */
00145 
00147 // I2C Interface
00148 #define I2C             ((i2cRegs_t *)0xE001C000)
00149 
00150 // I2C Registers
00151 #define I2CONSET        I2C->conset     /* Control Set Register */
00152 #define I2STAT          I2C->stat       /* Status Register */
00153 #define I2DAT           I2C->dat        /* Data Register */
00154 #define I2ADR           I2C->adr        /* Slave Address Register */
00155 #define I2SCLH          I2C->sclh       /* SCL Duty Cycle Register (high half word) */
00156 #define I2SCLL          I2C->scll       /* SCL Duty Cycle Register (low half word) */
00157 #define I2CONCLR        I2C->conclr     /* Control Clear Register */
00158 
00160 // Serial Peripheral Interface 0 (SPI0)
00161 #define SPI0            ((spiRegs_t *)0xE0020000)
00162 
00163 // SPI0 Registers
00164 #define S0SPCR          SPI0->cr        /* Control Register */
00165 #define S0SPSR          SPI0->sr        /* Status Register */
00166 #define S0SPDR          SPI0->dr        /* Data Register */
00167 #define S0SPCCR         SPI0->ccr       /* Clock Counter Register */
00168 #define S0SPINT         SPI0->flag      /* Interrupt Flag Register */
00169 
00171 // Serial Peripheral Interface 1 (SPI1)
00172 #define SPI1            ((spiRegs_t *)0xE0030000)
00173 
00174 // SPI1 Registers
00175 #define S1SPCR          SPI1->cr        /* Control Register */
00176 #define S1SPSR          SPI1->sr        /* Status Register */
00177 #define S1SPDR          SPI1->dr        /* Data Register */
00178 #define S1SPCCR         SPI1->ccr       /* Clock Counter Register */
00179 #define S1SPINT         SPI1->flag      /* Interrupt Flag Register */
00180 
00182 // Real Time Clock
00183 #define RTC             ((rtcRegs_t *)0xE0024000)
00184 
00185 // RTC Registers
00186 #define RTCILR          RTC->ilr        /* Interrupt Location Register */
00187 #define RTCCTC          RTC->ctc        /* Clock Tick Counter */
00188 #define RTCCCR          RTC->ccr        /* Clock Control Register */
00189 #define RTCCIIR         RTC->ciir       /* Counter Increment Interrupt Register */
00190 #define RTCAMR          RTC->amr        /* Alarm Mask Register */
00191 #define RTCCTIME0       RTC->ctime0     /* Consolidated Time Register 0 */
00192 #define RTCCTIME1       RTC->ctime1     /* Consolidated Time Register 1 */
00193 #define RTCCTIME2       RTC->ctime2     /* Consolidated Time Register 2 */
00194 #define RTCSEC          RTC->sec        /* Seconds Register */
00195 #define RTCMIN          RTC->min        /* Minutes Register */
00196 #define RTCHOUR         RTC->hour       /* Hours Register */
00197 #define RTCDOM          RTC->dom        /* Day Of Month Register */
00198 #define RTCDOW          RTC->dow        /* Day Of Week Register */
00199 #define RTCDOY          RTC->doy        /* Day Of Year Register */
00200 #define RTCMONTH        RTC->month      /* Months Register */
00201 #define RTCYEAR         RTC->year       /* Years Register */
00202 #define RTCALSEC        RTC->alsec      /* Alarm Seconds Register */
00203 #define RTCALMIN        RTC->almin      /* Alarm Minutes Register */
00204 #define RTCALHOUR       RTC->alhour     /* Alarm Hours Register */
00205 #define RTCALDOM        RTC->aldom      /* Alarm Day Of Month Register */
00206 #define RTCALDOW        RTC->aldow      /* Alarm Day Of Week Register */
00207 #define RTCALDOY        RTC->aldoy      /* Alarm Day Of Year Register */
00208 #define RTCALMON        RTC->almon      /* Alarm Months Register */
00209 #define RTCALYEAR       RTC->alyear     /* Alarm Years Register */
00210 #define RTCPREINT       RTC->preint     /* Prescale Value Register (integer) */
00211 #define RTCPREFRAC      RTC->prefrac    /* Prescale Value Register (fraction) */
00212 
00214 // General Purpose Input/Output
00215 #define GPIO0           ((gpioRegs_t *)0xE0028000)
00216 #define GPIO1           ((gpioRegs_t *)0xE0028010)
00217 
00218 // GPIO Registers
00219 #define IO0PIN          GPIO0->in       /* P0 Pin Value Register */
00220 #define IO0SET          GPIO0->set      /* P0 Pin Output Set Register */
00221 #define IO0DIR          GPIO0->dir      /* P0 Pin Direction Register */
00222 #define IO0CLR          GPIO0->clr      /* P0 Pin Output Clear Register */
00223 #define IO1PIN          GPIO1->in       /* P1 Pin Value Register */
00224 #define IO1SET          GPIO1->set      /* P1 Pin Output Set Register */
00225 #define IO1DIR          GPIO1->dir      /* P1 Pin Direction Register */
00226 #define IO1CLR          GPIO1->clr      /* P1 Pin Output Clear Register */
00227 
00229 // Pin Connect Block
00230 #define PINSEL          ((pinRegs_t *)0xE002C000)
00231 
00232 // Pin Connect Block Registers
00233 #define PINSEL0         PINSEL->sel0    /* Pin Function Select Register 0 */
00234 #define PINSEL1         PINSEL->sel1    /* Pin Function Select Register 1 */
00235 #define PINSEL2         PINSEL->sel2    /* Pin Function Select Register 2 */
00236 
00238 // A/D Converter
00239 #define ADC             ((adcRegs_t *)0xE0034000)
00240 
00241 // A/D Converter Registers
00242 #define ADCR            ADC->cr         /* Control Register */
00243 #define ADDR            ADC->dr         /* Data Register */
00244 
00246 // System Contol Block
00247 #define SCB             ((scbRegs_t *)0xE01FC000)
00248 
00249 // Memory Accelerator Module Registers (MAM)
00250 #define MAMCR           SCB->mam.cr     /* Control Register */
00251 #define MAMTIM          SCB->mam.tim    /* Timing Control Register */
00252 
00253 // Memory Mapping Control Register
00254 #define MEMMAP          SCB->memmap
00255 
00256 // Phase Locked Loop Registers (PLL)
00257 #define PLLCON          SCB->pll.con    /* Control Register */
00258 #define PLLCFG          SCB->pll.cfg    /* Configuration Register */
00259 #define PLLSTAT         SCB->pll.stat   /* Status Register */
00260 #define PLLFEED         SCB->pll.feed   /* Feed Register */
00261 
00262 // Power Control Registers
00263 #define PCON            SCB->p.con      /* Control Register */
00264 #define PCONP           SCB->p.conp     /* Peripherals Register */
00265 
00266 // VPB Divider Register
00267 #define VPBDIV          SCB->vpbdiv
00268 
00269 // External Interrupt Registers
00270 #define EXTINT          SCB->ext.flag   /* Flag Register */
00271 #define EXTWAKE         SCB->ext.wake   /* Wakeup Register */
00272 #define EXTMODE         SCB->ext.mode   /* Mode Register */
00273 #define EXTPOLAR        SCB->ext.polar  /* Polarity Register */
00274 
00276 // Vectored Interrupt Controller
00277 #define VIC             ((vicRegs_t *)0xFFFFF000)
00278 
00279 // Vectored Interrupt Controller Registers
00280 #define VICIRQStatus    VIC->irqStatus  /* IRQ Status Register */
00281 #define VICFIQStatus    VIC->fiqStatus  /* FIQ Status Register */
00282 #define VICRawIntr      VIC->rawIntr    /* Raw Interrupt Status Register */
00283 #define VICIntSelect    VIC->intSelect  /* Interrupt Select Register */
00284 #define VICIntEnable    VIC->intEnable  /* Interrupt Enable Register */
00285 #define VICIntEnClear   VIC->intEnClear /* Interrupt Enable Clear Register */
00286 #define VICSoftInt      VIC->softInt    /* Software Interrupt Register */
00287 #define VICSoftIntClear VIC->softIntClear /* Software Interrupt Clear Register */
00288 #define VICProtection   VIC->protection /* Protection Enable Register */
00289 #define VICVectAddr     VIC->vectAddr   /* Vector Address Register */
00290 #define VICDefVectAddr  VIC->defVectAddr /* Default Vector Address Register */
00291 #define VICVectAddr0    VIC->vectAddr0  /* Vector Address 0 Register */
00292 #define VICVectAddr1    VIC->vectAddr1  /* Vector Address 1 Register */
00293 #define VICVectAddr2    VIC->vectAddr2  /* Vector Address 2 Register */
00294 #define VICVectAddr3    VIC->vectAddr3  /* Vector Address 3 Register */
00295 #define VICVectAddr4    VIC->vectAddr4  /* Vector Address 4 Register */
00296 #define VICVectAddr5    VIC->vectAddr5  /* Vector Address 5 Register */
00297 #define VICVectAddr6    VIC->vectAddr6  /* Vector Address 6 Register */
00298 #define VICVectAddr7    VIC->vectAddr7  /* Vector Address 7 Register */
00299 #define VICVectAddr8    VIC->vectAddr8  /* Vector Address 8 Register */
00300 #define VICVectAddr9    VIC->vectAddr9  /* Vector Address 9 Register */
00301 #define VICVectAddr10   VIC->vectAddr10 /* Vector Address 10 Register */
00302 #define VICVectAddr11   VIC->vectAddr11 /* Vector Address 11 Register */
00303 #define VICVectAddr12   VIC->vectAddr12 /* Vector Address 12 Register */
00304 #define VICVectAddr13   VIC->vectAddr13 /* Vector Address 13 Register */
00305 #define VICVectAddr14   VIC->vectAddr14 /* Vector Address 14 Register */
00306 #define VICVectAddr15   VIC->vectAddr15 /* Vector Address 15 Register */
00307 #define VICVectAdrArray VIC->vectAdrArray /* Vector Address Register Array */
00308 #define VICVectCntl0    VIC->vectCntl0  /* Vector Control 0 Register */
00309 #define VICVectCntl1    VIC->vectCntl1  /* Vector Control 1 Register */
00310 #define VICVectCntl2    VIC->vectCntl2  /* Vector Control 2 Register */
00311 #define VICVectCntl3    VIC->vectCntl3  /* Vector Control 3 Register */
00312 #define VICVectCntl4    VIC->vectCntl4  /* Vector Control 4 Register */
00313 #define VICVectCntl5    VIC->vectCntl5  /* Vector Control 5 Register */
00314 #define VICVectCntl6    VIC->vectCntl6  /* Vector Control 6 Register */
00315 #define VICVectCntl7    VIC->vectCntl7  /* Vector Control 7 Register */
00316 #define VICVectCntl8    VIC->vectCntl8  /* Vector Control 8 Register */
00317 #define VICVectCntl9    VIC->vectCntl9  /* Vector Control 9 Register */
00318 #define VICVectCntl10   VIC->vectCntl10 /* Vector Control 10 Register */
00319 #define VICVectCntl11   VIC->vectCntl11 /* Vector Control 11 Register */
00320 #define VICVectCntl12   VIC->vectCntl12 /* Vector Control 12 Register */
00321 #define VICVectCntl13   VIC->vectCntl13 /* Vector Control 13 Register */
00322 #define VICVectCntl14   VIC->vectCntl14 /* Vector Control 14 Register */
00323 #define VICVectCntl15   VIC->vectCntl15 /* Vector Control 15 Register */
00324 #define VICVectCtlArray VIC->vectCtlArray /* Vector Control Register Array */
00325 
00326 #endif

Generated on Fri Sep 21 13:41:54 2007 for example1 by  doxygen 1.4.7