# mail

Chipsmall Limited consists of a professional team with an average of over 10 year of expertise in the distribution of electronic components. Based in Hongkong, we have already established firm and mutual-benefit business relationships with customers from, Europe, America and south Asia, supplying obsolete and hard-to-find components to meet their specific needs.

With the principle of "Quality Parts, Customers Priority, Honest Operation, and Considerate Service", our business mainly focus on the distribution of electronic components. Line cards we deal with include Microchip, ALPS, ROHM, Xilinx, Pulse, ON, Everlight and Freescale. Main products comprise IC, Modules, Potentiometer, IC Socket, Relay, Connector. Our parts cover such applications as commercial, industrial, and automotives areas.

We are looking forward to setting up business relationship with you and hope to provide you with the best service and solution. Let us make a better world for our industry!



# Contact us

Tel: +86-755-8981 8866 Fax: +86-755-8427 6832 Email & Skype: info@chipsmall.com Web: www.chipsmall.com Address: A1208, Overseas Decoration Building, #122 Zhenhua RD., Futian, Shenzhen, China



8-bit 80C51 3 V low power 16/32/64 kB flash microcontroller with 1 kB RAM

Rev. 05 — 15 December 2009

**Product data sheet** 

#### 1. General description

The P89LV51RB2/RC2/RD2 are 80C51 microcontrollers with 16/32/64 kB flash and 1024 B of data RAM.

A key feature of the P89LV51RB2/RC2/RD2 is its X2 mode option. The design engineer can choose to run the application with the conventional 80C51 clock rate (12 clocks per machine cycle) or select the X2 mode (six clocks per machine cycle) to achieve twice the throughput at the same clock frequency. Another way to benefit from this feature is to keep the same performance by reducing the clock frequency by half, thus dramatically reducing the EMI.

The flash program memory supports both parallel programming and in serial ISP. Parallel programming mode offers gang-programming at high speed, reducing programming costs and time to market. ISP allows a device to be reprogrammed in the end product under software control. The capability to field/update the application firmware makes a wide range of applications possible.

The P89LV51RB2/RC2/RD2 is also capable of IAP, allowing the flash program memory to be reconfigured even while the application is running.

#### 2. Features

- 80C51 CPU
- 3 V operating voltage from 0 MHz to 33 MHz
- 16/32/64 kB of on-chip flash user code memory with ISP and IAP
- Supports 12-clock (default) or 6-clock mode selection via software or ISP
- SPI and enhanced UART
- PCA with PWM and capture/compare functions
- Four 8-bit I/O ports with three high-current port 1 pins (16 mA each)
- Three 16-bit timers/counters
- Programmable watchdog timer
- Eight interrupt sources with four priority levels
- Second DPTR register
- Low EMI mode (ALE inhibit)
- TTL- and CMOS-compatible logic levels



8-bit microcontrollers with 80C51 core

- Brownout detection
- Low power modes
  - Power-down mode with external interrupt wake-up
  - Idle mode
- PLCC44 and TQFP44 packages

#### 3. Ordering information

#### Table 1.Ordering information

| Type number   | Package | Package                                                                     |          |  |  |  |  |  |  |
|---------------|---------|-----------------------------------------------------------------------------|----------|--|--|--|--|--|--|
|               | Name    | Description                                                                 | Version  |  |  |  |  |  |  |
| P89LV51RB2BA  | PLCC44  | plastic leaded chip carrier; 44 leads                                       | SOT187-2 |  |  |  |  |  |  |
| P89LV51RC2FBC | TQFP44  | plastic thin quad flat package; 44 leads; body $10 \times 10 \times 1.0$ mm | SOT376-1 |  |  |  |  |  |  |
| P89LV51RD2FA  | PLCC44  | plastic leaded chip carrier; 44 leads                                       | SOT187-2 |  |  |  |  |  |  |
| P89LV51RD2BBC | TQFP44  | plastic thin quad flat package; 44 leads; body $10 \times 10 \times 1.0$ mm | SOT376-1 |  |  |  |  |  |  |

#### 3.1 Ordering options

#### Table 2. Ordering options

| Type number   | Flash memory | Temperature range | Frequency       |
|---------------|--------------|-------------------|-----------------|
| P89LV51RB2BA  | 16 kB        | 0 °C to +70 °C    | 0 MHz to 40 MHz |
| P89LV51RC2FBC | 32 kB        | –40 °C to +85 °C  |                 |
| P89LV51RD2FA  | 64 kB        | –40 °C to +85 °C  |                 |
| P89LV51RD2BBC | 64 kB        | 0 °C to +70 °C    |                 |

8-bit microcontrollers with 80C51 core

#### 4. Block diagram



8-bit microcontrollers with 80C51 core

#### 5. Pinning information



#### 5.1 Pinning

8-bit microcontrollers with 80C51 core



8-bit microcontrollers with 80C51 core

#### 5.2 Pin description

| Symbol       | Pin          |        | Туре                            | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|--------------|--------------|--------|---------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|              | TQFP44       | PLCC44 |                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| P0.0 to P0.7 |              |        | I/O                             | <b>Port 0:</b> Port 0 is an 8-bit open drain bidirectional I/O port. Port 0 pins that have '1's written to them float, and in this state can be used as high-impedance inputs. Port 0 is also the multiplexed low-order address and data bus during accesses to external code and data memory. In this application, it uses strong internal pull-ups when transitioning to '1's. Port 0 also receives the code bytes during the external host mode programming, and outputs the code bytes during the external host mode verification. External pull-ups are required during program verification or as a general purpose I/O port. |
| P0.0/AD0     | 37           | 43     | I/O                             | <b>P0.0</b> — Port 0 bit 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|              |              |        | I/O                             | AD0 — Address/data bit 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| P0.1/AD1     | 36           | 42     | I/O                             | <b>P0.1</b> — Port 0 bit 1.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|              |              |        | I/O                             | AD1 — Address/data bit 1.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| P0.2/AD2     | 35 41        |        | I/O                             | <b>P0.2</b> — Port 0 bit 2.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|              |              |        | I/O                             | AD2 — Address/data bit 2.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| P0.3/AD3     | 0.3/AD3 34 4 |        | I/O                             | <b>P0.3</b> — Port 0 bit 3.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|              |              |        | I/O                             | AD3 — Address/data bit 3.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| P0.4/AD4     | 33 39        |        | I/O                             | <b>P0.4</b> — Port 0 bit 4.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|              |              |        | I/O                             | AD4 — Address/data bit 4.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| P0.5/AD5     | 32           | 38     | I/O                             | <b>P0.5</b> — Port 0 bit 5.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|              |              |        | I/O                             | AD5 — Address/data bit 5.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| P0.6/AD6     | 31           | 37     | I/O                             | <b>P0.6</b> — Port 0 bit 6.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|              |              |        | I/O                             | AD6 — Address/data bit 6.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| P0.7/AD7     | 30           | 36     | I/O                             | <b>P0.7</b> — Port 0 bit 7.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|              |              |        | I/O                             | AD7 — Address/data bit 7.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| P1.0 to P1.7 |              |        | I/O with<br>internal<br>pull-up | <b>Port 1:</b> Port 1 is an 8-bit bidirectional I/O port with internal pull-ups. The Port 1 pins are pulled high by the internal pull-ups when '1's are written to them and can be used as inputs in this state. As inputs, Port 1 pins that are externally pulled LOW will source current ( $I_{IL}$ ) because of the internal pull-ups. P1.5, P1.6, P1.7 have a high current drive of 16 mA. Port 1 also receives the low-order address bytes during the external host mode programming and verification.                                                                                                                         |
| P1.0/T2      | 40           | 2      | I                               | <b>P1.0</b> — Port 1 bit 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|              |              |        | I/O                             | <b>T2</b> — External count input to Timer/counter 2 or Clock-out from Timer/counter 2.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| P1.1/T2EX    | 41           | 3      | I/O                             | <b>P1.1</b> — Port 1 bit 1.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|              |              |        | I                               | <b>T2EX</b> : Timer/counter 2 capture/reload trigger and direction control input.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| P1.2/ECI     | 42           | 4      | I/O                             | <b>P1.2</b> — Port 1 bit 2.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|              |              |        | I                               | <b>ECI</b> — External clock input. This signal is the external clock input for the PCA.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |

#### 8-bit microcontrollers with 80C51 core

| Symbol       | Pin    |        | Туре                            | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|--------------|--------|--------|---------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|              | TQFP44 | PLCC44 |                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| P1.3/CEX0    | 43     | 5      | I/O                             | <b>P1.3</b> — Port 1 bit 3.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|              |        |        | I/O                             | <b>CEX0</b> — Capture/compare external I/O for PCA Module 0. Each capture/compare module connects to a Port 1 pin for external I/O. When not used by the PCA, this pin can handle standard I/O                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| P1.4/SS/CEX1 | 44     | 6      | I/O                             | <b>P1.4</b> — Port 1 bit 4.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|              |        |        | I                               | <b>SS</b> — Slave port select input for SPI.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|              |        |        | I/O                             | <b>CEX1</b> — Capture/compare external I/O for PCA Module 1.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| P1.5/MOSI/   | 1      | 7      | I/O                             | <b>P1.5</b> — Port 1 bit 5.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| CEX2         |        |        | I/O                             | MOSI — Master Output Slave Input for SPI.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|              |        |        | I/O                             | CEX2 — Capture/compare external I/O for PCA Module 2.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| P1.6/MISO/   | 2      | 8      | I/O                             | <b>P1.6</b> — Port 1 bit 6.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| CEX3         |        |        | I/O                             | MISO — Master Input Slave Output for SPI.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|              |        |        | I/O                             | CEX3 — Capture/compare external I/O for PCA Module 3.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| P1.7/SPICLK/ | 3      | 9      | I/O                             | <b>P1.7</b> — Port 1 bit 7.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| CEX4         |        |        | I/O                             | SPICLK — Serial clock input/output for SPI.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|              |        |        | I/O                             | CEX4 — Capture/compare external I/O for PCA Module 4.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| P2.0 to P2.7 |        |        | I/O with<br>internal<br>pull-up | <b>Port 2</b> : Port 2 is an 8-bit bidirectional I/O port with internal pull-ups. Port 2 pins are pulled HIGH by the internal pull-ups when '1's are written to them and can be used as inputs in this state. As inputs, Port 2 pins that are externally pulled LOW will source current ( $I_{IL}$ ) because of the internal pull-ups. Port 2 sends the high-order address byte during fetches from external program memory and during accesses to external Data Memory that use 16-bit address (MOVX@DPTR). In this application, it uses strong internal pull-ups when transitioning to '1's. Port 2 also receives some control signals and a partial of high-order address bits during the external host mode programming and verification. |
| P2.0/A8      | 18     | 24     | I/O                             | <b>P2.0</b> — Port 2 bit 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|              |        |        | 0                               | A8 — Address bit 8.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| P2.1/A9      | 19     | 25     | I/O                             | <b>P2.1</b> — Port 2 bit 1.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|              |        |        | 0                               | A9 — Address bit 9.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| P2.2/A10     | 20     | 26     | I/O                             | <b>P2.2</b> — Port 2 bit 2.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|              |        |        | 0                               | A10 — Address bit 10.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| P2.3/A11     | 21     | 27     | I/O                             | <b>P2.3</b> — Port 2 bit 3.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|              |        |        | 0                               | A11 — Address bit 11.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| P2.4/A12     | 22     | 28     | I/O                             | <b>P2.4</b> — Port 2 bit 4.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|              |        |        | 0                               | A12 — Address bit 12.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| P2.5/A13     | 23     | 29     | I/O                             | <b>P2.5</b> — Port 2 bit 5.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|              |        |        | 0                               | A13 — Address bit 13.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| P2.6/A14     | 24     | 30     | I/O                             | <b>P2.6</b> — Port 2 bit 6.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|              |        |        | 0                               | A14 — Address bit 14.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |

#### P89I V51BB2/BC2/BD2 pin description continued

P89LV51RB2\_RC2\_RD2\_5

Product data sheet

#### **NXP Semiconductors**

# P89LV51RB2/RC2/RD2

#### 8-bit microcontrollers with 80C51 core

| Symbol       | Pin        |        | Туре                            | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|--------------|------------|--------|---------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|              | TQFP44     | PLCC44 |                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| P2.7/A15     | 25         | 31     | I/O                             | <b>P2.7</b> — Port 2 bit 7.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|              |            |        | 0                               | A15 — Address bit 15.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| P3.0 to P3.7 |            |        | l/O with<br>internal<br>pull-up | <b>Port 3</b> : Port 3 is an 8-bit bidirectional I/O port with internal pull-ups. Port 3 pins are pulled HIGH by the internal pull-ups when '1's are written to them and can be used as inputs in this state. As inputs, Port 3 pins that are externally pulled LOW will source current ( $I_{IL}$ ) because of the internal pull-ups. Port 3 also receives some control signals and a partial of high-order address bits during the external host mode programming and verification.                                                                                         |
| P3.0/RXD     | 5          | 11     | I                               | <b>P3.0</b> — Port 3 bit 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|              |            |        | Ι                               | RXD — Serial input port.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| P3.1/TXD     | 7          | 13     | 0                               | <b>P3.1</b> — Port 3 bit 1.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|              |            |        | 0                               | <b>TXD</b> — Serial output port.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| P3.2/INT0    | 8          | 14     | 1                               | <b>P3.2</b> — Port 3 bit 2.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|              |            |        | I                               | <b>INTO</b> — External interrupt 0 input.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| P3.3/INT1    | 9          | 15     | I                               | <b>P3.3</b> — Port 3 bit 3.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|              |            |        | I                               | INT1 — External interrupt 1 input.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| P3.4/T0      | P3.4/T0 10 |        | I/O                             | <b>P3.4</b> — Port 3 bit 4.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|              |            |        | I                               | <b>T0</b> — External count input to Timer/counter 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| P3.5/T1      | 11         | 17     | I/O                             | <b>P3.5</b> — Port 3 bit 5.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|              |            |        | Ι                               | <b>T1</b> — External count input to Timer/counter 1.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| P3.6/WR      | 12         | 18     | 0                               | <b>P3.6</b> — Port 3 bit 6.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|              |            |        | 0                               | <b>WR</b> — External data memory write strobe.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| P3.7/RD      | 13         | 19     | 0                               | <b>P3.7</b> — Port 3 bit 7.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|              |            |        | 0                               | <b>RD</b> — External data memory read strobe.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| PSEN         | 26         | 32     | I/O                             | <b>Program Store Enable</b> : PSEN is the read strobe for external program memory. When the device is executing from internal program memory, PSEN is inactive (HIGH). When the device is executing code from external program memory, PSEN is activated twice each machine cycle, except that two PSEN activations are skipped during each access to external data memory. A forced HIGH-to-LOW input transition on the PSEN pin while the RST input is continually held HIGH for more than 10 machine cycles will cause the device to enter external host mode programming. |
| RST          | 4          | 10     | 1                               | <b>Reset</b> : While the oscillator is running, a HIGH logic state on this pin for two machine cycles will reset the device. If the $\overline{PSEN}$ pin is driven by a HIGH-to-LOW input transition while the RST input pin is held HIGH, the device will enter the external host mode, otherwise the device will enter the normal operation mode.                                                                                                                                                                                                                          |
| EA           | 29         | 35     | I                               | <b>External Access Enable</b> : $\overline{EA}$ must be connected to V <sub>SS</sub> in order to enable the device to fetch code from the external program memory. $\overline{EA}$ must be strapped to V <sub>DD</sub> for internal program execution. The $\overline{EA}$ pin can tolerate a high voltage of 12 V.                                                                                                                                                                                                                                                           |

#### Table 3. P89LV51RB2/RC2/RD2 pin description ...continued

#### 8-bit microcontrollers with 80C51 core

| Symbol          | Pin              |                  | Туре | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|-----------------|------------------|------------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                 | TQFP44           | PLCC44           |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| ALE/PROG        | 27               | 33               | I/O  | Address Latch Enable: ALE is the output signal for latching the low byte of the address during an access to external memory. This pin is also the programming pulse input (PROG) for flash programming. Normally the ALE <sup>[1]</sup> is emitted at a constant rate of $\frac{1}{6}$ the crystal frequency <sup>[2]</sup> and can be used for external timing and clocking. One ALE pulse is skipped during each access to external data memory. However, if bit AO is set to '1', ALE is disabled. |
| n.c.            | 6, 17, 28,<br>39 | 1, 12, 23,<br>34 | I/O  | not connected                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| XTAL1           | 15               | 21               | I    | <b>Crystal 1</b> : Input to the inverting oscillator amplifier and input to the internal clock generator circuits.                                                                                                                                                                                                                                                                                                                                                                                    |
| XTAL2           | 14               | 20               | 0    | Crystal 2: Output from the inverting oscillator amplifier.                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| V <sub>DD</sub> | 38               | 44               | I    | Power supply                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| V <sub>SS</sub> | 16               | 22               | I    | Ground                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |

#### Table 3. P89LV51RB2/RC2/RD2 pin description ...continued

[1] ALE loading issue: When ALE pin experiences higher loading (> 30 pF) during the reset, the microcontroller may accidentally enter into modes other than normal working mode. The solution is to connect a pull-up resistor of 3 kΩ to 50 kΩ from pin ALE to V<sub>DD</sub>.

[2] For 6-clock mode, ALE is emitted at  $\frac{1}{3}$  of crystal frequency.

8-bit microcontrollers with 80C51 core

#### 6. Functional description

#### 6.1 Special function registers

Remark: SFR accesses are restricted in the following ways:

- User must not attempt to access any SFR locations not defined.
- Accesses to any defined SFR locations must be strictly for the functions for the SFRs.
- SFR bits labeled '-', '0' or '1' can **only** be written and read as follows:
  - '-' Unless otherwise specified, must be written with '0', but can return any value when read (even if it was written with '0'). It is a reserved bit and may be used in future derivatives.
  - '0' must be written with '0', and will return a '0' when read.
  - '1' **must** be written with '1', and will return a '1' when read.

# NXP Semiconductors

# P89LV51RB2/RC2/RD2

8-bit microcontrollers with 80C51 core

#### Table 4.Special function registers\* Indicates SFRs that are bit addressable. Table 4.

| Name  | Description                   | SFR         | Bit functions and addresses |           |        |           |           |           |        |           |
|-------|-------------------------------|-------------|-----------------------------|-----------|--------|-----------|-----------|-----------|--------|-----------|
|       |                               | addr.       | MSB                         |           |        |           |           |           |        | LSB       |
|       |                               | Bit address | E7                          | <b>E6</b> | E5     | <b>E4</b> | E3        | <b>E2</b> | E1     | <b>E0</b> |
| ACC*  | Accumulator                   | E0H         |                             |           |        |           |           |           |        |           |
| AUXR  | Auxiliary function register   | 8EH         | -                           | -         | -      | -         | -         | -         | EXTRAM | AO        |
| AUXR1 | Auxiliary function register 1 | A2H         | -                           | -         | -      | -         | GF2       | 0         | -      | DPS       |
|       |                               | Bit address | <b>F7</b>                   | <b>F6</b> | F5     | F4        | <b>F3</b> | F2        | F1     | <b>F0</b> |
| B*    | B register                    | F0H         |                             |           |        |           |           |           |        |           |
| CCAPO | H Module 0 Capture HIGH       | FAH         |                             |           |        |           |           |           |        |           |
| CCAP1 | H Module 1 Capture HIGH       | FBH         |                             |           |        |           |           |           |        |           |
| CCAP2 | H Module 2 Capture HIGH       | FCH         |                             |           |        |           |           |           |        |           |
| CCAPS | H Module 3 Capture HIGH       | FDH         |                             |           |        |           |           |           |        |           |
| CCAP4 | H Module 4 Capture HIGH       | FEH         |                             |           |        |           |           |           |        |           |
| CCAPO | L Module 0 Capture LOW        | EAH         |                             |           |        |           |           |           |        |           |
| CCAP1 | L Module 1 Capture LOW        | EBH         |                             |           |        |           |           |           |        |           |
| CCAP2 | L Module 2 Capture LOW        | ECH         |                             |           |        |           |           |           |        |           |
| CCAPS | L Module 3 Capture LOW        | EDH         |                             |           |        |           |           |           |        |           |
| CCAP4 | L Module 4 Capture LOW        | EEH         |                             |           |        |           |           |           |        |           |
| CCAPN | 10 Module 0 Mode              | DAH         | -                           | ECOM_0    | CAPP_0 | CAPN_0    | MAT_0     | TOG_0     | PWM_0  | ECCF_     |
| CCAPN | 11 Module 1 Mode              | DBH         | -                           | ECOM_1    | CAPP_1 | CAPN_1    | MAT_1     | TOG_1     | PWM_1  | ECCF_     |
| CCAPN | 12 Module 2 Mode              | DCH         | -                           | ECOM_2    | CAPP_2 | CAPN_2    | MAT_2     | TOG_2     | PWM_2  | ECCF_     |
| CCAPN | A3 Module 3 Mode              | DDH         | -                           | ECOM_3    | CAPP_3 | CAPN_3    | MAT_3     | TOG_3     | PWM_3  | ECCF_     |
| CCAPN | Module 4 Mode                 | DEH         | -                           | ECOM_4    | CAPP_4 | CAPN_4    | MAT_4     | TOG_4     | PWM_4  | ECCF_     |
|       |                               | Bit address | DF                          | DE        | DD     | DC        | DB        | DA        | D9     | D8        |
| CCON' | PCA Counter Control           | D8H         | CF                          | CR        | -      | CCF4      | CCF3      | CCF2      | CCF1   | CCF0      |
| СН    | PCA Counter HIGH              | F9H         |                             |           |        |           |           |           |        |           |
| CL    | PCA Counter LOW               | E9H         |                             |           |        |           |           |           |        |           |
| CMOD  | PCA Counter Mode              | D9H         | CIDL                        | WDTE      | -      | -         | -         | CPS1      | CPS0   | ECF       |
| DPTR  | Data Pointer (2 B)            |             |                             |           |        |           |           |           |        |           |
| DPH   | Data Pointer HIGH             | 83H         |                             |           |        |           |           |           |        |           |
| DPL   | Data Pointer LOW              | 82H         |                             |           |        |           |           |           |        |           |

P89LV51R Product data sheet

# **NXP Semiconductors**

# P89LV51RB2/RC2/RD2

8-bit microcontrollers with 80C51 core

#### Table 4.Special function registers ... continued\* Indicates SFRs that are bit addressable. Table 4.

| Name   | Description               | SFR         | Bit functions and addresses |               |               |            |           |             |            |            |
|--------|---------------------------|-------------|-----------------------------|---------------|---------------|------------|-----------|-------------|------------|------------|
|        |                           | addr.       | MSB                         |               |               |            |           |             |            | LSB        |
| FST    | Flash Status Register     | B6          | -                           | SB            | -             | -          | EDC       | -           | -          | -          |
|        |                           | Bit address | AF                          | AE            | AD            | AC         | AB        | AA          | <b>A</b> 9 | <b>A</b> 8 |
| IEN0*  | Interrupt Enable 0        | A8H         | EA                          | EC            | ET2           | ES         | ET1       | EX1         | ET0        | EX0        |
|        |                           | Bit address | EF                          | EE            | ED            | EC         | EB        | EA          | <b>E9</b>  | <b>E</b> 8 |
| IEN1*  | Interrupt Enable 1        | E8H         | -                           | -             | -             | -          | EBO       | -           | -          | -          |
|        |                           | Bit address | BF                          | BE            | BD            | BC         | BB        | BA          | <b>B</b> 9 | <b>B</b> 8 |
| IP0*   | Interrupt Priority        | B8H         | -                           | PPC           | PT2           | PS         | PT1       | PX1         | PT0        | PXC        |
| IP0H   | Interrupt Priority 0 HIGH | B7H         | -                           | PPCH          | PT2H          | PSH        | PT1H      | PX1H        | PT0H       | PX0        |
|        |                           | Bit address | FF                          | FE            | FD            | FC         | FB        | FA          | <b>F9</b>  | <b>F</b> 8 |
| IP1*   | Interrupt Priority 1      | F8H         | -                           | -             | -             | PBO        | -         | -           | -          | -          |
| IP1H   | Interrupt Priority 1 HIGH | F7H         | -                           | -             | -             | PBOH       | -         | -           | -          | -          |
| FCF    |                           | B1H         | -                           | -             | -             | -          | -         | -           | SWR        | BSE        |
|        |                           | Bit address | 87                          | 86            | 85            | 84         | 83        | 82          | 81         | 80         |
| P0*    | Port 0                    | 80H         | AD7                         | AD6           | AD5           | AD4        | AD3       | AD2         | AD1        | AD(        |
|        |                           | Bit address | 97                          | 96            | 95            | 94         | 93        | 92          | 91         | 90         |
| P1*    | Port 1                    | 90H         | CEX4/<br>SPICLK             | CEX3/<br>MISO | CEX2/<br>MOSI | CEX1/SS    | CEX0      | ECI         | T2EX       | T2         |
|        |                           | Bit address | <b>A</b> 7                  | <b>A</b> 6    | A5            | <b>A</b> 4 | A3        | <b>A2</b>   | <b>A1</b>  | <b>A</b> 0 |
| P2*    | Port 2                    | A0H         | A15                         | A14           | A13           | A12        | A11       | A10         | A9         | A8         |
|        |                           | Bit address | <b>B</b> 7                  | <b>B</b> 6    | <b>B</b> 5    | <b>B</b> 4 | <b>B3</b> | <b>B2</b>   | B1         | <b>B</b> 0 |
| P3*    | Port 3                    | B0H         | RD                          | WR            | T1            | Т0         | INT1      | <b>INTO</b> | TXD        | RXE        |
| PCON   | Power Control Register    | 87H         | SMOD1                       | SMOD0         | BOF           | POF        | GF1       | GF0         | PD         | IDL        |
|        |                           | Bit address | D7                          | <b>D</b> 6    | D5            | D4         | D3        | D2          | D1         | D0         |
| PSW*   | Program Status Word       | D0H         | CY                          | AC            | F0            | RS1        | RS0       | OV          | F1         | Р          |
| RCAP2H | Timer2 Capture HIGH       | CBH         |                             |               |               |            |           |             |            |            |
| RCAP2L | Timer2 Capture LOW        | CAH         |                             |               |               |            |           |             |            |            |
|        |                           | Bit address | 9F                          | 9E            | 9D            | 9C         | 9B        | <b>9A</b>   | 99         | 98         |
| SCON*  | Serial Port Control       | 98H         | SM0/FE                      | SM1           | SM2           | REN        | TB8       | RB8         | ΤI         | RI         |

P89LV51F Product data sheet

Rev. 05 — 15 December 2009

# 12 of 76

# P89LV51RB2/RC2/RD2 8-bit microcontrollers with 80C51 core

#### Table 4. Special function registers ... continued

P89LV51 \* Indicates SFRs that are bit addressable.

| Name   | Description                  | SFR         |               |               | В             | it functions a | and addresse  | es                  |                     |               |
|--------|------------------------------|-------------|---------------|---------------|---------------|----------------|---------------|---------------------|---------------------|---------------|
|        |                              | addr.       | MSB           |               |               |                |               |                     |                     | LSB           |
| SADDR  | Serial Port Address Register | A9H         |               |               |               |                |               |                     |                     |               |
| SADEN  | Serial Port Address Enable   | B9H         |               |               |               |                |               |                     |                     |               |
|        |                              | Bit address | 87 <u>[1]</u> | 86 <u>[1]</u> | 85 <u>[1]</u> | 84 <u>[1]</u>  | 83 <u>[1]</u> | 82 <mark>[1]</mark> | 81 <mark>[1]</mark> | 80 <u>[1]</u> |
| SPCTL  | SPI Control Register         | D5H         | SPIE          | SPEN          | DORD          | MSTR           | CPOL          | CPHA                | PSC1                | PSC           |
| SPCFG  | SPI Configuration Register   | AAH         | SPIF          | WCOL          | -             | -              | -             | -                   | -                   | -             |
| SPDAT  | SPI Data                     | 86H         |               |               |               |                |               |                     |                     |               |
| SP     | Stack Pointer                | 81H         |               |               |               |                |               |                     |                     |               |
|        |                              | Bit address | 8F            | 8E            | 8D            | 8C             | 8B            | <b>8A</b>           | 89                  | 88            |
| TCON*  | Timer Control Register       | 88H         | TF1           | TR1           | TF0           | TR0            | IE1           | IT1                 | IE0                 | IT0           |
|        |                              | Bit address | CF            | CE            | CD            | CC             | СВ            | CA                  | <b>C</b> 9          | <b>C</b> 8    |
| T2CON* | Timer2 Control Register      | C8H         | TF2           | EXF2          | RCLK          | TCLK           | EXEN2         | TR2                 | C/T2                | CP/RI         |
| T2MOD  | Timer2 Mode Control          | C9H         | -             | -             | ENT2          | -              | -             | -                   | T2OE                | DCEI          |
| TH0    | Timer 0 HIGH                 | 8CH         |               |               |               |                |               |                     |                     |               |
| TH1    | Timer 1 HIGH                 | 8DH         |               |               |               |                |               |                     |                     |               |
| TH2    | Timer 2 HIGH                 | CDH         |               |               |               |                |               |                     |                     |               |
| TL0    | Timer 0 LOW                  | 8AH         |               |               |               |                |               |                     |                     |               |
| TL1    | Timer 1 LOW                  | 8BH         |               |               |               |                |               |                     |                     |               |
| TL2    | Timer 2 LOW                  | CCH         |               |               |               |                |               |                     |                     |               |
| TMOD   | Timer 0 and 1 Mode           | 89H         | T1GATE        | T1C/T         | T1M1          | T1M0           | TOGATE        | T0C/T               | T0M1                | TOM           |
| WDTC   | Watchdog Timer Control       | COH         | -             | -             | -             | WDOUT          | WDRE          | WDTS                | WDT                 | SWD           |
| WDTD   | Watchdog Timer Data/Reload   | d 85H       |               |               |               |                |               |                     |                     |               |

[1] Unimplemented bits in SFRs (labeled '-') are 'X's (unknown) at all times. Unless otherwise specified, '1's should not be written to these bits since they may be used for other purposes in future derivatives. The reset values shown for these bits are '0's although they are unknown when read.

Product data sheet

#### 6.2 Memory organization

The device has separate address spaces for program and data memory.

#### 6.2.1 Flash program memory bank selection

There are two internal flash memory blocks in the device. Block 0 has 16/32/64 kB and is organized as 128/256/512 sectors, each sector consists of 128 B. Block 1 contains the IAP/ISP routines and may be enabled such that it overlays the first 8 kB of the user code memory. The overlay function is controlled by the combination of the Software Reset Bit (SWR) at FCF.1 and the Bank Select Bit (BSEL) at FCF.0. The combination of these bits and the memory source used for instructions is shown in Table 5.

| Table 5. | Code mem | ory bank selection |                                  |                          |
|----------|----------|--------------------|----------------------------------|--------------------------|
| SWR (FC  | F.1)     | BSEL (FCF.0)       | Addresses from<br>0000H to 1FFFH | Addresses above<br>1FFFH |
| 0        |          | 0                  | boot code (in block 1)           | user code (in block 0)   |
| 0        |          | 1                  | user code (in block 0)           |                          |
| 1        |          | 0                  |                                  |                          |
| 1        |          | 1                  |                                  |                          |

Access to the IAP routines in block 1 may be enabled by clearing the BSEL bit (FCF.0), provided that the SWR bit (FCF.1) is cleared. Following a power-on sequence, the boot code is automatically executed and attempts to autobaud to a host. If no autobaud occurs within approximately 400 ms and the SoftICE flag is not set, control will be passed to the user code. A software reset is used to accomplish this control transfer and as a result the SWR bit will remain set. Therefore the user's code will need to clear the SWR bit in order to access the IAP routines in block 1. However, caution must be taken when dynamically changing the BSEL bit. Since this will cause different physical memory to be mapped to the logical program address space, the user must avoid clearing the BSEL bit when executing user code within the address range 0000H to 1FFFH.

#### 6.2.2 Power-on reset code execution

At initial power up, the port pins will be in a random state until the oscillator has started and the internal reset algorithm has weakly pulled all pins high. Powering up the device without a valid reset could cause the MCU to start executing instructions from an indeterminate location. Such undefined states may inadvertently corrupt the code in the flash. A system reset will not affect the 1 kB of on-chip RAM while the device is running, however, the contents of the on-chip RAM during power up are indeterminate.

When power is applied to the device, the RST pin must be held high long enough for the oscillator to start up (usually several milliseconds for a low frequency crystal), in addition to two machine cycles for a valid power-on reset. An example of a method to extend the RST signal is to implement a RC circuit by connecting the RST pin to  $V_{DD}$  through a 10  $\mu$ F capacitor and to V<sub>SS</sub> through an 8.2 k $\Omega$  resistor as shown in Figure 4. Note that if an RC circuit is used, provision should be made to ensure the  $V_{DD}$  rise time does not exceed 1 ms and the oscillator start-up time does not exceed 10 ms.

For a low frequency oscillator with slow start-up time the reset signal must be extended in order to account for the slow start-up time. This method maintains the necessary relationship between V<sub>DD</sub> and RST to avoid programming at an indeterminate location, which may cause corruption in the Flash code. The power-on detection is designed to

8-bit microcontrollers with 80C51 core

work during initial power up, before the voltage reaches the brownout detection level. The POF flag in the PCON register is set to indicate an initial power up condition. The POF flag will remain active until cleared by software.

Following a power-on or external reset the P89LV51RB2/RC2/RD2 will force the SWR and BSEL bits (FCF[1:0]) to 00. This causes the boot block to be mapped into the lower 8 kB of code memory and the device will execute the ISP code in the boot block and attempt to autobaud to the host. If the autobaud is successful the device will remain in ISP mode. If, after approximately 400 ms, the autobaud is unsuccessful the boot block code will check to see if the SoftICE flag is set (from a previous programming operation). If the SoftICE flag is set the device will enter SoftICE mode. If the SoftICE flag is cleared, the boot code will execute a software reset causing the device to execute the user code from block 0 starting at address 0000H. Note that an external reset applied to the RST pin has the same effect as a power-on reset.



#### 6.2.3 Software reset

A software reset is executed by changing the SWR bit (FCF.1) from '0' to '1'. A software reset will reset the program counter to address 0000H and force both the SWR and BSEL bits (FCF[1:0]) to 10. This will result in the lower 8 kB of the user code memory being mapped into the user code memory space. Thus the user's code will be executed starting at address 0000H. A software reset will not change bit WDTC.2 or RAM data. Other SFRs will be set to their reset values.

#### 6.2.4 Brownout detect reset

The device includes a brownout detection circuit to protect the system from severe supply voltage fluctuations. The P89LV51RB2/RC2/RD2's brownout detection threshold is 2.35 V. When  $V_{DD}$  drops below this voltage threshold, the brownout detect triggers the circuit to generate a brownout interrupt but the CPU still runs until the supplied voltage returns to the brownout detection voltage  $V_{bo}$ . The default operation for a brownout detection is to cause a processor reset.

8-bit microcontrollers with 80C51 core

 $V_{\text{DD}}$  must stay below  $V_{\text{bo}}$  at least four oscillator clock periods before the brownout detection circuit will respond.

Brownout interrupt can be enabled by setting the EBO bit (IEN1.3). If EBO bit is set and a brownout condition occurs, a brownout interrupt will be generated to execute the program at location 004BH. It is required that the EBO bit is cleared by software after the brownout interrupt is serviced. Clearing EBO bit when the brownout condition is active will properly reset the device. If brownout interrupt is not enabled, a brownout condition will reset the program to resume execution at location 0000H. A brownout detect reset will clear the BSEL bit (FCF.0) but will not change the SWR bit (FCF.1) and therefore will not change the banking of the lower 8 kB of user code memory space.

#### 6.2.5 Watchdog reset

Like a brownout detect reset, the watchdog timer reset will clear the BSEL bit (FCF.0) but will not change the SWR bit (FCF.1) and therefore will not change the banking of the lower 8 kB of user code memory space.

The state of the SWR and BSEL bits after different types of resets is shown in <u>Table 6</u>. This results in the code memory bank selections as shown.

| Reset source          | SWR bit result<br>(FCF.1) | BSEL bit result<br>(FCF.0) | Addresses from 0000H to<br>1FFFH                                                    | Addresses above<br>1FFFH |  |  |
|-----------------------|---------------------------|----------------------------|-------------------------------------------------------------------------------------|--------------------------|--|--|
| External reset        | 0                         | 0                          | Boot code (in block 1)                                                              | User code (in block 0)   |  |  |
| Power-on reset        |                           |                            |                                                                                     |                          |  |  |
| Watchdog reset        | х                         | 0                          | Retains state of SWR bit. If                                                        |                          |  |  |
| Brownout detect reset |                           |                            | SWR, BSEL = 00 then uses<br>boot code. If SWR,<br>BSEL = 10 then uses user<br>code. |                          |  |  |
| Software reset        | 1                         | 0                          | User code (in block 0)                                                              |                          |  |  |

Table 6. Effects of reset sources on bank selection

#### 6.2.6 Data RAM memory

The data RAM has 1024 B of internal memory. The device can also address up to 64 kB for external data memory.

#### 6.2.7 Expanded data RAM addressing

The P89LV51RB2/RC2/RD2 has 1 kB of RAM. See <u>Figure 5 "Internal and external data</u> memory structure" on page 19.

The device has four sections of internal data memory:

- 1. The lower 128 B of RAM (00H to 7FH) are directly and indirectly addressable.
- 2. The higher 128 B of RAM (80H to FFH) are indirectly addressable.
- 3. The special function registers (80H to FFH) are directly addressable only.
- 4. The expanded RAM of 768 B (00H to 2FFH) is indirectly addressable by the move external instruction (MOVX) and clearing the EXTRAM bit (see 'Auxiliary function Register' (AUXR) in Table 4 "Special function registers" on page 11).

8-bit microcontrollers with 80C51 core

Since the upper 128 B occupy the same addresses as the SFRs, the RAM must be accessed indirectly. The RAM and SFRs space are physically separate even though they have the same addresses.

#### Table 7. AUXR - Auxiliary register (address 8EH) bit allocation

Not bit addressable; reset value 00H.

| Bit    | 7 | 6 | 5 | 4 | 3 | 2 | 1      | 0  |
|--------|---|---|---|---|---|---|--------|----|
| Symbol | - | - | - | - | - | - | EXTRAM | AO |

AUXR - Auxiliary register (address 8EH) bit descriptions

| Bit    | Symbol | Description                                                                                                                                                                                                                                                                                                                                                                        |  |  |
|--------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 7 to 2 | -      | Reserved for future use. Should be set to '0' by user programs.                                                                                                                                                                                                                                                                                                                    |  |  |
| 1      | EXTRAM | Internal/External RAM access using MOVX-@Ri/@DPTR.<br>When '0', core attempts to access internal XRAM with address<br>specified in MOVX instruction. If address supplied with this instruction<br>exceeds on-chip available XRAM, off-chip XRAM is going to be<br>selected and accessed.<br>When '1', every MOVX-@Ri/@DPTR instruction targets external data<br>memory by default. |  |  |
| 0      | AO     | ALE off: disables/enables ALE. AO = 0 results in ALE emitted at a constant rate of $\frac{1}{2}$ the oscillator frequency. In case of AO = 1, ALE is active only during a MOVX or MOVC.                                                                                                                                                                                            |  |  |

When instructions access addresses in the upper 128 B (above 7FH), the MCU determines whether to access the SFRs or RAM by the type of instruction given. If it is indirect, then RAM is accessed. If it is direct, then an SFR is accessed. See the examples below.

Indirect access:

Table 8.

MOV@R0, #data; R0 contains 90H

Register R0 points to 90H which is located in the upper address range. Data in '#data' is written to RAM location 90H rather than port 1.

Direct access:

MOV90H, #data; write data to P1

Data in '#data' is written to port 1. Instructions that write directly to the address, write to the SFRs.

To access the expanded RAM, the EXTRAM bit must be cleared and MOVX instructions must be used. The extra 768 B of memory is physically located on the chip and logically occupies the first 768 B of external memory (addresses 000H to 2FFH).

When EXTRAM = 0, the expanded RAM is indirectly addressed using the MOVX instruction in combination with any of the registers R0, R1 of the selected bank or DPTR. Accessing the expanded RAM does not affect ports P0, P3.6 ( $\overline{WR}$ ), P3.7 ( $\overline{RD}$ ), or P2. With EXTRAM = 0, the expanded RAM can be accessed as in the following example.

Expanded RAM access (indirect addressing only):

MOVX@DPTR, A DPTR contains 0A0H

8-bit microcontrollers with 80C51 core

DPTR points to 0A0H and data in 'A' is written to address 0A0H of the expanded RAM rather than external memory. Access to external memory higher than 2FFH using the MOVX instruction will access external memory (0300H to FFFFH) and will perform in the same way as the standard 8051, with P0 and P2 as data/address bus, and P3.6 and P3.7 as write and read timing signals.

When EXTRAM = 1, MOVX@Ri and MOVX@DPTR will be similar to the standard 8051. Using MOVX @Ri provides an 8-bit address with multiplexed data on Port 0. Other output port pins can be used to output higher order address bits. This provides external paging capabilities. Using MOVX@DPTR generates a 16-bit address. This allows external addressing up to 64 kB. Port 2 provides the high-order eight address bits (DPH), and Port 0 multiplexes the low-order eight address bits (DPL) with data. Both MOVX@Ri and MOVX@DPTR generates the necessary read and write signals (P3.6, - WR and P3.7, - RD) for external memory use. Table 9 shows external data memory RD, WR operation with EXTRAM bit.

The stack pointer (SP) can be located anywhere within the 256 B of internal RAM (lower 128 B and upper 128 B). The stack pointer may not be located in any part of the expanded RAM.

| Register AUXR | MOVX-@DPTR, A or N | MOVX-@Ri, A or<br>MOVX A, @Ri                        |                                                      |
|---------------|--------------------|------------------------------------------------------|------------------------------------------------------|
|               | ADDR < 0300H       | $\textbf{ADDR} \geq \textbf{0300H}$                  | ADDR = any                                           |
| EXTRAM = 0    | RD/WR not asserted | RD/WR asserted                                       | RD/WR not asserted                                   |
| EXTRAM = 1    | RD/WR asserted     | $\overline{\text{RD}}/\overline{\text{WR}}$ asserted | $\overline{\text{RD}}/\overline{\text{WR}}$ asserted |

#### Table 9. External data memory RD, WR with EXTRAM bit<sup>[1]</sup>

[1] Access limited to Expanded RAM address within 0 to 0FFH; cannot access 100H to 02FFH.

#### 8-bit microcontrollers with 80C51 core



#### 6.2.8 Dual data pointers

The device has two 16-bit data pointers. The DPTR Select (DPS) bit in AUXR1 determines which of the two data pointers is accessed. When DPS = 0, DPTR0 is selected; when DPS = 1, DPTR1 is selected. Quickly switching between the two data pointers can be accomplished by a single INC instruction on AUXR1 (see Figure 6).

#### 8-bit microcontrollers with 80C51 core



# Table 10.AUXR1 - Auxiliary register 1 (address A2H) bit allocationNot bit addressable; reset value 00H.

| Bit    | 7 | 6 | 5 | 4 | 3   | 2 | 1 | 0   |
|--------|---|---|---|---|-----|---|---|-----|
| Symbol | - | - | - | - | GF2 | 0 | - | DPS |

#### Table 11. AUXR1 - Auxiliary register 1 (address A2H) bit descriptions

| Bit    | Symbol | Description                                                                                                                                    |
|--------|--------|------------------------------------------------------------------------------------------------------------------------------------------------|
| 7 to 4 | -      | Reserved for future use. Should be set to '0' by user programs.                                                                                |
| 3      | GF2    | General purpose user-defined flag.                                                                                                             |
| 2      | 0      | This bit contains a hard-wired '0'. Allows toggling of the DPS bit by incrementing AUXR1, without interfering with other bits in the register. |
| 1      | -      | Reserved for future use. Should be set to '0' by user programs.                                                                                |
| 0      | DPS    | Data pointer select. Chooses one of two Data Pointers for use by the program. See text for details.                                            |

#### 6.3 Flash memory IAP

#### 6.3.1 Flash organization

The P89LV51RB2/RC2/RD2 program memory consists of a 16/32/64 kB block. ISP capability, in a second 8 kB block, is provided to allow the user code to be programmed in-circuit through the serial port. There are three methods of erasing or programming of the flash memory that may be used. First, the flash may be programmed or erased in the end-user application by calling low-level routines through a common entry point (IAP). Second, the on-chip ISP bootloader may be invoked. This ISP bootloader will, in turn, call low-level routines through the same common entry point that can be used by the end-user application. Third, the flash may be programmed or erased using the parallel method by using a commercially available EPROM programmer which supports this device.

#### 6.3.2 Boot block (block 1)

When the microcontroller programs its own flash memory, all of the low level details are handled by code that is contained in block 1. A user program calls the common entry point in the block 1 with appropriate parameters to accomplish the desired operation. Boot block operations include erase user code, program user code, program security bits, etc.

8-bit microcontrollers with 80C51 core

A chip-erase operation can be performed using a commercially available parallel programer. This operation will erase the contents of this boot block and it will be necessary for the user to reprogram this boot block (block 1) with the NXP-provided ISP/IAP code in order to use the ISP or IAP capabilities of this device. Go to <a href="http://www.nxp.com/support">http://www.nxp.com/support</a> for questions or to obtain the hex file for this device.

#### 6.3.3 ISP

ISP is performed without removing the microcontroller from the system. The ISP facility consists of a series of internal hardware resources coupled with internal firmware to facilitate remote programming of the P89LV51RB2/RC2/RD2 through the serial port. This firmware is provided by NXP and embedded within each P89LV51RB2/RC2/RD2 device. The NXP ISP facility has made in-circuit programming in an embedded application possible with a minimum of additional expense in components and circuit board area. The ISP function uses five pins ( $V_{DD}$ ,  $V_{SS}$ , TXD, RXD, and RST). Only a small connector needs to be available to interface your application to an external circuit in order to use this feature.

#### 6.3.4 Using ISP

The ISP feature allows for a wide range of baud rates to be used in your application, independent of the oscillator frequency. It is also adaptable to a wide range of oscillator frequencies. This is accomplished by measuring the bit-time of a single bit in a received character. This information is then used to program the baud rate in terms of timer counts based on the oscillator frequency. The ISP feature requires that an initial character (an uppercase U) be sent to the P89LV51RB2/RC2/RD2 to establish the baud rate. The ISP firmware provides auto-echo of received characters. Once baud rate initialization has been performed, the ISP firmware will only accept Intel Hex-type records. Intel Hex records consist of ASCII characters used to represent hexadecimal values and are summarized below:

#### :NNAAAARRDD..DDCC<crlf>

In the Intel Hex record, the 'NN' represents the number of data bytes in the record. The P89LV51RB2/RC2/RD2 will accept up to 32 data bytes. The 'AAAA' string represents the address of the first byte in the record. If there are zero bytes in the record, this field is often set to 0000. The 'RR' string indicates the record type. A record type of '00' is a data record. A record type of '01' indicates the end-of-file mark. In this application, additional record types will be added to indicate either commands or data for the ISP facility.

The maximum number of data bytes in a record is limited to 32 (decimal). ISP commands are summarized in <u>Table 12</u>. As a record is received by the P89LV51RB2/RC2/RD2, the information in the record is stored internally and a checksum calculation is performed. The operation indicated by the record type is not performed until the entire record has been received. Should an error occur in the checksum, the P89LV51RB2/RC2/RD2 will send an 'X' out the serial port indicating a checksum error. If the checksum calculation is found to match the checksum in the record will be indicated by transmitting a '.' character out the serial port.

8-bit microcontrollers with 80C51 core

| Table 12. ISF | P hex record formats                                                                                                                                   |
|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|
| Record type   | Command/data function                                                                                                                                  |
| 00            | Program User Code Memory                                                                                                                               |
|               | :nnaaaa00ddddcc                                                                                                                                        |
|               | Where:                                                                                                                                                 |
|               | nn = number of bytes to program                                                                                                                        |
|               | aaaa = address                                                                                                                                         |
|               | dddd = data bytes                                                                                                                                      |
|               | cc = checksum                                                                                                                                          |
|               |                                                                                                                                                        |
| <u></u>       | :10000000102030405006070809cc                                                                                                                          |
| 01            | End of File (EOF), no operation<br>:xxxxxx01cc                                                                                                         |
|               | Where:                                                                                                                                                 |
|               | xxxxxx = required field but value is a 'don't care'                                                                                                    |
|               | cc = checksum                                                                                                                                          |
|               | Example:                                                                                                                                               |
|               | :0000001FF                                                                                                                                             |
| 02            | Set SoftICE mode                                                                                                                                       |
|               | Following the next reset the device will enter the SoftICE mode. Will erase user code memory, and erase device serial number.<br>:00000002cc<br>Where: |
|               | xxxxxx = required field but value is a 'don't care'                                                                                                    |
|               | cc = checksum                                                                                                                                          |
|               | Example:                                                                                                                                               |
|               | :0000002FE                                                                                                                                             |

#### 8-bit microcontrollers with 80C51 core

| Table 12. ISI | P hex record formatscontinued                              |
|---------------|------------------------------------------------------------|
| Record type   | Command/data function                                      |
| 03            | Miscellaneous Write functions                              |
|               | :nnxxxx03ffssddcc                                          |
|               | Where:                                                     |
|               | nn = number of bytes in the record                         |
|               | xxxx = required field but value is a 'don't care'          |
|               | ff = subfunction code                                      |
|               | ss = selection code                                        |
|               | dd = data (if needed)                                      |
|               | cc = checksum                                              |
|               | Subfunction code = 01 (Erase block 0)                      |
|               | ff = 01                                                    |
|               | Subfunction code = 05 (Program security bit, Double Clock) |
|               | ff = 05                                                    |
|               | ss = 01 program security bit                               |
|               | ss = 05 program double clock bit                           |
|               | Subfunction code = 08 (Erase sector, 128 B)                |
|               | ff = 08                                                    |
|               | ss = high byte of sector address (A15:8)                   |
|               | dd = low byte of sector address (A7, A6:0 ]= 0)            |
|               | Example:                                                   |
|               | :030000308E000F2 (erase sector at E000H)                   |
| 04            | Display Device Data or Blank Check                         |
|               | :05xxxx04sssseeeeffcc                                      |
|               | Where                                                      |
|               | 05 = number of bytes in the record                         |
|               | xxxx = required field but value is a 'don't care'          |
|               | 04 = function code for display or blank check              |
|               | ssss = starting address, MSB first                         |
|               | eeee = ending address, MSB first                           |
|               | ff = subfunction                                           |
|               | 00 = display data                                          |
|               | 01 = blank check                                           |
|               | cc = checksum                                              |
|               |                                                            |
|               | Subfunction codes:                                         |
|               |                                                            |

#### Table 12 ISP hex record formats continued

8-bit microcontrollers with 80C51 core

| Record type | Command/data function                                                                                                                                                                                                                                                                                                                                                                                                                     |
|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 05          | Miscellaneous Read functions<br>:02xxxx05ffsscc<br>Where:<br>02 = number of bytes in the record<br>xxxx = required field but value is a 'don't care'<br>05 = function code for misc read<br>ffss = subfunction and selection code<br>0000 = read manufacturer id<br>0001 = read device id 1<br>0002 = read boot code version<br>0700 = read security bit (00 SoftICE serial number match 0 SB 0 Double Clock<br>cc = checksum<br>Example: |
| 06          | :02000050000F9 (display manufacturer id)<br>Direct load of baud rate<br>:02xxxx06HHLLcc<br>Where:<br>02 = number of bytes in the record<br>xxxx = required field but value is a 'don't care'<br>HH = high byte of timer<br>LL = low byte of timer<br>cc = checksum<br>Example:<br>:02000006FFFFcc (load T2 = FFFF)                                                                                                                        |
| 07          | Reset serial number, erase user code, clear SoftICE mode<br>:xxxxx07cc<br>Where:<br>xxxxxx = required field but value is a 'don't care'<br>07 = reset serial number function<br>cc = checksum<br>Example:<br>:00000007F9                                                                                                                                                                                                                  |
| 08          | Verify serial number<br>:nnxxx08sssscc<br>Where:<br>xxxxxx = required field but value is a 'don't care'<br>08 = verify serial number function<br>ssss = serial number contents<br>cc = checksum<br>Example:<br>:03000008010203EF (verify serial number = 010203)                                                                                                                                                                          |

8-bit microcontrollers with 80C51 core

| Record type | Command/data function                               |
|-------------|-----------------------------------------------------|
| 09          | Write serial number                                 |
|             | :nnxxxx09sssscc                                     |
|             | Where:                                              |
|             | xxxxxx = required field but value is a 'don't care' |
|             | 09 = write serial number function                   |
|             | ssss = serial number contents                       |
|             | cc = checksum                                       |
|             | Example:                                            |
|             | :0300009010203EE (write serial number = 010203)     |
| 0A          | Display serial number                               |
|             | :xxxxx0Acc                                          |
|             | Where:                                              |
|             | xxxxxx = required field but value is a 'don't care' |
|             | 0A = display serial number function                 |
|             | cc = checksum                                       |
|             | Example:                                            |
|             | :000000AF6                                          |
| 0B          | Reset and run user code                             |
|             | :xxxxx0Bcc                                          |
|             | Where:                                              |
|             | xxxxxx = required field but value is a 'don't care' |
|             | 0B = reset and run user code                        |
|             | cc = checksum                                       |
|             | Example:                                            |
|             | :000000BF5                                          |

#### 6.3.5 Using the serial number

This device has the option of storing a 31 B serial number along with the length of the serial number (for a total of 32 B) in a non-volatile memory space. When ISP mode is entered, the serial number length is evaluated to determine if the serial number is in use. If the length of the serial number is programmed to either 00H or FFH, the serial number is considered not in use. If the serial number is in use, reading, programming, or erasing of the user code memory or the serial number is blocked until the user transmits a 'verify serial number' record containing a serial number and length that matches the serial number to all zeros and set the length to zero by sending the 'reset serial number' record. In addition, the 'reset serial number' record will also erase all user code.

#### 6.3.6 IAP method

Several IAP calls are available for use by an application program to permit selective erasing, reading and programming of flash sectors, security bit, configuration bytes, and device id. All calls are made through a common interface, PGM\_MTP. The programming functions are selected by setting up the microcontroller's registers before making a call to PGM\_MTP at 1FF0H. The IAP calls are shown in <u>Table 13</u>.