

# LPC2292/LPC2294

16/32-bit ARM microcontrollers; 256 kB ISP/IAP flash with CAN, 10-bit ADC and external memory interface

Rev. 7 — 4 December 2008

**Product data sheet** 

## 1. General description

The LPC2292/LPC2294 microcontrollers are based on a 16/32-bit ARM7TDMI-S CPU with real-time emulation and embedded trace support, together with 256 kB of embedded high-speed flash memory. A 128-bit wide memory interface and a unique accelerator architecture enable 32-bit code execution at the maximum clock rate. For critical code size applications, the alternative 16-bit Thumb mode reduces code by more than 30 % with minimal performance penalty.

With their 144-pin package, low power consumption, various 32-bit timers, 8-channel 10-bit ADC, 2/4 (LPC2294) advanced CAN channels, PWM channels and up to nine external interrupt pins these microcontrollers are particularly suitable for automotive and industrial control applications as well as medical systems and fault-tolerant maintenance buses. The number of available GPIOs ranges from 76 (with external memory) through 112 (single-chip). With a wide range of additional serial communications interfaces, they are also suited for communication gateways and protocol converters as well as many other general-purpose applications.

**Remark:** Throughout the data sheet, the term LPC2292/LPC2294 will apply to devices with and without the /00 or /01 suffix. The suffixes /00 and /01 will be used to differentiate from other devices only when necessary.

#### 2. Features

#### 2.1 Key features brought by LPC2292/LPC2294/01 devices

- Fast GPIO ports enable port pin toggling up to 3.5 times faster than the original device. They also allow for a port pin to be read at any time regardless of its function.
- Dedicated result registers for ADC(s) reduce interrupt overhead. The ADC pads are 5 V tolerant when configured for digital I/O function(s).
- UART0/1 include fractional baud rate generator, auto-bauding capabilities and handshake flow-control fully implemented in hardware.
- Buffered SSP serial controller supporting SPI, 4-wire SSI, and Microwire formats.
- SPI programmable data length and master mode enhancement.
- Diversified Code Read Protection (CRP) enables different security levels to be implemented. This feature is available in LPC2292/LPC2294/00 devices as well.
- General purpose timers can operate as external event counters.

#### 2.2 Key features common for all devices

■ 16/32-bit ARM7TDMI-S microcontroller in a LQFP144 package.



- 16 kB on-chip static RAM and 256 kB on-chip flash program memory. 128-bit wide interface/accelerator enables high-speed 60 MHz operation.
- In-System Programming/In-Application Programming (ISP/IAP) via on-chip bootloader software. Single flash sector or full chip erase in 400 ms and programming of 256 B in 1 ms
- EmbeddedICE-RT and Embedded Trace interfaces offer real-time debugging with the on-chip RealMonitor software as well as high-speed real-time tracing of instruction execution.
- Two/four (LPC2292/LPC2294) interconnected CAN interfaces with advanced acceptance filters. Additional serial interfaces include two UARTs (16C550), Fast I<sup>2</sup>C-bus (400 kbit/s) and two SPIs.
- **Eight channel 10-bit ADC with conversion time as low as 2.44 μs.**
- Two 32-bit timers (with four capture and four compare channels), PWM unit (six outputs), Real-Time Clock (RTC), and watchdog.
- Vectored Interrupt Controller (VIC) with configurable priorities and vector addresses.
- Configurable external memory interface with up to four banks, each up to 16 MB and 8/16/32-bit data width.
- Up to 112 general purpose I/O pins (5 V tolerant). Up to nine edge/level sensitive external interrupt pins available.
- 60 MHz maximum CPU clock available from programmable on-chip PLL with settling time of 100 μs.
- The on-chip crystal oscillator should have an operating range of 1 MHz to 25 MHz.
- Power saving modes include Idle and Power-down.
- Processor wake-up from Power-down mode via external interrupt.
- Individual enable/disable of peripheral functions for power optimization.
- Dual power supply:
  - CPU operating voltage range of 1.65 V to 1.95 V (1.8 V  $\pm$  0.15 V).
  - I/O power supply range of 3.0 V to 3.6 V (3.3 V  $\pm$  10 %) with 5 V tolerant I/O pads.

# 3. Ordering information

Table 1. Ordering information

| Type number      | Package  | Package                                                                                       |          |  |  |  |  |  |  |
|------------------|----------|-----------------------------------------------------------------------------------------------|----------|--|--|--|--|--|--|
|                  | Name     | Description                                                                                   | Version  |  |  |  |  |  |  |
| LPC2292FBD144    | LQFP144  | plastic low profile quad flat package; 144 leads; body $20 \times 20 \times 1.4$ mm           | SOT486-1 |  |  |  |  |  |  |
| LPC2292FBD144/00 | LQFP144  | plastic low profile quad flat package; 144 leads; body $20 \times 20 \times 1.4$ mm           | SOT486-1 |  |  |  |  |  |  |
| LPC2292FBD144/01 | LQFP144  | plastic low profile quad flat package; 144 leads; body $20 \times 20 \times 1.4$ mm           | SOT486-1 |  |  |  |  |  |  |
| LPC2292FET144/00 | TFBGA144 | plastic thin fine-pitch ball grid array package; 144 balls; body $12 \times 12 \times 0.8$ mm | SOT569-2 |  |  |  |  |  |  |
| LPC2292FET144/01 | TFBGA144 | plastic thin fine-pitch ball grid array package; 144 balls; body $12 \times 12 \times 0.8$ mm | SOT569-2 |  |  |  |  |  |  |
| LPC2292FET144/G  | TFBGA144 | plastic thin fine-pitch ball grid array package; 144 balls; body $12 \times 12 \times 0.8$ mm | SOT569-2 |  |  |  |  |  |  |

 Table 1.
 Ordering information ...continued

| Type number      | Package |                                                                                     |          |  |  |  |  |
|------------------|---------|-------------------------------------------------------------------------------------|----------|--|--|--|--|
|                  | Name    | Description                                                                         | Version  |  |  |  |  |
| LPC2294HBD144    | LQFP144 | plastic low profile quad flat package;<br>144 leads; body 20 × 20 × 1.4 mm          | SOT486-1 |  |  |  |  |
| LPC2294HBD144/00 | LQFP144 | plastic low profile quad flat package; 144 leads; body $20 \times 20 \times 1.4$ mm | SOT486-1 |  |  |  |  |
| LPC2294HBD144/01 | LQFP144 | plastic low profile quad flat package; 144 leads; body $20 \times 20 \times 1.4$ mm | SOT486-1 |  |  |  |  |

## 3.1 Ordering options

Table 2. Ordering options

| Type number      | Flash<br>memory | RAM   | CAN        | Fast GPIO/<br>SSP/<br>Enhanced<br>UART, ADC,<br>Timer | Temperature range                                |
|------------------|-----------------|-------|------------|-------------------------------------------------------|--------------------------------------------------|
| LPC2292FBD144    | 256 kB          | 16 kB | 2 channels | no                                                    | $-40~^{\circ}\text{C}$ to +85 $^{\circ}\text{C}$ |
| LPC2292FBD144/00 | 256 kB          | 16 kB | 2 channels | no                                                    | –40 °C to +85 °C                                 |
| LPC2292FBD144/01 | 256 kB          | 16 kB | 2 channels | yes                                                   | –40 °C to +85 °C                                 |
| LPC2292FET144/00 | 256 kB          | 16 kB | 2 channels | no                                                    | –40 °C to +85 °C                                 |
| LPC2292FET144/01 | 256 kB          | 16 kB | 2 channels | yes                                                   | –40 °C to +85 °C                                 |
| LPC2292FET144/G  | 256 kB          | 16 kB | 2 channels | no                                                    | –40 °C to +85 °C                                 |
| LPC2294HBD144    | 256 kB          | 16 kB | 4 channels | no                                                    | –40 °C to +125 °C                                |
| LPC2294HBD144/00 | 256 kB          | 16 kB | 4 channels | no                                                    | –40 °C to +125 °C                                |
| LPC2294HBD144/01 | 256 kB          | 16 kB | 4 channels | yes                                                   | –40 °C to +125 °C                                |

## 4. Block diagram



- (2) Pins shared with GPIO.
- (3) Available in LPC2294 only.
- (4) SSP interface and high-speed GPIO are available on LPC2292/2294/01 only.

Fig 1. Block diagram

## 5. Pinning information

### 5.1 Pinning



ball A1 LPC2292FET144(1) index area 1 2 3 4 5 6 7 8 9 10 11 12 13 000000000000 В 000000000000 С 000000000000 D 000000000000 Е 0000 0000 F 0000 0000 G 0000 0000 Н 0000 0000 0000 0000 Κ 000000000000 000000000000 L 000000000000 000000000000 002aad191 Transparent top view

(1) Pin configuration is identical for devices with and without  $\/00$  and  $\/01$  suffixes.

Fig 3. TFBGA144 pinning

Product data sheet

|   | Table | 3.  | Ball | allocation |
|---|-------|-----|------|------------|
| 3 | Row   | Col | umn  |            |

| Row | Column                                  |                          |                                         |                                |                |                                   |                 |                                          |                      |                                          |                             |                             |                                         |
|-----|-----------------------------------------|--------------------------|-----------------------------------------|--------------------------------|----------------|-----------------------------------|-----------------|------------------------------------------|----------------------|------------------------------------------|-----------------------------|-----------------------------|-----------------------------------------|
|     | 1                                       | 2                        | 3                                       | 4                              | 5              | 6                                 | 7               | 8                                        | 9                    | 10                                       | 11                          | 12                          | 13                                      |
| Α   | P2[22]/<br>D22                          | V <sub>DDA(1V8)</sub>    | P1[28]/<br>TDI                          | P2[21]/<br>D21                 | P2[18]/<br>D18 | P2[14]/<br>D14                    | P1[29]/<br>TCK  | P2[11]/<br>D11                           | P2[10]/<br>D10       | P2[7]/D7                                 | $V_{DD(3V3)}$               | $V_{DD(1V8)}$               | P2[4]/D4                                |
| В   | V <sub>DD(3V3)</sub>                    | P1[27]/<br>TDO           | XTAL2                                   | V <sub>SSA(PLL)</sub>          | P2[19]/<br>D19 | P2[15]/<br>D15                    | P2[12]/<br>D12  | P0[20]/<br>MAT1[3]/<br>SSEL1/<br>EINT3   | V <sub>DD(3V3)</sub> | P2[6]/D6                                 | $V_{SS}$                    | P2[3]/D3                    | V <sub>SS</sub>                         |
| С   | P0[21]/<br>PWM5/<br>CAP1[3]             | V <sub>SS</sub>          | XTAL1                                   | $V_{SSA}$                      | RESET          | P2[16]/<br>D16                    | P2[13]/<br>D13  | P0[19]/<br>MAT1[2]/<br>MOSI1/<br>CAP1[2] | P2[9]/D9             | P2[5]/D5                                 | P2[2]/D2                    | P2[1]/D1                    | V <sub>DD(3V3)</sub>                    |
| D   | P0[24]/<br>TD2                          | P1[19]/<br>TRACE<br>PKT3 | P0[23]/<br>RD2                          | P0[22]/<br>CAP0[0]/<br>MAT0[0] | P2[20]/<br>D20 | P2[17]/<br>D17                    | V <sub>SS</sub> | P0[18]/<br>CAP1[3]/<br>MISO1/<br>MAT1[3] | P2[8]/D8             | P1[30]/<br>TMS                           | $V_{SS}$                    | P1[20]/<br>TRACE<br>SYNC    | P0[17]/<br>CAP1[2]/<br>SCK1/<br>MAT1[2] |
| E   | P2[25]/<br>D25                          | P2[24]/<br>D24           | P2[23]                                  | V <sub>SS</sub>                |                |                                   |                 |                                          |                      | P0[16]/<br>EINT0/<br>MAT0[2]/<br>CAP0[2] | P0[15]/<br>RI1/<br>EINT2    | P2[0]/D0                    | P3[30]/<br>BLS1                         |
| F   | P2[27]/<br>D27/<br>BOOT1                | P1[18]/<br>TRACE<br>PKT2 | V <sub>DDA(3V3)</sub>                   | P2[26]/<br>D26/<br>BOOT0       |                |                                   |                 |                                          |                      | P3[31]/<br>BLS0                          | P1[21]/<br>PIPE<br>STAT0    | V <sub>DD(3V3)</sub>        | $V_{SS}$                                |
| G   | P2[29]/<br>D29                          | P2[28]/<br>D28           | P2[30]/<br>D30/AIN4                     | P2[31]/<br>D31/AIN5            |                |                                   |                 |                                          |                      | P0[14]/<br>DCD1/<br>EINT1                | P1[0]/CS0                   | P3[0]/A0                    | P1[1]/ <del>OE</del>                    |
| Н   | P0[25]/<br>RD1                          | TD1                      | P0[27]/<br>AIN0/<br>CAP0[1]/<br>MAT0[1] | P1[17]/<br>TRACE<br>PKT1       |                |                                   |                 |                                          |                      | P0[13]/<br>DTR1/<br>MAT1[1]              | P1[22]/<br>PIPE<br>STAT1    | P3[2]/A2                    | P3[1]/A1                                |
| J   | P0[28]/<br>AIN1/<br>CAP0[2]/<br>MAT0[2] | V <sub>SS</sub>          | P3[29]/<br>BLS2/<br>AIN6                | P3[28]/<br>BLS3/<br>AIN7       |                |                                   |                 |                                          |                      | P3[3]/A3                                 | P1[23]/<br>PIPE<br>STAT2    | P0[11]/<br>CTS1/<br>CAP1[1] | P0[12]/<br>DSR1/<br>MAT1[0]             |
| K   | P3[27]/<br>WE                           | P3[26]/<br>CS1           | V <sub>DD(3V3)</sub>                    | P3[22]/<br>A22                 | P3[20]/<br>A20 | P0[1]/<br>RXD0/<br>PWM3/<br>EINT0 | P3[14]/<br>A14  | P1[25]/<br>EXTIN0                        | P3[11]/<br>A11       | V <sub>DD(3V3)</sub>                     | P0[10]/<br>RTS1/<br>CAP1[0] | V <sub>SS</sub>             | P3[4]/A4                                |

13

P0[9]/

RXD1/

PWM6/

EINT3

P3[5]/A5

P3[6]/A6

EINT2

P0[6]/

MOSI0/

CAP0[2]

P3[8]/A8

P3[10]/

A10

P1[26]/

**RTCK** 

 $V_{SS}$ 

EINT1

 $V_{DD(3V3)}$ 

P0[5]/

MISO0/

MAT0[1]

 $V_{SS}$ 

 $V_{DD(1V8)}$ 

P3[23]/

A23/

XCLK

P3[21]/

A21

P3[17]/

A17

# 5.2 Pin description

Table 4. Pin description

| Symbol                      | Pin (LQFP)          | Pin<br>(TFBGA) <sup>[1]</sup> | Туре     | Description                                                                                                                                                                                              |
|-----------------------------|---------------------|-------------------------------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| P0[0] to P0[31]             |                     |                               | I/O      | <b>Port 0:</b> Port 0 is a 32-bit bidirectional I/O port with individual direction controls for each bit. The operation of port 0 pins depends upon the pin function selected via the Pin Connect Block. |
|                             |                     |                               |          | Pins 26 and 31 of port 0 are not available.                                                                                                                                                              |
| P0[0]/TXD0/                 | 42 <sup>[2]</sup>   | L4[2]                         | 0        | <b>TXD0</b> — Transmitter output for UART0.                                                                                                                                                              |
| PWM1                        |                     |                               | 0        | PWM1 — Pulse Width Modulator output 1.                                                                                                                                                                   |
| P0[1]/RXD0/                 | 49 <u>[4]</u>       | K6[4]                         | <u>l</u> | <b>RXD0</b> — Receiver input for UART0.                                                                                                                                                                  |
| PWM3/EINT0                  |                     |                               | 0        | <b>PWM3</b> — Pulse Width Modulator output 3.                                                                                                                                                            |
|                             |                     |                               | l        | EINT0 — External interrupt 0 input                                                                                                                                                                       |
| P0[2]/SCL/<br>CAP0[0]       | 50 <u>[5]</u>       | L6[5]                         | I/O      | <b>SCL</b> — I <sup>2</sup> C-bus clock input/output. Open-drain output (for I <sup>2</sup> C-bus compliance).                                                                                           |
|                             |                     |                               | I        | CAP0[0] — Capture input for Timer 0, channel 0.                                                                                                                                                          |
| P0[3]/SDA/<br>MAT0[0]/EINT1 | 58 <u>[5]</u>       | M8[5]                         | I/O      | <b>SDA</b> — I <sup>2</sup> C-bus data input/output. Open-drain output (for I <sup>2</sup> C-bus compliance).                                                                                            |
|                             |                     |                               | 0        | MAT0[0] — Match output for Timer 0, channel 0.                                                                                                                                                           |
|                             |                     |                               | I        | EINT1 — External interrupt 1 input.                                                                                                                                                                      |
| P0[4]/SCK0/<br>CAP0[1]      | 59[2]               | L8[2]                         | I/O      | <b>SCK0</b> — Serial clock for SPI0. SPI clock output from master or input to slave.                                                                                                                     |
|                             |                     |                               | I        | CAP0[1] — Capture input for Timer 0, channel 1.                                                                                                                                                          |
| P0[5]/MISO0/<br>MAT0[1]     | 61[2]               | 2] N9[2]                      | I/O      | <b>MISO0</b> — Master In Slave OUT for SPI0. Data input to SPI master or data output from SPI slave.                                                                                                     |
|                             |                     |                               | 0        | MAT0[1] — Match output for Timer 0, channel 1.                                                                                                                                                           |
| P0[6]/MOSI0/<br>CAP0[2]     | 68 <sup>[2]</sup>   | N11 <sup>[2]</sup>            | I/O      | <b>MOSI0</b> — Master Out Slave In for SPI0. Data output from SPI master or data input to SPI slave.                                                                                                     |
|                             |                     |                               | I        | CAP0[2] — Capture input for Timer 0, channel 2.                                                                                                                                                          |
| P0[7]/SSEL0/<br>PWM2/EINT2  | 69 <mark>[4]</mark> | M11 <sup>[4]</sup>            | I        | <b>SSEL0</b> — Slave Select for SPI0. Selects the SPI interface as a slave.                                                                                                                              |
|                             |                     |                               | 0        | PWM2 — Pulse Width Modulator output 2.                                                                                                                                                                   |
|                             |                     |                               |          | EINT2 — External interrupt 2 input.                                                                                                                                                                      |
| P0[8]/TXD1/                 | 75 <u>[2]</u>       | L12[2]                        | 0        | TXD1 — Transmitter output for UART1.                                                                                                                                                                     |
| PWM4                        |                     |                               | 0        | PWM4 — Pulse Width Modulator output 4.                                                                                                                                                                   |
| P0[9]/RXD1/                 | 76 <u>[4]</u>       | L13[4]                        | 1        | RXD1 — Receiver input for UART1.                                                                                                                                                                         |
| PWM6/EINT3                  |                     |                               | 0        | PWM6 — Pulse Width Modulator output 6.                                                                                                                                                                   |
|                             |                     |                               | I        | EINT3 — External interrupt 3 input.                                                                                                                                                                      |
| P0[10]/RTS1/                | 78 <u>[2]</u>       | K11[2]                        | 0        | RTS1 — Request to Send output for UART1.                                                                                                                                                                 |
| CAP1[0]                     |                     |                               | I        | CAP1[0] — Capture input for Timer 1, channel 0.                                                                                                                                                          |
| P0[11]/CTS1/                | 83 <mark>[2]</mark> | J12 <sup>[2]</sup>            | I        | CTS1 — Clear to Send input for UART1.                                                                                                                                                                    |
| CAP1[1]                     |                     |                               |          | CAP1[1] — Capture input for Timer 1, channel 1.                                                                                                                                                          |

 Table 4.
 Pin description ...continued

| Symbol              | Pin (LQFP)           | Pin<br>(TFBGA) <mark>[1]</mark> | Туре | Description                                                                                                             |
|---------------------|----------------------|---------------------------------|------|-------------------------------------------------------------------------------------------------------------------------|
| P0[12]/DSR1/        | 84[2]                | J13[2]                          | I    | <b>DSR1</b> — Data Set Ready input for UART1.                                                                           |
| MAT1[0]/RD4         |                      |                                 | 0    | MAT1[0] — Match output for Timer 1, channel 0.                                                                          |
|                     |                      |                                 |      | RD4 — CAN4 receiver input (LPC2294 only).                                                                               |
| P0[13]/DTR1/        | 85 <mark>[2]</mark>  | H10 <sup>[2]</sup>              | 0    | DTR1 — Data Terminal Ready output for UART1.                                                                            |
| MAT1[1]/TD4         |                      |                                 | 0    | MAT1[1] — Match output for Timer 1, channel 1.                                                                          |
|                     |                      |                                 | 0    | TD4 — CAN4 transmitter output (LPC2294 only).                                                                           |
| P0[14]/DCD1/        | 92 <mark>[4]</mark>  | G10[4]                          | I    | <b>DCD1</b> — Data Carrier Detect input for UART1.                                                                      |
| EINT1               |                      |                                 | 1    | EINT1 — External interrupt 1 input.                                                                                     |
|                     |                      |                                 |      | <b>Note:</b> LOW on this pin while RESET is LOW forces on-chip bootloader to take over control of the part after reset. |
| P0[15]/RI1/         | 99[4]                | E11[4]                          | I    | RI1 — Ring Indicator input for UART1.                                                                                   |
| EINT2               |                      |                                 |      | EINT2 — External interrupt 2 input.                                                                                     |
| P0[16]/EINT0/       | 100[4]               | E10[4]                          | I    | EINT0 — External interrupt 0 input.                                                                                     |
| MAT0[2]/<br>CAP0[2] |                      |                                 | 0    | MAT0[2] — Match output for Timer 0, channel 2.                                                                          |
| CAPU[2]             |                      |                                 |      | CAP0[2] — Capture input for Timer 0, channel 2.                                                                         |
| P0[17]/CAP1[2]/     | 101[2]               | D13 <sup>[2]</sup>              | I    | CAP1[2] — Capture input for Timer 1, channel 2.                                                                         |
| SCK1/MAT1[2]        |                      |                                 | I/O  | <b>SCK1</b> — Serial Clock for SPI1/SSP[3]. SPI clock output from master or input to slave.                             |
|                     |                      |                                 | 0    | MAT1[2] — Match output for Timer 1, channel 2.                                                                          |
| P0[18]/CAP1[3]/     | 121[2]               | D8[2]                           | I    | CAP1[3] — Capture input for Timer 1, channel 3.                                                                         |
| MISO1/MAT1[3]       |                      |                                 | I/O  | <b>MISO1</b> — Master In Slave Out for SPI1/SSP[3]. Data input to SPI master or data output from SPI slave.             |
|                     |                      |                                 | 0    | MAT1[3] — Match output for Timer 1, channel 3.                                                                          |
| P0[19]/MAT1[2]/     | 122 <mark>[2]</mark> | C8[2]                           | 0    | MAT1[2] — Match output for Timer 1, channel 2.                                                                          |
| MOSI1/CAP1[2]       |                      |                                 | I/O  | MOSI1 — Master Out Slave In for SPI1/SSP <sup>3</sup> . Data output from SPI master or data input to SPI slave.         |
|                     |                      |                                 | I    | CAP1[2] — Capture input for Timer 1, channel 2.                                                                         |
| P0[20]/MAT1[3]/     | 123[4]               | B8[4]                           | 0    | MAT1[3] — Match output for Timer 1, channel 3.                                                                          |
| SSEL1/EINT3         |                      |                                 | I    | <b>SSEL1</b> — Slave Select for SPI1/SSP[3]. Selects the SPI interface as a slave.                                      |
|                     |                      |                                 | I    | EINT3 — External interrupt 3 input.                                                                                     |
| P0[21]/PWM5/        | 4 <u>[2]</u>         | C1[2]                           | 0    | PWM5 — Pulse Width Modulator output 5.                                                                                  |
| RD3/CAP1[3]         |                      |                                 | I    | RD3 — CAN3 receiver input (LPC2294 only).                                                                               |
|                     |                      |                                 | I    | CAP1[3] — Capture input for Timer 1, channel 3.                                                                         |
| P0[22]/TD3/         | 5 <u>[2]</u>         | D4[2]                           | 0    | TD3 — CAN3 transmitter output (LPC2294 only).                                                                           |
| CAP0[0]/            |                      |                                 | I    | CAP0[0] — Capture input for Timer 0, channel 0.                                                                         |
| MAT0[0]             |                      |                                 | 0    | MAT0[0] — Match output for Timer 0, channel 0.                                                                          |
| P0[23]/RD2          | 6 <u>[2]</u>         | D3 <sup>[2]</sup>               | I    | RD2 — CAN2 receiver input.                                                                                              |
| P0[24]/TD2          | 8[2]                 | D1[2]                           | 0    | TD2 — CAN2 transmitter output.                                                                                          |
| P0[25]/RD1          | 21[2]                | H1[2]                           | I    | RD1 — CAN1 receiver input.                                                                                              |

 Table 4.
 Pin description ...continued

| Symbol                        | Pin (LQFP)          | Pin<br>(TFBGA) <mark>[1]</mark> | Туре | Description                                                                                                                                                                                              |
|-------------------------------|---------------------|---------------------------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| P0[27]/AIN0/<br>CAP0[1]/      | 23[6]               | H3[6]                           | I    | <b>AIN0</b> — ADC, input 0. This analog input is always connected to its pin.                                                                                                                            |
| MAT0[1]                       |                     |                                 | I    | CAP0[1] — Capture input for Timer 0, channel 1.                                                                                                                                                          |
|                               |                     |                                 | 0    | MAT0[1] — Match output for Timer 0, channel 1.                                                                                                                                                           |
| P0[28]/AIN1/<br>CAP0[2]/      | 25 <sup>[6]</sup>   | J1 <sup>[6]</sup>               | I    | <b>AIN1</b> — ADC, input 1. This analog input is always connected to its pin.                                                                                                                            |
| MAT0[2]                       |                     |                                 | I    | CAP0[2] — Capture input for Timer 0, channel 2.                                                                                                                                                          |
|                               |                     |                                 | 0    | MAT0[2] — Match output for Timer 0, channel 2.                                                                                                                                                           |
| P0[29]/AIN2/<br>CAP0[3]/      | 32[6]               | L1[6]                           | 1    | <b>AIN2</b> — ADC, input 2. This analog input is always connected to its pin.                                                                                                                            |
| MAT0[3]                       |                     |                                 | I    | CAP0[3] — Capture input for Timer 0, Channel 3.                                                                                                                                                          |
|                               |                     |                                 | 0    | MAT0[3] — Match output for Timer 0, channel 3.                                                                                                                                                           |
| P0[30]/AIN3/<br>EINT3/CAP0[0] | 33 <u>[6]</u>       | L2[6]                           | I    | <b>AIN3</b> — ADC, input 3. This analog input is always connected to its pin.                                                                                                                            |
|                               |                     |                                 | I    | EINT3 — External interrupt 3 input.                                                                                                                                                                      |
|                               |                     |                                 | I    | CAP0[0] — Capture input for Timer 0, channel 0.                                                                                                                                                          |
| P1[0] to P1[31]               |                     |                                 | I/O  | <b>Port 1:</b> Port 1 is a 32-bit bidirectional I/O port with individual direction controls for each bit. The operation of port 1 pins depends upon the pin function selected via the Pin Connect Block. |
|                               |                     |                                 |      | Pins 2 through 15 of port 1 are not available.                                                                                                                                                           |
| P1[0]/CS0                     | 91[7]               | G11 <u>17</u>                   | 0    | CS0 — LOW-active Chip Select 0 signal.                                                                                                                                                                   |
|                               | [7]                 | [7]                             |      | (Bank 0 addresses range 0x8000 0000 to 0x80FF FFFF)                                                                                                                                                      |
| P1[1]/ <del>OE</del>          | 90[7]               | G13 <sup>[7]</sup>              | 0    | OE — LOW-active Output Enable signal.                                                                                                                                                                    |
| P1[16]/<br>TRACEPKT0          | 34 <u>[7]</u>       | L3[7]                           | 0    | <b>TRACEPKT0</b> — Trace Packet, bit 0. Standard I/O port with internal pull-up.                                                                                                                         |
| P1[17]/<br>TRACEPKT1          | 24[7]               | H4[7]                           | 0    | <b>TRACEPKT1</b> — Trace Packet, bit 1. Standard I/O port with internal pull-up.                                                                                                                         |
| P1[18]/<br>TRACEPKT2          | 15 <u>17</u>        | F2[7]                           | 0    | <b>TRACEPKT2</b> — Trace Packet, bit 2. Standard I/O port with internal pull-up.                                                                                                                         |
| P1[19]/<br>TRACEPKT3          | 7 <sup>[7]</sup>    | D2[7]                           | 0    | <b>TRACEPKT3</b> — Trace Packet, bit 3. Standard I/O port with internal pull-up.                                                                                                                         |
| P1[20]/<br>TRACESYNC          | 102[7]              | D12[7]                          | 0    | <b>TRACESYNC</b> — Trace Synchronization. Standard I/O port with internal pull-up.                                                                                                                       |
|                               |                     |                                 |      | <b>Note:</b> LOW on this pin while RESET is LOW, enables pins P1[25:16] to operate as Trace port after reset.                                                                                            |
| P1[21]/<br>PIPESTAT0          | 95 <u>[7]</u>       | F11 <u>17</u>                   | 0    | <b>PIPESTAT0</b> — Pipeline Status, bit 0. Standard I/O port with internal pull-up.                                                                                                                      |
| P1[22]/<br>PIPESTAT1          | 86[7]               | H11[7]                          | 0    | <b>PIPESTAT1</b> — Pipeline Status, bit 1. Standard I/O port with internal pull-up.                                                                                                                      |
| P1[23]/<br>PIPESTAT2          | 82 <mark>[7]</mark> | J11 <u>[7]</u>                  | 0    | <b>PIPESTAT2</b> — Pipeline Status, bit 2. Standard I/O port with internal pull-up.                                                                                                                      |
| P1[24]/<br>TRACECLK           | 70[7]               | L11 <u>7</u>                    | 0    | <b>TRACECLK</b> — Trace Clock. Standard I/O port with internal pull-up.                                                                                                                                  |

 Table 4.
 Pin description ...continued

| Table 4. Pin o  | Pin (LQFP)           | Pin               | Type | Description                                                                                                                                                                                                                                |
|-----------------|----------------------|-------------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Syllibol        | riii (LQFF)          | (TFBGA)[1]        | Туре | Description                                                                                                                                                                                                                                |
| P1[25]/EXTIN0   | 60[7]                | K8[7]             | I    | <b>EXTIN0</b> — External Trigger Input. Standard I/O with internal pull-up.                                                                                                                                                                |
| P1[26]/RTCK     | 52 <u>[7]</u>        | N6 <sup>[7]</sup> | I/O  | RTCK — Returned Test Clock output. Extra signal added to the JTAG port. Assists debugger synchronization when processor frequency varies. Bidirectional pin with internal pull-up.  Note: LOW on this pin while RESET is LOW, enables pins |
|                 |                      |                   |      | P1[31:26] to operate as Debug port after reset.                                                                                                                                                                                            |
| P1[27]/TDO      | 144[7]               | B2[7]             | 0    | <b>TDO</b> — Test Data out for JTAG interface.                                                                                                                                                                                             |
| P1[28]/TDI      | 140[7]               | A3[7]             | I    | TDI — Test Data in for JTAG interface.                                                                                                                                                                                                     |
| P1[29]/TCK      | 126 <sup>[7]</sup>   | A7[7]             | I    | $\rm TCK$ — Test Clock for JTAG interface. This clock must be slower than $^{1}\!/_{\!6}$ of the CPU clock (CCLK) for the JTAG interface to operate.                                                                                       |
| P1[30]/TMS      | 113 <u>[7]</u>       | D10[7]            | I    | <b>TMS</b> — Test Mode Select for JTAG interface.                                                                                                                                                                                          |
| P1[31]/TRST     | 43 <u>[7]</u>        | M4[7]             | l    | TRST — Test Reset for JTAG interface.                                                                                                                                                                                                      |
| P2[0] to P2[31] |                      |                   | I/O  | <b>Port 2</b> — Port 2 is a 32-bit bidirectional I/O port with individual direction controls for each bit. The operation of port 2 pins depends upon the pin function selected via the Pin Connect Block.                                  |
| P2[0]/D0        | 98[7]                | E12[7]            | I/O  | <b>D0</b> — External memory data line 0.                                                                                                                                                                                                   |
| P2[1]/D1        | 105[7]               | C12[7]            | I/O  | D1 — External memory data line 1.                                                                                                                                                                                                          |
| P2[2]/D2        | 106 <sup>[7]</sup>   | C11 <u>17</u>     | I/O  | D2 — External memory data line 2.                                                                                                                                                                                                          |
| P2[3]/D3        | 108[7]               | B12[7]            | I/O  | D3 — External memory data line 3.                                                                                                                                                                                                          |
| P2[4]/D4        | 109[7]               | A13[7]            | I/O  | <b>D4</b> — External memory data line 4.                                                                                                                                                                                                   |
| P2[5]/D5        | 114 <u>[7]</u>       | C10[7]            | I/O  | <b>D5</b> — External memory data line 5.                                                                                                                                                                                                   |
| P2[6]/D6        | 115 <u>[7]</u>       | B10[7]            | I/O  | <b>D6</b> — External memory data line 6.                                                                                                                                                                                                   |
| P2[7]/D7        | 116 <mark>[7]</mark> | A10[7]            | I/O  | D7 — External memory data line 7.                                                                                                                                                                                                          |
| P2[8]/D8        | 117 <u>[7]</u>       | D9[7]             | I/O  | <b>D8</b> — External memory data line 8.                                                                                                                                                                                                   |
| P2[9]/D9        | 118 <mark>[7]</mark> | C9[7]             | I/O  | <b>D9</b> — External memory data line 9.                                                                                                                                                                                                   |
| P2[10]/D10      | 120 <mark>[7]</mark> | A9[7]             | I/O  | <b>D10</b> — External memory data line 10.                                                                                                                                                                                                 |
| P2[11]/D11      | 124 <mark>7</mark>   | A8[7]             | I/O  | D11 — External memory data line 11.                                                                                                                                                                                                        |
| P2[12]/D12      | 125 <mark>[7]</mark> | B7[7]             | I/O  | D12 — External memory data line 12.                                                                                                                                                                                                        |
| P2[13]/D13      | 127 <mark>7</mark>   | C7[7]             | I/O  | D13 — External memory data line 13.                                                                                                                                                                                                        |
| P2[14]/D14      | 129 <mark>[7]</mark> | A6[7]             | I/O  | D14 — External memory data line 14.                                                                                                                                                                                                        |
| P2[15]/D15      | 130[7]               | B6[7]             | I/O  | D15 — External memory data line 15.                                                                                                                                                                                                        |
| P2[16]/D16      | 131[7]               | C6[7]             | I/O  | D16 — External memory data line 16.                                                                                                                                                                                                        |
| P2[17]/D17      | 132[7]               | D6[7]             | I/O  | D17 — External memory data line 17.                                                                                                                                                                                                        |
| P2[18]/D18      | 133[7]               | A5[7]             | I/O  | D18 — External memory data line 18.                                                                                                                                                                                                        |
| P2[19]/D19      | 134 <u>[7]</u>       | B5[7]             | I/O  | D19 — External memory data line 19.                                                                                                                                                                                                        |
| P2[20]/D20      | 136 <mark>[7]</mark> | D5[7]             | I/O  | <b>D20</b> — External memory data line 20.                                                                                                                                                                                                 |
| P2[21]/D21      | 137[7]               | A4[7]             | I/O  | <b>D21</b> — External memory data line 21.                                                                                                                                                                                                 |
| P2[22]/D22      | 1[7]                 | A1[7]             | I/O  | D22 — External memory data line 22.                                                                                                                                                                                                        |
| P2[23]/D23      | 10[7]                | E3[7]             | I/O  | <b>D23</b> — External memory data line 23.                                                                                                                                                                                                 |

 Table 4.
 Pin description ...continued

| Symbol          | Pin (LQFP)          | Pin<br>(TFBGA)[1] | Type | Description                                                                                                                                                                                               |
|-----------------|---------------------|-------------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| P2[24]/D24      | 11[7]               | E2[7]             | I/O  | D24 — External memory data line 24.                                                                                                                                                                       |
| P2[25]/D25      | 12[7]               | E1[7]             | I/O  | D25 — External memory data line 25.                                                                                                                                                                       |
| P2[26]/D26/     | 13[7]               | F4[7]             | I/O  | <b>D26</b> — External memory data line 26.                                                                                                                                                                |
| BOOT0           |                     |                   | I    | <b>BOOT0</b> — While RESET is low, together with BOOT1 control booting and internal operation. Internal pull-up ensures high state if pin is left unconnected.                                            |
| P2[27]/D27/     | 16 <u>[7]</u>       | F1[7]             | I/O  | <b>D27</b> — External memory data line 27.                                                                                                                                                                |
| BOOT1           |                     |                   | I    | <b>BOOT1</b> — While RESET is low, together with BOOT0 contro booting and internal operation. Internal pull-up ensures high state if pin is left unconnected.                                             |
|                 |                     |                   |      | BOOT1:0 = 00 selects 8-bit memory on $\overline{CSO}$ for boot.                                                                                                                                           |
|                 |                     |                   |      | BOOT1:0 = 01 selects 16-bit memory on $\overline{CS0}$ for boot.                                                                                                                                          |
|                 |                     |                   |      | BOOT1:0 = 10 selects 32-bit memory on $\overline{CS0}$ for boot.                                                                                                                                          |
|                 |                     |                   |      | BOOT1:0 = 11 selects internal flash memory.                                                                                                                                                               |
| P2[28]/D28      | 17 <u>17</u>        | G2[7]             | I/O  | D28 — External memory data line 28.                                                                                                                                                                       |
| P2[29]/D29      | 18 <u>17</u>        | G1 <u>1</u>       | I/O  | <b>D29</b> — External memory data line 29.                                                                                                                                                                |
| P2[30]/D30/     | 19 <mark>6</mark>   | G3[6]             | I/O  | D30 — External memory data line 30.                                                                                                                                                                       |
| AIN4            |                     |                   | I    | <b>AIN4</b> — ADC, input 4. This analog input is always connected to its pin.                                                                                                                             |
| P2[31]/D31/     | 20[6]               | G4[6]             | I/O  | D31 — External memory data line 31.                                                                                                                                                                       |
| AIN5            |                     |                   | I    | AIN5 — ADC, input 5. This analog input is always connected<br>to its pin.                                                                                                                                 |
| P3[0] to P3[31] |                     |                   | I/O  | <b>Port 3</b> — Port 3 is a 32-bit bidirectional I/O port with individual direction controls for each bit. The operation of port 3 pins depends upon the pin function selected via the Pin Connect Block. |
| P3[0]/A0        | 89 <u>[7]</u>       | G12[7]            | 0    | A0 — External memory address line 0.                                                                                                                                                                      |
| P3[1]/A1        | 88[7]               | H13[7]            | 0    | A1 — External memory address line 1.                                                                                                                                                                      |
| P3[2]/A2        | 87 <mark>[7]</mark> | H12[7]            | 0    | A2 — External memory address line 2.                                                                                                                                                                      |
| P3[3]/A3        | 81 <u>7</u>         | J10[7]            | 0    | A3 — External memory address line 3.                                                                                                                                                                      |
| P3[4]/A4        | 80[7]               | K13[7]            | 0    | A4 — External memory address line 4.                                                                                                                                                                      |
| P3[5]/A5        | 74 <u>[7]</u>       | M13[7]            | 0    | A5 — External memory address line 5.                                                                                                                                                                      |
| P3[6]/A6        | 73 <mark>[7]</mark> | N13[7]            | 0    | A6 — External memory address line 6.                                                                                                                                                                      |
| P3[7]/A7        | 72 <mark>[7]</mark> | M12[7]            | 0    | A7 — External memory address line 7.                                                                                                                                                                      |
| P3[8]/A8        | 71[7]               | N12[7]            | 0    | A8 — External memory address line 8.                                                                                                                                                                      |
| P3[9]/A9        | 66 <mark>[7]</mark> | M10[7]            | 0    | A9 — External memory address line 9.                                                                                                                                                                      |
| P3[10]/A10      | 65 <u>[7]</u>       | N10[7]            | 0    | A10 — External memory address line 10.                                                                                                                                                                    |
| P3[11]/A11      | 64 <u>[7]</u>       | K9[7]             | 0    | A11 — External memory address line 11.                                                                                                                                                                    |
| P3[12]/A12      | 63 <mark>[7]</mark> | L9[7]             | 0    | A12 — External memory address line 12.                                                                                                                                                                    |
| P3[13]/A13      | 62 <mark>[7]</mark> | M9[7]             | 0    | A13 — External memory address line 13.                                                                                                                                                                    |
| P3[14]/A14      | 56 <mark>[7]</mark> | K7 <u>[7]</u>     | 0    | A14 — External memory address line 14.                                                                                                                                                                    |
| P3[15]/A15      | 55 <u>[7]</u>       | L7[7]             | 0    | A15 — External memory address line 15.                                                                                                                                                                    |
| P3[16]/A16      | 53[7]               | M7[7]             | 0    | A16 — External memory address line 16.                                                                                                                                                                    |

 Table 4.
 Pin description ...continued

| Symbol                | Pin (LQFP)                                                | Pin<br>(TFBGA) <mark>[1]</mark>                                  | Туре | Description                                                                                                                                                                                                            |
|-----------------------|-----------------------------------------------------------|------------------------------------------------------------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| P3[17]/A17            | 48 <u>[7]</u>                                             | N5[7]                                                            | 0    | A17 — External memory address line 17.                                                                                                                                                                                 |
| P3[18]/A18            | 47 <u>[7]</u>                                             | M5[7]                                                            | 0    | A18 — External memory address line 18.                                                                                                                                                                                 |
| P3[19]/A19            | 46[7]                                                     | L5[7]                                                            | 0    | A19 — External memory address line 19.                                                                                                                                                                                 |
| P3[20]/A20            | 45 <u>[7]</u>                                             | K5[7]                                                            | 0    | A20 — External memory address line 20.                                                                                                                                                                                 |
| P3[21]/A21            | 44[7]                                                     | N4[7]                                                            | 0    | A21 — External memory address line 21.                                                                                                                                                                                 |
| P3[22]/A22            | 41[7]                                                     | K4[7]                                                            | 0    | A22 — External memory address line 22.                                                                                                                                                                                 |
| P3[23]/A23/           | 40[7]                                                     | N3[7]                                                            | I/O  | A23 — External memory address line 23.                                                                                                                                                                                 |
| XCLK                  |                                                           |                                                                  | 0    | XCLK — Clock output.                                                                                                                                                                                                   |
| P3[24]/CS3            | 36 <mark>[7]</mark>                                       | M2[7]                                                            | 0    | CS3 — LOW-active Chip Select 3 signal.                                                                                                                                                                                 |
|                       |                                                           |                                                                  |      | (Bank 3 addresses range 0x8300 0000 to 0x83FF FFFF)                                                                                                                                                                    |
| P3[25]/CS2            | 35 <mark>[7]</mark>                                       | M1 <u></u>                                                       | 0    | CS2 — LOW-active Chip Select 2 signal.                                                                                                                                                                                 |
|                       |                                                           |                                                                  |      | (Bank 2 addresses range 0x8200 0000 to 0x82FF FFFF)                                                                                                                                                                    |
| P3[26]/CS1            | 30[7]                                                     | K2[7]                                                            | 0    | CS1 — LOW-active Chip Select 1 signal.                                                                                                                                                                                 |
|                       |                                                           |                                                                  |      | (Bank 1 addresses range 0x8100 0000 to 0x81FF FFFF)                                                                                                                                                                    |
| P3[27]/WE             | 29 <mark>[7]</mark>                                       | K1[7]                                                            | 0    | WE — LOW-active Write enable signal.                                                                                                                                                                                   |
| P3[28]/BLS3/          | 28 <mark>6</mark>                                         | [ <u>6]</u> J4 <u>[6]</u>                                        | 0    | BLS3 — LOW-active Byte Lane Select signal (Bank 3).                                                                                                                                                                    |
| AIN7                  |                                                           |                                                                  | I    | <b>AIN7</b> — ADC, input 7. This analog input is always connected to its pin.                                                                                                                                          |
| P3[29]/BLS2/          | 27 <mark>6</mark>                                         | J3 <u>[6]</u>                                                    | 0    | BLS2 — LOW-active Byte Lane Select signal (Bank 2).                                                                                                                                                                    |
| AIN6                  |                                                           |                                                                  | I    | <b>AIN6</b> — ADC, input 6. This analog input is always connected to its pin.                                                                                                                                          |
| P3[30]/BLS1           | 97 <u>[7]</u>                                             | E13[7]                                                           | 0    | BLS1 — LOW-active Byte Lane Select signal (Bank 1).                                                                                                                                                                    |
| P3[31]/BLS0           | 96[7]                                                     | F10[7]                                                           | 0    | BLS0 — LOW-active Byte Lane Select signal (Bank 0).                                                                                                                                                                    |
| TD1                   | 22[7]                                                     | H2[7]                                                            | 0    | TD1: CAN1 transmitter output.                                                                                                                                                                                          |
| RESET                 | 135 <sup>[8]</sup>                                        | C5[8]                                                            | I    | <b>External Reset input:</b> A LOW on this pin resets the device, causing I/O ports and peripherals to take on their default states, and processor execution to begin at address 0. TTL with hysteresis, 5 V tolerant. |
| XTAL1                 | 142 <sup>[9]</sup>                                        | C3[9]                                                            | I    | Input to the oscillator circuit and internal clock generator circuits.                                                                                                                                                 |
| XTAL2                 | 141 <mark>9</mark>                                        | B3 <sup>[9]</sup>                                                | 0    | Output from the oscillator amplifier.                                                                                                                                                                                  |
| Vss                   | 3, 9, 26, 38,<br>54, 67, 79,<br>93, 103, 107,<br>111, 128 | C2, E4, J2,<br>N2, N7, L10,<br>K12, F13,<br>D11, B13,<br>B11, D7 | I    | Ground: 0 V reference.                                                                                                                                                                                                 |
| $V_{SSA}$             | 139                                                       | C4                                                               | I    | <b>Analog ground:</b> 0 V reference. This should nominally be the same voltage as $V_{SS}$ , but should be isolated to minimize noise and error.                                                                       |
| V <sub>SSA(PLL)</sub> | 138                                                       | B4                                                               | I    | <b>PLL analog ground:</b> 0 V reference. This should nominally be the same voltage as $V_{SS}$ , but should be isolated to minimize noise and error.                                                                   |
| V <sub>DD(1V8)</sub>  | 37, 110                                                   | N1, A12                                                          | I    | <b>1.8 V core power supply:</b> This is the power supply voltage for internal circuitry.                                                                                                                               |

Table 4. Pin description ... continued

| Symbol                | Pin (LQFP)                                     | Pin<br>(TFBGA)[1] | Туре | Description                                                                                                                                                                                                    |
|-----------------------|------------------------------------------------|-------------------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| V <sub>DDA(1V8)</sub> | 143                                            | A2                | I    | <b>Analog 1.8 V core power supply:</b> This is the power supply voltage for internal circuitry. This should be nominally the same voltage as $V_{DD(1V8)}$ but should be isolated to minimize noise and error. |
| V <sub>DD(3V3)</sub>  | 2, 31, 39, 51,<br>57, 77, 94,<br>104, 112, 119 | M6, N8, K10,      | I    | <b>3.3 V pad power supply:</b> This is the power supply voltage for the I/O ports.                                                                                                                             |
| V <sub>DDA(3V3)</sub> | 14                                             | F3                | I    | <b>Analog 3.3 V pad power supply:</b> This should be nominally the same voltage as $V_{DD(3V3)}$ but should be isolated to minimize noise and error.                                                           |

- [1] LPC2294 only.
- [2] 5 V tolerant pad providing digital I/O functions with TTL levels and hysteresis and 10 ns slew rate control.
- [3] SSP interface available on LPC2292/2294/01 only.
- [4] 5 V tolerant pad providing digital I/O functions with TTL levels and hysteresis and 10 ns slew rate control. If configured for an input function, this pad utilizes built-in glitch filter that blocks pulses shorter than 3 ns.
- [5] Open-drain 5 V tolerant digital I/O I<sup>2</sup>C-bus 400 kHz specification compatible pad. It requires external pull-up to provide an output functionality. Open-drain configuration applies to all output functions on this pin.
- [6] 5 V tolerant pad providing digital I/O (with TTL levels and hysteresis and 10 ns slew rate control) and analog input function. If configured for a digital input function, this pad utilizes built-in glitch filter that blocks pulses shorter than 3 ns. When configured as an ADC input, digital section of the pad is disabled.
- [7] 5 V tolerant pad with built-in pull-up resistor providing digital I/O functions with TTL levels and hysteresis and 10 ns slew rate control. The pull-up resistor's value ranges from 60 kΩ to 300 kΩ.
- [8] 5 V tolerant pad providing digital input (with TTL levels and hysteresis) function only.
- [9] Pad provides special analog functionality.

## 6. Functional description

#### 6.1 Architectural overview

The ARM7TDMI-S is a general purpose 32-bit microprocessor, which offers high performance and very low power consumption. The ARM architecture is based on RISC principles, and the instruction set and related decode mechanism are much simpler than those of microprogrammed CISC. This simplicity results in a high instruction throughput and impressive real-time interrupt response from a small and cost-effective processor core.

Pipeline techniques are employed so that all parts of the processing and memory systems can operate continuously. Typically, while one instruction is being executed, its successor is being decoded, and a third instruction is being fetched from memory.

The ARM7TDMI-S processor also employs a unique architectural strategy known as Thumb, which makes it ideally suited to high-volume applications with memory restrictions, or applications where code density is an issue.

The key idea behind Thumb is that of a super-reduced instruction set. Essentially, the ARM7TDMI-S processor has two instruction sets:

- The standard 32-bit ARM set
- A 16-bit Thumb set

The Thumb set's 16-bit instruction length allows it to approach twice the density of standard ARM code while retaining most of the ARM's performance advantage over a traditional 16-bit processor using 16-bit registers. This is possible because Thumb code operates on the same 32-bit register set as ARM code.

Thumb code is able to provide up to 65 % of the code size of ARM, and 160 % of the performance of an equivalent ARM processor connected to a 16-bit memory system.

#### 6.2 On-chip flash program memory

The LPC2292/LPC2294 incorporate a 256 kB flash memory system respectively. This memory may be used for both code and data storage. Programming of the flash memory may be accomplished in several ways. It may be programmed In System via the serial port. The application program may also erase and/or program the flash while the application is running, allowing a great degree of flexibility for data storage field firmware upgrades, etc. When the on-chip bootloader is used, 248 kB of flash memory is available for user code.

The LPC2292/LPC2294 flash memory provides a minimum of 100000 erase/write cycles and 20 years of data retention.

On-chip bootloader (as of revision 1.64) provides Code Read Protection (CRP) for the LPC2292/LPC2294 on-chip flash memory. When the CRP is enabled, the JTAG debug port, external memory boot and ISP commands accessing either the on-chip RAM or flash memory are disabled. However, the ISP flash erase command can be executed at any time (no matter whether the CRP is on or off). Removal of CRP is achieved by erasure of full on-chip user flash. With the CRP off, full access to the chip via the JTAG and/or ISP is restored.

## 6.3 On-chip SRAM

On-chip SRAM may be used for code and/or data storage. The SRAM may be accessed as 8-bit, 16-bit, and 32-bit. The LPC2292/LPC2294 provide 16 kB of SRAM.

#### 6.4 Memory map

The LPC2292/LPC2294 memory maps incorporate several distinct regions, as shown in Figure 4.

In addition, the CPU interrupt vectors may be re-mapped to allow them to reside in either flash memory (the default) or on-chip static RAM. This is described in <u>Section 6.19</u> "System control".



## 6.5 Interrupt controller

The VIC accepts all of the interrupt request inputs and categorizes them as Fast Interrupt Request (FIQ), vectored Interrupt Request (IRQ), and non-vectored IRQ as defined by programmable settings. The programmable assignment scheme means that priorities of interrupts from the various peripherals can be dynamically assigned and adjusted.

FIQ has the highest priority. If more than one request is assigned to FIQ, the VIC combines the requests to produce the FIQ signal to the ARM processor. The fastest possible FIQ latency is achieved when only one request is classified as FIQ, because then the FIQ service routine can simply start dealing with that device. But if more than one request is assigned to the FIQ class, the FIQ service routine can read a word from the VIC that identifies which FIQ source(s) is (are) requesting an interrupt.

Vectored IRQs have the middle priority. Sixteen of the interrupt requests can be assigned to this category. Any of the interrupt requests can be assigned to any of the 16 vectored IRQ slots, among which slot 0 has the highest priority and slot 15 has the lowest.

Non-vectored IRQs have the lowest priority.

The VIC combines the requests from all the vectored and non-vectored IRQs to produce the IRQ signal to the ARM processor. The IRQ service routine can start by reading a register from the VIC and jumping there. If any of the vectored IRQs are requesting, the VIC provides the address of the highest-priority requesting IRQs service routine, otherwise it provides the address of a default routine that is shared by all the non-vectored IRQs. The default routine can read another VIC register to see what IRQs are active.

#### 6.5.1 Interrupt sources

<u>Table 5</u> lists the interrupt sources for each peripheral function. Each peripheral device has one interrupt line connected to the VIC, but may have several internal interrupt flags. Individual interrupt flags may also represent more than one interrupt source.

Table 5. Interrupt sources

| Block    | Flag(s)                                | VIC channel # |
|----------|----------------------------------------|---------------|
| WDT      | Watchdog Interrupt (WDINT)             | 0             |
| -        | Reserved for software interrupts only  | 1             |
| ARM Core | EmbeddedICE, DbgCommRx                 | 2             |
| ARM Core | EmbeddedICE, DbgCommTx                 | 3             |
| Timer 0  | Match 0 to 3 (MR0, MR1, MR2, MR3)      | 4             |
|          | Capture 0 to 3 (CR0, CR1, CR2, CR3)    |               |
| Timer 1  | Match 0 to 3 (MR0, MR1, MR2, MR3)      | 5             |
|          | Capture 0 to 3 (CR0, CR1, CR2, CR3)    |               |
| UART0    | RX Line Status (RLS)                   | 6             |
|          | Transmit Holding Register Empty (THRE) |               |
|          | RX Data Available (RDA)                |               |
|          | Character Time-out Indicator (CTI)     |               |
|          | Auto-baud time-out (ABTO)[1]           |               |
|          | End of auto-baud (ABEO)[1]             |               |
|          |                                        |               |

 Table 5.
 Interrupt sources ...continued

|               | - Continued                                      | \#6 I         |
|---------------|--------------------------------------------------|---------------|
| Block         | Flag(s)                                          | VIC channel # |
| UART1         | RX Line Status (RLS)                             | 7             |
|               | Transmit Holding Register empty (THRE)           |               |
|               | RX Data Available (RDA)                          |               |
|               | Character Time-out Indicator (CTI)               |               |
|               | Modem Status Interrupt (MSI)                     |               |
|               | Auto-baud time-out (ABTO)[1]                     |               |
|               | End of auto-baud (ABEO)[1]                       |               |
| PWM0          | Match 0 to 6 (MR0, MR1, MR2, MR3, MR4, MR5, MR6) | 8             |
| I2C           | SI (state change)                                | 9             |
| SPI0          | SPIF, MODF                                       | 10            |
| SPI1 and SSF  | SPIF, MODF and TXRIS, RXRIS, RTRIS, RORRIS       | 11            |
| PLL           | PLL Lock (PLOCK)                                 | 12            |
| RTC           | RTCCIF (Counter Increment), RTCALF (Alarm)       | 13            |
| System Contro | ol External Interrupt 0 (EINT0)                  | 14            |
|               | External Interrupt 1 (EINT1)                     | 15            |
|               | External Interrupt 2 (EINT2)                     | 16            |
|               | External Interrupt 3 (EINT3)                     | 17            |
| ADC           | ADC                                              | 18            |
| CAN           | 1 ORed CAN Acceptance Filter                     | 19            |
|               | CAN1/2 Tx                                        | 20, 21        |
|               | CAN2/3 Tx (LPC2294 only)                         | 22, 23        |
|               | reserved                                         | 24, 25        |
|               | CAN1/2 Rx                                        | 26, 27        |
|               | CAN3/4 Rx (LPC2294 only)                         | 28,29         |
|               |                                                  |               |

<sup>[1]</sup> SSP interface and UART0/1 auto-baud control are available on LPC2292/2294/01 only.

#### 6.6 Pin connect block

The pin connect block allows selected pins of the microcontroller to have more than one function. Configuration registers control the multiplexers to allow connection between the pin and the on chip peripherals. Peripherals should be connected to the appropriate pins prior to being activated, and prior to any related interrupt(s) being enabled. Activity of any enabled peripheral function that is not mapped to a related pin should be considered undefined.

#### 6.7 External memory controller

The external Static Memory Controller is a module which provides an interface between the system bus and external (off-chip) memory devices. It provides support for up to four independently configurable memory banks (16 MB each with byte lane enable control) simultaneously. Each memory bank is capable of supporting SRAM, ROM, flash EPROM, burst ROM memory, or some external I/O devices.

Each memory bank may be 8-bit, 16-bit, or 32-bit wide.

## 6.8 General purpose parallel I/O (GPIO) and Fast I/O

Device pins that are not connected to a specific peripheral function are controlled by the parallel I/O registers. Pins may be dynamically configured as inputs or outputs. Separate registers allow setting or clearing any number of outputs simultaneously. The value of the output register may be read back, as well as the current state of the port pins.

#### 6.8.1 Features

- Bit-level set and clear registers allow a single instruction set or clear of any number of bits in one port.
- Direction control of individual bits.
- · Separate control of output set and clear.
- All I/O default to inputs after reset.

# 6.8.2 Features added with the Fast GPIO set of registers available on LPC2292/LPC2294/01 only

- Fast GPIO registers are relocated to the ARM local bus for the fastest possible I/O timing, enabling port pin toggling up to 3.5 times faster than earlier LPC2000 devices.
- Mask registers allow treating sets of port bits as a group, leaving other bits unchanged.
- All Fast GPIO registers are byte addressable.
- Entire port value can be written in one instruction.
- Ports are accessible via either the legacy group of registers (GPIOs) or the group of registers providing accelerated port access (Fast GPIOs).

## 6.9 10-bit ADC

The LPC2292/LPC2294 each contain a single 10-bit successive approximation ADC with four multiplexed channels.

#### 6.9.1 Features

- Measurement range of 0 V to 3 V.
- Capable of performing more than 400000 10-bit samples per second.
- Burst conversion mode for single or multiple inputs.
- Optional conversion on transition on input pin or Timer Match signal.

#### 6.9.2 ADC features available in LPC2292/LPC2294/01 only

- Every analog input has a dedicated result register to reduce interrupt overhead.
- Every analog input can generate an interrupt once the conversion is completed.
- The ADC pads are 5 V tolerant when configured for digital I/O function(s).

#### 6.10 CAN controllers and acceptance filter

The LPC2292/LPC2294 each contain two/four CAN controllers. The CAN is a serial communications protocol which efficiently supports distributed real-time control with a very high level of security. Its domain of application ranges from high-speed networks to low cost multiplex wiring.

#### 6.10.1 Features

- Data rates up to 1 Mbit/s on each bus.
- 32-bit register and RAM access.
- Compatible with CAN specification 2.0B, ISO 11898-1.
- Global Acceptance Filter recognizes 11-bit and 29-bit RX identifiers for all CAN buses.
- Acceptance Filter can provide FullCAN-style automatic reception for selected Standard identifiers.

#### **6.11 UARTs**

The LPC2292/LPC2294 each contain two UARTs. In addition to standard transmit and receive data lines, the UART1 also provides a full modem control handshake interface.

#### 6.11.1 Features

- 16 B Receive and Transmit FIFOs.
- Register locations conform to 16C550 industry standard.
- Receiver FIFO trigger points at 1 B, 4 B, 8 B, and 14 B
- Built-in fractional baud rate generator covering wide range of baud rates without a need for external crystals of particular values.
- Transmission FIFO control enables implementation of software (XON/XOFF) flow control on both UARTs.
- UART1 is equipped with standard modem interface signals. This module also provides full support for hardware flow control (auto-CTS/RTS).

#### 6.11.2 UART features available in LPC2292/LPC2294/01 only

Compared to previous LPC2000 microcontrollers, UARTs in LPC2292/LPC2294/01 introduce a fractional baud rate generator for both UARTs, enabling these microcontrollers to achieve standard baud rates such as 115200 Bd with any crystal frequency above 2 MHz. In addition, auto-CTS/RTS flow-control functions are fully implemented in hardware.

- Fractional baud rate generator enables standard baud rates such as 115200 Bd to be achieved with any crystal frequency above 2 MHz.
- Auto-bauding.
- Auto-CTS/RTS flow-control fully implemented in hardware.

#### 6.12 I<sup>2</sup>C-bus serial I/O controller

The I<sup>2</sup>C-bus is bidirectional, for inter-IC control using only two wires: a serial clock line (SCL), and a serial data line (SDA). Each device is recognized by a unique address and can operate as either a receiver-only device (e.g., an LCD driver or a transmitter with the

capability to both receive and send information (such as memory). Transmitters and/or receivers can operate in either master or slave mode, depending on whether the chip has to initiate a data transfer or is only addressed. The I<sup>2</sup>C-bus is a multi-master bus, it can be controlled by more than one bus master connected to it.

The  $I^2C$ -bus implemented in LPC2292/LPC2294 supports bit rate up to 400 kbit/s (Fast  $I^2C$ -bus).

#### 6.12.1 Features

- Compliant with standard I<sup>2</sup>C-bus interface.
- Easy to configure as master, slave, or master/slave.
- Programmable clocks allow versatile rate control.
- Bidirectional data transfer between masters and slaves.
- Multi-master bus (no central master).
- Arbitration between simultaneously transmitting masters without corruption of serial data on the bus.
- Serial clock synchronization allows devices with different bit rates to communicate via one serial bus.
- Serial clock synchronization can be used as a handshake mechanism to suspend and resume serial transfer.
- The I<sup>2</sup>C-bus may be used for test and diagnostic purposes.

#### 6.13 SPI serial I/O controller

The LPC2292/LPC2294 each contain two SPIs. The SPI is a full duplex serial interface, designed to be able to handle multiple masters and slaves connected to a given bus. Only a single master and a single slave can communicate on the interface during a given data transfer. During a data transfer the master always sends a byte of data to the slave, and the slave always sends a byte of data to the master.

#### 6.13.1 Features

- Compliant with Serial Peripheral Interface (SPI) specification.
- Synchronous, Serial, Full Duplex communication.
- Combined SPI master and slave.
- Maximum data bit rate of ½ of the input clock rate.

#### 6.13.2 Features available in LPC2292/LPC2294/01 only

- Eight to 16 bits per frame.
- When the SPI interface is used in Master mode, the SSELn pin is not needed (can be used for a different function).

#### 6.14 SSP controller (LPC2292/94/01 only)

The SSP is a controller capable of operation on a SPI, 4-wire SSI, or Microwire bus. It can interact with multiple masters and slaves on the bus. Only a single master and a single slave can communicate on the bus during a given data transfer. Data transfers are in principle full duplex, with frames of four to 16 bits of data flowing from the master to the slave and from the slave to the master.

While the SSP and SPI1 peripherals share the same physical pins, it is not possible to have both of these two peripherals active at the same time. Application can switch on the fly from SPI1 to SSP and back.

#### **6.14.1** Features

- Compatible with Motorola's SPI, Texas Instrument's 4-wire SSI, and National Semiconductor's Microwire buses.
- Synchronous serial communication.
- Master or slave operation.
- 8-frame FIFOs for both transmit and receive.
- Four to 16 bits per frame.

#### 6.15 General purpose timers

The Timer/Counter is designed to count cycles of the peripheral clock (PCLK) or an externally supplied clock and optionally generate interrupts or perform other actions at specified timer values, based on four match registers. It also includes four capture inputs to trap the timer value when an input signal transitions, optionally generating an interrupt. Multiple pins can be selected to perform a single capture or match function, providing an application with 'or' and 'and', as well as 'broadcast' functions among them.

#### 6.15.1 Features

- A 32-bit Timer/Counter with a programmable 32-bit Prescaler.
- Timer or external event counter operation
- Four 32-bit capture channels per timer that can take a snapshot of the timer value when an input signal transitions. A capture event may also optionally generate an interrupt.
- Four 32-bit match registers that allow:
  - Continuous operation with optional interrupt generation on match.
  - Stop timer on match with optional interrupt generation.
  - Reset timer on match with optional interrupt generation.
- Four external outputs per timer corresponding to match registers, with the following capabilities:

22 of 53

- Set LOW on match.
- Set HIGH on match.
- Toggle on match.
- Do nothing on match.

#### 6.15.2 Features available in LPC2292/LPC2294/01 only

The LPC2292/LPC2294/01 can count external events on one of the capture inputs if the external pulse lasts at least one half of the period of the PCLK. In this configuration, unused capture lines can be selected as regular timer capture inputs, or used as external interrupts.

- Timer can count cycles of either the peripheral clock (PCLK) or an externally supplied clock.
- When counting cycles of an externally supplied clock, only one of the timer's capture
  inputs can be selected as the timer's clock. The rate of such a clock is limited to
  PCLK / 4. Duration of HIGH/LOW levels on the selected CAP input cannot be shorter
  than 1 / (2PCLK).

#### 6.16 Watchdog timer

The purpose of the watchdog is to reset the microcontroller within a reasonable amount of time if it enters an erroneous state. When enabled, the watchdog will generate a system reset if the user program fails to 'feed' (or reload) the watchdog within a predetermined amount of time.

#### **6.16.1** Features

- · Internally resets chip if not periodically reloaded.
- Debug mode.
- Enabled by software but requires a hardware reset or a watchdog reset/interrupt to be disabled.
- Incorrect/incomplete feed sequence causes reset/interrupt if enabled.
- Flag to indicate watchdog reset.
- Programmable 32-bit timer with internal prescaler.
- Selectable time period from (T<sub>cy(PCLK)</sub> × 256 × 4) to (T<sub>cy(PCLK)</sub> × 2<sup>32</sup> × 4) in multiples of T<sub>cy(PCLK)</sub> × 4.

#### 6.17 Real-time clock

The Real-Time Clock (RTC) is designed to provide a set of counters to measure time when normal or idle operating mode is selected. The RTC has been designed to use little power, making it suitable for battery powered systems where the CPU is not running continuously (Idle mode).

#### 6.17.1 Features

- Measures the passage of time to maintain a calendar and clock.
- Ultra-low power design to support battery powered systems.
- Provides Seconds, Minutes, Hours, Day of Month, Month, Year, Day of Week, and Day of Year.
- Programmable Reference Clock Divider allows adjustment of the RTC to match various crystal frequencies.

#### 6.18 Pulse width modulator

The PWM is based on the standard Timer block and inherits all of its features, although only the PWM function is pinned out on the LPC2292/LPC2294. The Timer is designed to count cycles of the peripheral clock (PCLK) and optionally generate interrupts or perform other actions when specified timer values occur, based on seven match registers. The PWM function is also based on match register events.

The ability to separately control rising and falling edge locations allows the PWM to be used for more applications. For instance, multi-phase motor control typically requires three non-overlapping PWM outputs with individual control of all three pulse widths and positions.

Two match registers can be used to provide a single edge controlled PWM output. One match register (MR0) controls the PWM cycle rate, by resetting the count upon match. The other match register controls the PWM edge position. Additional single edge controlled PWM outputs require only one match register each, since the repetition rate is the same for all PWM outputs. Multiple single edge controlled PWM outputs will all have a rising edge at the beginning of each PWM cycle, when an MR0 match occurs.

Three match registers can be used to provide a PWM output with both edges controlled. Again, the MR0 match register controls the PWM cycle rate. The other match registers control the two PWM edge positions. Additional double edge controlled PWM outputs require only two match registers each, since the repetition rate is the same for all PWM outputs.

With double edge controlled PWM outputs, specific match registers control the rising and falling edge of the output. This allows both positive going PWM pulses (when the rising edge occurs prior to the falling edge), and negative going PWM pulses (when the falling edge occurs prior to the rising edge).

#### 6.18.1 Features

- Seven match registers allow up to six single edge controlled or three double edge controlled PWM outputs, or a mix of both types.
- The match registers also allow:
  - Continuous operation with optional interrupt generation on match.
  - Stop timer on match with optional interrupt generation.
  - Reset timer on match with optional interrupt generation.
- Supports single edge controlled and/or double edge controlled PWM outputs. Single
  edge controlled PWM outputs all go HIGH at the beginning of each cycle unless the
  output is a constant LOW. Double edge controlled PWM outputs can have either edge
  occur at any position within a cycle. This allows for both positive going and negative
  going pulses.
- Pulse period and width can be any number of timer counts. This allows complete
  flexibility in the trade-off between resolution and repetition rate. All PWM outputs will
  occur at the same repetition rate.
- Double edge controlled PWM outputs can be programmed to be either positive going or negative going pulses.

- Match register updates are synchronized with pulse outputs to prevent generation of erroneous pulses. Software must 'release' new match values before they can become effective.
- May be used as a standard timer if the PWM mode is not enabled.
- A 32-bit Timer/Counter with a programmable 32-bit prescaler.

#### 6.19 System control

#### 6.19.1 Crystal oscillator

The oscillator supports crystals in the range of 1 MHz to 25 MHz. The oscillator output frequency is called f<sub>osc</sub> and the ARM processor clock frequency is referred to as CCLK for purposes of rate equations, etc. f<sub>osc</sub> and CCLK are the same value unless the PLL is running and connected. Refer to Section 6.19.2 "PLL" for additional information.

#### 6.19.2 PLL

The PLL accepts an input clock frequency in the range of 10 MHz to 25 MHz. The input frequency is multiplied up into the range of 10 MHz to 60 MHz with a Current Controlled Oscillator (CCO). The multiplier can be an integer value from 1 to 32 (in practice, the multiplier value cannot be higher than 6 on this family of microcontrollers due to the upper frequency limit of the CPU). The CCO operates in the range of 156 MHz to 320 MHz, so there is an additional divider in the loop to keep the CCO within its frequency range while the PLL is providing the desired output frequency. The output divider may be set to divide by 2, 4, 8, or 16 to produce the output clock. Since the minimum output divider value is 2, it is insured that the PLL output has a 50 % duty cycle. The PLL is turned off and bypassed following a chip reset and may be enabled by software. The program must configure and activate the PLL, wait for the PLL to Lock, then connect to the PLL as a clock source. The PLL settling time is 100  $\mu$ s.

## 6.19.3 Reset and wake-up timer

Reset has two sources on the LPC2292/LPC2294: the  $\overline{\text{RESET}}$  pin and watchdog reset. The  $\overline{\text{RESET}}$  pin is a Schmitt trigger input pin with an additional glitch filter. Assertion of chip reset by any source starts the Wake-up Timer (see Wake-up Timer description below), causing the internal chip reset to remain asserted until the external reset is de-asserted, the oscillator is running, a fixed number of clocks have passed, and the on-chip flash controller has completed its initialization.

When the internal reset is removed, the processor begins executing at address 0, which is the reset vector. At that point, all of the processor and peripheral registers have been initialized to predetermined values.

The Wake-up Timer ensures that the oscillator and other analog functions required for chip operation are fully functional before the processor is allowed to execute instructions. This is important at power-on, all types of reset, and whenever any of the aforementioned functions are turned off for any reason. Since the oscillator and other functions are turned off during Power-down mode, any wake-up of the processor from Power-down mode makes use of the Wake-up Timer.

The Wake-up Timer monitors the crystal oscillator as the means of checking whether it is safe to begin code execution. When power is applied to the chip, or some event caused the chip to exit Power-down mode, some time is required for the oscillator to produce a signal of sufficient amplitude to drive the clock logic. The amount of time depends on many factors, including the rate of  $V_{DD}$  ramp (in the case of power-on), the type of crystal and its electrical characteristics (if a quartz crystal is used), as well as any other external circuitry (e.g. capacitors), and the characteristics of the oscillator itself under the existing ambient conditions.

#### 6.19.4 Code security (Code Read Protection - CRP)

This feature of the LPC2292/LPC2294/01 allows the user to enable different levels of security in the system so that access to the on-chip flash and use of the JTAG and ISP can be restricted. When needed, CRP is invoked by programming a specific pattern into a dedicated flash location. IAP commands are not affected by the CRP.

There are three levels of the Code Read Protection.

CRP1 disables access to chip via the JTAG and allows partial flash update (excluding flash sector 0) using a limited set of the ISP commands. This mode is useful when CRP is required and flash field updates are needed but all sectors can not be erased.

CRP2 disables access to chip via the JTAG and only allows full flash erase and update using a reduced set of the ISP commands.

Running an application with level CRP3 selected fully disables any access to chip via the JTAG pins and the ISP. This mode effectively disables ISP override using P0[14] pin, too. It is up to the user's application to provide (if needed) flash update mechanism using IAP calls or call reinvoke ISP command to enable flash update via UART0.

#### **CAUTION**



If level three Code Read Protection (CRP3) is selected, no future factory testing can be performed on the device.

**Remark:** Devices without a /00 or /01 in the name have only a security level equivalent to CRP2 available.

#### 6.19.5 External interrupt inputs

The LPC2292/LPC2294 include up to nine edge or level sensitive External Interrupt Inputs as selectable pin functions. When the pins are combined, external events can be processed as four independent interrupt signals. The External Interrupt Inputs can optionally be used to wake up the processor from Power-down mode.

#### 6.19.6 Memory mapping control

The Memory Mapping Control alters the mapping of the interrupt vectors that appear beginning at address 0x0000 0000. Vectors may be mapped to the bottom of the on-chip flash memory, or to the on-chip static RAM. This allows code running in different memory spaces to have control of the interrupts.

#### 6.19.7 Power control

The LPC2292/LPC2294 support two reduced power modes: Idle mode and Power-down mode. In Idle mode, execution of instructions is suspended until either a reset or interrupt occurs. Peripheral functions continue operation during Idle mode and may generate interrupts to cause the processor to resume execution. Idle mode eliminates power used by the processor itself, memory systems and related controllers, and internal buses.

In Power-down mode, the oscillator is shut down, and the chip receives no internal clocks. The processor state and registers, peripheral registers, and internal SRAM values are preserved throughout Power-down mode, and the logic levels of chip output pins remain static. The Power-down mode can be terminated and normal operation resumed by either a reset or certain specific interrupts that are able to function without clocks. Since all dynamic operation of the chip is suspended, Power-down mode reduces chip power consumption to nearly zero.

A Power Control for Peripherals feature allows individual peripherals to be turned off if they are not needed in the application, resulting in additional power savings.

#### 6.19.8 APB bus

The APB divider determines the relationship between the processor clock (CCLK) and the clock used by peripheral devices (PCLK). The APB divider serves two purposes. The first is to provide peripherals with the desired PCLK via APB bus so that they can operate at the speed chosen for the ARM processor. In order to achieve this, the APB bus may be slowed down to  $\frac{1}{2}$  to  $\frac{1}{4}$  of the processor clock rate. Because the APB bus must work properly at power-up (and its timing cannot be altered if it does not work since the APB divider control registers reside on the APB bus), the default condition at reset is for the APB bus to run at  $\frac{1}{4}$  of the processor clock rate. The second purpose of the APB divider is to allow power savings when an application does not require any peripherals to run at the full processor rate. Because the APB divider is connected to the PLL output, the PLL remains active (if it was running) during Idle mode.

#### 6.20 Emulation and debugging

The LPC2292/LPC2294 support emulation and debugging via a JTAG serial port. A trace port allows tracing program execution. Debugging and trace functions are multiplexed only with GPIOs on Port 1. This means that all communication, timer and interface peripherals residing on Port 0 are available during the development and debugging phase as they are when the application is run in the embedded system itself.

#### 6.20.1 EmbeddedICE

Standard ARM EmbeddedICE logic provides on-chip debug support. The debugging of the target system requires a host computer running the debugger software and an EmbeddedICE protocol converter. EmbeddedICE protocol converter converts the remote debug protocol commands to the JTAG data needed to access the ARM core.

The ARM core has a Debug Communication Channel function built-in. The debug communication channel allows a program running on the target to communicate with the host debugger or another separate host without stopping the program flow or even entering the debug state. The debug communication channel is accessed as a co-processor 14 by the program running on the ARM7TDMI-S core. The debug

communication channel allows the JTAG port to be used for sending and receiving data without affecting the normal program flow. The debug communication channel data and control registers are mapped in to addresses in the EmbeddedICE logic.

The JTAG clock (TCK) must be slower than  $\frac{1}{6}$  of the CPU clock (CCLK) for the JTAG interface to operate.

#### 6.20.2 Embedded trace

Since the LPC2292/LPC2294 have significant amounts of on-chip memory, it is not possible to determine how the processor core is operating simply by observing the external pins. The Embedded Trace Macrocell (ETM) provides real-time trace capability for deeply embedded processor cores. It outputs information about processor execution to the trace port.

The ETM is connected directly to the ARM core and not to the main AMBA system bus. It compresses the trace information and exports it through a narrow trace port. An external trace port analyzer must capture the trace information under software debugger control. Instruction trace (or PC trace) shows the flow of execution of the processor and provides a list of all the instructions that were executed. Instruction trace is significantly compressed by only broadcasting branch addresses as well as a set of status signals that indicate the pipeline status on a cycle by cycle basis. Trace information generation can be controlled by selecting the trigger resource. Trigger resources include address comparators, counters and sequencers. Since trace information is compressed the software debugger requires a static image of the code being executed. Self-modifying code cannot be traced because of this restriction.

#### 6.20.3 RealMonitor

RealMonitor is a configurable software module, developed by ARM Inc., which enables real-time debug. It is a lightweight debug monitor that runs in the background while users debug their foreground application. It communicates with the host using the Debug Communications Channel (DCC), which is present in the EmbeddedICE logic. The LPC2292/LPC2294 contain a specific configuration of RealMonitor software programmed into the on-chip flash memory.

## 7. Limiting values

Table 6. Limiting values

In accordance with the Absolute Maximum Rating System (IEC 60134).[1]

| Symbol                 | Parameter                             | Conditions                                                         |               | Min   | Max                 | Unit |
|------------------------|---------------------------------------|--------------------------------------------------------------------|---------------|-------|---------------------|------|
| $V_{DD(1V8)}$          | supply voltage (1.8 V)                |                                                                    | <u>[2]</u>    | -0.5  | +2.5                | V    |
| $V_{DD(3V3)}$          | supply voltage (3.3 V)                |                                                                    | <u>[3]</u>    | -0.5  | +3.6                | V    |
| $V_{\text{DDA(3V3)}}$  | analog supply voltage (3.3 V)         |                                                                    |               | -0.5  | +4.6                | V    |
| $V_{IA}$               | analog input voltage                  |                                                                    |               | -0.5  | +5.1                | V    |
| $V_{I}$                | input voltage                         | 5 V tolerant I/O pins                                              | <u>[4][5]</u> | -0.5  | +6.0                | V    |
|                        |                                       | other I/O pins                                                     | [4][6]        | -0.5  | $V_{DD(3V3)} + 0.5$ | V    |
| $I_{DD}$               | supply current                        |                                                                    | [7][8]        | -     | 100                 | mA   |
| I <sub>SS</sub>        | ground current                        |                                                                    | [8][9]        | -     | 100                 | mA   |
| Tj                     | junction temperature                  |                                                                    |               | -     | 150                 | °C   |
| T <sub>stg</sub>       | storage temperature                   |                                                                    | [10]          | -65   | +150                | °C   |
| P <sub>tot(pack)</sub> | total power dissipation (per package) | based on package heat<br>transfer, not device<br>power consumption |               | -     | 1.5                 | W    |
| V <sub>esd</sub>       | electrostatic discharge voltage       | human body model                                                   | [11]          |       |                     |      |
|                        |                                       | all pins                                                           |               | -2000 | +2000               | V    |
|                        |                                       |                                                                    |               |       |                     |      |

- [1] The following applies to Table 6:
  - a) This product includes circuitry specifically designed for the protection of its internal devices from the damaging effects of excessive static charge. Nonetheless, it is suggested that conventional precautions be taken to avoid applying greater than the rated maximum.
  - b) Parameters are valid over operating temperature range unless otherwise specified. All voltages are with respect to V<sub>SS</sub> unless otherwise noted.
- [2] Internal rail.
- [3] External rail.
- [4] Including voltage on outputs in 3-state mode.
- [5] Only valid when the V<sub>DD(3V3)</sub> supply voltage is present.
- [6] Not to exceed 4.6 V.
- [7] Per supply pin.
- [8] The peak current is limited to 25 times the corresponding maximum current.
- [9] Per ground pin.
- [10] Dependent on package type.
- [11] Human body model: equivalent to discharging a 100 pF capacitor through a 1.5 k $\Omega$  series resistor.

## 8. Static characteristics

Table 7. Static characteristics

 $T_{amb}$  = -40 °C to +125 °C, unless otherwise specified.

| Symbol                | Parameter                               | Conditions                                                                  |               | Min                 | Typ[1] | Max           | Unit |
|-----------------------|-----------------------------------------|-----------------------------------------------------------------------------|---------------|---------------------|--------|---------------|------|
| V <sub>DD(1V8)</sub>  | supply voltage (1.8 V)                  |                                                                             | [2]           | 1.65                | 1.8    | 1.95          | V    |
| V <sub>DD(3V3)</sub>  | supply voltage (3.3 V)                  |                                                                             | [3]           | 3.0                 | 3.3    | 3.6           | V    |
| V <sub>DDA(3V3)</sub> | analog supply voltage (3.3 V)           |                                                                             |               | 2.5                 | 3.3    | 3.6           | V    |
| Standard              | port pins, RESET, RTCK                  |                                                                             |               |                     |        |               |      |
| I <sub>IL</sub>       | LOW-level input current                 | V <sub>I</sub> = 0 V; no pull-up                                            |               | -                   | -      | 3             | μΑ   |
| I <sub>IH</sub>       | HIGH-level input current                | $V_I = V_{DD(3V3)}$ ; no pull-down                                          |               | -                   | -      | 3             | μΑ   |
| l <sub>OZ</sub>       | OFF-state output current                | $V_O = 0 V$ , $V_O = V_{DD(3V3)}$ ;<br>no pull-up/down                      |               | -                   | -      | 3             | μΑ   |
| I <sub>latch</sub>    | I/O latch-up current                    | $-(0.5V_{DD(3V3)}) < V_{I} < (1.5V_{DD(3V3)}); T_{j} < 125 °C$              |               | 100                 | -      | -             | mA   |
| VI                    | input voltage                           |                                                                             | [4][5]<br>[6] | 0                   | -      | 5.5           | V    |
| Vo                    | output voltage                          | output active                                                               |               | 0                   | -      | $V_{DD(3V3)}$ | V    |
| $V_{IH}$              | HIGH-level input voltage                |                                                                             |               | 2.0                 | -      | -             | V    |
| $V_{IL}$              | LOW-level input voltage                 |                                                                             |               | -                   | -      | 0.8           | V    |
| $V_{hys}$             | hysteresis voltage                      |                                                                             |               | 0.4                 | -      | -             | V    |
| $V_{OH}$              | HIGH-level output voltage               | $I_{OH} = -4 \text{ mA}$                                                    | <u>[7]</u>    | $V_{DD(3V3)} - 0.4$ | -      | -             | V    |
| $V_{OL}$              | LOW-level output voltage                | $I_{OL} = 4 \text{ mA}$                                                     | <u>[7]</u>    | -                   | -      | 0.4           | V    |
| I <sub>OH</sub>       | HIGH-level output current               | $V_{OH} = V_{DD(3V3)} - 0.4 \text{ V}$                                      | <u>[7]</u>    | -4                  | -      | -             | mA   |
| I <sub>OL</sub>       | LOW-level output current                | V <sub>OL</sub> = 0.4 V                                                     | <u>[7]</u>    | 4                   | -      | -             | mA   |
| I <sub>OHS</sub>      | HIGH-level short-circuit output current | $V_{OH} = 0 V$                                                              | [8]           | -                   | -      | <b>–45</b>    | mA   |
| I <sub>OLS</sub>      | LOW-level short-circuit output current  | $V_{OL} = V_{DD(3V3)}$                                                      | [8]           | -                   | -      | 50            | mA   |
| I <sub>pd</sub>       | pull-down current                       | V <sub>I</sub> = 5 V                                                        | [9]           | 10                  | 50     | 150           | μΑ   |
| I <sub>pu</sub>       | pull-up current                         | $V_I = 0 V$                                                                 | [10]          | -15                 | -50    | -85           | μΑ   |
|                       |                                         | $V_{DD(3V3)} < V_{I} < 5 V$                                                 | [9]           | 0                   | 0      | 0             | μΑ   |
| Power co              | nsumption LPC2292, LPC22                | 292/00, LPC2294, LPC2294/0                                                  | 0             |                     |        |               |      |
| I <sub>DD(act)</sub>  | active mode supply current              | CCLK = 60 MHz;<br>$T_{amb} = 25$ °C; code                                   |               | -                   | 50     | -             | mA   |
|                       |                                         | while(1){}                                                                  |               |                     |        |               |      |
|                       |                                         | executed from flash; all peripherals enabled via PCONP[11] register but not |               |                     |        |               |      |

LPC2292\_2294\_7 © NXP B.V. 2008. All rights reserved.

configured to run

 Table 7.
 Static characteristics ...continued

 $T_{amb}$  = -40 °C to +125 °C, unless otherwise specified.

| Symbol                 | Parameter                      | Conditions                                                                                                 | Min                     | Typ[1]                  | Max                     | Unit |
|------------------------|--------------------------------|------------------------------------------------------------------------------------------------------------|-------------------------|-------------------------|-------------------------|------|
| I <sub>DD(pd)</sub>    | Power-down mode supply current | $V_{DD(1V8)} = 1.8 \text{ V};$<br>$T_{amb} = 25 ^{\circ}\text{C}$                                          | -                       | 10                      | -                       | μΑ   |
|                        |                                | $V_{DD(1V8)} = 1.8 \text{ V};$<br>$T_{amb} = 85 ^{\circ}\text{C}$                                          | -                       | 110                     | 500                     | μΑ   |
|                        |                                | $V_{DD(1V8)} = 1.8 \text{ V};$<br>$T_{amb} = 125 ^{\circ}\text{C}$                                         | -                       | 300                     | 1000                    | μΑ   |
| Power co               | onsumption LPC2292/01 and      | LPC2294/01                                                                                                 |                         |                         |                         |      |
| I <sub>DD(act)</sub>   | active mode supply current     | $V_{DD(1V8)} = 1.8 \text{ V};$ $CCLK = 60 \text{ MHz};$ $T_{amb} = 25 \text{ °C}; \text{ code}$ while(1){} | -                       | 45                      | -                       | mA   |
|                        |                                | executed from flash; all peripherals enabled via PCONP[11] register but not configured to run              |                         |                         |                         |      |
| I <sub>DD(idle)</sub>  | Idle mode supply current       | $V_{DD(1V8)} = 1.8 \text{ V};$<br>CCLK = 60  MHz;<br>$T_{amb} = 25 ^{\circ}C;$                             | -                       | 11.5                    | -                       | mA   |
|                        |                                | executed from flash; all peripherals enabled via PCONP[11] register but not configured to run              |                         |                         |                         |      |
| I <sub>DD(pd)</sub>    | Power-down mode supply current | $V_{DD(1V8)} = 1.8 \text{ V};$<br>$T_{amb} = 25 ^{\circ}\text{C}$                                          | -                       | 10                      | -                       | μΑ   |
|                        |                                | $V_{DD(1V8)} = 1.8 \text{ V};$ $T_{amb} = 85 ^{\circ}\text{C}$                                             | -                       | -                       | 180                     | μΑ   |
|                        |                                | $V_{DD(1V8)} = 1.8 \text{ V};$<br>$T_{amb} = 125 ^{\circ}\text{C}$                                         | -                       | -                       | 430                     | μΑ   |
| I <sup>2</sup> C-bus p | oins                           |                                                                                                            |                         |                         |                         |      |
| $V_{IH}$               | HIGH-level input voltage       |                                                                                                            | 0.7V <sub>DD(3V3)</sub> | -                       | -                       | V    |
| $V_{IL}$               | LOW-level input voltage        |                                                                                                            | -                       | -                       | 0.3V <sub>DD(3V3)</sub> | V    |
| $V_{hys}$              | hysteresis voltage             |                                                                                                            | -                       | 0.5V <sub>DD(3V3)</sub> | -                       | V    |
| $V_{OL}$               | LOW-level output voltage       | $I_{OLS} = 3 \text{ mA}$                                                                                   | <u>[7]</u> _            | -                       | 0.4                     | V    |
| I <sub>LI</sub>        | input leakage current          | $V_I = V_{DD(3V3)}$                                                                                        | [12]                    | 2                       | 4                       | μΑ   |
|                        |                                | $V_I = 5 V$                                                                                                | -                       | 10                      | 22                      | μΑ   |

Table 7. Static characteristics ... continued

 $T_{amb}$  = -40 °C to +125 °C, unless otherwise specified.

| arrie.                | · ·                            | •          |     |        |     |      |
|-----------------------|--------------------------------|------------|-----|--------|-----|------|
| Symbol                | Parameter                      | Conditions | Min | Typ[1] | Max | Unit |
| Oscillator            | r pins                         |            |     |        |     |      |
| V <sub>i(XTAL1)</sub> | input voltage on pin XTAL1     |            | 0   | -      | 1.8 | V    |
| $V_{o(XTAL2)}$        | output voltage on pin<br>XTAL2 |            | 0   | -      | 1.8 | V    |

- [1] Typical ratings are not guaranteed. The values listed are at room temperature (+25 °C), nominal supply voltages.
- [2] Internal rail.
- [3] External rail.
- [4] Including voltage on outputs in 3-state mode.
- [5] V<sub>DD(3V3)</sub> supply voltages must be present.
- [6] 3-state outputs go into 3-state mode when V<sub>DD(3V3)</sub> is grounded.
- [7] Accounts for 100 mV voltage drop in all supply lines.
- [8] Allowed as long as the current limit does not exceed the maximum current allowed by the device.
- [9] Minimum condition for  $V_1 = 4.5 \text{ V}$ , maximum condition for  $V_1 = 5.5 \text{ V}$ .
- [10] Applies to P1[25:16].
- [11] See the LPC2119/2129/2194/2292/2294 User Manual.
- [12] To V<sub>SS</sub>.

Table 8. ADC static characteristics

V<sub>DDA</sub> = 2.5 V to 3.6 V; T<sub>amb</sub> = -40 °C to +125 °C unless otherwise specified. ADC frequency 4.5 MHz.

|      |                              | · · · · · · · · · · · · · · · · · · · |            | <u> </u> |           |      |
|------|------------------------------|---------------------------------------|------------|----------|-----------|------|
| mbol | Parameter                    | Conditions                            | Min        | Тур      | Max       | Unit |
|      | analog input voltage         |                                       | 0          | -        | $V_{DDA}$ | V    |
|      | analog input capacitance     |                                       | -          | -        | 1         | pF   |
|      | differential linearity error | [1][2                                 | -<br>2][3] | -        | ±1        | LSB  |
| adj) | integral non-linearity       | <u>[</u>                              | 1][4]      | -        | ±2        | LSB  |
|      | offset error                 | <u>[</u>                              | 1][5] _    | -        | ±3        | LSB  |
|      | gain error                   | <u>[</u>                              | 1][6]      | -        | ±0.5      | %    |
|      | absolute error               | <u>[</u>                              | 1][7] _    | -        | ±4        | LSB  |
|      | gain error                   | <u>[</u>                              | 1][6]      | -        | ±0.5      | _    |

- [1] Conditions:  $V_{SSA} = 0 \text{ V}$ ,  $V_{DDA} = 3.3 \text{ V}$ .
- [2] The ADC is monotonic, there are no missing codes.
- [3] The differential linearity error (ED) is the difference between the actual step width and the ideal step width. See Figure 5.
- [4] The integral non-linearity (E<sub>L(adj)</sub>) is the peak difference between the center of the steps of the actual and the ideal transfer curve after appropriate adjustment of gain and offset errors. See Figure 5.
- [5] The offset error (E<sub>O</sub>) is the absolute difference between the straight line which fits the actual curve and the straight line which fits the ideal curve. See Figure 5.
- [6] The gain error (E<sub>G</sub>) is the relative difference in percent between the straight line fitting the actual transfer curve after removing offset error, and the straight line which fits the ideal transfer curve. See Figure 5.
- [7] The absolute voltage error (E<sub>T</sub>) is the maximum difference between the center of the steps of the actual transfer curve of the non-calibrated ADC and the ideal transfer curve. See Figure 5.



- (4) Integral non-linearity (E<sub>L(adj)</sub>).
- (5) Center of a step of the actual transfer curve.

Fig 5. ADC characteristics

## 8.1 Power consumption measurements for LPC2292/01 and LPC2294/01

The power consumption measurements represent typical values for the given conditions. The peripherals were enabled through the PCONP register, but for these measurements, the peripherals were not configured to run. Peripherals were disabled through the PCONP register. For a description of the PCONP register bits, refer to the LPC2119/2129/2194/2292/2294 User Manual.





















Test conditions: Active mode entered executing code from on-chip flash; PCLK =  $^{\text{CCLK}}_{4}$ ; core voltage 1.8 V; all peripherals disabled.

Fig 15. Typical LPC2294/01 I<sub>DD(act)</sub> measured at different temperatures







Test conditions: Idle mode entered executing code from on-chip flash; PCLK =  $^{\text{CCLK}}_{4}$ ; core voltage 1.8 V; all peripherals disabled.

Fig 18. Typical LPC2294/01 I<sub>DD(idle)</sub> measured at different temperatures



Test conditions: Power-down mode entered executing code from on-chip flash.

Fig 19. Typical LPC2294/01 core power-down current  $I_{\text{DD(pd)}}$  measured at different temperatures





Table 9. Typical LPC2292/01 peripheral power consumption in active mode Core voltage 1.8 V:  $T_{amb} = 25 \,^{\circ}$ C: all measurements in µA: PCLK =  $^{CCLK}/_{4}$ ; all peripherals enabled.

| core venage ne v, | Tamb = 20 0, an incadaro | σ μ. ι, ι σ <u>ε</u> ιι = | 74, an pempinerale enabled. |
|-------------------|--------------------------|---------------------------|-----------------------------|
| Peripheral        | CCLK = 12 MHz            | CCLK = 48 MHz             | CCLK = 60 MHz               |
| Timer0            | 43                       | 141                       | 184                         |
| Timer1            | 46                       | 150                       | 180                         |
| UART0             | 98                       | 320                       | 398                         |
| UART1             | 103                      | 351                       | 421                         |

LPC2292\_2294\_7 © NXP B.V. 2008. All rights reserved.

Table 9. Typical LPC2292/01 peripheral power consumption in active mode ...continued Core voltage 1.8 V;  $T_{amb} = 25 \,^{\circ}$ C; all measurements in  $\mu$ A;  $PCLK = {^{CCLK}/_4}$ ; all peripherals enabled.

| Peripheral           | CCLK = 12 MHz | CCLK = 48 MHz | CCLK = 60 MHz |
|----------------------|---------------|---------------|---------------|
| PWM0                 | 103           | 341           | 407           |
| I <sup>2</sup> C-bus | 9             | 37            | 53            |
| SPI0/1               | 6             | 27            | 29            |
| RTC                  | 16            | 55            | 78            |
| PCEMC                | 306           | 994           | 1205          |
| ADC                  | 33            | 128           | 167           |
| CAN1/2               | 229           | 771           | 914           |

Table 10. Typical LPC2294/01 peripheral power consumption in active mode

Core voltage 1.8 V;  $T_{amb} = 25 \,^{\circ}$ C; all measurements in  $\mu$ A;  $PCLK = {CCLK}/{4}$ ; all peripherals enabled.

| Peripheral           | CCLK = 12 MHz | CCLK = 48 MHz | CCLK = 60 MHz |
|----------------------|---------------|---------------|---------------|
| Timer0               | 43            | 141           | 184           |
| Timer1               | 46            | 150           | 180           |
| UART0                | 98            | 320           | 398           |
| UART1                | 103           | 351           | 421           |
| PWM0                 | 103           | 341           | 407           |
| I <sup>2</sup> C-bus | 9             | 37            | 53            |
| SPI0/1               | 6             | 27            | 29            |
| RTC                  | 16            | 55            | 78            |
| PCEMC                | 306           | 994           | 1205          |
| ADC                  | 33            | 128           | 167           |
| CAN1/2/3/4           | 230           | 769           | 912           |

# 9. Dynamic characteristics

Table 11. Dynamic characteristics

 $T_{amb}$  = -40 °C to +125 °C;  $V_{DD(1V8)}$ ,  $V_{DD(3V3)}$  over specified ranges.[1]

| u                    | , 55(110); 55(       | 1 0                                                                                    |                                 |     |      |      |
|----------------------|----------------------|----------------------------------------------------------------------------------------|---------------------------------|-----|------|------|
| Symbol               | Parameter            | Conditions                                                                             | Min                             | Тур | Max  | Unit |
| External clock       |                      |                                                                                        |                                 |     |      |      |
| f <sub>osc</sub>     | oscillator frequency | supplied by an external oscillator (signal generator)                                  | 1                               | -   | 25   | MHz  |
|                      |                      | external clock frequency<br>supplied by an external<br>crystal oscillator              | 1                               | -   | 25   | MHz  |
|                      |                      | external clock frequency if on-chip PLL is used                                        | 10                              | -   | 25   | MHz  |
|                      |                      | external clock frequency if<br>on-chip bootloader is used<br>for initial code download | 10                              | -   | 25   | MHz  |
| T <sub>cy(clk)</sub> | clock cycle time     |                                                                                        | 20                              | -   | 1000 | ns   |
| t <sub>CHCX</sub>    | clock HIGH time      |                                                                                        | $T_{\text{cy(clk)}} \times 0.4$ | -   | -    | ns   |
| t <sub>CLCX</sub>    | clock LOW time       |                                                                                        | $T_{cy(clk)} \times 0.4$        | -   | -    | ns   |

LPC2292\_2294\_7 © NXP B.V. 2008. All rights reserved.

 Table 11.
 Dynamic characteristics ...continued

 $T_{amb} = -40 \,^{\circ}C$  to +125  $^{\circ}C$ ;  $V_{DD(1V8)}$ ,  $V_{DD(3V3)}$  over specified ranges.[1]

| Symbol                    | Parameter             | Conditions           | Min            | Тур              | Max | Unit |
|---------------------------|-----------------------|----------------------|----------------|------------------|-----|------|
| t <sub>CLCH</sub>         | clock rise time       |                      | -              | -                | 5   | ns   |
| t <sub>CHCL</sub>         | clock fall time       |                      | -              | -                | 5   | ns   |
| Port pins (ex             | cept P0[2] and P0[3]) |                      |                |                  |     |      |
| t <sub>r</sub>            | rise time             |                      | -              | 10               | -   | ns   |
| t <sub>f</sub>            | fall time             |                      | -              | 10               | -   | ns   |
| I <sup>2</sup> C-bus pins | (P0[2] and P0[3])     |                      |                |                  |     |      |
| t <sub>f</sub>            | fall time             | $V_{IH}$ to $V_{IL}$ | [2] 20 + 0.1 × | C <sub>b</sub> - | -   | ns   |

<sup>[1]</sup> Parameters are valid over operating temperature range unless otherwise specified.

<sup>[2]</sup> Bus capacitance  $C_b$  in pF, from 10 pF to 400 pF.

Table 12. External memory interface dynamic characteristics

 $C_L = 25$  pF,  $T_{amb} = 40$  °C

| Symbol                | Parameter                                                     | Conditions | Min                                                      | Тур | Max                                  | Unit |
|-----------------------|---------------------------------------------------------------|------------|----------------------------------------------------------|-----|--------------------------------------|------|
| Common                | to read and write cycles                                      |            |                                                          |     |                                      |      |
| t <sub>CHAV</sub>     | XCLK HIGH to address valid time                               |            | -                                                        | -   | 10                                   | ns   |
| t <sub>CHCSL</sub>    | XCLK HIGH to $\overline{\text{CS}}$ LOW time                  |            | -                                                        | -   | 10                                   | ns   |
| tснсsн                | XCLK HIGH to $\overline{\text{CS}}$ HIGH time                 |            | -                                                        | -   | 10                                   | ns   |
| t <sub>CHANV</sub>    | XCLK HIGH to address invalid time                             |            | -                                                        | -   | 10                                   | ns   |
| Read cycl             | le parameters                                                 |            |                                                          |     |                                      |      |
| t <sub>CSLAV</sub>    | CS LOW to address valid time                                  | [1]        | -5                                                       | -   | +10                                  | ns   |
| t <sub>OELAV</sub>    | OE LOW to address valid time                                  | [1]        | -5                                                       | -   | +10                                  | ns   |
| tcsloel               | $\overline{\text{CS}}$ LOW to $\overline{\text{OE}}$ LOW time |            | -5                                                       | -   | +5                                   | ns   |
| t <sub>am</sub>       | memory access time                                            | [2][3]     | $(T_{cy(CCLK)} \times (2 + WST1)) + (-20)$               | -   | -                                    | ns   |
| t <sub>am(ibr)</sub>  | memory access time (initial burst-ROM)                        | [2][3]     | $(T_{\text{cy(CCLK})} \times (2 + \text{WST1})) + (-20)$ | -   | -                                    | ns   |
| t <sub>am(sbr)</sub>  | memory access time (subsequent burst-ROM)                     | [2][4]     | $T_{\text{cy(CCLK)}} + (-20)$                            | -   | -                                    | ns   |
| t <sub>h(D)</sub>     | data input hold time                                          | [5]        | 0                                                        | -   | -                                    | ns   |
| t <sub>CSHOEH</sub>   | CS HIGH to OE HIGH time                                       |            | -5                                                       | -   | +5                                   | ns   |
| t <sub>OEHANV</sub>   | OE HIGH to address invalid time                               |            | -5                                                       | -   | +5                                   | ns   |
| t <sub>CHOEL</sub>    | XCLK HIGH to $\overline{\text{OE}}$ LOW time                  |            | -5                                                       | -   | +5                                   | ns   |
| tсноен                | XCLK HIGH to $\overline{\text{OE}}$ HIGH time                 |            | -5                                                       | -   | +5                                   | ns   |
| Write cyc             | le parameters                                                 |            |                                                          |     |                                      |      |
| t <sub>AVCSL</sub>    | address valid to $\overline{\text{CS}}$ LOW time              | [1]        | T <sub>cy(CCLK)</sub> – 10                               | -   | -                                    | ns   |
| t <sub>CSLDV</sub>    | CS LOW to data valid time                                     |            | -5                                                       | -   | +5                                   | ns   |
| t <sub>CSLWEL</sub>   | CS LOW to WE LOW time                                         |            | -5                                                       | -   | +5                                   | ns   |
| tcslblsl              | CS LOW to BLS LOW time                                        |            | -5                                                       | -   | +5                                   | ns   |
| t <sub>WELDV</sub>    | WE LOW to data valid time                                     |            | -5                                                       | -   | +5                                   | ns   |
| t <sub>CSLDV</sub>    | CS LOW to data valid time                                     |            | -5                                                       | -   | +5                                   | ns   |
| t <sub>WELWEH</sub>   | WE LOW to WE HIGH time                                        | [2]        | $T_{\text{cy(CCLK)}} \times (1 + \text{WST2}) - 5$       | -   | $T_{cy(CCLK)} \times (1 + WST2) + 5$ | ns   |
| t <sub>BLSLBLSH</sub> | BLS LOW to BLS HIGH time                                      | [2]        | $T_{\text{cy(CCLK)}} \times (1 + \text{WST2}) - 5$       | -   | $T_{cy(CCLK)} \times (1 + WST2) + 5$ | ns   |
| t <sub>WEHANV</sub>   | WE HIGH to address invalid time                               | [2]        | T <sub>cy(CCLK)</sub> – 5                                | -   | $T_{cy(CCLK)} + 5$                   | ns   |
| t <sub>WEHDNV</sub>   | WE HIGH to data invalid time                                  | [2]        | $(2 \times T_{cy(CCLK)}) - 5$                            | -   | $(2 \times T_{cy(CCLK)}) + 5$        | ns   |
| t <sub>BLSHANV</sub>  | BLS HIGH to address invalid time                              |            | T <sub>cy(CCLK)</sub> – 5                                | -   | T <sub>cy(CCLK)</sub> + 5            | ns   |

Table 12. External memory interface dynamic characteristics ...continued

 $C_L = 25 \ pF, \ T_{amb} = 40 \ ^{\circ}C$ 

| Symbol               | Parameter                                     | Conditions | Min                           | Тур | Max                           | Unit |
|----------------------|-----------------------------------------------|------------|-------------------------------|-----|-------------------------------|------|
| t <sub>BLSHDNV</sub> | BLS HIGH to data invalid time                 | <u>[2</u>  | $(2 \times T_{cy(CCLK)}) - 5$ | -   | $(2 \times T_{cy(CCLK)}) + 5$ | ns   |
| t <sub>CHDV</sub>    | XCLK HIGH to data valid time                  |            | -                             | -   | 10                            | ns   |
| t <sub>CHWEL</sub>   | XCLK HIGH to $\overline{\text{WE}}$ LOW time  |            | -                             | -   | 10                            | ns   |
| t <sub>CHBLSL</sub>  | XCLK HIGH to $\overline{\rm BLS}$ LOW time    |            | -                             | -   | 10                            | ns   |
| t <sub>CHWEH</sub>   | XCLK HIGH to $\overline{\text{WE}}$ HIGH time |            | -                             | -   | 10                            | ns   |
| t <sub>CHBLSH</sub>  | XCLK HIGH to $\overline{\rm BLS}$ HIGH time   |            | -                             | -   | 10                            | ns   |
| t <sub>CHDNV</sub>   | XCLK HIGH to data invalid time                |            | -                             | -   | 10                            | ns   |

- [1] Except on initial access, in which case the address is set up  $T_{cy(CCLK)}$  earlier.
- [2]  $T_{cy(CCLK)} = \frac{1}{CCLK}$ .
- [3] Latest of address valid,  $\overline{\text{CS}}$  LOW,  $\overline{\text{OE}}$  LOW to data valid.
- [4] Address valid to data valid.
- [5] Earliest of  $\overline{\text{CS}}$  HIGH,  $\overline{\text{OE}}$  HIGH, address change to data invalid.

Table 13. Standard read access specifications

| Access cycle               | Max frequency                                     | WST <sup>[1]</sup> setting<br>WST ≥ 0; round up to<br>integer | Memory access time requirement                                |
|----------------------------|---------------------------------------------------|---------------------------------------------------------------|---------------------------------------------------------------|
| standard read              | $f_{MAX} \le \frac{2 + WSTI}{t_{RAM} + 20 \ ns}$  | $WST1 \ge \frac{t_{RAM} + 20 \ ns}{t_{cy(CCLK)}} - 2$         | $t_{RAM} \le t_{cy(CCLK)} \times (2 + WST1) - 20 \text{ ns}$  |
| standard write             | $f_{MAX} \le \frac{1 + WST2}{t_{WRITE} + 5 \ ns}$ | $WST2 \ge \frac{t_{WRITE} - t_{CYC} + 5}{t_{cy(CCLK)}}$       | $t_{WRITE} \le t_{cy(CCLK)} \times (1 + WST2) - 5 \text{ ns}$ |
| burst read - initial       | $f_{MAX} \le \frac{2 + WSTI}{t_{INIT} + 20 \ ns}$ | $WSTI \ge \frac{t_{INIT} + 20 \ ns}{t_{cy(CCLK)}} - 2$        | $t_{INIT} \le t_{cy(CCLK)} \times (2 + WST1) - 20 \text{ ns}$ |
| burst read - subsequent 3× | $f_{MAX} \le \frac{1}{t_{ROM} + 20 \ ns}$         | N/A                                                           | $t_{ROM} \le t_{cy(CCLK)} - 20 \ ns$                          |

<sup>[1]</sup> See the LPC2119/2129/2194/2292/2294 User Manual for a description of the WSTn bits.

# 9.1 Timing







# 10. Package outline

LQFP144: plastic low profile quad flat package; 144 leads; body 20 x 20 x 1.4 mm

SOT486-1



Fig 25. Package outline SOT486-1 (LQFP144)

LPC2292\_2294\_7 © NXP B.V. 2008. All rights reserved.



Fig 26. Package outline SOT569-2 (TFBGA144)

# 11. Abbreviations

Table 14. Acronym list

|         | · · · · <b>,</b> · · · · · · · ·            |
|---------|---------------------------------------------|
| Acronym | Description                                 |
| ADC     | Analog-to-Digital Converter                 |
| AHB     | Advanced High-performance Bus               |
| AMBA    | Advanced Microcontroller Bus Architecture   |
| APB     | Advanced Peripheral Bus                     |
| CAN     | Controller Area Network                     |
| CISC    | Complex Instruction Set Computer            |
| FIFO    | First In, First Out                         |
| GPIO    | General Purpose Input/Output                |
| I/O     | Input/Output                                |
| JTAG    | Joint Test Action Group                     |
| LSB     | Least Significant Bit                       |
| PLL     | Phase-Locked Loop                           |
| PWM     | Pulse Width Modulator                       |
| RISC    | Reduced Instruction Set Computer            |
| SPI     | Serial Peripheral Interface                 |
| SRAM    | Static Random Access Memory                 |
| SSI     | Synchronous Serial Interface                |
| SSP     | Synchronous Serial Port                     |
| TTL     | Transistor-Transistor Logic                 |
| UART    | Universal Asynchronous Receiver/Transmitter |
|         |                                             |

# 12. Revision history

Table 15. Revision history

| Document ID     | Release date                          | Data sheet status                                       | Change notice             | Supersedes                                     |
|-----------------|---------------------------------------|---------------------------------------------------------|---------------------------|------------------------------------------------|
| LPC2292 2294 7  | 20081204                              | Product data sheet                                      | -                         | LPC2292 2294 6                                 |
|                 |                                       |                                                         | - CDIO manta 40           |                                                |
| Modifications:  |                                       | ock diagram": corrected high                            | • • •                     | •                                              |
|                 |                                       | row "V <sub>DD</sub> = 1.8 V", updated                  |                           | $V_{i(RMS)} = 200 \text{ mV})$ ": removed      |
|                 | · ·                                   |                                                         | • .                       | 2[30], P2[31], P3[28], P3[30]                  |
|                 | P3[31].                               |                                                         | ·                         |                                                |
|                 | <ul> <li>Table 5 "Interest</li> </ul> | errupt sources": CAN and l                              | JART0/1 interrupt sourc   | es corrected.                                  |
|                 | <ul> <li>Table 7 "Sta</li> </ul>      | atic characteristics": V <sub>hys</sub> , m             | noved 0.4 from Typ to M   | in column.                                     |
|                 | <ul> <li>Maximum fr</li> </ul>        | equency fosc for external of                            | scillator and external cr | ystal updated.                                 |
|                 | <ul> <li>Changed S</li> </ul>         | OT569-1 to SOT569-2.                                    |                           |                                                |
|                 | <ul> <li>Added over</li> </ul>        | bar to indicate LOW-active                              | for BLSn, CSn, OE, and    | d <u>ME</u>                                    |
| LPC2292_2294_6  | 20071210                              | Product data sheet                                      | -                         | LPC2292_2294_5                                 |
| Modifications:  | <ul> <li>Type number</li> </ul>       | er LPC2292FBD144/01 has                                 | s been added.             |                                                |
|                 | <ul> <li>Type number</li> </ul>       | er LPC2292FET144/01 has                                 | been added.               |                                                |
|                 | <ul> <li>Type number</li> </ul>       | er LPC2294HBD144/01 ha                                  | s been added.             |                                                |
|                 |                                       | duced with /01 devices on<br>ements to existing ones (U |                           | s (Fast I/O ports, SSP, CRP<br>and SPI) added. |
|                 | <ul> <li>Power cons</li> </ul>        | umption measurements for                                | · LPC2292/2294/01 add     | ed.                                            |
|                 | <ul> <li>Description</li> </ul>       | of JTAG pin TCK has beer                                | updated.                  |                                                |
| LPC2292_2294_5  | 20070215                              | Product data sheet                                      | -                         | LPC2292_2294_4                                 |
| LPC2292_2294_4  | 20060711                              | Product data sheet                                      | -                         | LPC2292_2294_3                                 |
| LPC2292_2294_3  | 20051101                              | Product data sheet                                      | -                         | LPC2292_2294-02                                |
| LPC2292_2294-02 | 20041223                              | Product data                                            | -                         | LPC2292_2294-01                                |
| LPC2292 2294-01 | 20040205                              | Preliminary data                                        | -                         | _                                              |

# 13. Legal information

#### 13.1 Data sheet status

| Document status[1][2]          | Product status[3] | Definition                                                                            |
|--------------------------------|-------------------|---------------------------------------------------------------------------------------|
| Objective [short] data sheet   | Development       | This document contains data from the objective specification for product development. |
| Preliminary [short] data sheet | Qualification     | This document contains data from the preliminary specification.                       |
| Product [short] data sheet     | Production        | This document contains the product specification.                                     |

- [1] Please consult the most recently issued document before initiating or completing a design.
- [2] The term 'short data sheet' is explained in section "Definitions"
- [3] The product status of device(s) described in this document may have changed since this document was published and may differ in case of multiple devices. The latest product status information is available on the Internet at URL <a href="http://www.nxp.com">http://www.nxp.com</a>.

#### 13.2 Definitions

Draft — The document is a draft version only. The content is still under internal review and subject to formal approval, which may result in modifications or additions. NXP Semiconductors does not give any representations or warranties as to the accuracy or completeness of information included herein and shall have no liability for the consequences of use of such information.

Short data sheet — A short data sheet is an extract from a full data sheet with the same product type number(s) and title. A short data sheet is intended for quick reference only and should not be relied upon to contain detailed and full information. For detailed and full information see the relevant full data sheet, which is available on request via the local NXP Semiconductors sales office. In case of any inconsistency or conflict with the short data sheet, the full data sheet shall prevail.

## 13.3 Disclaimers

**General** — Information in this document is believed to be accurate and reliable. However, NXP Semiconductors does not give any representations or warranties, expressed or implied, as to the accuracy or completeness of such information and shall have no liability for the consequences of use of such information.

Right to make changes — NXP Semiconductors reserves the right to make changes to information published in this document, including without limitation specifications and product descriptions, at any time and without notice. This document supersedes and replaces all information supplied prior to the publication hereof.

Suitability for use — NXP Semiconductors products are not designed, authorized or warranted to be suitable for use in medical, military, aircraft, space or life support equipment, nor in applications where failure or malfunction of an NXP Semiconductors product can reasonably be expected

to result in personal injury, death or severe property or environmental damage. NXP Semiconductors accepts no liability for inclusion and/or use of NXP Semiconductors products in such equipment or applications and therefore such inclusion and/or use is at the customer's own risk.

**Applications** — Applications that are described herein for any of these products are for illustrative purposes only. NXP Semiconductors makes no representation or warranty that such applications will be suitable for the specified use without further testing or modification.

Limiting values — Stress above one or more limiting values (as defined in the Absolute Maximum Ratings System of IEC 60134) may cause permanent damage to the device. Limiting values are stress ratings only and operation of the device at these or any other conditions above those given in the Characteristics sections of this document is not implied. Exposure to limiting values for extended periods may affect device reliability.

Terms and conditions of sale — NXP Semiconductors products are sold subject to the general terms and conditions of commercial sale, as published at <a href="http://www.nxp.com/profile/terms">http://www.nxp.com/profile/terms</a>, including those pertaining to warranty, intellectual property rights infringement and limitation of liability, unless explicitly otherwise agreed to in writing by NXP Semiconductors. In case of any inconsistency or conflict between information in this document and such terms and conditions, the latter will prevail.

**No offer to sell or license** — Nothing in this document may be interpreted or construed as an offer to sell products that is open for acceptance or the grant, conveyance or implication of any license under any copyrights, patents or other industrial or intellectual property rights.

#### 13.4 Trademarks

Notice: All referenced brands, product names, service names and trademarks are the property of their respective owners.

I<sup>2</sup>C-bus — logo is a trademark of NXP B.V.

#### 14. Contact information

For more information, please visit: http://www.nxp.com

For sales office addresses, please send an email to: salesaddresses@nxp.com

# 15. Contents

| 1      | General description                        | . 1 | 6.15.2 | Features available in LPC2292/             |    |
|--------|--------------------------------------------|-----|--------|--------------------------------------------|----|
| 2      | Features                                   | . 1 |        | LPC2294/01 only                            |    |
| 2.1    | Key features brought by LPC2292/           |     | 6.16   | Watchdog timer                             |    |
|        | LPC2294/01 devices                         | . 1 | 6.16.1 | Features                                   | 23 |
| 2.2    | Key features common for all devices        | . 1 | 6.17   | Real-time clock                            | _  |
| 3      | Ordering information                       |     | 6.17.1 | Features                                   |    |
| 3.1    | Ordering options                           |     | 6.18   | Pulse width modulator                      |    |
|        |                                            |     | 6.18.1 | Features                                   |    |
| 4      | Block diagram                              |     | 6.19   | System control                             |    |
| 5      | Pinning information                        |     | 6.19.1 | Crystal oscillator                         |    |
| 5.1    | Pinning                                    |     | 6.19.2 | PLL                                        |    |
| 5.2    | Pin description                            | . 8 | 6.19.3 | Reset and wake-up timer                    |    |
| 6      | Functional description                     | 15  | 6.19.4 | Code security (Code Read Protection - CRP) |    |
| 6.1    | Architectural overview                     | 15  | 6.19.5 | External interrupt inputs                  |    |
| 6.2    | On-chip flash program memory               | 15  | 6.19.6 | Memory mapping control                     |    |
| 6.3    | On-chip SRAM                               |     | 6.19.7 | Power control                              |    |
| 6.4    | Memory map                                 |     | 6.19.8 | APB bus                                    |    |
| 6.5    | Interrupt controller                       |     | 6.20   | Emulation and debugging                    |    |
| 6.5.1  | Interrupt sources                          |     | 6.20.1 | EmbeddedICE                                |    |
| 6.6    | Pin connect block                          |     | 6.20.2 | Embedded trace                             |    |
| 6.7    | External memory controller                 | 18  | 6.20.3 | RealMonitor                                |    |
| 6.8    | General purpose parallel I/O (GPIO) and    |     | 7      | Limiting values                            | 29 |
|        | Fast I/O                                   | 19  | 8      | Static characteristics                     | 30 |
| 6.8.1  | Features                                   | 19  | 8.1    | Power consumption measurements for         |    |
| 6.8.2  | Features added with the Fast GPIO set of   |     |        | LPC2292/01 and LPC2294/01                  | 34 |
|        | registers available on LPC2292/            |     | 9      | Dynamic characteristics                    |    |
|        | LPC2294/01 only                            | 19  | 9.1    | Timing                                     |    |
| 6.9    | 10-bit ADC                                 | 19  | -      |                                            |    |
| 6.9.1  | Features                                   | 19  | 10     | Package outline                            |    |
| 6.9.2  | ADC features available in LPC2292/         |     | 11     | Abbreviations                              |    |
|        | LPC2294/01 only                            |     | 12     | Revision history                           | 51 |
| 6.10   | CAN controllers and acceptance filter      | 20  | 13     | Legal information                          | 52 |
| 6.10.1 | Features                                   | 20  | 13.1   | Data sheet status                          |    |
| 6.11   | UARTs                                      | 20  | 13.2   | Definitions                                | 52 |
| 6.11.1 | Features                                   | 20  | 13.3   | Disclaimers                                |    |
| 6.11.2 | UART features available in LPC2292/        |     | 13.4   | Trademarks                                 | 52 |
|        | LPC2294/01 only                            |     | 14     | Contact information                        | 52 |
| 6.12   | I <sup>2</sup> C-bus serial I/O controller |     | 15     | Contents                                   |    |
| 6.12.1 | Features                                   |     | 13     | Contents                                   | 33 |
| 6.13   | SPI serial I/O controller                  |     |        |                                            |    |
| 6.13.1 | Features                                   | 21  |        |                                            |    |
| 6.13.2 | Features available in LPC2292/LPC2294/     |     |        |                                            |    |
|        | 01 only                                    |     |        |                                            |    |
| 6.14   | SSP controller (LPC2292/94/01 only)        |     |        |                                            |    |
| 6.14.1 | Features                                   |     |        |                                            |    |
| 6.15   | General purpose timers                     |     |        |                                            |    |
| 6.15.1 | Features                                   | 22  |        |                                            |    |





© NXP B.V. 2008. All rights reserved.

For more information, please visit: http://www.nxp.com For sales office addresses, please send an email to: salesaddresses@nxp.com