



Welcome to **E-XFL.COM** 

What is "Embedded - Microcontrollers"?

"Embedded - Microcontrollers" refer to small, integrated circuits designed to perform specific tasks within larger systems. These microcontrollers are essentially compact computers on a single chip, containing a processor core, memory, and programmable input/output peripherals. They are called "embedded" because they are embedded within electronic devices to control various functions, rather than serving as standalone computers. Microcontrollers are crucial in modern electronics, providing the intelligence and control needed for a wide range of applications.

Applications of "<u>Embedded - Microcontrollers</u>"

| Details                    |                                                                        |
|----------------------------|------------------------------------------------------------------------|
| Product Status             | Obsolete                                                               |
| Core Processor             | 8051                                                                   |
| Core Size                  | 8-Bit                                                                  |
| Speed                      | 40MHz                                                                  |
| Connectivity               | UART/USART                                                             |
| Peripherals                | POR                                                                    |
| Number of I/O              | 32                                                                     |
| Program Memory Size        | 8KB (8K x 8)                                                           |
| Program Memory Type        | FLASH                                                                  |
| EEPROM Size                | 192 x 8                                                                |
| RAM Size                   | 256 x 8                                                                |
| Voltage - Supply (Vcc/Vdd) | 2.7V ~ 5.5V                                                            |
| Data Converters            | -                                                                      |
| Oscillator Type            | External                                                               |
| Operating Temperature      | -40°C ~ 85°C (TA)                                                      |
| Mounting Type              | Through Hole                                                           |
| Package / Case             | 40-DIP (0.600", 15.24mm)                                               |
| Supplier Device Package    | 40-DIP                                                                 |
| Purchase URL               | https://www.e-xfl.com/product-detail/nxp-semiconductors/p89v52x2fn-112 |

# 80C51 with 256 B RAM, 192 B data EEPROM

# 3. Ordering information

Table 1. Ordering information

| Type number | Package | Version                                                                                    |          |  |
|-------------|---------|--------------------------------------------------------------------------------------------|----------|--|
|             | Name    | Description                                                                                |          |  |
| P89V52X2FN  | DIP40   | plastic dual in-line package; 40 leads (600 mil)                                           | SOT129-1 |  |
| P89V52X2FBD | LQFP44  | plastic low profile quad flat package; 44 leads; body $10 \times 10 \times 1.4 \text{ mm}$ | SOT389-1 |  |
| P89V52X2FA  | PLCC44  | plastic leaded chip carrier; 44 leads                                                      | SOT187-2 |  |

# 4. Block diagram



80C51 with 256 B RAM, 192 B data EEPROM

# 5. Pinning information

# 5.1 Pinning



# 80C51 with 256 B RAM, 192 B data EEPROM





# 80C51 with 256 B RAM, 192 B data EEPROM

# 5.2 Pin description

Table 2. Pin description

| Symbol         | Pin   |        |        | Туре                            | Description                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |
|----------------|-------|--------|--------|---------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
|                | DIP40 | LQFP44 | PLCC44 |                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |
| P0[0] to P0[7] |       |        |        | I/O                             | Port 0: 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. External pull-ups are required as a general purpose I/O port. |  |  |  |
| P0[0]/AD0      | 39    | 37     | 43     | I/O                             | <b>P0[0]</b> — Port 0 bit 0.                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |
|                |       |        |        | I/O                             | AD0 — Address/data bit 0.                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |
| P0[1]/AD1      | 38    | 36     | 42     | I/O                             | <b>P0[1]</b> — Port 0 bit 1.                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |
|                |       |        |        | I/O                             | AD1 — Address/data bit 1.                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |
| P0[2]/AD2      | 37    | 35     | 41     | I/O                             | <b>P0[2]</b> — Port 0 bit 2.                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |
|                |       |        |        | I/O                             | AD2 — Address/data bit 2.                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |
| P0[3]/AD3      | 36    | 34     | 40     | I/O                             | <b>P0[3]</b> — Port 0 bit 3.                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |
|                |       |        |        | I/O                             | AD3 — Address/data bit 3.                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |
| P0[4]/AD4      | 35    | 33     | 39     | I/O                             | <b>P0[4]</b> — Port 0 bit 4.                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |
|                |       |        |        | I/O                             | AD4 — Address/data bit 4.                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |
| P0[5]/AD5      | 34    | 32     | 38     | I/O                             | <b>P0[5]</b> — Port 0 bit 5.                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |
|                |       |        |        | I/O                             | AD5 — Address/data bit 5.                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |
| P0[6]/AD6      | 33    | 31     | 37     | I/O                             | <b>P0[6]</b> — Port 0 bit 6.                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |
|                |       |        |        | I/O                             | AD6 — Address/data bit 6.                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |
| P0[7]/AD7      | 32    | 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 <sub>IL</sub> ) because of the internal pull-ups. P1[5], P1[6], P1[7] have high current drive of 16 mA.                                   |  |  |  |
| P1[0]/T2       | 1     | 40     | 2      | I/O                             | <b>P1[0]</b> — Port 1 bit 0.                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |
|                |       |        |        | I                               | <b>T2</b> — External count input to Timer/Counter 2 or Clock-out from Timer/Counter 2                                                                                                                                                                                                                                                                                                                                                   |  |  |  |
| P1[1]/T2EX     | 2     | 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                                                                                                                                                                                                                                                                                                                                                              |  |  |  |
| P1[2]          | 3     | 42     | 4      | I/O                             | <b>P1[2]</b> — Port 1 bit 2.                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |
| P1[3]          | 4     | 43     | 5      | I/O                             | <b>P1[3]</b> — Port 1 bit 3.                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |
| P1[4]          | 5     | 44     | 6      | I/O                             | <b>P1[4]</b> — Port 1 bit 4.                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |
| P1[5]          | 6     | 1      | 7      | I/O                             | <b>P1[5]</b> — Port 1 bit 5.                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |
| P1[6]          | 7     | 2      | 8      | I/O                             | <b>P1[6]</b> — Port 1 bit 6.                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |

**NXP Semiconductors** 

Table 3. Special function registers[1] \* indicates SFRs that are bit addressable.

| Name   | Description                   | SFR         |                 |                 | Ві      | t functions a | and address | es      |            |           |
|--------|-------------------------------|-------------|-----------------|-----------------|---------|---------------|-------------|---------|------------|-----------|
|        |                               | addr.       | MSB             |                 |         |               |             |         |            | LSB       |
|        |                               | Bit address | <b>E7</b>       | <b>E</b> 6      | E5      | E4            | E3          | E2      | E1         | E0        |
| ACC*   | Accumulator                   | E0H         | -               | -               | -       | -             | -           | -       | -          | -         |
| AUXR   | Auxiliary function register   | 8EH         | -               | -               | -       | -             | -           | -       | -          | AO        |
| AUXR1  | Auxiliary function register 1 | A2H         | -               | -               | -       |               | GF2         | 0       | -          | DPS       |
|        |                               | Bit address | F7              | F6              | F5      | F4            | F3          | F2      | F1         | F0        |
| B*     | B register                    | F0H         | -               | -               | -       | -             | -           | -       | -          | -         |
| CKCON  | B register                    | 8FH         | -               | -               | -       | -             | -           | -       | -          | X2        |
| DPTR   | Data Pointer (2 B)            |             |                 |                 |         |               |             |         |            |           |
| DPH    | Data Pointer HIGH             | 83H         | -               | -               | -       | -             | -           | -       | -          | -         |
| DPL    | Data Pointer LOW              | 82H         | -               | -               | -       | -             | -           | -       | -          | -         |
| FMCON  | Flash control register (R)    | F4H         | BUSY            | WE              | -       | DAP           | -           | -       | SV         | ERR       |
|        | Flash control register (W)    |             | FMCMD.7         | FMCMD.6         | FMCMD.5 | FMCMD.4       | FMCMD.3     | FMCMD.2 | FMCMD.1    | FMCMD.0   |
| FMDATA | Flash data register           | F5H         | -               | -               | -       | -             | -           | -       | -          | -         |
| FMADRH | Flash memory address HIGH     | F6H         | -               | -               | -       | -             | -           | -       | -          | -         |
| FMADRL | Flash memory address LOW      | F7H         | -               | -               | -       | -             | -           | -       | -          | -         |
|        |                               | Bit address | AF              | AE              | AD      | AC            | AB          | AA      | <b>A9</b>  | <b>A8</b> |
| IE*    | Interrupt Enable 0            | H8A         | EA              | -               | ET2     | ES            | ET1         | EX1     | ET0        | EX0       |
|        |                               | Bit address | BF              | BE              | BD      | ВС            | BB          | BA      | <b>B9</b>  | B8        |
| IP*    | Interrupt Priority 0          | B8H         | -               | -               | PT2     | PS            | PT1         | PX1     | PT0        | PX0       |
| IPH    | Interrupt Priority 0 HIGH     | B7H         | -               | -               | PT2H    | PS0H          | PT1H        | PX1H    | PT0H       | PX0H      |
|        |                               | Bit address | 87              | 86              | 85      | 84            | 83          | 82      | 81         | 80        |
| P0*    | Port 0                        | 80H         | AD7             | AD6             | AD5     | AD4           | AD3         | AD2     | AD1        | AD0       |
|        |                               | Bit address | 97              | 96              | 95      | 94            | 93          | 92      | 91         | 90        |
| P1*    | Port 1                        | 90H         | -               | -               | -       | -             | -           | -       | T2EX       | T2        |
|        |                               | Bit address | <b>A7</b>       | A6              | A5      | <b>A4</b>     | A3          | A2      | <b>A</b> 1 | Α0        |
| P2*    | Port 2                        | A0H         | AD15            | AD14            | AD13    | AD12          | AD11        | AD10    | AD9        | AD8       |
|        |                               | Bit address | B7              | B6              | B5      | B4            | В3          | B2      | B1         | В0        |
| P3*    | Port 3                        | В0Н         | $\overline{RD}$ | $\overline{WR}$ | T1      | T0            | ĪNT1        | ĪNT0    | TXD        | RXD       |
| PCON   | Power Control Register        | 87H         | SMOD1           | SMOD0           | -       | POF           | GF1         | GF0     | PD         | IDL       |

# 80C51 with 256 B RAM, 192 B data EEPROM

# 6.2 Memory organization

The various P89V52X2 memory spaces are as follows:

#### DATA

128 B of internal data memory space (00H:7FH) accessed via direct or indirect addressing, using instructions other than MOVX and MOVC. All or part of the Stack may be in this area.

#### IDATA

Indirect Data. 256 B of internal data memory space (00H:FFH) accessed via indirect addressing using instructions other than MOVX and MOVC. All or part of the Stack may be in this area. This area includes the DATA area and the 128 B immediately above it.

#### • SFR

Special Function Registers. Selected CPU registers and peripheral control and status registers, accessible only via direct addressing.

#### CODE

64 kB of Code memory space, accessed as part of program execution and via the MOVC instruction. The P89V52X2 has 8 kB of on-chip Code memory.

# 6.3 System clock and clock options

# 6.3.1 Clock input options and recommended capacitor values for the oscillator

Shown in Figure 5 and Figure 6 are the input and output of an internal inverting amplifier (XTAL1, XTAL2), which can be configured for use as an on-chip oscillator.

When driving the device from an external clock source, XTAL2 should be left disconnected and XTAL1 should be driven. Power consumption can be further reduced by programming the EXTCLK bit (UCFG.0).

At start-up, the external oscillator may encounter a higher capacitive load at XTAL1 due to interaction between the amplifier and its feedback capacitance. However, the capacitance will not exceed 15 pF once the external signal meets the  $V_{IL}$  and  $V_{IH}$  specifications.

Resonator manufacturer, supply voltage, and other factors may cause circuit performance to differ from one application to another.  $C_1$  and  $C_2$  should be adjusted appropriately for each design. Table 4 shows the typical values for  $C_1$  and  $C_2$  vs. resonator type for various frequencies.

Table 4. Recommended values for C<sub>1</sub> and C<sub>2</sub> by crystal type

| Resonator | $C_1 = C_2$    |
|-----------|----------------|
| Quartz    | 20 pF to 30 pF |
| Ceramic   | 40 pF to 50 pF |

# 80C51 with 256 B RAM, 192 B data EEPROM

| Table 3. | AUXINI - Aux | tiliary register i (address AZH) bit description                                                                                               |
|----------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------|
| 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.                                            |

Table 9. AUXR1 - Auxiliary register 1 (address A2H) bit description

#### 6.6 Reset

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 device 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 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_{SS}$  through an 8.2 k $\Omega$  resistor as shown in Figure 9.

During initial power 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 reset condition, under normal conditions, the device will start executing code from address 0000H in the user's code memory. However if the requirements are met for ICP entry, the device will enter ICP mode.



# 80C51 with 256 B RAM, 192 B data EEPROM



#### 6.8.3 Mode 2

Mode 2 configures the Timer register as an 8-bit Counter (TLn) with automatic reload, as shown in <u>Figure 12</u>. Overflow from TLn not only sets TFn, but also reloads TLn with the contents of THn, which must be preset by software. The reload leaves THn unchanged. Mode 2 operation is the same for Timer 0 and Timer 1.



#### 6.8.4 Mode 3

When timer 1 is in Mode 3 it is stopped (holds its count). The effect is the same as setting TR1 = 0.

Timer 0 in Mode 3 establishes TL0 and TH0 as two separate 8-bit counters. The logic for Mode 3 and Timer 0 is shown in <u>Figure 13</u>. TL0 uses the Timer 0 control bits:  $TOC/\overline{T}$ , T0GATE, TR0,  $\overline{INT0}$ , and TF0. TH0 is locked into a timer function (counting machine cycles) and takes over the use of TR1 and TF1 from Timer 1. Thus, TH0 now controls the 'Timer 1' interrupt.

Mode 3 is provided for applications that require an extra 8-bit timer. With Timer 0 in Mode 3, the P89V52X2 can look like it has an additional Timer.

**Note:** When Timer 0 is in Mode 3, Timer 1 can be turned on and off by switching it into and out of its own Mode 3. It can still be used by the serial port as a baud rate generator, or in any application not requiring an interrupt.

#### 80C51 with 256 B RAM, 192 B data EEPROM

used as the UART transmit baud rate generator. RCLK has the same effect for the UART receive baud rate. With these two bits, the serial port can have different receive and transmit baud rates – Timer 1 or Timer 2.

Figure 17 shows Timer 2 in baud rate generator mode:



The baud rate generation mode is like the auto-reload mode, when a rollover in TH2 causes the Timer 2 registers to be reloaded with the 16-bit value in registers RCAP2H and RCAP2L, which are preset by software.

The baud rates in modes 1 and 3 are determined by Timer 2's overflow rate given below:

Modes 1 and 3 Baud Rates = Timer 2 Overflow Rate/16

The timer can be configured for either 'timer' or 'counter' operation. In many applications, it is configured for 'timer' operation ( $C/\overline{T}2 = 0$ ). Timer operation is different for Timer 2 when it is being used as a baud rate generator.

Usually, as a timer it would increment every machine cycle (i.e.,  $\frac{1}{6}$  the oscillator frequency). As a baud rate generator, it increments at the oscillator frequency. Thus the baud rate formula is as follows:

Modes 1 and 3 Baud Rates =

$$\frac{OscillatorFrequency}{(16 \times (65536 - (RCAP2H, RCAP2L)))}$$
(3)

Where: (RCAP2H, RCAP2L) = The content of RCAP2H and RCAP2L taken as a 16-bit unsigned integer.

The Timer 2 as a baud rate generator mode is valid only if RCLK and/or TCLK = 1 in T2CON register. Note that a rollover in TH2 does not set TF2, and will not generate an interrupt. Thus, the Timer 2 interrupt does not have to be disabled when Timer 2 is in the baud rate generator mode. Also if the EXEN2 (T2 external enable flag) is set, a 1-to-0 transition in T2EX (Timer/counter 2 trigger input) will set EXF2 (T2 external flag) but will not cause a reload from (RCAP2H, RCAP2L) to (TH2, TL2). Therefore when Timer 2 is in use as a baud rate generator, T2EX can be used as an additional external interrupt, if needed.

# 80C51 with 256 B RAM, 192 B data EEPROM



The following examples will help to show the versatility of this scheme.

Example 1, slave 0:

SADDR = 
$$1100\ 0000$$
  

$$\frac{\text{SADEN} = 1111\ 1101}{\text{Given} = 1100\ 00X0}$$
(4)

Example 2, slave 1:

SADDR = 
$$1100\ 0000$$
  

$$\frac{\text{SADEN} = 1111\ 1110}{\text{Given} = 1100\ 000X}$$
(5)

In the above example SADDR is the same and the SADEN data is used to differentiate between the two slaves. Slave 0 requires a '0' in bit 0 and it ignores bit 1. Slave 1 requires a '0' in bit 1 and bit 0 is ignored. A unique address for Slave 0 would be 1100 0010 since slave 1 requires a '0' in bit 1. A unique address for slave 1 would be 1100 0001 since a '1' in bit 0 will exclude slave 0. Both slaves can be selected at the same time by an address which has bit 0 = 0 (for slave 0) and bit 1 = 0 (for slave 1). Thus, both could be addressed with 1100 0000.

In a more complex system the following could be used to select slaves 1 and 2 while excluding slave 0:

Example 1, slave 0:

# 80C51 with 256 B RAM, 192 B data EEPROM

SADDR =  $1100\ 0000$  $\frac{\text{SADEN} = 1111\ 1001}{\text{Given} = 1100\ 0XX0}$ (6)

Example 2, slave 1:

 $SADDR = 1110\ 0000$ 

 $\frac{\text{SADEN} = 1111\ 1010}{\text{Given} = 1110\ 0X0X} \tag{7}$ 

Example 2. slave 2:

 $SADDR = 1100\ 0000$ 

 $\frac{\text{SADEN} = 1111\ 1100}{\text{Given} = 1100\ 00XX} \tag{8}$ 

In the above example the differentiation among the 3 slaves is in the lower 3 address bits. Slave 0 requires that bit 0 = 0 and it can be uniquely addressed by 1110 0110. Slave 1 requires that bit 1 = 0 and it can be uniquely addressed by 1110 0101. Slave 2 requires that bit 2 = 0 and its unique address is 1110 0011. To select Slaves 0 and 1 and exclude Slave 2 use address 1110 0100, since it is necessary to make bit 2 = 1 to exclude slave 2. The Broadcast Address for each slave is created by taking the logical OR of SADDR and SADEN. Zeros in this result are treated as don't-cares. In most cases, interpreting the don't-cares as ones, the broadcast address will be FF hexadecimal. Upon reset SADDR and SADEN are loaded with 0s. This produces a given address of all 'don't cares' as well as a Broadcast address of all 'don't cares'. This effectively disables the Automatic Addressing mode and allows the microcontroller to use standard UART drivers which do not make use of this feature.

# 6.11 Interrupt priority and polling sequence

The device supports six interrupt sources under a four level priority scheme. <u>Table 24</u> summarizes the polling sequence of the supported interrupts. (See Figure 19).

Table 24. Interrupt polling sequence

| Description             | Interrupt flag | Vector address | Interrupt<br>enable | Interrupt<br>priority | Service<br>priority | Wake-up<br>Power-down |
|-------------------------|----------------|----------------|---------------------|-----------------------|---------------------|-----------------------|
| External<br>Interrupt 0 | IE0            | 0003H          | EX0                 | PX0/H                 | 1 (highest)         | yes                   |
| T0                      | TF0            | 000BH          | ET0                 | PT0/H                 | 2                   | no                    |
| External<br>Interrupt 1 | IE1            | 0013H          | EX1                 | PX1/H                 | 3                   | yes                   |
| T1                      | TF1            | 001BH          | ET1                 | PT1/H                 | 4                   | no                    |
| UART                    | TI/RI          | 0023H          | ES0                 | PS0/H                 | 5                   | no                    |
| T2                      | TF2, EXF2      | 003BH          | ET2                 | PT2/H                 | 6                   | no                    |

# 80C51 with 256 B RAM, 192 B data EEPROM

Writing either the PROG or EP command to FMCON will start the program or erase-program process and place the CPU in a program-idle state. The CPU will remain in this idle state until the program or erase-program cycle is completed. Interrupts will NOT be serviced until the cycle is completed.

Erase-program or programming of a single byte (or multiple bytes) in the data EEPROM array is accomplished using the following steps:

- Write the LOAD command (00H) to FMCON. The LOAD command will clear all locations in the page register and their corresponding update flags.
- Write the address within the page register to FMADRL. Since the loading the page register uses FMADRL[5:0], and since the erase-program or program command uses FMADRH and FMADRL[7:6], the user can write the byte location within the page register (FMADRL[5:0]) and the code memory page address (FMADRH and FMADRL[7:6]) at this time.
- Write the data to be programmed to FMDATA. This will increment FMADRL pointing to the next byte in the page register.
- Write the address of the next byte to be programmed to FMADRL, if desired. (This is not needed for contiguous bytes since FMADRL is auto-incremented). All bytes to be programmed must be within the same page.
- Write the data for the next byte to be programmed to FMDATA.
- Repeat writing of FMADRL and/or FMDATA until all desired bytes have been loaded into the page register.
- Write the page address mapped into user code memory to FMADRH and FMADRL[7:6], if not previously included when writing the page register address to FMADRL[5:0].
- Write the EP (68H) or PROG (48H) command to FMCON, starting the erase-program or program cycle.
- Read FMCON to check status. If aborted, repeat starting with the LOAD command.

Table 33. Flash Memory Control register (FMCON - address F4H) bit allocation

| Bit        | 7       | 6       | 5       | 4       | 3       | 2       | 1       | 0       |
|------------|---------|---------|---------|---------|---------|---------|---------|---------|
| Symbol (R) | BUSY    | WE      | -       | DAP     | -       | -       | SV      | ERR     |
| Symbol (W) | FMCMD.7 | FMCMD.6 | FMCMD.5 | FMCMD.4 | FMCMD.3 | FMCMD.2 | FMCMD.1 | FMCMD.0 |
| Reset      | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0       |

# 80C51 with 256 B RAM, 192 B data EEPROM

Table 34. Flash Memory Control register (FMCON - address E4H) bit description

| Di  |         |        | Described:                                                                                                                                                                                               |
|-----|---------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit | - ,     | Access | Description                                                                                                                                                                                              |
| 0   | ERR     | R      | Set when either of the following conditions occur:                                                                                                                                                       |
|     |         |        | <ul> <li>Device was reset before the operation was completed.</li> </ul>                                                                                                                                 |
|     |         |        | <ul> <li>Attempt made to access data EEPROM while Data Access Protect (DAP) is set.</li> </ul>                                                                                                           |
|     |         |        | <ul> <li>An error occurs in the device's internal high voltage circuits.</li> </ul>                                                                                                                      |
|     | FMCMD.0 | W      | Command byte bit 0.                                                                                                                                                                                      |
| 1   | SV      | R      | Security violation. Set when an attempt is made to program, erase, or CRC a secured page. The specific cause of the security violation depends on the operation:                                         |
|     |         |        | <ul> <li>PROG or EP: CSEC.0 = 1 or DPxSEC.1 = 1 for the page addressed by FMADRH/L.</li> </ul>                                                                                                           |
|     |         |        | • ERS_G: Any DPxSEC.0 = 1.                                                                                                                                                                               |
|     |         |        | <ul> <li>ERS_DP: DPxSEC.2 = 1 for addressed page while in execution mode.</li> </ul>                                                                                                                     |
|     |         |        | • CRC_DP: DPxCSEC.0 = 1 and DPxSEC.1 = 0.                                                                                                                                                                |
|     | FMCMD.1 | W      | Command byte bit 1                                                                                                                                                                                       |
| 2   | -       | R      | Reserved                                                                                                                                                                                                 |
|     | FMCMD.2 | W      | Command byte bit 2.                                                                                                                                                                                      |
| 3   | -       | R      | Reserved                                                                                                                                                                                                 |
|     | FMCMD.3 | W      | Command byte bit 3.                                                                                                                                                                                      |
| 4   | DAP     | R      | Data Access Protect. When set, access to the data EEPROM is unmapped and thus prohibited. Set by the MAP command. Cleared by the UNMAP command.                                                          |
|     | FMCMD.4 | W      | Command byte bit 4.                                                                                                                                                                                      |
| 5   | -       | R      | Reserved                                                                                                                                                                                                 |
|     | FMCMD.5 | W      | Command byte bit 5.                                                                                                                                                                                      |
| 6   | WE      | R      | When set, indicates that data EEPROM writes during program execution are enabled.                                                                                                                        |
|     | FMCMD.6 | W      | Command byte bit 6.                                                                                                                                                                                      |
| 7   | BUSY    | R      | Indicates that a program, erase, CRC calculation or similar operation is in progress. Note that this bit is usable only in ICP mode since the CPU is stalled whenever this bit is set in execution mode. |
|     | FMCMD.7 | W      | Command byte bit 7.                                                                                                                                                                                      |
|     |         |        |                                                                                                                                                                                                          |

An assembly language routine to load the page register and perform an erase/program operation is shown below. This code assumes the data EEPROM has been mapped into user code space.

# 80C51 with 256 B RAM, 192 B data EEPROM



- (3) Maximum I<sub>DD(idle)</sub>
- (4) Typical I<sub>DD(idle)</sub>

Fig 20. I<sub>DD</sub> vs. frequency

# 80C51 with 256 B RAM, 192 B data EEPROM

# 9.1 Explanation of symbols

Each timing symbol has 5 characters. The first character is always a 't' (stands for time). The other characters, depending on their positions, stand for the name of a signal or the logical status of that signal. The following is a list of all the characters and what they stand for.

A — Address

C — Clock

**D** — Input data

H — Logic level HIGH

I — Instruction (program memory contents)

L — Logic level LOW or ALE

P — PSEN

**Q** — Output data

R — RD signal

T — Time

V — Valid

W - WR signal

X — No longer a valid logic level

**Z** — High impedance (Float)

# Example:

t<sub>AVLL</sub> = Address valid to ALE LOW time

 $t_{LLPL} = ALE LOW to \overline{PSEN} LOW time$ 



P89V52X2\_3 © NXP B.V. 2009. All rights reserved.

# 80C51 with 256 B RAM, 192 B data EEPROM







# 80C51 with 256 B RAM, 192 B data EEPROM





P89V52X2 **NXP Semiconductors** 

LQFP44: plastic low profile quad flat package; 44 leads; body 10 x 10 x 1.4 mm

SOT389-1



|      |           |                |                |                |              | ,,           |                  |                  |     |                |     |   |              |     |     |     |                               |                               |          |
|------|-----------|----------------|----------------|----------------|--------------|--------------|------------------|------------------|-----|----------------|-----|---|--------------|-----|-----|-----|-------------------------------|-------------------------------|----------|
| UNIT | A<br>max. | A <sub>1</sub> | A <sub>2</sub> | A <sub>3</sub> | bp           | С            | D <sup>(1)</sup> | E <sup>(1)</sup> | е   | H <sub>D</sub> | HE  | L | Lp           | v   | w   | у   | Z <sub>D</sub> <sup>(1)</sup> | Z <sub>E</sub> <sup>(1)</sup> | θ        |
| mm   | 1.6       | 0.15<br>0.05   | 1.45<br>1.35   | 1 11 25        | 0.45<br>0.30 | 0.20<br>0.12 | 10.1<br>9.9      | 10.1<br>9.9      | 0.8 | 12.15<br>11.85 | - 1 | 1 | 0.75<br>0.45 | 0.2 | 0.2 | 0.1 | 1.14<br>0.85                  | 1.14<br>0.85                  | 7°<br>0° |

#### Note

1. Plastic or metal protrusions of 0.25 mm maximum per side are not included.

|       |        | EUROPEAN | ISSUE DATE |            |                                  |  |
|-------|--------|----------|------------|------------|----------------------------------|--|
| IEC   | JEDEC  | JEITA    |            | PROJECTION | 1330E DATE                       |  |
| 36E08 | MS-026 |          |            |            | <del>-00-01-19</del><br>02-06-07 |  |
|       | -      |          |            |            | IEC JEDEC JEHA                   |  |

Fig 31. Package outline SOT389-1 (LQFP44)

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

P89V52X2 **NXP Semiconductors** 

# 80C51 with 256 B RAM, 192 B data EEPROM

# PLCC44: plastic leaded chip carrier; 44 leads

#### SOT187-2



1. Plastic or metal protrusions of 0.25 mm (0.01 inch) maximum per side are not included.

0.013 | 0.026 | 0.650 | 0.650

| OUTLINE  |                 | REFER  | EUROPEAN | ISSUE DATE |            |                                 |
|----------|-----------------|--------|----------|------------|------------|---------------------------------|
| VERSION  | IEC JEDEC JEITA |        |          | PROJECTION | ISSUE DATE |                                 |
| SOT187-2 | 112E10          | MS-018 | EDR-7319 |            |            | <del>99-12-27</del><br>01-11-14 |

0.59

0.685 0.685 0.042 0.040

0.59

Fig 32. Package outline SOT187-2 (PLCC44)

P89V52X2\_3 © NXP B.V. 2009. All rights reserved.

# 80C51 with 256 B RAM, 192 B data EEPROM

# 13. Legal information

# 13.1 Data sheet status

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

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

# 13.2 Definitions

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

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

# 13.3 Disclaimers

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

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

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

damage. NXP Semiconductors accepts no liability for inclusion and/or use of NXP Semiconductors products in such equipment or applications and therefore such inclusion and/or use is at the customer's own risk.

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

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

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

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

**Export control** — This document as well as the item(s) described herein may be subject to export control regulations. Export might require a prior authorization from national authorities.

#### 13.4 Trademarks

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

# 14. Contact information

For more information, please visit: <a href="http://www.nxp.com">http://www.nxp.com</a>

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

P89V52X2\_3 © NXP B.V. 2009. All rights reserved.