# imall

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

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

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



## Contact us

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



## Features

- 80C52 Compatible
  - 8051 Pin and Instruction Compatible
  - Four 8-bit I/O Ports
  - Three 16-bit timer/counters
  - 256 Bytes Scratch Pad RAM
  - 10 Interrupt Sources with 4 Priority Levels
  - Dual Data Pointer
- Variable Length MOVX for slow RAM/Peripherals
- ISP (In-System Programming) using Standard V<sub>CC</sub> Power Supply
- Boot ROM Contains Low Level FLASH Programming Routines and a Default Serial
- Loader
- High-Speed Architecture
   A0 MHz in Standard Max
  - 40 MHz in Standard Mode
  - 20 MHz in X2 Mode (6 clocks/machine cycle)
- 16K/32K Bytes on-chip FLASH Program/Data Memory
  - Byte and Page (128 Bytes) Erase and Write
    - 10k Write Cycles
- On-chip 1024 Bytes Expanded RAM (XRAM)

   Software Selectable Size (0, 256, 512, 768, 1024 bytes)
   256 Bytes Selected at Reset for TS87C51RB2/RC2 Compatibility
- Keyboard Interrupt Interface on port P1
- SPI Interface (Master / Slave Mode)
- 8-bit Clock Prescaler
- Improved X2 Mode with Independent Selection for CPU and each Peripheral
- Programmable Counter Array 5 Channels with:
  - High Speed Output
  - Compare / Capture
  - Pulse Width Modulator
  - Watchdog Timer Capabilities
- Asynchronous Port Reset
- Full Duplex Enhanced UART
- Dedicated Baud Rate Generator for UART
- Low EMI (Inhibit ALE)
- Hardware Watchdog Timer (One-time enabled with Reset-Out)
- Power Control Modes:
  - Idle Mode
  - Power-down mode
  - Power-off Flag
- Power supply: 4.5 to 5.5V or 2.7 to 3.6V
- Temperature ranges: Commercial (0 to +70°C) and Industrial (-40°C to +85°C)
- Packages: PDIL40, PLCC44, VQFP44

## Description

T89C51RB2/RC2 is a high-performance FLASH version of the 80C51 8-bit microcontrollers. It contains a 16K or 32K byte Flash memory block for program and data.

The Flash memory can be programmed either in parallel mode or in serial mode with the ISP capability or with software. The programming voltage is internally generated from the standard  $V_{\rm CC}$  pin.

The T89C51RB2/RC2 retains all features of the 80C52 with 256 bytes of internal RAM, a 7-source 4-level interrupt controller and three timer/counters.

In addition, the T89C51RB2/RC2 has a Programmable Counter Array, an XRAM of 1024 bytes, a Hardware Watchdog Timer, a Keyboard Interface, an SPI Interface,





8-bit Microcontroller with 16K/ 32K byte Flash

## T89C51RB2 T89C51RC2

## Preliminary



a more versatile serial channel that facilitates multiprocessor communication (EUART) and a speed improvement mechanism (X2 mode).

Pinout is the standard 40/44 pins of the C52.

The fully static design reduces system power consumption of the T89C51RB2/RC2 by allowing it to bring the clock frequency down to any value, even DC, without loss of data.

The T89C51RB2/RC2 has 2 software-selectable modes of reduced activity and 8-bit clock prescaler for further reduction in power consumption. In Idle mode, the CPU is frozen while the peripherals and the interrupt system are still operating. In power-down mode, the RAM is saved and all other functions are inoperative.

The added features of the T89C51RB2/RC2 make it more powerful for applications that need pulse width modulation, high speed I/O and counting capabilities such as alarms, motor control, corded phones, and smart card readers.

| Part Number | Flash (bytes) | XRAM (bytes) | TOTAL RAM<br>(bytes) | I/O |
|-------------|---------------|--------------|----------------------|-----|
| T89C51RB2   | 16K           | 1024         | 1280                 | 32  |
| T89C51RC2   | 32K           | 1024         | 1280                 | 32  |

## **Block Diagram**



Figure 1. Block Diagram



## SFR Mapping

The Special Function Registers (SFRs) of the T89C51RB2/RC2 fall into the following categories:

- C51 core registers: ACC, B, DPH, DPL, PSW, SP
- I/O port registers: P0, P1, P2, P3
- Timer registers: T2CON, T2MOD, TCON, TH0, TH1, TH2, TMOD, TL0, TL1, TL2, RCAP2L, RCAP2H
- Serial I/O port registers: SADDR, SADEN, SBUF, SCON
- PCA (Programmable Counter Array) registers: CCON, CCAPMx, CL, CH, CCAPxH, CCAPxL (x: 0 to 4)
- Power and clock control registers: PCON
- Hardware Watchdog Timer registers: WDTRST, WDTPRG
- Interrupt system registers: IE0, IPL0, IPH0, IE1, IPL1, IPH1
- Keyboard Interface registers: KBE, KBF, KBLS
- SPI registers: SPCON, SPSTR, SPDAT
- BRG (Baud Rate Generator) registers: BRL, BDRCON
- Flash register: FCON
- Clock Prescaler register: CKRL
- Others: AUXR, AUXR1, CKCON0, CKCON1



The table below shows all SFRs with their address and their reset value.

### Table 2. SFR Mapping

|     | Bit<br>addressable |                                  |                     |                     | Non Bit addre        | ssable               |                      |                     |     |
|-----|--------------------|----------------------------------|---------------------|---------------------|----------------------|----------------------|----------------------|---------------------|-----|
|     | 0/8                | 1/9                              | 2/A                 | 3/B                 | 4/C                  | 5/D                  | 6/E                  | 7/F                 |     |
| F8h |                    | CH<br>0000 0000                  | CCAP0H<br>XXXX      | CCAP1H<br>XXXX      | CCAPL2H<br>XXXX      | CCAPL3H<br>XXXX      | CCAPL4H<br>XXXX      |                     | FFh |
| F0h | B<br>0000 0000     |                                  |                     |                     |                      |                      |                      |                     | F7h |
| E8h |                    | CL<br>0000 0000                  | CCAP0L<br>XXXX XXXX | CCAP1L<br>XXXX XXXX | CCAPL2L<br>XXXX XXXX | CCAPL3L<br>XXXX XXXX | CCAPL4L<br>XXXX XXXX |                     | EFh |
| E0h | ACC<br>0000 0000   |                                  |                     |                     |                      |                      |                      |                     | E7h |
| D8h | CCON<br>00X0 0000  | CMOD<br>00XX X000                | CCAPM0<br>X000 0000 | CCAPM1<br>X000 0000 | CCAPM2<br>X000 0000  | CCAPM3<br>X000 0000  | CCAPM4<br>X000 0000  |                     | DFh |
| D0h | PSW<br>0000 0000   | FCON <sup>(a)</sup><br>XXXX 0000 |                     |                     |                      |                      |                      |                     | D7h |
| C8h | T2CON<br>0000 0000 | T2MOD<br>XXXX XX00               | RCAP2L<br>0000 0000 | RCAP2H<br>0000 0000 | TL2<br>0000 0000     | TH2<br>0000 0000     |                      |                     | CFh |
| C0h |                    |                                  |                     | SPCON<br>0001 0100  | SPSTA<br>0000 0000   | SPDAT<br>XXXX XXXX   |                      |                     | C7h |
| B8h | IPL0<br>X000 000   | SADEN<br>0000 0000               |                     |                     |                      |                      |                      |                     | BFh |
| B0h | P3<br>1111 1111    | IE1<br>XXXXX 000                 | IPL1<br>XXXXX000    | IPH1<br>XXXX X111   |                      |                      |                      | IPH0<br>X000 0000   | B7h |
| A8h | IE0<br>0000 0000   | SADDR<br>0000 0000               |                     |                     |                      |                      |                      | CKCON1<br>XXXX XXX0 | AFh |
| A0h | P2<br>1111 1111    |                                  | AUXR1<br>XXXXX0X0   |                     |                      |                      | WDTRST<br>XXXX XXXX  | WDTPRG<br>XXXX X000 | A7h |
| 98h | SCON<br>0000 0000  | SBUF<br>XXXX XXXX                | BRL<br>0000 0000    | BDRCON<br>XXX0 0000 | KBLS<br>0000 0000    | KBE<br>0000 0000     | KBF<br>0000 0000     |                     | 9Fh |
| 90h | P1<br>1111 1111    |                                  |                     |                     |                      |                      |                      | CKRL<br>1111 1111   | 97h |
| 88h | TCON<br>0000 0000  | TMOD<br>0000 0000                | TL0<br>0000 0000    | TL1<br>0000 0000    | TH0<br>0000 0000     | TH1<br>0000 0000     | AUXR<br>XX0X 0000    | CKCON0<br>0000 0000 | 8Fh |
| 80h | P0<br>1111 1111    | SP<br>0000 0111                  | DPL<br>0000 0000    | DPH<br>0000 0000    |                      |                      |                      | PCON<br>00X1 0000   | 87h |
|     | 0/8                | 1/9                              | 2/A                 | 3/B                 | 4/C                  | 5/D                  | 6/E                  | 7/F                 |     |

a. FCON access is reserved for the FLASH API and ISP software

Note: Reserved

## T89C51RB2/RC2

## **Pin Configurations**

#### Figure 2. Pin Configurations

| P1.0/T2 [1<br>P1.1/T2EX/SS [2<br>P1.2/ECI [3<br>P1.3CEX0 [4<br>P1.4/CEX1 [5<br>P1.5/CEX2/MISO [6<br>P1.6/CEX3/SCK [7<br>P1.7CEX4/MOSI [8<br>RST [9<br>P3.0/RXD [10<br>P3.1/TXD [11<br>P3.2/INT0 [12<br>P3.3/INT1 [13<br>P3.4/T0 [14<br>P3.5/T1 [15<br>P3.6/WR [16<br>P3.7/RD [17<br>XTAL2 [18<br>XTAL1 [19<br>VSS [20 | 40 VCC<br>39 P0.0/AD0<br>38 P0.1/AD1<br>37 P0.2/AD2<br>36 P0.3/AD3<br>35 P0.4/AD4<br>34 P0.5/AD5<br>33 P0.6/AD6<br>32 P0.7/AD7<br>31 EA<br>30 ALE/PROG<br>29 PSEN<br>28 P2.7/AD15<br>27 P2.6/AD14<br>26 P2.5/AD13<br>25 P2.4/AD12<br>24 P2.3/AD11<br>23 P2.2/AD10<br>22 P2.1/AD9<br>21 P2.0/AD8 | P1.5/CEX2/MISO<br>P1.6/CEX2/MISO<br>P1.6/CEX3/SCK<br>P1.7/CEx4/MOSI<br>P3.0/RxD<br>NIC*<br>P3.0/RxD<br>NIC*<br>P3.0/RxD<br>NIC*<br>P3.0/RxD<br>NIC*<br>P3.0/RxD<br>NIC*<br>P3.0/RxD<br>NIC*<br>P3.0/RxD<br>NIC*<br>P3.0/RxD<br>NIC*<br>P3.0/RxD<br>NIC*<br>P3.0/RxD<br>NIC*<br>P3.0/RxD<br>NIC*<br>P3.0/RxD<br>NIC*<br>P3.0/RxD<br>NIC*<br>P3.0/RxD<br>NIC*<br>P3.0/RxD<br>NIC*<br>P3.0/RxD<br>NIC*<br>P3.0/RxD<br>NIC*<br>P3.0/RxD<br>NIC*<br>P3.0/RxD<br>NIC*<br>P3.0/RxD<br>NIC*<br>P3.0/RxD<br>NIC*<br>P3.0/RxD<br>NIC*<br>P3.0/RxD<br>NIC*<br>P3.0/RxD<br>NIC*<br>P3.0/RxD<br>NIC*<br>P3.0/RxD<br>NIC*<br>P3.0/RxD<br>NIC*<br>P3.0/RxD<br>NIC*<br>P3.0/RxD<br>NIC*<br>P3.0/RxD<br>NIC*<br>P3.0/RxD<br>NIC*<br>P3.0/RxD<br>NIC*<br>P3.0/RxD<br>NIC*<br>P3.0/RxD<br>NIC*<br>P3.0/RxD<br>NIC*<br>P3.0/RxD<br>NIC*<br>P3.0/RxD<br>NIC*<br>P3.0/RxD<br>NIC*<br>P3.0/RxD<br>NIC*<br>P3.0/RxD<br>NIC*<br>P3.0/RxD<br>NIC*<br>P3.0/RxD<br>NIC*<br>P3.0/RxD<br>NIC*<br>P3.0/RxD<br>NIC*<br>P3.0/RxD<br>NIC*<br>P3.0/RxD<br>NIC*<br>P3.0/RxD<br>NIC*<br>P3.0/RxD<br>NIC*<br>P3.0/RxD<br>NIC*<br>P3.0/RxD<br>NIC*<br>P3.0/RxD<br>NIC*<br>P3.0/RxD<br>NIC*<br>P3.0/RxD<br>NIC*<br>P3.0/RxD<br>NIC*<br>P3.0/RxD<br>NIC*<br>P3.0/RxD<br>NIC*<br>P3.0/RxD<br>NIC*<br>P3.0/RxD<br>NIC*<br>P3.0/RxD<br>NIC*<br>P3.0/RxD<br>NIC*<br>P3.0/RxD<br>NIC*<br>P3.0/RxD<br>NIC*<br>P3.0/RXD<br>NIC*<br>P3.0/RXD<br>NIC*<br>P3.0/RXD<br>NIC*<br>P3.0/RXD<br>NIC*<br>P3.0/RXD<br>NIC*<br>P3.0/RXD<br>NIC*<br>P3.0/RXD<br>NIC*<br>P3.0/RXD<br>NIC*<br>P3.0/RXD<br>NIC*<br>P3.0/RXD<br>NIC*<br>P3.0/RXD<br>NIC*<br>P3.0/RXD<br>NIC*<br>P3.0/RXD<br>NIC*<br>P3.0/RXD<br>NIC*<br>P3.0/RXD<br>NIC*<br>P3.0/RXD<br>NIC*<br>P3.0/RXD<br>NIC*<br>P3.0/RXD<br>NIC*<br>P3.0/RXD<br>NIC*<br>P3.0/RXD<br>NIC*<br>P3.0/RXD<br>NIC*<br>P3.0/RXD<br>NIC*<br>P3.0/RXD<br>NIC*<br>P3.0/RXD<br>NIC*<br>P3.0/RXD<br>NIC*<br>P3.0/RXD<br>NIC*<br>P3.0/RXD<br>NIC*<br>P3.0/RXD<br>NIC*<br>P3.0/RXD<br>NIC*<br>P3.0/RXD<br>NIC*<br>P3.0/RXD<br>NIC*<br>P3.0/RXD<br>NIC*<br>P3.0/RXD<br>NIC*<br>P3.0/RXD<br>NIC*<br>P3.0/RXD<br>NIC*<br>P3.0/RXD<br>NIC*<br>P3.0/RXD<br>NIC*<br>P3.0/RXD<br>NIC*<br>P3.0/RXD<br>NIC*<br>P3.0/RXD<br>NIC*<br>P3.0/RXD<br>NIC*<br>P3.0/RXD<br>NIC*<br>P3.0/RXD<br>NIC*<br>P3.0/RXD<br>NIC*<br>P3.0/RXD<br>NIC*<br>P3.0/RXD<br>NIC*<br>P3.0/RXD<br>NIC*<br>P3.0/RXD<br>NIC*<br>P3.0/RXD<br>NIC*<br>P3.0/RXD<br>NIC*<br>P3.0/RXD<br>NIC*<br>P3.0/RXD<br>NIC*<br>P3.0/RXD<br>NIC*<br>P3.0/RXD<br>NIC*<br>P3.0/RXD<br>NIC*<br>P3.0/RXD<br>NIC*<br>P3.0/RXD<br>NIC*<br>P3.0/RXD<br>NIC*<br>P3.0/RXD<br>NIC*<br>P3.0/RXD<br>NIC*<br>P3.0/RXD<br>NIC*<br>P3.0/RXD<br>NIC*<br>P3.0/RXD<br>NIC*<br>P3.0/RXD<br>NIC*<br>P3.0/RXD<br>NIC*<br>P3.0/RXD<br>NIC*<br>P3.0/RXD<br>NIC*<br>P3.0/RXD<br>NIC*<br>P3.0/RXD<br>NIC*<br>P3.0/RXD<br>NIC*<br>P3.0/RXD<br>NIC*<br>P3.0/RXD<br>NIC*<br>P3.0/RXD<br>NIC*<br>P3.0/RXD<br>NIC*<br>P3.0/RXD<br>NIC*<br>P3.0/RXD<br>NIC*<br>P3.0/RXD<br>NIC*<br>P3.0/RXD<br>NIC*<br>P3.0/RXD<br>NIC*<br>P3.0/RXD<br>NIC* |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|



\*NIC: No Internal Connection





## Table 3. Pin Description for 40 - 44 Pin Packages

|                 | Pin Num | ıber    |                  |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |
|-----------------|---------|---------|------------------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| Mnemonic        | DIL     | LCC     | VQFP44 1.4       | Туре | Name and Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |
| V <sub>SS</sub> | 20      | 22      | 16               | I    | Ground: 0V reference                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |
| V <sub>cc</sub> | 40      | 44      | 38               | I    | <b>Power Supply</b> : This is the power supply voltage for normal, idle and power - down operation                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |
| P0.0 - P0.7     | 39 - 32 | 43 - 36 | 37 - 30          | I/O  | <b>Port 0</b> : Port 0 is an open-drain, bidirectional I/O port. Port 0 pins that have 1s written to them float and can be used as high impedance inputs. Port 0 must be polarized to $V_{CC}$ or $V_{SS}$ in order to prevent any parasitic current consumption. Port 0 is also the multiplexed low - order address and data bus during access to external program and data memory. In this application, it uses strong internal pull - up wher emitting 1s. Port 0 also inputs the code bytes during FLASH programming. External pull - ups are required during program verification during which P0 outputs the code bytes. |  |  |  |  |
| P1.0 - P1.7     | 1 - 8   | 2 - 9   | 40 - 44<br>1 - 3 | I/O  | <b>Port 1</b> : Port 1 is an 8 - bit bidirectional I/O port with internal pull - ups. Port 1 pins that have 1s written to them are pulled high by the internal pull - ups and can be used as inputs. As inputs, Port 1 pins that are externally pulled low will source current because of the internal pull - ups. Port 1 also receives the low - order address byte during memory programming and verification.<br>Alternate functions for T89C51RB2/RC2 Port 1 include:                                                                                                                                                      |  |  |  |  |
|                 | 1       | 2       | 40               | I/O  | P1.0: Input / Output                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |
|                 |         |         |                  | I/O  | T2 (P1.0): Timer/Counter 2 external count input/Clockout                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |
|                 | 2       | 3       | 41               | I/O  | P1.1: Input / Output                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |
|                 |         |         |                  | I    | T2EX: Timer/Counter 2 Reload/Capture/Direction Control                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |  |
|                 |         |         |                  | I    | SS: SPI Slave Select                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |
|                 | 3       | 4       | 42               | I/O  | P1.2: Input / Output                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |
|                 |         |         |                  | I    | ECI: External Clock for the PCA                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |
|                 | 4       | 5       | 43               | I/O  | P1.3: Input / Output                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |
|                 |         |         |                  | I/O  | CEX0: Capture/Compare External I/O for PCA module 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |  |
|                 | 5       | 6       | 44               | I/O  | P1.4: Input / Output                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |
|                 |         |         |                  | I/O  | CEX1: Capture/Compare External I/O for PCA module 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |  |
|                 | 6       | 7       | 1                | I/O  | P1.5: Input / Output                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |
|                 |         |         |                  | I/O  | CEX2: Capture/Compare External I/O for PCA module 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |  |
|                 |         |         |                  | I/O  | MISO: SPI Master Input Slave Output line                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |
|                 |         |         |                  |      | When SPI is in master mode, MISO receives data from the slave peripheral. When SPI is in slave mode, MISO outputs data to the master controller.                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |
|                 | 7       | 8       | 2                | I/O  | P1.6: Input / Output                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |
|                 |         |         |                  | I/O  | CEX3: Capture/Compare External I/O for PCA module 3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |  |
|                 |         |         |                  | I/O  | SCK: SPI Serial Clock                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |  |
|                 |         |         |                  |      | SCK outputs clock to the slave peripheral                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |
|                 | 8       | 9       | 3                | I/O  | P1.7: Input / Output:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |  |

6

## Table 3. Pin Description for 40 - 44 Pin Packages (Continued)

|             | Pin Num | ber            |              |       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |
|-------------|---------|----------------|--------------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Mnemonic    | DIL     | LCC            | VQFP44 1.4   | Туре  | Name and Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |
|             |         |                |              | I/O   | CEX4: Capture/Compare External I/O for PCA module 4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |
| P1.0 - P1.7 |         |                |              | I/O   | MOSI: SPI Master Output Slave Input line                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |
|             |         |                |              |       | When SPI is in master mode, MOSI outputs data to the slave peripheral. When SPI is in slave mode, MOSI receives data from the master controller.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |
| XTAL1       | 19      | 21             | 15           | I     | <b>Crystal 1:</b> Input to the inverting oscillator amplifier and input to the internal clock generator circuits.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |
| XTAL2       | 18      | 20             | 14           | 0     | Crystal 2: Output from the inverting oscillator amplifier                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |
| P2.0 - P2.7 | 21 - 28 | 24 - 31        | 18 - 25      | 1/0   | Port 2: Port 2 is an 8 - bit bidirectional I/O port with internal pull - ups. Port 2 pins<br>that have 1s written to them are pulled high by the internal pull - ups and can be<br>used as inputs. As inputs, Port 2 pins that are externally pulled low will source<br>current because of the internal pull - ups. Port 2 emits the high - order address byte<br>during fetches from external program memory and during accesses to external data<br>memory that use 16 - bit addresses (MOVX @DPTR). In this application, it uses<br>strong internal pull - ups emitting 1s. During accesses to external data memory that<br>use 8 - bit addresses (MOVX @Ri), port 2 emits the contents of the P2 SFR. Some<br>Port 2 pins receive the high order address bits during EPROM programming and<br>verification:<br>P2.0 to P2.5 for 16 KB devices<br>P2.0 to P2.6 for 32KB devices |  |  |  |
| P3.0 - P3.7 | 10 - 17 | 11,<br>13 - 19 | 5,<br>7 - 13 | I/O   | <b>Port 3:</b> Port 3 is an 8 - bit bidirectional I/O port with internal pull - ups. Port 3 pins that have 1s written to them are pulled high by the internal pull - ups and can be used as inputs. As inputs, Port 3 pins that are externally pulled low will source current because of the internal pull - ups. Port 3 also serves the special features of the 80C51 family, as listed below.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |
|             | 10      | 11             | 5            | I     | RXD (P3.0): Serial input port                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |
|             | 11      | 13             | 7            | 0     | TXD (P3.1): Serial output port                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |
|             | 12      | 14             | 8            | I     | INTO (P3.2): External interrupt 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |
|             | 13      | 15             | 9            | I     | INT1 (P3.3): External interrupt 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |
|             | 14      | 16             | 10           | I     | T0 (P3.4): Timer 0 external input                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |
|             | 15      | 17             | 11           | I     | T1 (P3.5): Timer 1 external input                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |
|             | 16      | 18             | 12           | 0     | WR (P3.6): External data memory write strobe                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |
|             | 17      | 19             | 13           | 0     | RD (P3.7): External data memory read strobe                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |
| RST         | 9       | 10             | 4            | I/O   | <b>Reset:</b> A high on this pin for two machine cycles while the oscillator is running, resets the device. An internal diffused resistor to $V_{SS}$ permits a power - on reset using only an external capacitor to $V_{CC}$ . This pin is an output when the hardware watchdog forces a system reset.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |
| ALE/PROG    | 30      | 33             | 27           | O (I) | Address Latch Enable/Program Pulse: Output pulse for latching the low byte of the address during an access to external memory. In normal operation, ALE is emitted at a constant rate of 1/6 (1/3 in X2 mode) the oscillator frequency, and can be used for external timing or clocking. Note that one ALE pulse is skipped during each access to external data memory. This pin is also the program pulse input (PROG) during Flash programming. ALE can be disabled by setting SFR's AUXR. 0 bit. With this bit set, ALE will be inactive during internal fetches.                                                                                                                                                                                                                                                                                                               |  |  |  |





## Table 3. Pin Description for 40 - 44 Pin Packages (Continued)

|          | Pin Number                  |    |            |      |                                                                                                                                                                                                                                                                                                                                         |  |  |  |
|----------|-----------------------------|----|------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Mnemonic | Mnemonic DIL LCC VQFP44 1.4 |    | VQFP44 1.4 | Туре | Name and Function                                                                                                                                                                                                                                                                                                                       |  |  |  |
| PSEN     | 29                          | 32 | 26         | 0    | <b>Program Strobe ENable:</b> The read strobe to external program memory. When executing code from the external program memory, PSEN is activated twice each machine cycle, except that two PSEN activations are skipped during each access to external data memory. PSEN is not activated during fetches from internal program memory. |  |  |  |
| EA       | 31                          | 35 | 29         | 1    | <b>External Access Enable:</b> $\overrightarrow{\text{EA}}$ must be externally held low to enable the device to fetch code from external program memory locations 0000H to FFFFH (RD). If security level 1 is programmed, $\overrightarrow{\text{EA}}$ will be internally latched on Reset.                                             |  |  |  |

## T89C51RB2/RC2

## Oscillator

In order to optimize the power consumption and execution time needed for a specific task, an internal, prescaler feature has been implemented between oscillator and the CPU and peripherals.

### Registers

#### Table 4. CKRL Register

CKRL - Clock Reload Register (97h)

| 7        | 6     | 5        | 4                                     | 3 | 2 | 1 | 0 |
|----------|-------|----------|---------------------------------------|---|---|---|---|
| -        | -     | -        | -                                     | - | - | - | - |
| Bit Numb | er Mn | emonic I | Description                           |   |   |   |   |
| 7:0      |       | CKRI     | <b>Clock Reload</b><br>Prescaler valu | - |   |   |   |

Reset Value = 1111 1111b Not bit addressable

#### Table 5. PCON Register

PCON – Power Control Register (87h)

| 7        | 6   | 5     | 5       | 4                                                                                                               | 3                             | 2             | 1               | 0           |  |  |  |  |  |  |
|----------|-----|-------|---------|-----------------------------------------------------------------------------------------------------------------|-------------------------------|---------------|-----------------|-------------|--|--|--|--|--|--|
| SMOD1    | SMC | DD0   | -       | POF                                                                                                             | GF1                           | GF0           | PD              | IDL         |  |  |  |  |  |  |
| Bit Numb | er  | Bit M | nemonic | Description                                                                                                     |                               |               |                 |             |  |  |  |  |  |  |
| 7        |     | S     | MOD1    | Serial port Mode bit 1<br>Set to select double baud rate in mode 1, 2 or 3.                                     |                               |               |                 |             |  |  |  |  |  |  |
| 6        | 6 S |       | MOD0    | Serial port Mode bit 0<br>Cleared to select SM0 bit in SCON register.<br>Set to select FE bit in SCON register. |                               |               |                 |             |  |  |  |  |  |  |
| 5        |     |       | -       | <b>Reserved</b><br>The value read                                                                               | from this bit i               | s indetermina | te. Do not set  | this bit.   |  |  |  |  |  |  |
| 4        |     |       | POF     | Power-Off Fla<br>Cleared to reco<br>Set by hardwa<br>also be set by                                             | ognize next re<br>re when VCC |               | o its nominal v | oltage. Can |  |  |  |  |  |  |
| 3        |     |       | GF1     | General Purp<br>Cleared by sof<br>Set by software                                                               | tware for gene                |               | •               |             |  |  |  |  |  |  |
| 2        |     |       | GF0     | General Purp<br>Cleared by sof<br>Set by software                                                               | tware for gene                |               |                 |             |  |  |  |  |  |  |
| 1        |     |       | PD      | Power-Down mode bit<br>Cleared by hardware when reset occurs.<br>Set to enter power-down mode.                  |                               |               |                 |             |  |  |  |  |  |  |
| 0        |     |       | IDL     | Idle mode bit<br>Cleared by hardware when interrupt or reset occurs.<br>Set to enter idle mode.                 |                               |               |                 |             |  |  |  |  |  |  |

Reset Value = 00X1 0000b Not bit addressable





## Functional Block Diagram

Figure 3. Functional Oscillator Block Diagram



#### **Prescaler Divider**

- A hardware RESET puts the prescaler divider in the following state:
  - CKRL = FFh: F<sub>CLK CPU</sub> = F<sub>CLK PERIPH</sub> = F<sub>OSC</sub>/2 (Standard C51 feature)
- Any value between FFh down to 00h can be written by software into CKRL register in order to divide frequency of the selected oscillator:
  - CKRL = 00h: minimum frequency  $F_{CLK CPU} = F_{CLK PERIPH} = F_{OSC}/1020$  (Standard Mode)  $F_{CLK CPU} = F_{CLK PERIPH} = F_{OSC}/510$  (X2 Mode)
  - CKRL = FFh: maximum frequency  $F_{CLK CPU} = F_{CLK PERIPH} = F_{OSC}/2$  (Standard Mode)  $F_{CLK CPU} = F_{CLK PERIPH} = F_{OSC}$  (X2 Mode)

 $F_{CLK\,CPU}$  and  $F_{CLK\,PERIPH}$ 

In X2 Mode:

$$F_{CPU} = F_{CLKPERIPH} = \frac{F_{OSC}}{2 \times (255 - CKRL)}$$

In X1 Mode:

$$F_{CPU} = F_{CLKPERIPH} = \frac{F_{OSC}}{4 \times (255 - CKRL)}$$

## Enhanced Features In c

In comparison to the original 80C52, the T89C51RB2/RC2 implements some new features, which are:

- the X2 option
- the Dual Data Pointer
- the extended RAM
- the Programmable Counter Array (PCA)
- the Hardware Watchdog
- the SPI interface
- the 4-level interrupt priority system
- the power-off flag
- the ONCE mode
- the ALE disabling

•

some enhanced features are also located in the UART and the timer 2

X2 Feature

The T89C51RB2/RC2 core needs only 6 clock periods per machine cycle. This feature called 'X2' provides the following advantages:

- Divide frequency crystals by 2 (cheaper crystals) while keeping same CPU power.
- Save power consumption while keeping same CPU power (oscillator power saving).
- Save power consumption by dividing dynamically the operating frequency by 2 in operating and idle modes.
- Increase CPU power by 2 while keeping same crystal frequency.

In order to keep the original C51 compatibility, a divider by 2 is inserted between the XTAL1 signal and the main clock input of the core (phase generator). This divider may be disabled by software.

**Description** The clock for the whole circuit and peripherals is first divided by two before being used by the CPU core and the peripherals.

This allows any cyclic ratio to be accepted on XTAL1 input. In X2 mode, as this divider is bypassed, the signals on XTAL1 must have a cyclic ratio between 40 to 60%.

Figure 4 shows the clock generation block diagram. X2 bit is validated on the rising edge of the XTAL1+2 to avoid glitches when switching from X2 to STD mode. Figure 5 shows the switching mode waveforms.

Figure 4. Clock Generation Diagram







#### Figure 5. Mode Switching Waveforms



The X2 bit in the CKCON0 register (see Table 6) allows a switch from 12 clock periods per instruction to 6 clock periods and vice versa. At reset, the speed is set according to X2 bit of Hardware Security Byte (HSB). By default, Standard mode is active. Setting the X2 bit activates the X2 feature (X2 mode).

The T0X2, T1X2, T2X2, UartX2, PcaX2, and WdX2 bits in the CKCON0 register (See Table 6.) and SPIX2 bit in the CKCON1 register (see Table 7) allows a switch from standard peripheral speed (12 clock periods per peripheral clock cycle) to fast peripheral speed (6 clock periods per peripheral clock cycle). These bits are active only in X2 mode.

## T89C51RB2/RC2

### Table 6. CKCON0 Register

CKCON0 - Clock Control Register (8Fh)

| 7             | 6               | 5                                                | 4                                                                                                                                                                                                                                                        | 3                                                                     | 2                               | 1                            | 0                        |  |
|---------------|-----------------|--------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------|---------------------------------|------------------------------|--------------------------|--|
| -             | WDX2            | PCAX2                                            | SIX2                                                                                                                                                                                                                                                     | T2X2                                                                  | T1X2                            | T0X2                         | X2                       |  |
| Bit<br>Number | Bit<br>Mnemonic | Description                                      |                                                                                                                                                                                                                                                          |                                                                       |                                 |                              |                          |  |
| 7             | Reserved        |                                                  |                                                                                                                                                                                                                                                          |                                                                       |                                 |                              |                          |  |
| 6             | WDX2            | has no effect<br>Cleared to se                   | bit is validate<br>).<br>elect 6 clock p                                                                                                                                                                                                                 | d when the CP<br>periods per per<br>ods per periph                    | ipheral clock (                 | cycle.                       | s low, this bit          |  |
| 5             | PCAX2           | bit has no eff                                   | bit is validate<br>ect).<br>elect 6 clock p                                                                                                                                                                                                              | d when the CF<br>eriods per peri                                      |                                 |                              |                          |  |
| 4             | SIX2            | (This control<br>bit has no eff                  | bit is validate<br>ect).<br>lect 6 clock p                                                                                                                                                                                                               | Mode 0 and 2<br>d when the CF<br>eriods per peri<br>ck cycle.         | PU clock X2 is                  |                              |                          |  |
| 3             | T2X2            | bit has no eff<br>Cleared to se                  | bit is validate<br>ect).<br>elect 6 clock p                                                                                                                                                                                                              | d when the CF<br>periods per per<br>ods per periph                    | ipheral clock (                 | cycle.                       | is low, this             |  |
| 2             | T1X2            | bit has no eff                                   | bit is validate<br>ect).<br>·lect 6 clock p                                                                                                                                                                                                              | d when the CF<br>eriods per peri<br>ck cycle.                         |                                 |                              |                          |  |
| 1             | T0X2            | (This control<br>bit has no eff<br>Cleared to se | <b>Timer0 Clock</b><br>(This control bit is validated when the CPU clock X2 is set; when X2 is low, this bit has no effect).<br>Cleared to select 6 clock periods per peripheral clock cycle. Set to select 12 clock periods per peripheral clock cycle. |                                                                       |                                 |                              |                          |  |
| 0             | X2              | all the periphetor to enable the                 | erals. Set to s<br>individual pe                                                                                                                                                                                                                         | periods per m<br>elect 6clock p<br>ripherals'X2' b<br>vare Security F | eriods per mai<br>its. Programm | chine cycle (Xaned by hardwa | 2 mode) and<br>are after |  |

Reset Value = 0000 000'HSB. X2'b (See Table 69 "Hardware Security Byte") Not bit addressable





### Table 7. CKCON1 Register

CKCON1 - Clock Control Register (AFh)

| 7             | 6               | 5                                 | 4                             | 3              | 2                                                  | 1    | 0            |
|---------------|-----------------|-----------------------------------|-------------------------------|----------------|----------------------------------------------------|------|--------------|
| -             | -               | -                                 | -                             | -              | -                                                  | -    | SPIX2        |
| Bit<br>Number | Bit<br>Mnemonic | Description                       |                               |                |                                                    |      |              |
| 7             | -               | Reserved                          |                               |                |                                                    |      |              |
| 6             | -               | Reserved                          |                               |                |                                                    |      |              |
| 5             | -               | Reserved                          |                               |                |                                                    |      |              |
| 4             | -               | Reserved                          |                               |                |                                                    |      |              |
| 3             | -               | Reserved                          |                               |                |                                                    |      |              |
| 2             | -               | Reserved                          |                               |                |                                                    |      |              |
| 1             | -               | Reserved                          |                               |                |                                                    |      |              |
| 0             | SPIX2           | this bit has no<br>Clear to selec | o effect).<br>ct 6 clock peri | ods per peripl | e CPU clock ><br>neral clock cyc<br>eral clock cyc | cle. | n X2 is low, |

Reset Value = XXXX XXX0b Not bit addressable

## Dual Data Pointer Register DPTR

The additional data pointer can be used to speed up code execution and reduce code size.

The dual DPTR structure is a way by which the chip will specify the address of an external data memory location. There are two 16-bit DPTR registers that address the external memory, and a single bit called DPS = AUXR1.0 (see Table 8) that allows the program code to switch between them (Refer to Figure 6).

#### Figure 6. Use of Dual Pointer







#### Table 8. AUXR1 register

AUXR1- Auxiliary Register 1(0A2h)

| 7             | 6               | 5                                              | 4                                                                               | 3                   | 2               | 1            | 0   |  |
|---------------|-----------------|------------------------------------------------|---------------------------------------------------------------------------------|---------------------|-----------------|--------------|-----|--|
| -             | -               | ENBOOT                                         | -                                                                               | GF3                 | 0               | -            | DPS |  |
| Bit<br>Number | Bit<br>Mnemonic | Description                                    |                                                                                 |                     |                 |              |     |  |
| 7             | -               | <b>Reserved</b><br>The value rea               | ad from this b                                                                  | it is indetermi     | nate. Do not se | et this bit. |     |  |
| 6             | -               | <b>Reserved</b><br>The value rea               | ad from this b                                                                  | it is indetermi     | nate. Do not se | et this bit. |     |  |
| 5             | ENBOOT          | Enable Boot<br>Cleared to dis<br>Set to map th | able boot RC                                                                    | DM.<br>between F800 | )h - OFFFFh.    |              |     |  |
| 4             | -               | <b>Reserved</b><br>The value rea               | ad from this b                                                                  | it is indetermi     | nate. Do not se | et this bit. |     |  |
| 3             | GF3             | This bit is a                                  | general pur                                                                     | oose user flag      | g. *            |              |     |  |
| 2             | 0               | Always clear                                   | ed.                                                                             |                     |                 |              |     |  |
| 1             | -               | <b>Reserved</b><br>The value rea               | Reserved<br>The value read from this bit is indeterminate. Do not set this bit. |                     |                 |              |     |  |
| 0             | DPS             | Data Pointer<br>Cleared to se<br>Set to select | lect DPTR0.                                                                     |                     |                 |              |     |  |

Reset Value: XXXX XX0X0b

; Block move using dual data pointers

#### Not bit addressable

Note: \*Bit 2 stuck at 0; this allows to use INC AUXR1 to toggle DPS without changing GF3.

#### ASSEMBLY LANGUAGE

; Modifies DPTR0, DPTR1, A and PSW ; note: DPS exits opposite of entry state ; unless an extra INC AUXR1 is added 00A2 AUXR1 EQU 0A2H 0000 909000MOV DPTR,#SOURCE ; address of SOURCE 0003 05A2 INC AUXR1 ; switch data pointers 0005 90A000 MOV DPTR,#DEST ; address of DEST 0008 LOOP: 0008 05A2 INC AUXR1 ; switch data pointers 000A E0 MOVX A,@DPTR ; get a byte from SOURCE 000B A3 INC DPTR ; increment SOURCE address 000C 05A2 INC AUXR1 ; switch data pointers 000E F0 MOVX @DPTR,A ; write the byte to DEST 000F A3 INC DPTR ; increment DEST address 0010 70F6JNZ LOOP ; check for 0 terminator 0012 05A2 INC AUXR1 ; (optional) restore DPS

INC is a short (2 bytes) and fast (12 clocks) way to manipulate the DPS bit in the AUXR1 SFR. However, note that the INC instruction does not directly force the DPS bit to a particular state, but simply toggles it. In simple routines, such as the block move example, only the fact that DPS is toggled in the proper sequence matters, not its actual value. In other words, the block move routine works the same whether DPS is '0' or '1' on entry. Observe that without the last instruction (INC AUXR1), the routine will exit with DPS in the opposite state.





## Expanded RAM (XRAM)

The T89C51RB2/RC2 provides additional Bytes of random access memory (RAM) space for increased data parameter handling and high level language usage.

T89C51RB2/RC2 devices have expanded RAM in external data space; maximum size and location are described in Table 9.

| Table 9. E | xpanded RAM |
|------------|-------------|
|------------|-------------|

|               |           | Address |      |  |  |
|---------------|-----------|---------|------|--|--|
| Part Number   | XRAM size | Start   | End  |  |  |
| T89C51RB2/RC2 | 1024      | 00h     | 3FFh |  |  |

The T89C51RB2/RC2 has internal data memory that is mapped into four separate segments.

The four segments are:

- 1. The Lower 128 bytes of RAM (addresses 00h to 7Fh) are directly and indirectly addressable.
- 2. The Upper 128 bytes of RAM (addresses 80h to FFh) are indirectly addressable only.
- 3. The Special Function Registers, SFRs, (addresses 80h to FFh) are directly addressable only.
- 4. The expanded RAM bytes are indirectly accessed by MOVX instructions, and with the EXTRAM bit cleared in the AUXR register (see Table 9).

The lower 128 bytes can be accessed by either direct or indirect addressing. The Upper 128 bytes can be accessed by indirect addressing only. The Upper 128 bytes occupy the same address space as the SFR. That means they have the same address, but are physically separate from SFR space.

#### Figure 7. Internal and External Data Memory Address



When an instruction accesses an internal location above address 7Fh, the CPU knows whether the access is to the upper 128 bytes of data RAM or to SFR space by the addressing mode used in the instruction.

Instructions that use direct addressing access SFR space. For example: MOV 0A0H, # data, accesses the SFR at location 0A0h (which is P2).

- Instructions that use indirect addressing access the Upper 128 bytes of data RAM. For example: MOV @R0, # data where R0 contains 0A0h, accesses the data byte at address 0A0h, rather than P2 (whose address is 0A0h).
- The XRAM bytes can be accessed by indirect addressing, with EXTRAM bit cleared and MOVX instructions. This part of memory which is physically located on-chip, logically occupies the first bytes of external data memory. The bits XRS0 and XRS1 are used to hide a part of the available XRAM as explained in Table 9. This can be useful if external peripherals are mapped at addresses already used by the internal XRAM.
- With <u>EXTRAM = 0</u>, the XRAM is indirectly addressed, using the MOVX instruction in combination with any of the registers R0, R1 of the selected bank or DPTR. An access to XRAM will not affect ports P0, P2, P3.6 (WR) and P3.7 (RD). For example, with EXTRAM = 0, MOVX @R0, # data where R0 contains 0A0H, accesses the XRAM at address 0A0H rather than external memory. An access to external data memory locations higher than the accessible size of the XRAM will be performed with the MOVX DPTR instructions in the same way as in the standard 80C51, with P0 and P2 as data/address busses, and P3.6 and P3.7 as write and read timing signals. Accesses to XRAM above 0FFH can only be done by the use of DPTR.
- With <u>EXTRAM = 1</u>, MOVX @Ri and MOVX @DPTR will be similar to the standard 80C51.MOVX @ Ri will provide an eight-bit address multiplexed with data on Port0 and any output port pins can be used to output higher order address bits. This is to provide the external paging capability. MOVX @DPTR will generate a sixteen-bit address. Port2 outputs the high-order eight address bits (the contents of DPH) while Port0 multiplexes the low-order eight address bits (DPL) with data. MOVX @ Ri and MOVX @DPTR will generate either read or write signals on P3.6 (WR) and P3.7 (RD).

The stack pointer (SP) may be located anywhere in the 256 bytes RAM (lower and upper RAM) internal data memory. The stack may not be located in the XRAM.

The M0 bit allows to stretch the XRAM timings; if M0 is set, the read and write pulses are extended from 6 to 30 clock periods. This is useful to access external slow peripherals.





## Registers

#### Table 10. AUXR Register

AUXR - Auxiliary Register (8Eh)

| 7             | 6               | 5                                                                                                                                                                                                                            | 4                                                                               | 3    | 2    | 1      | 0  |  |  |  |
|---------------|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------|------|------|--------|----|--|--|--|
| -             | -               | МО                                                                                                                                                                                                                           | -                                                                               | XRS1 | XRS0 | EXTRAM | AO |  |  |  |
| Bit<br>Number | Bit<br>Mnemonic | Description                                                                                                                                                                                                                  |                                                                                 |      |      |        |    |  |  |  |
| 7             | -               | Reserved<br>The value read from this bit is indeterminate. Do not set this bit.                                                                                                                                              |                                                                                 |      |      |        |    |  |  |  |
| 6             | -               | Reserved<br>The value read from this bit is indeterminate. Do not set this bit.                                                                                                                                              |                                                                                 |      |      |        |    |  |  |  |
| 5             | MO              | Pulse length<br>Cleared to stretch MOVX control: the RD/ and the WR/ pulse length is 6 clock<br>periods (default).<br>Set to stretch MOVX control: the RD/ and the WR/ pulse length is 30 clock<br>periods.                  |                                                                                 |      |      |        |    |  |  |  |
| 4             | -               | Reserved<br>The value re                                                                                                                                                                                                     | Reserved<br>The value read from this bit is indeterminate. Do not set this bit. |      |      |        |    |  |  |  |
| 3             | XRS1            | XRAM Size                                                                                                                                                                                                                    |                                                                                 |      |      |        |    |  |  |  |
| 2             | XRS0            | XRS1         XRS0         XRAM size           0         0         256 bytes (default)           0         1         512 bytes           1         0         768 bytes           1         1024 bytes                         |                                                                                 |      |      |        |    |  |  |  |
| 1             | EXTRAM          | EXTRAM bit<br>Cleared to access internal XRAM using movx @ Ri/ @ DPTR.<br>Set to access external memory.<br>Programmed by hardware after Power-up regarding Hardware Security Byte<br>(HSB), default setting, XRAM selected. |                                                                                 |      |      |        |    |  |  |  |
| 0             | AO              | ALE Output bit<br>Cleared, ALE is emitted at a constant rate of 1/6 the oscillator frequency (or 1/3 if<br>X2 mode is used). (default) Set, ALE is active only during a MOVX or MOVC<br>instruction is used.                 |                                                                                 |      |      |        |    |  |  |  |

Reset Value = XX0X 00'HSB. XRAM'0b (See Table 69) Not bit addressable

| Timer 2          | The Timer 2 in the T89C51RB2/RC2 is the standard C52 Timer 2.<br>It is a 16-bit timer/counter: the count is maintained by two eight-bit timer registers, TH2 and TL2 are cascaded. It is controlled by T2CON (Table 11) and T2MOD (Table 12) registers. Timer 2 operation is similar to Timer 0 and Timer 1.C/T2 selects $F_{OSC}/12$ (timer operation) or external pin T2 (counter operation) as the timer clock input. Setting TR2 allows TL2 to increment by the selected input. |  |  |  |  |
|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
|                  | Timer 2 has 3 operating modes: capture, autoreload and Baud Rate Generator. These modes are selected by the combination of RCLK, TCLK and CP/RL2 (T2CON).                                                                                                                                                                                                                                                                                                                           |  |  |  |  |
|                  | Refer to the Atmel 8-bit Microcontroller Hardware description for the description of Cap-<br>ture and Baud Rate Generator Modes.                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |
|                  | Timer 2 includes the following enhancements:                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |  |
|                  | Auto-reload mode with up or down counter                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |  |
|                  | Programmable clock-output                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |
| Auto-Reload Mode | The auto-reload mode configures Timer 2 as a 16-bit timer or event counter with auto-<br>matic reload. If DCEN bit in T2MOD is cleared, Timer 2 behaves as in 80C52 (refer to<br>the Atmel C51 Microcontroller Hardware description). If DCEN bit is set, Timer 2 acts as<br>an Up/down timer/counter as shown in Figure 8. In this mode the T2EX pin controls the<br>direction of count.                                                                                           |  |  |  |  |
|                  | When T2EX is high, Timer 2 counts up. Timer overflow occurs at FFFFh which sets the TF2 flag and generates an interrupt request. The overflow also causes the 16-bit value in RCAP2H and RCAP2L registers to be loaded into the timer registers TH2 and TL2.                                                                                                                                                                                                                        |  |  |  |  |
|                  | When T2EX is low, Timer 2 counts down. Timer underflow occurs when the count in the timer registers TH2 and TL2 equals the value stored in RCAP2H and RCAP2L registers. The underflow sets TF2 flag and reloads FFFFh into the timer registers.                                                                                                                                                                                                                                     |  |  |  |  |
|                  | The EXF2 bit toggles when Timer 2 overflows or underflows according to the direction of the count. EXF2 does not generate any interrupt. This bit can be used to provide 17-bit resolution.                                                                                                                                                                                                                                                                                         |  |  |  |  |









(UP COUNTING RELOAD VALUE)

### Programmable Clock-Output

In the clock-out mode, Timer 2 operates as a 50%-duty-cycle, programmable clock generator (See Figure 9). The input clock increments TL2 at frequency  $F_{CLK PERIPH}/2$ . The timer repeatedly counts to overflow from a loaded value. At overflow, the contents of RCAP2H and RCAP2L registers are loaded into TH2 and TL2. In this mode, Timer 2 overflows do not generate interrupts. The formula gives the clock-out frequency as a function of the system oscillator frequency and the value in the RCAP2H and RCAP2L registers:

$$Clock-OutFrequency = \frac{F_{CLKPERIPH}}{4 \times (65536 - RCAP2H/RCAP2L)}$$

For a 16 MHz system clock, Timer 2 has a programmable frequency range of 61 Hz  $(F_{CLK PERIPH}/2^{16})$  to 4 MHz  $(F_{CLK PERIPH}/4)$ . The generated clock signal is brought out to T2 pin (P1.0).

Timer 2 is programmed for the clock-out mode as follows:

- Set T2OE bit in T2MOD register.
- Clear C/T2 bit in T2CON register.
- Determine the 16-bit reload value from the formula and enter it in RCAP2H/RCAP2L registers.
- Enter a 16-bit initial value in timer registers TH2/TL2.It can be the same as the reload value or a different one depending on the application.
- To start the timer, set TR2 run control bit in T2CON register.

It is possible to use Timer 2 as a baud rate generator and a clock generator simultaneously. For this configuration, the baud rates and clock frequencies are not independent since both functions use the values in the RCAP2H and RCAP2L registers.

## T89C51RB2/RC2









## Registers

#### Table 11. T2CON Register

T2CON - Timer 2 Control Register (C8h)

| 7             | 6               | 5                                                                                                                                                                                                                                                                                                           | 4                                                                                                                                                                                                                                                                                                                                     | 3     | 2   | 1     | 0       |  |  |  |
|---------------|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|-----|-------|---------|--|--|--|
| TF2           | EXF2            | RCLK                                                                                                                                                                                                                                                                                                        | TCLK                                                                                                                                                                                                                                                                                                                                  | EXEN2 | TR2 | C/T2# | CP/RL2# |  |  |  |
| Bit<br>Number | Bit<br>Mnemonic | Description                                                                                                                                                                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                       |       |     |       |         |  |  |  |
| 7             | TF2             | Must be clea                                                                                                                                                                                                                                                                                                | <b>Timer 2 overflow Flag</b><br>Must be cleared by software.<br>Set by hardware on Timer 2 overflow, if RCLK = 0 and TCLK = 0.                                                                                                                                                                                                        |       |     |       |         |  |  |  |
| 6             | EXF2            | Set when a c<br>EXEN2=1.<br>When set, ca<br>interrupt is e<br>Must be clear                                                                                                                                                                                                                                 | Timer 2 External Flag<br>Set when a capture or a reload is caused by a negative transition on T2EX pin if<br>EXEN2=1.<br>When set, causes the CPU to vector to Timer 2 interrupt routine when Timer 2<br>interrupt is enabled.<br>Must be cleared by software. EXF2 doesn't cause an interrupt in Up/down<br>counter mode (DCEN = 1). |       |     |       |         |  |  |  |
| 5             | RCLK            | Cleared to us                                                                                                                                                                                                                                                                                               | Receive Clock bit<br>Cleared to use timer 1 overflow as receive clock for serial port in mode 1 or 3.<br>Set to use Timer 2 overflow as receive clock for serial port in mode 1 or 3.                                                                                                                                                 |       |     |       |         |  |  |  |
| 4             | TCLK            | Cleared to u                                                                                                                                                                                                                                                                                                | <b>Transmit Clock bit</b><br>Cleared to use timer 1 overflow as transmit clock for serial port in mode 1 or 3.<br>Set to use Timer 2 overflow as transmit clock for serial port in mode 1 or 3.                                                                                                                                       |       |     |       |         |  |  |  |
| 3             | EXEN2           | Timer 2 External Enable bit<br>Cleared to ignore events on T2EX pin for Timer 2 operation.<br>Set to cause a capture or reload when a negative transition on T2EX pin is<br>detected, if Timer 2 is not used to clock the serial port.                                                                      |                                                                                                                                                                                                                                                                                                                                       |       |     |       |         |  |  |  |
| 2             | TR2             | Timer 2 Run control bit<br>Cleared to turn off Timer 2.<br>Set to turn on Timer 2.                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                       |       |     |       |         |  |  |  |
| 1             | C/T2#           | <b>Timer/Counter 2 select bit</b><br>Cleared for timer operation (input from internal clock system: F <sub>CLK PERIPH</sub> ).<br>Set for counter operation (input from T2 input pin, falling edge trigger). Must be 0<br>for clock out mode.                                                               |                                                                                                                                                                                                                                                                                                                                       |       |     |       |         |  |  |  |
| 0             | CP/RL2#         | <b>Timer 2 Capture/Reload bit</b><br>If RCLK=1 or TCLK=1, CP/RL2# is ignored and timer is forced to auto-reload on<br>Timer 2 overflow.<br>Cleared to auto-reload on Timer 2 overflows or negative transitions on T2EX pin<br>if EXEN2=1.<br>Set to capture on negative transitions on T2EX pin if EXEN2=1. |                                                                                                                                                                                                                                                                                                                                       |       |     |       |         |  |  |  |

Reset Value = 0000 0000b Bit addressable

T89C51RB2/RC2

### Table 12. T2MOD Register

T2MOD - Timer 2 Mode Control Register (C9h)

| 7             | 6               | 5                                                                                                                                     | 4                                                                               | 3 | 2 | 1    | 0    |  |  |  |
|---------------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------|---|---|------|------|--|--|--|
| -             | -               | -                                                                                                                                     | -                                                                               | - | - | T2OE | DCEN |  |  |  |
| Bit<br>Number | Bit<br>Mnemonic | Description                                                                                                                           |                                                                                 |   |   |      |      |  |  |  |
| 7             | -               | <b>Reserved</b><br>The value re-                                                                                                      | Reserved<br>The value read from this bit is indeterminate. Do not set this bit. |   |   |      |      |  |  |  |
| 6             | -               | <b>Reserved</b><br>The value re-                                                                                                      | Reserved<br>The value read from this bit is indeterminate. Do not set this bit. |   |   |      |      |  |  |  |
| 5             | -               | Reserved<br>The value re                                                                                                              | Reserved<br>The value read from this bit is indeterminate. Do not set this bit. |   |   |      |      |  |  |  |
| 4             | -               | <b>Reserved</b><br>The value re                                                                                                       | Reserved<br>The value read from this bit is indeterminate. Do not set this bit. |   |   |      |      |  |  |  |
| 3             | -               | Reserved<br>The value read from this bit is indeterminate. Do not set this bit.                                                       |                                                                                 |   |   |      |      |  |  |  |
| 2             | -               | Reserved<br>The value read from this bit is indeterminate. Do not set this bit.                                                       |                                                                                 |   |   |      |      |  |  |  |
| 1             | T2OE            | <b>Timer 2 Output Enable bit</b><br>Cleared to program P1.0/T2 as clock input or I/O port.<br>Set to program P1.0/T2 as clock output. |                                                                                 |   |   |      |      |  |  |  |
| 0             | DCEN            | Down Counter Enable bit<br>Cleared to disable Timer 2 as up/down counter.<br>Set to enable Timer 2 as up/down counter.                |                                                                                 |   |   |      |      |  |  |  |

Reset Value = XXXX XX00b Not bit addressable

