



Welcome to E-XFL.COM

#### What is "Embedded - Microcontrollers"?

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

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

#### Details

| Product Status             | Obsolete                                                                  |
|----------------------------|---------------------------------------------------------------------------|
| Core Processor             | 80C51                                                                     |
| Core Size                  | 8-Bit                                                                     |
| Speed                      | 40MHz                                                                     |
| Connectivity               | SPI, UART/USART                                                           |
| Peripherals                | POR, PWM, WDT                                                             |
| Number of I/O              | 32                                                                        |
| Program Memory Size        | 16KB (16K × 8)                                                            |
| Program Memory Type        | FLASH                                                                     |
| EEPROM Size                | -                                                                         |
| RAM Size                   | 1.25K x 8                                                                 |
| Voltage - Supply (Vcc/Vdd) | 4.5V ~ 5.5V                                                               |
| Data Converters            | -                                                                         |
| Oscillator Type            | External                                                                  |
| Operating Temperature      | -40°C ~ 85°C (TA)                                                         |
| Mounting Type              | Surface Mount                                                             |
| Package / Case             | 44-LQFP                                                                   |
| Supplier Device Package    | 44-VQFP (10x10)                                                           |
| Purchase URL               | https://www.e-xfl.com/product-detail/microchip-technology/t89c51rb2-rltim |

Email: info@E-XFL.COM

Address: Room A, 16/F, Full Win Commercial Centre, 573 Nathan Road, Mongkok, Hong Kong

### **Pin Configurations**

#### Figure 2. Pin Configurations



\*NIC: No Internal Connection



| 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-<br>the Atmel C51 Microcontroller Hardware description). If DCEN bit is set, Timer 2 acts a<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.                                                                                                                                                                                                                                                                                         |  |  |  |  |

















cause an internal reset. The second option is also not recommended if other PCA modules are being used. Remember, the PCA timer is the time base for all modules; changing the time base for other modules would not be a good idea. Thus, in most applications the first solution is the best option.

This watchdog timer won't generate a reset out on the reset pin.



#### Table 29. SBUF Register

SBUF - Serial Buffer Register for UART (99h)

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|---|---|---|---|---|---|---|---|
|   |   |   |   |   |   |   |   |

Reset Value = XXXX XXXXb

#### Table 30. BRL Register

BRL - Baud Rate Reload Register for the internal baud rate generator, UART (9Ah)

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|---|---|---|---|---|---|---|---|
|   |   |   |   |   |   |   |   |

Reset Value = 0000 0000b

#### Table 31. 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 |                                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                      | Desc                   | ription      |             |         |  |  |
| 7             | TF2             | Timer 2 over<br>Must be clear<br>Set by hard                                                                                                                                                                                                                                                         | erflow Flag<br>ared by softwa<br>ware on timer                                                                                                                                                                                                                                                                                       | are.<br>2 overflow, if | RCLK = 0 and | 1 TCLK = 0. |         |  |  |
| 6             | EXF2            | Timer 2 Ext<br>Set when a<br>EXEN2=1.<br>When set, c<br>interrupt is e<br>Must be clea<br>counter mod                                                                                                                                                                                                | 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            | Receive Cle<br>Cleared to u<br>Set to use to                                                                                                                                                                                                                                                         | Receive Clock bit for UART<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            | Transmit C<br>Cleared to u<br>Set to use ti                                                                                                                                                                                                                                                          | <b>Transmit Clock bit for UART</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 Ext<br>Cleared to it<br>Set to cause<br>detected, if                                                                                                                                                                                                                                         | <b>Timer 2 External Enable bit</b><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 Ru<br>Cleared to t<br>Set to turn o                                                                                                                                                                                                                                                          | Timer 2 Run control bit<br>Cleared to turn off timer 2.<br>Set to turn on timer 2.                                                                                                                                                                                                                                                   |                        |              |             |         |  |  |
| 1             | C/T2#           | Timer/Cour<br>Cleared for<br>Set for cour<br>0 for clock c                                                                                                                                                                                                                                           | <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<br>0 for clock out mode.                                                                                        |                        |              |             |         |  |  |
| 0             | CP/RL2#         | Timer 2 Capture/Reload bit<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





#### Table 39. IPL1 Register

IPL1 - Interrupt Priority Register (B2h)

| 7             | 6               | 5                               | 4                                                                               | 3                          | 2    | 1 | 0    |  |  |  |
|---------------|-----------------|---------------------------------|---------------------------------------------------------------------------------|----------------------------|------|---|------|--|--|--|
| -             | -               | -                               | -                                                                               | -                          | SPIL | - | KBDL |  |  |  |
| Bit<br>Number | Bit<br>Mnemonic | Description                     | 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             | -               | Reserved<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             | -               | <b>Reserved</b><br>The value re | Reserved<br>The value read from this bit is indeterminate. Do not set this bit. |                            |      |   |      |  |  |  |
| 2             | SPIL            | SPI interrup<br>Refer to SPI    | SPI interrupt Priority bit<br>Refer to SPIH for priority level.                 |                            |      |   |      |  |  |  |
| 1             | -               | <b>Reserved</b><br>The value re | Reserved<br>The value read from this bit is indeterminate. Do not set this bit. |                            |      |   |      |  |  |  |
| 0             | KBDL            | Keyboard in<br>Refer to KBD     | nterrupt Prion<br>DH for priority                                               | r <b>ity bit</b><br>level. |      |   |      |  |  |  |

Reset Value = XXXX X000b Bit addressable

# Serial Port Interface (SPI)

The Serial Peripheral Interface module (SPI) allows full-duplex, synchronous, serial communication between the MCU and peripheral devices, including other MCUs.

#### Features

Features of the SPI module include the following:

- Full-duplex, three-wire synchronous transfers
- Master or Slave operation
- Eight programmable Master clock rates
- Serial clock with programmable polarity and phase
- Master Mode fault error flag with MCU interrupt capability
- Write collision flag protection

Signal DescriptionFigure 20 shows a typical SPI bus configuration using one Master controller and many<br/>Slave peripherals. The bus is made of three wires connecting all the devices:

Figure 24. SPI Master/Slaves interconnection



The Master device selects the individual Slave devices by using four pins of a parallel port to control the four SS pins of the Slave devices.

Master Output Slave Input<br/>(MOSI)This 1-bit signal is directly connected between the Master Device and a Slave Device.<br/>The MOSI line is used to transfer data in series from the Master to the Slave. Therefore,<br/>it is an output signal from the Master, and an input signal to a Slave. A byte (8-bit word)<br/>is transmitted most significant bit (MSB) first, least significant bit (LSB) last.

Master Input Slave Output<br/>(MISO)This 1-bit signal is directly connected between the Slave Device and a Master Device.<br/>The MISO line is used to transfer data in series from the Slave to the Master. Therefore,<br/>it is an output signal from the Slave, and an input signal to the Master. A byte (8-bit<br/>word) is transmitted most significant bit (MSB) first, least significant bit (LSB) last.

**SPI Serial Clock (SCK)** This signal is used to synchronize the data movement both in and out the devices through their MOSI and MISO lines. It is driven by the Master for eight clock cycles which allows to exchange one byte on the serial lines.

Slave Select (SS)Each Slave peripheral is selected by one Slave Select pin (SS). This signal must stay<br/>low for any message for a Slave. It is obvious that only one Master (SS high level) can



#### **Functional Description**

Figure 25 shows a detailed structure of the SPI module.

Figure 25. SPI Module Block Diagram



#### **Operating Modes**

The Serial Peripheral Interface can be configured as one of the two modes: Master mode or Slave mode. The configuration and initialization of the SPI module is made through one register:

The Serial Peripheral CONtrol register (SPCON)

Once the SPI is configured, the data exchange is made using:

- SPCON
- The Serial Peripheral STAtus register (SPSTA)
- The Serial Peripheral DATa register (SPDAT)

During an SPI transmission, data is simultaneously transmitted (shifted out serially) and received (shifted in serially). A serial clock line (SCK) synchronizes shifting and sampling on the two serial data lines (MOSI and MISO). A Slave Select line (SS) allows individual selection of a Slave SPI device; Slave devices that are not selected do not interfere with SPI bus activities.

When the Master device transmits data to the Slave device via the MOSI line, the Slave device responds by sending data to the Master device via the MISO line. This implies full-duplex transmission with both data out and data in synchronized with the same clock (Figure 26).









- 1. The SPI module should be configured as a Master before it is enabled (SPEN set). Also the Master SPI should be configured before the Slave SPI.
- 2. The SPI module should be configured as a Slave before it is enabled (SPEN set).
- The maximum frequency of the SCK for an SPI configured as a Slave is the bus clock speed.
- 4. Before writing to the CPOL and CPHA bits, the SPI should be disabled (SPEN ='0').



| Error conditions       | The following flags in the SPSTA signal SPI error conditions:                                                                                                                                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |
|------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| Mode Fault (MODF)      | Mode Fault error in Master mode SPI indi<br>pin is inconsistent with the actual mode o<br>may have a multi-master conflict for sys<br>affected in the following ways:                                                                                                                                                                                                            | Mode Fault error in Master mode SPI indicates that the level on the Slave Select ( $\overline{SS}$ ) pin is inconsistent with the actual mode of the device. MODF is set to warn that there may have a multi-master conflict for system control. In this case, the SPI system is affected in the following ways:                                               |  |  |  |  |
|                        | An SPI receiver/error CPU interrupt re                                                                                                                                                                                                                                                                                                                                           | quest is generated,                                                                                                                                                                                                                                                                                                                                            |  |  |  |  |
|                        | The SPEN bit in SPCON is cleared. The SPEN bit in SPCON is cleared.                                                                                                                                                                                                                                                                                                              | his disable the SPI,                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |
|                        | The MSTR bit in SPCON is cleared                                                                                                                                                                                                                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |
|                        | When $\overline{SS}$ DISable (SSDIS) bit in the SPC when the $\overline{SS}$ signal becomes'0'.                                                                                                                                                                                                                                                                                  | ON register is cleared, the MODF flag is set                                                                                                                                                                                                                                                                                                                   |  |  |  |  |
|                        | However, as stated before, for a system with one Master, if the $\overline{SS}$ pin of the Master device is pulled low, there is no way that another Master attempt to drive the network. In this case, to prevent the MODF flag from being set, software can set the SSDIS bit in the SPCON register and therefore making the $\overline{SS}$ pin as a general purpose I/O pin. |                                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |
|                        | Clearing the MODF bit is accomplished by followed by a write to the SPCON register. inal set state after the MODF bit has been                                                                                                                                                                                                                                                   | a read of SPSTA register with MODF bit set,<br>SPEN Control bit may be restored to its orig-<br>cleared.                                                                                                                                                                                                                                                       |  |  |  |  |
| Write Collision (WCOL) | A Write Collision (WCOL) flag in the SPSTA is set when a write to the SPDAT register is done during a transmit sequence.                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |
|                        | WCOL does not cause an interruption, and the transfer continues uninterrupted.                                                                                                                                                                                                                                                                                                   |                                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |
|                        | Clearing the WCOL bit is done through a software sequence of an access to SPSTA and an access to SPDAT.                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |
| Overrun Condition      | An overrun condition occurs when the Ma<br>and the Slave devise has not cleared the<br>transmitted. In this case, the receiver buffe<br>last cleared. A read of the SPDAT returns                                                                                                                                                                                                | An overrun condition occurs when the Master device tries to send several data bytes<br>and the Slave devise has not cleared the SPIF bit issuing from the previous data byte<br>transmitted. In this case, the receiver buffer contains the byte sent after the SPIF bit was<br>ast cleared. A read of the SPDAT returns this byte. All others bytes are lost. |  |  |  |  |
|                        | This condition is not detected by the SPI peripheral.                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |
| Interrupts             | Two SPI status flags can generate a CPU interrupt requests:                                                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |
|                        | Table 46. SPI Interrupts                                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |
|                        | Flag                                                                                                                                                                                                                                                                                                                                                                             | Request                                                                                                                                                                                                                                                                                                                                                        |  |  |  |  |
|                        | SPIF (SP data transfer)                                                                                                                                                                                                                                                                                                                                                          | SPI Transmitter Interrupt request                                                                                                                                                                                                                                                                                                                              |  |  |  |  |
|                        | MODF (Mode Fault)                                                                                                                                                                                                                                                                                                                                                                | SPI Receiver/Error Interrupt Request (if SSDIS ='0')                                                                                                                                                                                                                                                                                                           |  |  |  |  |
|                        | Serial Peripheral data transfer flag. SPIF                                                                                                                                                                                                                                                                                                                                       | This bit is set by hardware when a transfer                                                                                                                                                                                                                                                                                                                    |  |  |  |  |

Serial Peripheral data transfer flag, SPIF: This bit is set by hardware when a transfer has been completed. SPIF bit generates transmitter CPU interrupt requests.

Mode Fault flag, MODF: This bit becomes set to indicate that the level on the SS is inconsistent with the mode of the SPI. MODF with SSDIS reset, generates receiver/error CPU interrupt requests.

Figure 30 gives a logical view of the above statements.

| Bit<br>Number | Bit<br>Mnemonic | Description                                                                            |
|---------------|-----------------|----------------------------------------------------------------------------------------|
| 1             | -               | <b>Reserved</b><br>The value read from this bit is indeterminate. Do not set this bit. |
| 0             | -               | <b>Reserved</b><br>The value read from this bit is indeterminate. Do not set this bit. |

Reset Value= 00X0 XXXXb

Not Bit addressable

Serial Peripheral DATa register (SPDAT) The Serial Peripheral Data Register (Table 49) is a read/write buffer for the receive data register. A write to SPDAT places data directly into the shift register. No transmit buffer is available in this model.

A Read of the SPDAT returns the value located in the receive buffer and not the content of the shift register.

#### Table 49. SPDAT Register

SPDAT - Serial Peripheral Data Register (0C5H)

| 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|----|----|----|----|----|----|----|----|
| R7 | R6 | R5 | R4 | R3 | R2 | R1 | R0 |

Reset Value= Indeterminate

R7:R0: Receive data bits

SPCON, SPSTA and SPDAT registers may be read and written at any time while there is no on-going exchange. However, special care should be taken when writing to them while a transmission is on-going:

- Do not change SPR2, SPR1 and SPR0
- Do not change CPHA and CPOL
- Do not change MSTR
- Clearing SPEN would immediately disable the peripheral
- Writing to the SPDAT will cause an overflow



#### **Power Management**

Two power reduction modes are implemented in the T89C51RB2/RC2: the Idle mode and the Power-Down mode. These modes are detailed in the following sections. In addition to these power reduction modes, the clocks of the core and peripherals can be dynamically divided by 2 using the X2 mode detailed in Section "Clock".

Reset

A reset is required after applying power at turn-on. To achieve a valid reset, the reset signal must be maintained for at least 2 machine cycles (24 oscillator clock periods) while the oscillator is running and stabilized and VCC established within the specified operating ranges. A device reset initializes the T89C51RB2/RC2 and vectors the CPU to address 0000h. RST input has a pull-down resistor allowing power-on reset by simply connecting an external capacitor to  $V_{DD}$  as shown in Figure 31. Resistor value and input characteristics are discussed in the Section "DC Characteristics" of the T89C51RB2/RC2 datasheet. The status of the Port pins during reset is detailed in Table 53.

#### Figure 31. Reset Circuitry and Power-On Reset



| Mode  | Port 0   | Port 1 | Port 2 | Port 3 | Port 4 | ALE  |  |  |  |
|-------|----------|--------|--------|--------|--------|------|--|--|--|
| Reset | Floating | High   | High   | High   | High   | High |  |  |  |
| Idle  | Data     | Data   | Data   | Data   | Data   | High |  |  |  |

Data

Table 53. Pin Conditions in Special Operating Modes

Data

#### Reset Recommendation to Prevent Flash Corruption

Power-

Down

Data

A bad reset sequence will lead to bad microcontroller initialization and system registers like SFR's, Program Counter, etc. will not be correctly initialized. A bad initialization may lead to unpredictable behaviour of the C51 microcontroller.

Data

Data

Low

An example of this situation may occur in an instance where the bit ENBOOT in AUXR1 register is initialized from the hardware bit BLJB upon reset. Since this bit allows mapping of the bootloader in the code area, a reset failure can be critical.

If one wants the ENBOOT cleared inorder to unmap the boot from the code area (yet due to a bad reset) the bit ENBOOT in SFR's may be set. If the value of Program Counter is accidently in the range of the boot memory addresses then a flash access (write or erase) may corrupt the Flash on-chip memory.

It is recommended to use an external reset circuitry featuring power supply monitoring to prevent system malfunction during periods of insufficient power supply voltage(power supply failure, power supply switched off).



PSEN# High High

Low

#### **Power-off Flag**

The power-off flag allows the user to distinguish between a "cold start" reset and a "warm start" reset.

A cold start reset is the one induced by  $V_{CC}$  switch-on. A warm start reset occurs while  $V_{CC}$  is still applied to the device and could be generated for example by an exit from power-down.

The power-off flag (POF) is located in PCON register (Table 54). POF is set by hardware when  $V_{CC}$  rises from 0 to its nominal voltage. The POF can be set or cleared by software allowing the user to determine the type of reset.

#### Table 54. PCON Register

| 7             | 6               | 5                                                         | 4                                                                                                                                                                        | 3              | 2          | 1  | 0   |  |  |
|---------------|-----------------|-----------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|------------|----|-----|--|--|
| SMOD1         | SMOD0           | -                                                         | POF                                                                                                                                                                      | GF1            | GF0        | PD | IDL |  |  |
| Bit<br>Number | Bit<br>Mnemonic | Description                                               |                                                                                                                                                                          |                |            |    |     |  |  |
| 7             | SMOD1           | Serial port N<br>Set to select                            | <b>Node bit 1</b><br>double baud                                                                                                                                         | rate in mode 1 | 1, 2 or 3. |    |     |  |  |
| 6             | SMOD0           | Serial port M<br>Cleared to se<br>Set to select           | Serial port Mode bit 0<br>Cleared to select SM0 bit in SCON register.<br>Set to select FE bit in SCON register.                                                          |                |            |    |     |  |  |
| 5             | -               | Reserved<br>The value re-                                 | Reserved<br>The value read from this bit is indeterminate. Do not set this bit.                                                                                          |                |            |    |     |  |  |
| 4             | POF             | Power-Off F<br>Cleared to re<br>Set by hardw<br>software. | <b>Power-Off Flag</b><br>Cleared to recognize next reset type.<br>Set by hardware when V <sub>CC</sub> rises from 0 to its nominal voltage. Can also be set by software. |                |            |    |     |  |  |
| 3             | GF1             | General pur<br>Cleared by u<br>Set by user f              | General purpose Flag<br>Cleared by user for general purpose usage.<br>Set by user for general purpose usage.                                                             |                |            |    |     |  |  |
| 2             | GF0             | General pur<br>Cleared by u<br>Set by user f              | General purpose Flag<br>Cleared by user for general purpose usage.<br>Set by user for general purpose usage.                                                             |                |            |    |     |  |  |
| 1             | PD              | Power-Down<br>Cleared by h<br>Set to enter p              | Power-Down mode bit<br>Cleared by hardware when reset occurs.<br>Set to enter power-down mode.                                                                           |                |            |    |     |  |  |
| 0             | IDL             | Idle mode b<br>Cleared by h<br>Set to enter i             | Idle mode bit<br>Cleared by hardware when interrupt or reset occurs.<br>Set to enter idle mode.                                                                          |                |            |    |     |  |  |

PCON - Power Control Register (87h)

Reset Value = 00X1 0000b Not bit addressable





#### **External Data Memory Read** Cycle



Figure 38. External Data Memory Read Cycle

#### Serial Port Timing – Shift **Register Mode**

Table 64. Symbol Description

| Symbol            | Parameter                                |
|-------------------|------------------------------------------|
| T <sub>XLXL</sub> | Serial port clock cycle time             |
| T <sub>QVHX</sub> | Output data set-up to clock rising edge  |
| T <sub>XHQX</sub> | Output data hold after clock rising edge |
| T <sub>XHDX</sub> | Input data hold after clock rising edge  |
| T <sub>XHDV</sub> | Clock rising edge to input data valid    |

| Table 65. | AC | Parameters | for a | a Fix | Clock |
|-----------|----|------------|-------|-------|-------|
|-----------|----|------------|-------|-------|-------|

|                   | -M  |     | -L  |     |       |
|-------------------|-----|-----|-----|-----|-------|
| Symbol            | Min | Мах | Min | Max | Units |
| T <sub>XLXL</sub> | 300 |     | 300 |     | ns    |
| T <sub>QVHX</sub> | 200 |     | 200 |     | ns    |
| $T_{XHQX}$        | 30  |     | 30  |     | ns    |
| $T_{XHDX}$        | 0   |     | 0   |     | ns    |
| $T_{XHDV}$        |     | 117 |     | 117 | ns    |



This diagram indicates when signals are clocked internally. The time it takes the signals to propagate to the pins, however, ranges from 25 to 125 ns. This propagation delay is dependent on variables such as temperature and pin loading. Propagation also varies from output to output and component. Typically though ( $T_A=25^{\circ}C$  fully loaded) RD and WR propagation delays are approximately 50ns. The other signals are typically 85 ns. Propagation delays are incorporated in the AC specifications.

TXD (MODE 0)

v

After programming the Flash, the status byte should be programmed to zero in order to allow execution of the user's application code beginning at address 0000h.

**Boot Process Summary** 

The boot process is summarized on the following flowchart:







## In-System Programming (ISP)

The In-System Programming (ISP) is performed without removing the microcontroller from the system. The ISP facility consists of a series of internal hardware resources coupled with internal firmware to facilitate remote programming of theT89C51RB2/RC2 through the serial port.

The Atmel ISP facility has made in-circuit programming in an embedded application possible with a minimum of additional expense in components and circuit board area.

The ISP function through UART uses four pins: TxD, RxD,  $V_{SS}$ ,  $V_{CC}$ . Only a small connector needs to be available to interface the application to an external circuit in order to use this feature.

Using In-System Programming (ISP) The ISP feature allows a wide range of baud rates in the user application. It is also adaptable to a wide range of oscillator frequencies. This is accomplished by measuring the bit-time of a single bit in a received character. This information is then used to program the baud rate in terms of timer counts based on the oscillator frequency. The ISP feature requires that an initial character (an uppercase U) be sent to the T89C51RB2/RC2 to establish the baud rate. The ISP firmware provides auto-echo of received characters.

> Once baud rate initialization has been performed, the ISP firmware will only accept Intel Hex-type records. Intel Hex records consist of ASCII characters used to represent hexadecimal values and are summarized below:

#### :NNAAAARRDD. DDCC

T89C51RB2/RC2 will accept up to 16 (10h) data bytes. The "AAAA" string represents the address of the first byte in the record. If there are zero bytes in the record, this field is often set to "0000". The "RR" string indicates the record type. A record type of "00" is a data record. A record type of "01" indicates the end-of-file mark. In this application, additional record types will be added to indicate either commands or data for the ISP facility. The "DD" string represents the data bytes. The maximum number of data bytes in a record is limited to 16 (decimal). The "CC" string represents the checksum byte. ISP commands are summarized in Table 74.

As a record is received by the T89C51RB2/RC2, the information in the record is stored internally and a checksum calculation is performed and compared to "CC".

The operation indicated by the record type is not performed until the entire record has been received. Should an error occur in the checksum, the T89C51RB2/RC2 will send an "X" out the serial port indicating a checksum error. If the checksum calculation is found to match the checksum in the record, then the command will be executed. In most cases, successful reception of the record will be indicated by transmitting a ". " character out the serial port (displaying the contents of the internal program memory is an exception). In the case of a Data Record (record type "00"), an additional check is made. A ". " character will NOT be sent unless the record checksum matched the calculated checksum and all of the bytes in the record were successfully programmed. For a data record, an "X" indicates that the checksum failed to match, and an "R" character indicates that one of the bytes did not properly program.

FLIP, a software utility to implement ISP programming with a PC, is available from the Atmel the web site.

| API Call                 | Parameter                                                                                                                                                                                     |
|--------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| READ BOOT<br>STATUS BYTE | Input Parameters:<br>R0 = osc freq (integer Not required, left for Philips compatibility)<br>R1 = 07h<br>DPH = 00h<br>DPL = 01h (status byte)<br>Return Parameter<br>ACC = value of byte read |
| READ BOOT<br>VECTOR      | Input Parameters:<br>R0 = osc freq (integer Not required, left for Philips compatibility)<br>R1 = 07h<br>DPH = 00h<br>DPL = 02h (boot vector)<br>Return Parameter<br>ACC = value of byte read |

Note: These functions can only be called by user's code. The standard boot loader cannot decrease the security level.

| Number | DPTR | Block                          |
|--------|------|--------------------------------|
| 0      | 00h  | 0 - 8 KB                       |
| 1      | 20h  | 8 - 16 KB                      |
| 2      | 40h  | 16 - 32 KB (Only on T89C51RC2) |

