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

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

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