



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                      | 33MHz                                                                      |
| Connectivity               | UART/USART                                                                 |
| Peripherals                | POR, PWM, WDT                                                              |
| Number of I/O              | 32                                                                         |
| Program Memory Size        | 64KB (64K x 8)                                                             |
| Program Memory Type        | FLASH                                                                      |
| EEPROM Size                | -                                                                          |
| RAM Size                   | 1K x 8                                                                     |
| Voltage - Supply (Vcc/Vdd) | 4.5V ~ 5.5V                                                                |
| Data Converters            | -                                                                          |
| Oscillator Type            | Internal                                                                   |
| Operating Temperature      | 0°C ~ 70°C (TA)                                                            |
| Mounting Type              | Surface Mount                                                              |
| Package / Case             | 44-LCC (J-Lead)                                                            |
| Supplier Device Package    | 44-PLCC (16.59x16.59)                                                      |
| Purchase URL               | https://www.e-xfl.com/product-detail/nxp-semiconductors/p89c51rd2ba-01-512 |

## 80C51 8-bit Flash microcontroller family

## P89C51RA2/RB2/RC2/RD2xx

8KB/16KB/32KB/64KB ISP/IAP Flash with 512B/512B/512B/1KB RAM

#### **BLOCK DIAGRAM - CPU ORIENTED**



## 80C51 8-bit Flash microcontroller family

## P89C51RA2/RB2/RC2/RD2xx

8KB/16KB/32KB/64KB ISP/IAP Flash with 512B/512B/512B/1KB RAM

#### LOGIC SYMBOL



#### **PINNING**

#### Plastic Dual In-Line Package



#### **Plastic Leaded Chip Carrier**



#### **Plastic Quad Flat Pack**



2002 Jul 18

6

# 80C51 8-bit Flash microcontroller family

## P89C51RA2/RB2/RC2/RD2xx

8KB/16KB/32KB/64KB ISP/IAP Flash with 512B/512B/512B/1KB RAM

Table 1. Special Function Registers

| SYMBOL   | DESCRIPTION             | DESCRIPTION DIRECT ADDRESS MSB MSB |       |       |        |        |      |          |        | RESET<br>VALUE |           |
|----------|-------------------------|------------------------------------|-------|-------|--------|--------|------|----------|--------|----------------|-----------|
|          |                         |                                    | MSB   |       |        |        |      |          |        | LSB            |           |
| ACC*     | Accumulator             | E0H                                | E7    | E6    | E5     | E4     | E3   | E2       | E1     | E0             | 00H       |
| AUXR#    | Auxiliary               | 8EH                                | _     | _     | -      | -      | _    | _        | EXTRAM | AO             | xxxxxx00B |
| AUXR1#   | Auxiliary 1             | A2H                                | _     | -     | ENBOOT | -      | GF2  | 0        | -      | DPS            | xxxxxxx0B |
| B*       | B register              | F0H                                | F7    | F6    | F5     | F4     | F3   | F2       | F1     | F0             | 00H       |
| CCAP0H#  | Module 0 Capture High   | FAH                                |       |       |        |        |      |          |        |                | xxxxxxxxB |
| CCAP1H#  | Module 1 Capture High   | FBH                                |       |       |        |        |      |          |        |                | xxxxxxxxB |
| CCAP2H#  | Module 2 Capture High   | FCH                                |       |       |        |        |      |          |        |                | xxxxxxxxB |
| CCAP3H#  | Module 3 Capture High   | FDH                                |       |       |        |        |      |          |        |                | xxxxxxxxB |
| CCAP4H#  | Module 4 Capture High   | FEH                                |       |       |        |        |      |          |        |                | xxxxxxxxB |
| CCAP0L#  | Module 0 Capture Low    | EAH                                |       |       |        |        |      |          |        |                | xxxxxxxxB |
| CCAP1L#  | Module 1 Capture Low    | EBH                                |       |       |        |        |      |          |        |                | xxxxxxxxB |
| CCAP2L#  | Module 2 Capture Low    | ECH                                |       |       |        |        |      |          |        |                | xxxxxxxxB |
| CCAP3L#  | Module 3 Capture Low    | EDH                                |       |       |        |        |      |          |        |                | xxxxxxxxB |
| CCAP4L#  | Module 4 Capture Low    | EEH                                |       |       |        |        |      |          |        |                | xxxxxxxxB |
| CCAPM0#  | Module 0 Mode           | DAH                                | _     | ECOM  | CAPP   | CAPN   | MAT  | TOG      | PWM    | ECCF           | x0000000E |
| CCAPM1#  | Module 1 Mode           | DBH                                | _     | ECOM  | CAPP   | CAPN   | MAT  | TOG      | PWM    | ECCF           | x0000000B |
| CCAPM2#  | Module 2 Mode           | DCH                                | _     | ECOM  | CAPP   | CAPN   | MAT  | TOG      | PWM    | ECCF           | x0000000B |
| CCAPM3#  | Module 3 Mode           | DDH                                | _     | ECOM  | CAPP   | CAPN   | MAT  | TOG      | PWM    | ECCF           | x0000000B |
| CCAPM4#  | Module 4 Mode           | DEH                                | _     | ECOM  | CAPP   | CAPN   | MAT  | TOG      | PWM    | ECCF           | x0000000B |
|          |                         |                                    | DF    | DE    | DD     | DC     | DB   | DA       | D9     | D8             | ]         |
| CCON*#   | PCA Counter Control     | D8H                                | CF    | CR    | -      | CCF4   | CCF3 | CCF2     | CCF1   | CCF0           | 00x00000B |
| CH#      | PCA Counter High        | F9H                                |       |       |        |        |      |          |        |                | 00H       |
| CKCON#   | Clock control           | 8FH                                | _     | WDX2  | PCAX2  | SIX2   | T2X2 | T1X2     | T0X2   | X2             | x0000000B |
| CL#      | PCA Counter Low         | E9H                                |       |       |        |        |      |          |        |                | 00H       |
| CMOD#    | PCA Counter Mode        | D9H                                | CIDL  | WDTE  | _      | _      | _    | CPS1     | CPS0   | ECF            | 00xxx000E |
| DPTR:    | Data Pointer (2 bytes)  | 1                                  |       |       |        |        |      |          |        |                | 1         |
| DPH      | Data Pointer High       | 83H                                |       |       |        |        |      |          |        |                | 00H       |
| DPL      | Data Pointer Low        | 82H                                |       |       |        |        |      |          |        |                | 00H       |
| D. L     | Data i dintoi 2011      | 02.1                               | AF    | AE    | AD     | AC     | AB   | AA       | A9     | A8             | 0011      |
| IE*      | Interrupt Enable 0      | A8H                                | EA    | EC    | ET2    | ES     | ET1  | EX1      | ET0    | EX0            | 00H       |
|          | '                       |                                    | BF    | BE    | BD     | BC     | BB   | BA       | B9     | B8             | 1         |
| IP*      | Interrupt Priority      | B8H                                | _     | PPC   | PT2    | PS     | PT1  | PX1      | PT0    | PX0            | x0000000E |
| IPH#     | Interrupt Priority High | B7H                                | _     | PPCH  | PT2H   | PSH    | PT1H | PX1H     | PT0H   | PX0H           | x0000000B |
|          |                         |                                    |       |       |        |        |      | <u> </u> |        |                | 1         |
|          |                         |                                    | 87    | 86    | 85     | 84     | 83   | 82       | 81     | 80             |           |
| P0*      | Port 0                  | 80H                                | AD7   | AD6   | AD5    | AD4    | AD3  | AD2      | AD1    | AD0            | FFH       |
|          |                         |                                    | 97    | 96    | 95     | 94     | 93   | 92       | 91     | 90             |           |
| P1*      | Port 1                  | 90H                                | CEX4  | CEX3  | CEX2   | CEX1   | CEX0 | ECI      | T2EX   | T2             | FFH       |
|          |                         |                                    | A7    | A6    | A5     | A4     | A3   | A2       | A1     | A0             |           |
| P2*      | Port 2                  | A0H                                | AD15  | AD14  | AD13   | AD12   | AD11 | AD10     | AD9    | AD8            | FFH       |
|          |                         |                                    | B7    | B6    | B5     | B4     | В3   | B2       | B1     | В0             |           |
| P3*      | Port 3                  | ВОН                                | RD    | WR    | T1     | T0     | ĪNT1 | ĪNT0     | TxD    | RxD            | FFH       |
| D001:::4 |                         |                                    | 01155 | 0.16  |        | - nc - |      | 05:      | 5-     |                |           |
| PCON#1   | Power Control           | 87H                                | SMOD1 | SMOD0 | _      | POF    | GF1  | GF0      | PD     | IDL            | 00xxx000B |

<sup>\*</sup> SFRs are bit addressable.

<sup>#</sup> SFRs are modified from or added to the 80C51 SFRs.

Reserved bits.

<sup>1.</sup> Reset value depends on reset source.

## 80C51 8-bit Flash microcontroller family

#### P89C51RA2/RB2/RC2/RD2xx

8KB/16KB/32KB/64KB ISP/IAP Flash with 512B/512B/512B/1KB RAM

#### LOW POWER MODES Stop Clock Mode

The static design enables the clock speed to be reduced down to 0 MHz (stopped). When the oscillator is stopped, the RAM and Special Function Registers retain their values. This mode allows step-by-step utilization and permits reduced system power consumption by lowering the clock frequency down to any value. For lowest power consumption the Power Down mode is suggested.

#### **Idle Mode**

In the idle mode (see Table 2), the CPU puts itself to sleep while all of the on-chip peripherals stay active. The instruction to invoke the idle mode is the last instruction executed in the normal operating mode before the idle mode is activated. The CPU contents, the on-chip RAM, and all of the special function registers remain intact during this mode. The idle mode can be terminated either by any enabled interrupt (at which time the process is picked up at the interrupt service routine and continued), or by a hardware reset which starts the processor in the same manner as a power-on reset.

#### **Power-Down Mode**

To save even more power, a Power Down mode (see Table 2) can be invoked by software. In this mode, the oscillator is stopped and the instruction that invoked Power Down is the last instruction executed. The on-chip RAM and Special Function Registers retain their values down to 2 V and care must be taken to return  $V_{CC}$  to the minimum specified operating voltages before the Power Down Mode is terminated.

Either a hardware reset or external interrupt can be used to exit from Power Down. Reset redefines all the SFRs but does not change the on-chip RAM. An external interrupt allows both the SFRs and the on-chip RAM to retain their values.

To properly terminate Power Down, the reset or external interrupt should not be executed before  $V_{CC}$  is restored to its normal operating level and must be held active long enough for the oscillator to restart and stabilize (normally less than 10 ms).

With an external interrupt, INT0 and INT1 must be enabled and configured as level-sensitive. Holding the pin low restarts the oscillator but bringing the pin back high completes the exit. Once the interrupt is serviced, the next instruction to be executed after RETI will be the one following the instruction that put the device into Power Down.

#### **POWER-ON FLAG**

The Power-On Flag (POF) is set by on-chip circuitry when the  $V_{CC}$  level on the P89C51RA2/RB2/RC2/RD2xx rises from 0 to 5 V. The POF bit can be set or cleared by software allowing a user to determine if the reset is the result of a power-on or a warm start after powerdown. The  $V_{CC}$  level must remain above 3 V for the POF to remain unaffected by the  $V_{CC}$  level.

#### **Design Consideration**

When the idle mode is terminated by a hardware reset, the device normally resumes program execution, from where it left off, up to two machine cycles before the internal reset algorithm takes control. On-chip hardware inhibits access to internal RAM in this event, but access to the port pins is not inhibited. To eliminate the possibility of an unexpected write when Idle is terminated by reset, the instruction following the one that invokes Idle should not be one that writes to a port pin or to external memory.

#### ONCE™ Mode

The ONCE ("On-Circuit Emulation") Mode facilitates testing and debugging of systems without the device having to be removed from the circuit. The ONCE Mode is invoked by:

- 1. Pull ALE low while the device is in reset and PSEN is high;
- 2. Hold ALE low as RST is deactivated.

While the device is in ONCE Mode, the Port 0 pins go into a float state, and the other port pins and ALE and PSEN are weakly pulled high. The oscillator circuit remains active. While the device is in this mode, an emulator or test CPU can be used to drive the circuit. Normal operation is restored when a normal reset is applied.

#### **Programmable Clock-Out**

A 50% duty cycle clock can be programmed to come out on P1.0. This pin, besides being a regular I/O pin, has two alternate functions. It can be programmed:

- 1. to input the external clock for Timer/Counter 2, or
- to output a 50% duty cycle clock ranging from 61 Hz to 4 MHz at a 16 MHz operating frequency in 12-clock mode (122 Hz to 8 MHz in 6-clock mode).

To configure the Timer/Counter 2 as a clock generator, bit C/T2 (in T2CON) must be cleared and bit T20E in T2MOD must be set. Bit TR2 (T2CON.2) also must be set to start the timer.

The Clock-Out frequency depends on the oscillator frequency and the reload value of Timer 2 capture registers (RCAP2H, RCAP2L) as shown in this equation:

Oscillator Frequency

n × (65536 - RCAP2H, RCAP2L)

n = 2 in 6-clock mode

4 in 12-clock mode

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

In the Clock-Out mode Timer 2 roll-overs will not generate an interrupt. This is similar to when it is used as a baud-rate generator. It is possible to use Timer 2 as a baud-rate generator and a clock generator simultaneously. Note, however, that the baud-rate and the Clock-Out frequency will be the same.

Table 2. External Pin Status During Idle and Power-Down Mode

| MODE       | PROGRAM MEMORY | ALE | PSEN | PORT 0 | PORT 1 | PORT 2  | PORT 3 |
|------------|----------------|-----|------|--------|--------|---------|--------|
| Idle       | Internal       | 1   | 1    | Data   | Data   | Data    | Data   |
| Idle       | External       | 1   | 1    | Float  | Data   | Address | Data   |
| Power-down | Internal       | 0   | 0    | Data   | Data   | Data    | Data   |
| Power-down | External       | 0   | 0    | Float  | Data   | Data    | Data   |

## 80C51 8-bit Flash microcontroller family

#### P89C51RA2/RB2/RC2/RD2xx

8KB/16KB/32KB/64KB ISP/IAP Flash with 512B/512B/512B/1KB RAM

#### **TIMER 0 AND TIMER 1 OPERATION**

#### Timer 0 and Timer 1

The "Timer" or "Counter" function is selected by control bits C/T in the Special Function Register TMOD. These two Timer/Counters have four operating modes, which are selected by bit-pairs (M1, M0) in TMOD. Modes 0, 1, and 2 are the same for both Timers/Counters. Mode 3 is different. The four operating modes are described in the following text.

#### Mode 0

Putting either Timer into Mode 0 makes it look like an 8048 Timer, which is an 8-bit Counter with a divide-by-32 prescaler. Figure 2 shows the Mode 0 operation.

In this mode, the Timer register is configured as a 13-bit register. As the count rolls over from all 1s to all 0s, it sets the Timer interrupt flag TFn. The counted input is enabled to the Timer when TRn = 1 and either GATE = 0 or  $\overline{\text{INTn}}$  = 1. (Setting GATE = 1 allows the Timer to be controlled by external input  $\overline{\text{INTn}}$ , to facilitate pulse width measurements). TRn is a control bit in the Special Function Register TCON (Figure 3).

The 13-bit register consists of all 8 bits of THn and the lower 5 bits of TLn. The upper 3 bits of TLn are indeterminate and should be ignored. Setting the run flag (TRn) does not clear the registers.

Mode 0 operation is the same for Timer 0 as for Timer 1. There are two different GATE bits, one for Timer 1 (TMOD.7) and one for Timer 0 (TMOD.3).

#### Mode 1

Mode 1 is the same as Mode 0, except that the Timer register is being run with all 16 bits.

#### Mode 2

Mode 2 configures the Timer register as an 8-bit Counter (TLn) with automatic reload, as shown in Figure 4. Overflow from TLn not only sets TFn, but also reloads TLn with the contents of THn, which is preset by software. The reload leaves THn unchanged.

Mode 2 operation is the same for Timer 0 as for Timer 1.

#### Mode 3

Timer 1 in Mode 3 simply holds its count. The effect is the same as setting TR1 = 0.

Timer 0 in Mode 3 establishes TL0 and TH0 as two separate counters. The logic for Mode 3 on Timer 0 is shown in Figure 5. TL0 uses the Timer 0 control bits:  $C/\overline{T}$ , GATE, TR0, and TF0 as well as pin  $\overline{\text{INT0}}$ . 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 requiring an extra 8-bit timer on the counter. With Timer 0 in Mode 3, an 80C51 can look like it has three Timer/Counters. When Timer 0 is in Mode 3, Timer 1 can be turned on and off by switching it out of and into its own Mode 3, or can still be used by the serial port as a baud rate generator, or in fact, in any application not requiring an interrupt.



Figure 1. Timer/Counter 0/1 Mode Control (TMOD) Register

## 80C51 8-bit Flash microcontroller family

#### P89C51RA2/RB2/RC2/RD2xx

8KB/16KB/32KB/64KB ISP/IAP Flash with 512B/512B/512B/1KB RAM



Figure 2. Timer/Counter 0/1 Mode 0: 13-Bit Timer/Counter



Figure 3. Timer/Counter 0/1 Control (TCON) Register

## 80C51 8-bit Flash microcontroller family

## P89C51RA2/RB2/RC2/RD2xx

8KB/16KB/32KB/64KB ISP/IAP Flash with 512B/512B/512B/1KB RAM

Table 3. Timer 2 Operating Modes

| RCLK + TCLK | CP/RL2 | TR2 | MODE                |
|-------------|--------|-----|---------------------|
| 0           | 0      | 1   | 16-bit Auto-reload  |
| 0           | 1      | 1   | 16-bit Capture      |
| 1           | X      | 1   | Baud rate generator |
| X           | Х      | 0   | (off)               |



Figure 7. Timer 2 in Capture Mode



Figure 8. Timer 2 Mode (T2MOD) Control Register

# 80C51 8-bit Flash microcontroller family

## P89C51RA2/RB2/RC2/RD2xx

8KB/16KB/32KB/64KB ISP/IAP Flash with 512B/512B/512B/1KB RAM



Figure 9. Timer 2 in Auto-Reload Mode (DCEN = 0)



Figure 10. Timer 2 Auto Reload Mode (DCEN = 1)

## 80C51 8-bit Flash microcontroller family

## P89C51RA2/RB2/RC2/RD2xx

8KB/16KB/32KB/64KB ISP/IAP Flash with 512B/512B/512B/1KB RAM

When Timer 2 is in the baud rate generator mode, one should not try to read or write TH2 and TL2. As a baud rate generator, Timer 2 is incremented every state time (osc/2) or asynchronously from pin T2; under these conditions, a read or write of TH2 or TL2 may not be accurate. The RCAP2 registers may be read, but should not be written to, because a write might overlap a reload and cause write and/or reload errors. The timer should be turned off (clear TR2) before accessing the Timer 2 or RCAP2 registers.

Table 4 shows commonly used baud rates and how they can be obtained from Timer 2.

#### **Summary of Baud Rate Equations**

Timer 2 is in baud rate generating mode. If Timer 2 is being clocked through pin T2 (P1.0) the baud rate is:

Baud Rate = 
$$\frac{\text{Timer 2 Overflow Rate}}{16}$$

If Timer 2 is being clocked internally, the baud rate is:

Baud Rate = 
$$\frac{f_{OSC}}{[n* \times [65536 - (RCAP2H, RCAP2L)]]}$$
\* n = \quad \quad \text{16 in 6-clock mode} \quad \text{20 in 6-clock mode}

Where f<sub>OSC</sub>= Oscillator Frequency

To obtain the reload value for RCAP2H and RCAP2L, the above equation can be rewritten as:

RCAP2H, RCAP2L = 
$$65536 - \left(\frac{f_{OSC}}{n^* \times Baud Rate}\right)$$

#### **Timer/Counter 2 Set-up**

Except for the baud rate generator mode, the values given for T2CON do not include the setting of the TR2 bit. Therefore, bit TR2 must be set, separately, to turn the timer on. see Table 5 for set-up of Timer 2 as a timer. Also see Table 6 for set-up of Timer 2 as a counter.

Table 5. Timer 2 as a Timer

|                                                         | T20                          | CON                          |
|---------------------------------------------------------|------------------------------|------------------------------|
| MODE                                                    | INTERNAL CONTROL<br>(Note 1) | EXTERNAL CONTROL<br>(Note 2) |
| 16-bit Auto-Reload                                      | 00H                          | 08H                          |
| 16-bit Capture                                          | 01H                          | 09H                          |
| Baud rate generator receive and transmit same baud rate | 34H                          | 36H                          |
| Receive only                                            | 24H                          | 26H                          |
| Transmit only                                           | 14H                          | 16H                          |

#### Table 6. Timer 2 as a Counter

| 14515 01 111101 2 45 4 55411101 |                              |                              |
|---------------------------------|------------------------------|------------------------------|
|                                 | Tr                           | MOD                          |
| MODE                            | INTERNAL CONTROL<br>(Note 1) | EXTERNAL CONTROL<br>(Note 2) |
| 16-bit                          | 02H                          | 0AH                          |
| Auto-Reload                     | 03H                          | 0BH                          |

#### NOTES:

- Capture/reload occurs only on timer/counter overflow.
- 2. Capture/reload occurs on timer/counter overflow and a 1-to-0 transition on T2EX (P1.1) pin except when Timer 2 is used in the baud rate generator mode.

## 80C51 8-bit Flash microcontroller family

## P89C51RA2/RB2/RC2/RD2xx

8KB/16KB/32KB/64KB ISP/IAP Flash with 512B/512B/512B/1KB RAM

| S    | CON                                                                                                                                                                                                                                                                                               | Addres                                                                                                                                                                                              | s = 98H             |                                                                                                                             |                      |          |           |                       |                                  |          |         | Reset Value = 00H |
|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------|-----------------------------------------------------------------------------------------------------------------------------|----------------------|----------|-----------|-----------------------|----------------------------------|----------|---------|-------------------|
|      |                                                                                                                                                                                                                                                                                                   | Bit Addressable                                                                                                                                                                                     |                     | 7                                                                                                                           | 6                    | 5        | 4         | 3                     | 2                                | 1        | 0       |                   |
|      |                                                                                                                                                                                                                                                                                                   |                                                                                                                                                                                                     |                     | SM0                                                                                                                         | SM1                  | SM2      | REN       | TB8                   | RB8                              | TI       | RI      |                   |
| Wher | Where SM0, SM1 specify the serial port mode, as follows:                                                                                                                                                                                                                                          |                                                                                                                                                                                                     |                     |                                                                                                                             |                      |          |           |                       |                                  |          |         |                   |
| SM0  | MO SM1 Mode Description Baud Rate                                                                                                                                                                                                                                                                 |                                                                                                                                                                                                     |                     |                                                                                                                             |                      |          |           |                       |                                  |          |         |                   |
| 0    | 0                                                                                                                                                                                                                                                                                                 | 0                                                                                                                                                                                                   | shift register      |                                                                                                                             | f <sub>OSC</sub> /12 | 2 (12-cl | ock mod   | le) or f <sub>O</sub> | SC/6 (6-                         | -clock m | node)   |                   |
| 0    | 1                                                                                                                                                                                                                                                                                                 | 1                                                                                                                                                                                                   | 8-bit UART          |                                                                                                                             | variable             | Э        |           |                       |                                  |          |         |                   |
| 1    | 0                                                                                                                                                                                                                                                                                                 | 2                                                                                                                                                                                                   | 9-bit UART          | f <sub>OSC</sub> /64 or f <sub>OSC</sub> /32 (12-clock mode) or f <sub>OSC</sub> /32 or f <sub>OSC</sub> /16 (6-clock mode) |                      |          |           |                       | <sub>SC</sub> /16 (6-clock mode) |          |         |                   |
| 1    | 1                                                                                                                                                                                                                                                                                                 | 3                                                                                                                                                                                                   | 9-bit UART          |                                                                                                                             | variable             | Э        |           |                       |                                  |          |         |                   |
| SM2  | Enables the multiprocessor communication feature in Modes 2 and 3. In Mode 2 or 3, if SM2 is set to 1, then RI will not be activated if the received 9th data bit (RB8) is 0. In Mode 1, if SM2=1 then RI will not be activated if a valid stop bit was not received. In Mode 0, SM2 should be 0. |                                                                                                                                                                                                     |                     |                                                                                                                             |                      |          |           |                       |                                  |          |         |                   |
| REN  | Ena                                                                                                                                                                                                                                                                                               | ables seri                                                                                                                                                                                          | al reception. Set   | by soft                                                                                                                     | ware to              | enable   | reception | n. Clea               | r by sof                         | tware to | disable | reception.        |
| TB8  | The                                                                                                                                                                                                                                                                                               | 9th data                                                                                                                                                                                            | bit that will be to | ransmitt                                                                                                                    | ed in M              | odes 2   | and 3. S  | Set or cl             | ear by s                         | oftware  | as desi | red.              |
| RB8  |                                                                                                                                                                                                                                                                                                   | In Modes 2 and 3, is the 9th data bit that was received. In Mode 1, it SM2=0, RB8 is the stop bit that was received. In Mode 0, RB8 is not used.                                                    |                     |                                                                                                                             |                      |          |           |                       |                                  |          |         |                   |
| TI   |                                                                                                                                                                                                                                                                                                   | Transmit interrupt flag. Set by hardware at the end of the 8th bit time in Mode 0, or at the beginning of the stop bit in the other modes, in any serial transmission. Must be cleared by software. |                     |                                                                                                                             |                      |          |           |                       |                                  |          |         |                   |
| RI   |                                                                                                                                                                                                                                                                                                   | Receive interrupt flag. Set by hardware at the end of the 8th bit time in Mode 0, or halfway through the stop bit time in the other                                                                 |                     |                                                                                                                             |                      |          |           |                       |                                  |          |         |                   |
|      | mo                                                                                                                                                                                                                                                                                                | des, in an                                                                                                                                                                                          | y serial receptio   | n (exce                                                                                                                     | pt see S             | SM2). N  | lust be d | leared                | by softw                         | are.     |         | SU01626           |

Figure 12. Serial Port Control (SCON) Register

|               | Baud Rate     |              | £          | SMOD   | Timer 1 |      |              |  |
|---------------|---------------|--------------|------------|--------|---------|------|--------------|--|
| Mode          | 12-clock mode | 6-clock mode | fosc       | SINIOD | C/T     | Mode | Reload Value |  |
| Mode 0 Max    | 1.67 MHz      | 3.34 MHz     | 20 MHz     | Х      | Х       | Х    | Х            |  |
| Mode 2 Max    | 625 k         | 1250 k       | 20 MHz     | 1      | Х       | Х    | X            |  |
| Mode 1, 3 Max | 104.2 k       | 208.4 k      | 20 MHz     | 1      | 0       | 2    | FFH          |  |
| Mode 1, 3     | 19.2 k        | 38.4 k       | 11.059 MHz | 1      | 0       | 2    | FDH          |  |
|               | 9.6 k         | 19.2 k       | 11.059 MHz | 0      | 0       | 2    | FDH          |  |
|               | 4.8 k         | 9.6 k        | 11.059 MHz | 0      | 0       | 2    | FAH          |  |
|               | 2.4 k         | 4.8 k        | 11.059 MHz | 0      | 0       | 2    | F4H          |  |
|               | 1.2 k         | 2.4 k        | 11.059 MHz | 0      | 0       | 2    | E8H          |  |
|               | 137.5         | 275          | 11.986 MHz | 0      | 0       | 2    | 1DH          |  |
|               | 110           | 220          | 6 MHz      | 0      | 0       | 2    | 72H          |  |
|               | 110           | 220          | 12 MHz     | 0      | 0       | 1    | FEEBH        |  |

Figure 13. Timer 1 Generated Commonly Used Baud Rates

#### More About Mode 0

Serial data enters and exits through RxD. TxD outputs the shift clock. 8 bits are transmitted/received: 8 data bits (LSB first). The baud rate is fixed a 1/12 the oscillator frequency (12-clock mode) or 1/6 the oscillator frequency (6-clock mode).

Figure 14 shows a simplified functional diagram of the serial port in Mode 0, and associated timing.

Transmission is initiated by any instruction that uses SBUF as a destination register. The "write to SBUF" signal at S6P2 also loads a 1 into the 9th position of the transmit shift register and tells the TX Control block to commence a transmission. The internal timing is such that one full machine cycle will elapse between "write to SBUF" and activation of SEND.

SEND enables the output of the shift register to the alternate output function line of P3.0 and also enable SHIFT CLOCK to the alternate output function line of P3.1. SHIFT CLOCK is low during S3, S4, and S5 of every machine cycle, and high during S6, S1, and S2. At

S6P2 of every machine cycle in which SEND is active, the contents of the transmit shift are shifted to the right one position.

As data bits shift out to the right, zeros come in from the left. When the MSB of the data byte is at the output position of the shift register, then the 1 that was initially loaded into the 9th position, is just to the left of the MSB, and all positions to the left of that contain zeros. This condition flags the TX Control block to do one last shift and then deactivate SEND and set T1. Both of these actions occur at S1P1 of the 10th machine cycle after "write to SBUF."

Reception is initiated by the condition REN = 1 and R1 = 0. At S6P2 of the next machine cycle, the RX Control unit writes the bits 11111110 to the receive shift register, and in the next clock phase activates RECEIVE.

RECEIVE enable SHIFT CLOCK to the alternate output function line of P3.1. SHIFT CLOCK makes transitions at S3P1 and S6P1 of every machine cycle. At S6P2 of every machine cycle in which RECEIVE is active, the contents of the receive shift register are

## 80C51 8-bit Flash microcontroller family

## P89C51RA2/RB2/RC2/RD2xx

8KB/16KB/32KB/64KB ISP/IAP Flash with 512B/512B/512B/1KB RAM



Figure 16. Serial Port Mode 2

## 80C51 8-bit Flash microcontroller family

#### P89C51RA2/RB2/RC2/RD2xx

8KB/16KB/32KB/64KB ISP/IAP Flash with 512B/512B/512B/1KB RAM



Figure 22. IP Registers



Figure 23. IPH Registers

## 80C51 8-bit Flash microcontroller family

#### P89C51RA2/RB2/RC2/RD2xx

8KB/16KB/32KB/64KB ISP/IAP Flash with 512B/512B/512B/1KB RAM

```
INIT_WATCHDOG:
                     ; Module 4 in compare mode
; Write to low byte first
  MOV CCAPM4, #4CH
  MOV CCAP4L, #0FFH
                       ; Before PCA timer counts up to
  MOV CCAP4H, #0FFH
                        ; FFFF Hex, these compare values
                        ; must be changed
  ORL CMOD, #40H
                        ; Set the WDTE bit to enable the
                        ; watchdog timer without changing
                        ; the other bits in CMOD
; Main program goes here, but CALL WATCHDOG periodically.
WATCHDOG:
                       ; Hold off interrupts
  CLR EA
                       ; Next compare value is within
  MOV CCAP4L, #00
  MOV CCAP4H, CH
                        ; 255 counts of the current PCA
  SETB EA
                        ; timer value
  RET
```

Figure 37. PCA Watchdog Timer Initialization Code

## 80C51 8-bit Flash microcontroller family

#### P89C51RA2/RB2/RC2/RD2xx

8KB/16KB/32KB/64KB ISP/IAP Flash with 512B/512B/512B/1KB RAM



Figure 39. Internal and External Data Memory Address Space with EXTRAM = 0

# HARDWARE WATCHDOG TIMER (ONE-TIME ENABLED WITH RESET-OUT FOR P89C51RA2/RB2/RC2/RD2xx)

The WDT is intended as a recovery method in situations where the CPU may be subjected to software upset. The WDT consists of a 14-bit counter and the WatchDog Timer reset (WDTRST) SFR. The WDT is disabled at reset. To enable the WDT, the user must write 01EH and 0E1H in sequence to the WDTRST, SFR location 0A6H. When the WDT is enabled, it will increment every machine cycle while the oscillator is running and there is no way to disable the WDT except through reset (either hardware reset or WDT overflow reset). When the WDT overflows, it will drive an output reset HIGH pulse at the RST-pin (see the note below).

#### **Using the WDT**

To enable the WDT, the user must write 01EH and 0E1H in sequence to the WDTRST, SFR location 0A6H. When the WDT is enabled, the user needs to service it by writing 01EH and 0E1H to WDTRST to avoid a WDT overflow. The 14-bit counter overflows when it reaches 16383 (3FFFH) and this will reset the device. When the WDT is enabled, it will increment every machine cycle while the oscillator is running. This means the user must reset the WDT at least every 16383 machine cycles. To reset the WDT, the user must write 01EH and 0E1H to WDTRST. WDTRST is a write only register. The WDT counter cannot be read or written. When the WDT overflows, it will generate an output RESET pulse at the reset pin (see note below). The RESET pulse duration is  $98 \times T_{OSC}$  (6-clock mode; 196 in 12-clock mode), where  $T_{OSC} = 1/f_{OSC}$ . To make the best use of the WDT, it should be serviced in those sections of code that will periodically be executed within the time required to prevent a WDT reset.

# 80C51 8-bit Flash microcontroller family

## P89C51RA2/RB2/RC2/RD2xx

8KB/16KB/32KB/64KB ISP/IAP Flash with 512B/512B/512B/1KB RAM

| RECORD TYPE | COMMAND/DATA FUNCTION                                                                                                                                                                                                                                                                 |  |  |  |  |  |
|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| 05          | Miscellaneous Read Functions (Selection)                                                                                                                                                                                                                                              |  |  |  |  |  |
|             | General Format of Function 05 :02xxxx05ffsscc  Where:  02                                                                                                                                                                                                                             |  |  |  |  |  |
| 06          | :02000005008079 read ROM Code Revision (0A: Rev. A, 0B:Rev. B)  Direct Load of Baud Rate                                                                                                                                                                                              |  |  |  |  |  |
| Ju          | General Format of Function 06 :02xxxx06hhllcc Where:  02 = number of bytes (hex) in record xxxx = required field, but value is a "don't care" 06 = "Direct Load of Baud Rate" function code hh = high byte of Timer 2 11 = low byte of Timer 2 cc = checksum Example: :02000006F500F3 |  |  |  |  |  |
| 07          | Program Data in Data Block :nnaaaa07ddddcc Where: nn = number of bytes (hex) in record aaaa = memory address of first byte in record (the valid address:0001~0FFFH) dddd = data bytes cc = checksum Example: :10008007AF5F67F0602703E0322CFA92007780C3F6                              |  |  |  |  |  |

# 80C51 8-bit Flash microcontroller family

## P89C51RA2/RB2/RC2/RD2xx

8KB/16KB/32KB/64KB ISP/IAP Flash with 512B/512B/512B/1KB RAM

| IAP CALL                                                    | PARAMETER                                                                                                                                                                                                                              |
|-------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PROGRAM SECURITY BITS                                       | Input Parameter:  R0 = osc freq (integer) R1 = 05h or R1 = 85h (WDT feed) DPH = 00h DPL = 00h , security bit #1 DPL = 01h , security bit #2 DPL = 02h , security bit #3 Return Parameter: ACC = 00 if pass , !=0 if fail               |
| PROGRAM STATUS BYTE                                         | Input Parameter:  R0 = osc freq (integer) R1 = 06h or R1 = 86h (WDT feed) DPH = 00h DPL = 00H - program status byte ACC = status byte Return Parameter: ACC = 00 if pass , !=0 if fail                                                 |
| PROGRAM BOOT VECTOR                                         | Input Parameter:  R0 = osc freq (integer)  R1 = 06h or R1 = 86h (WDT feed)  DPH = 00h  DPL = 01H - program boot vector  ACC = boot vector  Return Parameter:  ACC = 00 if pass , !=0 if fail                                           |
| PROGRAM 6–CLK/12–CLK<br>CONFIGURATION BIT<br>(New function) | <pre>Input Parameter:     R0 = osc freq (integer)     R1 = 06h or R1 = 86h (WDT feed)     DPH = 00h     DPL = 02H - program config bit     ACC = 80H (MSB = 6clk/12clk bit) Return Parameter:     ACC = 00 if pass , !=0 if fail</pre> |
| PROGRAM DATA BLOCK (New function)                           | <pre>Input Parameter:     R0 = osc freq (integer)     R1 = 0Dh or R1 = 8Dh (WDT feed)     DPTR = address of byte to program</pre>                                                                                                      |
| READ DEVICE DATA                                            | Input Parameter:  R0 = osc freq (integer) R1 = 03h or R1 = 83h (WDT feed) DPTR = address of byte to read Return Parameter: ACC = value of byte read                                                                                    |
| READ DATA BLOCK<br>(New function)                           | <pre>Input Parameter:     R0 = osc freq (integer)     R1 = 0Eh or R1 = 8Eh (WDT feed)     DPTR = address of byte to read</pre>                                                                                                         |
| READ MANUFACTURER ID                                        | Input Parameter:  R0 = osc freq (integer) R1 = 00h or R1 = 80h (WDT feed) DPH = 00h DPL = 00h - read manufacturer ID Return Parameter: ACC = value of byte read                                                                        |

# 80C51 8-bit Flash microcontroller family

## P89C51RA2/RB2/RC2/RD2xx

8KB/16KB/32KB/64KB ISP/IAP Flash with 512B/512B/512B/1KB RAM

| IAP CALL                        | PARAMETER                                                                                                                                                                               |
|---------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| READ DEVICE ID #1               | Input Parameter:  R0 = osc freq (integer)  R1 = 00h or R1 = 80h (WDT feed)  DPH = 00h  DPL = 01h - read device ID #1  Return Parameter:  ACC = value of byte read                       |
| READ DEVICE ID #2               | Input Parameter:  R0 = osc freq (integer) R1 = 00h or R1 = 80h (WDT feed) DPH = 00h DPL = 02h - read device ID #2 Return Parameter: ACC = value of byte read                            |
| READ SECURITY BITS              | <pre>Input Parameter:     R0 = osc freq (integer)     R1 = 07h or R1 = 87h (WDT feed)     DPH = 00h     DPL = 00h - read lock byte Return Parameter:     ACC = value of byte read</pre> |
| READ STATUS BYTE                | Input Parameter:  R0 = osc freq (integer)  R1 = 07h or R1 = 87h (WDT feed)  DPH = 00h  DPL = 01h - read status byte  Return Parameter:  ACC = value of byte read                        |
| READ BOOT VECTOR                | Input Parameter:  R0 = osc freq (integer)  R1 = 07h or R1 = 87h (WDT feed)  DPH = 00h  DPL = 02h - read boot vector  Return Parameter:  ACC = value of byte read                        |
| READ CONFIG<br>(New function)   | Input Parameter:  R0 = osc freq (integer)  R1 = 00h or R1 = 80h (WDT feed)  DPH = 00h  DPL = 03h - read config byte  Return Parameter:  ACC = value of byte read                        |
| READ REVISION<br>(New function) | Input Parameter:  R0 = osc freq (integer)  R1 = 00h or R1 = 80h (WDT feed)  DPH = 00h  DPL = 80h - read revision of ROM Code  Return Parameter:  ACC = value of byte read               |

## 80C51 8-bit Flash microcontroller family

## P89C51RA2/RB2/RC2/RD2xx

8KB/16KB/32KB/64KB ISP/IAP Flash with 512B/512B/512B/1KB RAM



Figure 47. AC Testing Input/Output



Figure 48. Float Waveform



Figure 49. I<sub>CC</sub> vs. FREQ Valid only within frequency specifications of the device under test

# 80C51 8-bit Flash microcontroller family

## P89C51RA2/RB2/RC2/RD2xx

8KB/16KB/32KB/64KB ISP/IAP Flash with 512B/512B/512B/1KB RAM



Figure 50. AC Testing Input/Output



Figure 51. Float Waveform

# 80C51 8-bit Flash microcontroller family

## P89C51RA2/RB2/RC2/RD2xx

8KB/16KB/32KB/64KB ISP/IAP Flash with 512B/512B/512B/1KB RAM

#### **REVISION HISTORY**

| Date         | CPCN           | Description                         |  |  |  |
|--------------|----------------|-------------------------------------|--|--|--|
| 2002 July 18 | 9397 750 10129 | Modified ordering information table |  |  |  |
| 2002 May 20  | 9397 750 09843 | Initial release                     |  |  |  |