



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                      | 30/20MHz                                                                 |
| Connectivity               | UART/USART                                                               |
| Peripherals                | POR, PWM, WDT                                                            |
| Number of I/O              | 48                                                                       |
| Program Memory Size        | 64KB (64K x 8)                                                           |
| Program Memory Type        | OTP                                                                      |
| EEPROM Size                | -                                                                        |
| RAM Size                   | 1K x 8                                                                   |
| Voltage - Supply (Vcc/Vdd) | 2.7V ~ 5.5V                                                              |
| Data Converters            | -                                                                        |
| Oscillator Type            | Internal                                                                 |
| Operating Temperature      | 0°C ~ 70°C (TA)                                                          |
| Mounting Type              | Surface Mount                                                            |
| Package / Case             | 68-LCC (J-Lead)                                                          |
| Supplier Device Package    | 68-PLCC (24.23x24.23)                                                    |
| Purchase URL               | https://www.e-xfl.com/product-detail/microchip-technology/ts87c51rd2-lcl |

Email: info@E-XFL.COM

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



|                 | Pin Number |              |              | -    | Name And Equation                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |
|-----------------|------------|--------------|--------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Mnemonic        | DIL        | LCC          | VQFP 1.4     | Туре | Name And Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |
| V <sub>SS</sub> | 20         | 22           | 16           | Ι    | Ground: 0V reference                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |
| Vss1            |            | 1            | 39           | Ι    | Optional Ground: Contact the Sales Office for ground connection.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |
| V <sub>CC</sub> | 40         | 44           | 38           | Ι    | <b>Power Supply:</b> This is the power supply voltage for normal, idle and power-<br>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 pins must be polarized to Vcc or Vss 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 when emitting 1s. Port 0 also inputs the code bytes during EPROM 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. Alternate functions for Port 1 include:                                                                                                                                                                                                                                                                                                                                             |  |  |  |
|                 | 1          | 2            | 40           | I/O  | T2 (P1.0): Timer/Counter 2 external count input/Clockout                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |
|                 | 2          | 3            | 41           | Ι    | T2EX (P1.1): Timer/Counter 2 Reload/Capture/Direction Control                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |
|                 | 3          | 4            | 42           | Ι    | ECI (P1.2): External Clock for the PCA                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |
|                 | 4          | 5            | 43           | I/O  | CEX0 (P1.3): Capture/Compare External I/O for PCA module 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |
|                 | 5          | 6            | 44           | I/O  | CEX1 (P1.4): Capture/Compare External I/O for PCA module 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |
|                 | 6          | 7            | 45           | I/O  | CEX0 (P1.5): Capture/Compare External I/O for PCA module 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |
|                 | 7          | 8            | 46           | I/O  | CEX0 (P1.6): Capture/Compare External I/O for PCA module 3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |
|                 | 8          | 9            | 47           | I/O  | CEX0 (P1.7): Capture/Compare External I/O for PCA module 4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |
| P2.0-P2.7       | 21-28      | 24-31        | 18-25        | I/O  | <b>Port 2:</b> Port 2 is an 8-bit bidirectional I/O port with internal pull-ups. Port 2 pins that have 1s written to them are pulled high by the internal pull-ups and can be used as inputs. As inputs, Port 2 pins that are externally pulled low will source current because of the internal pull-ups. Port 2 emits the high-order address byte during fetches from external program memory and during accesses to external data memory that use 16-bit addresses (MOVX @DPTR).In this application, it uses strong internal pull-ups emitting 1s. During accesses to external data memory that use 8-bit addresses (MOVX @Ri), port 2 emits the contents of the P2 SFR. Some Port 2 pins (P2.0 to P2.5) receive the high order address bits during EPROM programming and verification: |  |  |  |
| 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. Some Port 3 pins (P3.4 to P3.5) receive the high order address bits during EPROM programming and verification. Port 3 also serves the special features of the 80C51 family, as listed below.                                                                                                                                                                                                                                                                                    |  |  |  |
|                 | 10         | 11           | 5            | Ι    | RXD (P3.0): Serial input port                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |
|                 | 11         | 13           | 7            | 0    | TXD (P3.1): Serial output port                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |
|                 | 12         | 14           | 8            | Ι    | <b>INTO</b> (P3.2): External interrupt 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |
|                 | 13         | 15           | 9            | Ι    | <b>INT1</b> (P3.3): External interrupt 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |
|                 | 14         | 16           | 10           | Ι    | T0 (P3.4): Timer 0 external input                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |
|                 | 15         | 17           | 11           | Ι    | T1 (P3.5): Timer 1 external input                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |
|                 | 16         | 18           | 12           | 0    | WR (P3.6): External data memory write strobe                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |
|                 | 17         | 19           | 13           | 0    | <b>RD</b> (P3.7): External data memory read strobe                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |





Figure 4. Internal and External Data Memory Address

| Ad | AUXR<br>Address 08EH                                     |                       | -                                                                                               | -                                            | -         | -           | -       | -          | EXTRA<br>M | AO |  |  |
|----|----------------------------------------------------------|-----------------------|-------------------------------------------------------------------------------------------------|----------------------------------------------|-----------|-------------|---------|------------|------------|----|--|--|
|    | Reset                                                    | value                 | Х                                                                                               | Х                                            | Х         | X           | Х       | Х          | 0          | 0  |  |  |
|    | Symbol                                                   |                       |                                                                                                 |                                              |           | Function    | 1       |            |            |    |  |  |
|    | - Not implemented, reserved for future use. <sup>a</sup> |                       |                                                                                                 |                                              |           |             |         |            |            |    |  |  |
|    | AO                                                       | AO Disable/Enable ALE |                                                                                                 |                                              |           |             |         |            |            |    |  |  |
|    |                                                          | AO                    | Ope                                                                                             | Operating Mode                               |           |             |         |            |            |    |  |  |
|    |                                                          | 0                     | 0 ALE is emitted at a constant rate of 1/6 the oscillator frequency (or 1/3 if X2 mode is used) |                                              |           |             |         |            |            |    |  |  |
|    |                                                          | 1                     | ALI                                                                                             | E is active                                  | only duri | ng a MOV    | X or MO | VC instruc | tion       |    |  |  |
|    | EXTRAM                                                   | Internal/E:           | xternal R.                                                                                      | AM (00H-                                     | FFH) acce | ess using N | AOVX @  | Ri/@DP     | TR         |    |  |  |
|    |                                                          | EXTRA                 | AM Operating Mode                                                                               |                                              |           |             |         |            |            |    |  |  |
|    |                                                          | 0                     | Inte                                                                                            | Internal XRAM access using MOVX @ Ri/ @ DPTR |           |             |         |            |            |    |  |  |
|    |                                                          | 1                     | Exte                                                                                            | External data memory access                  |           |             |         |            |            |    |  |  |

 Table 5. Auxiliary Register AUXR

a. User software should not write 1s to reserved bits. These bits may be used in future 8051 family products to invoke new features. In that case, the reset or inactive value of the new bit will be 0, and its active value will be 1. The value read from a reserved bit is indeterminate.



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.



Figure 6. Clock-Out Mode  $C/\overline{T2} = 0$ 



**The CCON SFR** contains the run control bit for the PCA and the flags for the PCA timer (CF) and each module (Refer to Table 9).

- Bit CR (CCON.6) must be set by software to run the PCA. The PCA is shut off by clearing this bit.
- Bit CF: The CF bit (CCON.7) is set when the PCA counter overflows and an interrupt will be generated if the ECF bit in the CMOD register is set. The CF bit can only be cleared by software.
- Bits 0 through 4 are the flags for the modules (bit 0 for module 0, bit 1 for module 1, etc.) and are set by hardware when either a match or a capture occurs. These flags also can only be cleared by software.

| CCON<br>Address 0D8H                                                                |      | CF                                     | CR                                                                                                        | -          | CCF4       | CCF3            | CCF2        | CCF1       | CCF0       |            |
|-------------------------------------------------------------------------------------|------|----------------------------------------|-----------------------------------------------------------------------------------------------------------|------------|------------|-----------------|-------------|------------|------------|------------|
|                                                                                     | Rese | et value                               | 0                                                                                                         | 0          | X          | 0               | 0           | 0          | 0          | 0          |
| Sy                                                                                  | nbol | Function                               | ı                                                                                                         |            |            |                 |             |            |            |            |
| CF                                                                                  |      | PCA Coun<br>an interrup<br>can only be | t if bit EC                                                                                               | F in CMC   | DD is set. |                 |             |            |            | 0          |
| CR                                                                                  |      | PCA Coun<br>by software                |                                                                                                           |            | •          |                 | Irn the PCA | A counter  | on. Must   | be cleared |
| -                                                                                   |      | Not implen                             | nented, res                                                                                               | erved for  | future use | e. <sup>a</sup> |             |            |            |            |
| CCF4                                                                                |      | PCA Modu cleared by                    |                                                                                                           | rupt flag. | Set by ha  | ardware wh      | nen a matc  | h or captu | are occurs | . Must be  |
| CCF3                                                                                |      | PCA Modu cleared by                    |                                                                                                           | rupt flag. | Set by ha  | ardware wł      | nen a matc  | h or captu | are occurs | . Must be  |
| CCF2                                                                                |      |                                        | PCA Module 2 interrupt flag. Set by hardware when a match or capture occurs. Must be cleared by software. |            |            |                 |             |            |            |            |
| CCF1 PCA Module 1 interrupt flag. Set by hardware when a match cleared by software. |      |                                        |                                                                                                           |            |            | h or captu      | are occurs  | . Must be  |            |            |
| CCF0 PCA M                                                                          |      |                                        | ile 0 inter<br>software.                                                                                  | rupt flag. | Set by ha  | ardware wł      | nen a matc  | h or captu | are occurs | . Must be  |

 Table 9. CCON: PCA Counter Control Register

a. User software should not write 1s to reserved bits. These bits may be used in future 8051 family products to invoke new features. In that case, the reset or inactive value of the new bit will be 0, and its active value will be 1. The value read from a reserved bit is indeterminate.

The watchdog timer function is implemented in module 4 (See Figure 10).

The PCA interrupt system is shown in Figure 8



### 6.6. TS80C51Rx2 Serial I/O Port

The serial I/O port in the TS80C51Rx2 is compatible with the serial I/O port in the 80C52. It provides both synchronous and asynchronous communication modes. It operates as an Universal Asynchronous

Receiver and Transmitter (UART) in three full-duplex modes (Modes 1, 2 and 3). Asynchronous transmission and reception can occur simultaneously and at different baud rates

Serial I/O port includes the following enhancements:

- Framing error detection
- Automatic address recognition

### 6.6.1. Framing Error Detection

Framing bit error detection is provided for the three asynchronous modes (modes 1, 2 and 3). To enable the framing bit error detection feature, set SMOD0 bit in PCON register (See Figure 13).



### Figure 13. Framing Error Block Diagram

When this feature is enabled, the receiver checks each incoming data frame for a valid stop bit. An invalid stop bit may result from noise on the serial lines or from simultaneous transmission by two CPUs. If a valid stop bit is not found, the Framing Error bit (FE) in SCON register (See Table 16.) bit is set.



#### 6.6.3. Given Address

Each device has an individual address that is specified in SADDR register; the SADEN register is a mask byte that contains don't-care bits (defined by zeros) to form the device's given address. The don't-care bits provide the flexibility to address one or more slaves at a time. The following example illustrates how a given address is formed. To address a device by its individual address, the SADEN mask byte must be 1111 1111b. For example:

| SADDR | 0101 0110b        |
|-------|-------------------|
| SADEN | <u>1111 1100b</u> |
| Given | 0101 01XXb        |

The following is an example of how to use given addresses to address different slaves:

| Slave A: | SADDR<br><u>SADEN</u><br>Given | 1111 0001b<br><u>1111 1010b</u><br>1111 0X0Xb |
|----------|--------------------------------|-----------------------------------------------|
| Slave B: | SADDR<br><u>SADEN</u><br>Given | 1111 0011b<br><u>1111 1001b</u><br>1111 0XX1b |
| Slave C: | SADDR<br><u>SADEN</u><br>Given | 1111 0010b<br><u>1111 1101b</u><br>1111 00X1b |

The SADEN byte is selected so that each slave may be addressed separately.

For slave A, bit 0 (the LSB) is a don't-care bit; for slaves B and C, bit 0 is a 1. To communicate with slave A only, the master must send an address where bit 0 is clear (e.g. 1111 0000b).

For slave A, bit 1 is a 1; for slaves B and C, bit 1 is a don't care bit. To communicate with slaves B and C, but not slave A, the master must send an address with bits 0 and 1 both set (e.g. 1111 0011b).

To communicate with slaves A, B and C, the master must send an address with bit 0 set, bit 1 clear, and bit 2 clear (e.g. 1111 0001b).

### 6.6.4. Broadcast Address

A broadcast address is formed from the logical OR of the SADDR and SADEN registers with zeros defined as don't-care bits, e.g.:

| 0101 0110b |
|------------|
| 1111 1100b |
| 1111 111Xb |
|            |

The use of don't-care bits provides flexibility in defining the broadcast address, however in most applications, a broadcast address is FFh. The following is an example of using broadcast addresses:

| Slave A: | SADDR<br><u>SADEN</u><br>Broadcast  | 1111 0001b<br><u>1111 1010b</u><br>1111 1X11b, |
|----------|-------------------------------------|------------------------------------------------|
| Slave B: | SADDR<br><u>SADEN</u><br>Broadcast  | 1111 0011b<br><u>1111 1001b</u><br>1111 1X11B, |
| Slave C: | SADDR=<br><u>SADEN</u><br>Broadcast | 1111 0010b<br><u>1111 1101b</u><br>1111 1111b  |

For slaves A and B, bit 2 is a don't care bit; for slave C, bit 2 is set. To communicate with all of the slaves, the master must send an address FFh. To communicate with slaves A and B, but not slave C, the master can send and address FBh.



#### 6.6.5. Reset Addresses

On reset, the SADDR and SADEN registers are initialized to 00h, i.e. the given and broadcast addresses are XXXX (all don't-care bits). This ensures that the serial port will reply to any address, and so, that it is backwards compatible with the 80C51 microcontrollers that do not support automatic address recognition.

#### SADEN - Slave Address Mask Register (B9h)

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

Reset Value = 0000 0000b Not bit addressable

#### SADDR - Slave Address Register (A9h)

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

Reset Value = 0000 0000b Not bit addressable



### Table 17. PCON Register

#### PCON - Power Control Register (87h)

| 7          | 6               | 5                             | 4                                                                                                            |         | 3                  | 2                    | 1                   | 0   |  |  |
|------------|-----------------|-------------------------------|--------------------------------------------------------------------------------------------------------------|---------|--------------------|----------------------|---------------------|-----|--|--|
| SMOD1      | SMOD            | ) -                           | POI                                                                                                          | F       | GF1                | GF0                  | PD                  | IDL |  |  |
| Bit Number | Bit<br>Mnemonic | Description                   |                                                                                                              |         |                    |                      |                     |     |  |  |
| 7          | SMOD1           | Serial port Mo<br>Set to sele | <b>de bit 1</b><br>ct double baud ra                                                                         | te in m | ode 1, 2 or 3.     |                      |                     |     |  |  |
| 6          | SMOD0           |                               | <b>de bit 0</b><br>ect SM0 bit in S0<br>lect FE bit in SC0                                                   |         |                    |                      |                     |     |  |  |
| 5          | -               | Reserved<br>The value         | Reserved<br>The value read from this bit is indeterminate. Do not set this bit.                              |         |                    |                      |                     |     |  |  |
| 4          | POF             |                               | cognize next reset                                                                                           |         | rom 0 to its nomin | al voltage. Can also | o be set by softwar | re. |  |  |
| 3          | GF1             |                               | se Flag<br>user for general j<br>for general purp                                                            |         |                    |                      |                     |     |  |  |
| 2          | GF0             | Cleared by                    | General purpose Flag<br>Cleared by user for general purpose usage.<br>Set by user for general purpose usage. |         |                    |                      |                     |     |  |  |
| 1          | PD              | Cleared by                    | Power-Down mode bit<br>Cleared by hardware when reset occurs.<br>Set to enter power-down mode.               |         |                    |                      |                     |     |  |  |
| 0          | IDL             |                               | 1                                                                                                            |         |                    |                      |                     |     |  |  |

Reset Value = 00X1 0000b Not bit addressable

Power-off flag reset value will be 1 only after a power on (cold reset). A warm reset doesn't affect the value of this bit.



#### Table 21. IPH Register

#### IPH - Interrupt Priority High Register (B7h)

| 7             | 6               | 5                                                                  | 4                                                                                | 3                                                             | 2            | 1    | 0    |
|---------------|-----------------|--------------------------------------------------------------------|----------------------------------------------------------------------------------|---------------------------------------------------------------|--------------|------|------|
| -             | РРСН            | РТ2Н                                                               | PSH                                                                              | PT1H                                                          | PX1H         | РТОН | РХОН |
| Bit<br>Number | Bit<br>Mnemonic |                                                                    |                                                                                  | Descrip                                                       | tion         |      |      |
| 7             | -               | <b>Reserved</b><br>The value read f                                | from this bit is ind                                                             | eterminate. Do not s                                          | et this bit. |      |      |
| 6             | РРСН            | PCA interrupt prio<br><u>PPCH</u><br>0<br>1<br>1                   |                                                                                  | <u>ority Level</u><br>Lowest<br>Highest                       |              |      |      |
| 5             | РТ2Н            | <b>Timer 2 overflow in</b><br><u>PT2H</u><br>0<br>0<br>1<br>1<br>1 | tterrupt Priority<br><u>PT2</u> 0<br>1<br>0<br>1<br>1<br>1<br>1<br>1<br>1<br>1   | <b>High bit</b><br><u>Priority Level</u><br>Lowest<br>Highest |              |      |      |
| 4             | PSH             | Serial port Priority<br><u>PSH</u><br>0<br>1<br>1<br>1             | High bit<br><u>PS</u><br>0<br>1<br>0<br>1                                        | <u>Priority Level</u><br>Lowest<br>Highest                    |              |      |      |
| 3             | PT1H            | <b>Timer 1 overflow in</b><br><u>PT1H</u><br>0<br>0<br>1<br>1<br>1 | terrupt Priority<br><u>PT1</u><br>0<br>1<br>0<br>1<br>1<br>1<br>1<br>1<br>1<br>1 | High bit<br><u>Priority Level</u><br>Lowest<br>Highest        |              |      |      |
| 2             | PX1H            | External interrupt<br><u>PX1H</u><br>0<br>0<br>1<br>1<br>1         | 1 Priority High b<br><u>PX1</u><br>0<br>1<br>0<br>1<br>1                         | it <u>Priority Level</u><br>Lowest<br>Highest                 |              |      |      |
| 1             | РТОН            | Timer 0 overflow in <u>PT0H</u> 0           1           1          | tterrupt Priority<br><u>PTO</u><br>0<br>1<br>0<br>1<br>1                         | <b>High bit</b><br><u>Priority Level</u><br>Lowest<br>Highest |              |      |      |
| 0             | РХОН            | External interrupt                                                 | 0 Priority High b<br><u>PX0</u><br>0<br>1<br>0<br>1                              | <b>it</b><br><u>Priority Level</u><br>Lowest<br>Highest       |              |      |      |

Reset Value = X000 0000b Not bit addressable



# 7. TS83C51RB2/RC2/RD2 ROM

### 7.1. ROM Structure

The TS83C51RB2/RC2/RD2 ROM memory is divided in three different arrays:

| • | the code array:       | . 16/32/64 Kbytes. |
|---|-----------------------|--------------------|
| ٠ | the encryption array: | 64 bytes.          |
| ٠ | the signature array:  | 4 bytes.           |

## 7.2. ROM Lock System

The program Lock system, when programmed, protects the on-chip program against software piracy.

### 7.2.1. 7.2.1. Encryption Array

Within the ROM array are 64 bytes of encryption array that are initially unprogrammed (all FF's). Every time a byte is addressed during program verify, 6 address lines are used to select a byte of the encryption array. This byte is then exclusive-NOR'ed (XNOR) with the code byte, creating an encrypted verify byte. The algorithm, with the encryption array in the unprogrammed state, will return the code in its original, unmodified form.

When using the encryption array, one important factor needs to be considered. If a byte has the value FFh, verifying the byte will produce the encryption byte value. If a large block (>64 bytes) of code is left unprogrammed, a verification routine will display the content of the encryption array. For this reason all the unused code bytes should be programmed with random values. This will ensure program protection.

### 7.2.2. Program Lock Bits

The lock bits when programmed according to Table 28. will provide different level of protection for the on-chip code and data.

|                   | Program Lock Bits |     |     |                                                                                                                                                                                                 |  |  |  |
|-------------------|-------------------|-----|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Security<br>level | LB1               | LB2 | LB3 | Protection description                                                                                                                                                                          |  |  |  |
| 1                 | U                 | U   | U   | No program lock features enabled. Code verify will still be encrypted by the encryption array if programmed. MOVC instruction executed from external program memory returns non encrypted data. |  |  |  |
| 2                 | Р                 | U   | U   | MOVC instruction executed from external program memory are disabled from fetching code bytes from internal memory, $\overline{EA}$ is sampled and latched on reset.                             |  |  |  |
| 3                 | U                 | Р   | U   | Same as level 1+ Verify disable.<br>This security level is only available for 51RDX2 devices.                                                                                                   |  |  |  |

| Table 28. Program Lock bits | Table | 28. | Program | Lock | bits |
|-----------------------------|-------|-----|---------|------|------|
|-----------------------------|-------|-----|---------|------|------|

U: unprogrammed

P: programmed

### 7.2.3. Signature bytes

The TS83C51RB2/RC2/RD2 contains 4 factory programmed signatures bytes. To read these bytes, perform the process described in section 8.3.

### 7.2.4. Verify Algorithm

Refer to 8.3.4.



### **8.3. EPROM Programming**

### 8.3.1. Set-up modes

In order to program and verify the EPROM or to read the signature bytes, the TS87C51RB2/RC2/RD2 is placed in specific set-up modes (See Figure 18.).

Control and program signals must be held at the levels indicated in Table 30.

### **8.3.2.** Definition of terms

Address Lines: P1.0-P1.7, P2.0-P2.5, P3.4, P3.5 respectively for A0-A15 (P2.5 (A13) for RB, P3.4 (A14) for RC, P3.5 (A15) for RD)

Data Lines: P0.0-P0.7 for D0-D7

**Control Signals:** RST, <u>PSEN</u>, P2.6, P2.7, P3.3, P3.6, P3.7.

Program Signals: ALE/PROG, EA/VPP.

| Mode                                      | RST | PSEN | ALE/<br>PROG | <b>EA</b> /VPP | P2.6 | P2.7 | P3.3 | P3.6 | P3.7 |
|-------------------------------------------|-----|------|--------------|----------------|------|------|------|------|------|
| Program Code data                         | 1   | 0    | Г            | 12.75V         | 0    | 1    | 1    | 1    | 1    |
| Verify Code data                          | 1   | 0    | 1            | 1              | 0    |      | 0    | 1    | 1    |
| Program Encryption Array<br>Address 0-3Fh | 1   | 0    | Г            | 12.75V         | 0    | 1    | 1    | 0    | 1    |
| Read Signature Bytes                      | 1   | 0    | 1            | 1              | 0    |      | 0    | 0    | 0    |
| Program Lock bit 1                        | 1   | 0    | Г            | 12.75V         | 1    | 1    | 1    | 1    | 1    |
| Program Lock bit 2                        | 1   | 0    | Г            | 12.75V         | 1    | 1    | 1    | 0    | 0    |
| Program Lock bit 3                        | 1   | 0    | Г            | 12.75V         | 1    | 0    | 1    | 1    | 0    |

Table 30. EPROM Set-Up Modes





\* See Table 31. for proper value on these inputs

Figure 18. Set-Up Modes Configuration

### 8.3.3. Programming Algorithm

The Improved Quick Pulse algorithm is based on the Quick Pulse algorithm and decreases the number of pulses applied during byte programming from 25 to 1.

To program the TS87C51RB2/RC2/RD2 the following sequence must be exercised:

- Step 1: Activate the combination of control signals.
- Step 2: Input the valid address on the address lines.
- Step 3: Input the appropriate data on the data lines.
- Step 4: Raise  $\overline{EA}/VPP$  from VCC to VPP (typical 12.75V).
- Step 5: Pulse ALE/PROG once.
- Step 6: Lower  $\overline{EA}/VPP$  from VPP to VCC

Repeat step 2 through 6 changing the address and data for the entire array or until the end of the object file is reached (See Figure 19.).

### 8.3.4. Verify algorithm

Code array verify must be done after each byte or block of bytes is programmed. In either case, a complete verify of the programmed array will ensure reliable programming of the TS87C51RB2/RC2/RD2.

P 2.7 is used to enable data output.

To verify the TS87C51RB2/RC2/RD2 code the following sequence must be exercised:

- Step 1: Activate the combination of program and control signals.
- Step 2: Input the valid address on the address lines.
- Step 3: Read data on the data lines.

Repeat step 2 through 3 changing the address for the entire array verification (See Figure 19.)

The encryption array cannot be directly verified. Verification of the encryption array is done by observing that the code array is well encrypted.



| Symbol                       | Parameter                                                    | Min | Тур | Max                                                 | Unit | Test Conditions        |
|------------------------------|--------------------------------------------------------------|-----|-----|-----------------------------------------------------|------|------------------------|
| I <sub>CC</sub><br>operating | Power Supply Current Maximum values, X1 mode: <sup>(7)</sup> |     |     | 3 + 0.6 Freq<br>(MHz)<br>@12MHz 10.2<br>@16MHz 12.6 | mA   | $V_{CC} = 5.5 V^{(8)}$ |
| I <sub>CC</sub><br>idle      | Power Supply Current Maximum values, X1 mode: <sup>(7)</sup> |     |     | 0.25+0.3Freq<br>(MHz)<br>@12MHz 3.9<br>@16MHz 5.1   | mA   | $V_{CC} = 5.5 V^{(2)}$ |

### **10.4. DC Parameters for Low Voltage**

TA = 0°C to +70°C; V<sub>SS</sub> = 0 V; V<sub>CC</sub> = 2.7 V to 5.5 V  $\pm$  10%; F = 0 to 30 MHz. TA = -40°C to +85°C; V<sub>SS</sub> = 0 V; V<sub>CC</sub> = 2.7 V to 5.5 V  $\pm$  10%; F = 0 to 30 MHz.

| Table 33. | <b>DC</b> Parameters | for Low | Voltage |
|-----------|----------------------|---------|---------|
|-----------|----------------------|---------|---------|

| Symbol                            | Parameter                                                    | Min                       | Тур                                    | Max                                               | Unit | Test Conditions                                                                                      |
|-----------------------------------|--------------------------------------------------------------|---------------------------|----------------------------------------|---------------------------------------------------|------|------------------------------------------------------------------------------------------------------|
| V <sub>IL</sub>                   | Input Low Voltage                                            | -0.5                      |                                        | 0.2 V <sub>CC</sub> - 0.1                         | v    |                                                                                                      |
| V <sub>IH</sub>                   | Input High Voltage except XTAL1, RST                         | 0.2 V <sub>CC</sub> + 0.9 |                                        | V <sub>CC</sub> + 0.5                             | v    |                                                                                                      |
| V <sub>IH1</sub>                  | Input High Voltage, XTAL1, RST                               | 0.7 V <sub>CC</sub>       |                                        | V <sub>CC</sub> + 0.5                             | V    |                                                                                                      |
| V <sub>OL</sub>                   | Output Low Voltage, ports 1, 2, 3, 4, 5 <sup>(6)</sup>       |                           |                                        | 0.45                                              | V    | $I_{OL} = 0.8 \text{ mA}^{(4)}$                                                                      |
| V <sub>OL1</sub>                  | Output Low Voltage, port 0, ALE, PSEN (6)                    |                           |                                        | 0.45                                              | v    | $I_{OL} = 1.6 \text{ mA}^{(4)}$                                                                      |
| V <sub>OH</sub>                   | Output High Voltage, ports 1, 2, 3, 4, 5                     | 0.9 V <sub>CC</sub>       |                                        |                                                   | V    | $I_{OH} = -10 \ \mu A$                                                                               |
| V <sub>OH1</sub>                  | Output High Voltage, port 0, ALE, PSEN                       | 0.9 V <sub>CC</sub>       |                                        |                                                   | V    | $I_{OH} = -40 \ \mu A$                                                                               |
| I <sub>IL</sub>                   | Logical 0 Input Current ports 1, 2, 3, 4, 5                  |                           |                                        | -50                                               | μΑ   | Vin = 0.45 V                                                                                         |
| I <sub>LI</sub>                   | Input Leakage Current                                        |                           |                                        | ±10                                               | μΑ   | 0.45 V < Vin < V <sub>CC</sub>                                                                       |
| I <sub>TL</sub>                   | Logical 1 to 0 Transition Current, ports 1, 2, 3, 4, 5       |                           |                                        | -650                                              | μΑ   | Vin = 2.0 V                                                                                          |
| R <sub>RST</sub>                  | RST Pulldown Resistor                                        | 50                        | 90 <sup>(5)</sup>                      | 200                                               | kΩ   |                                                                                                      |
| CIO                               | Capacitance of I/O Buffer                                    |                           |                                        | 10                                                | pF   | $Fc = 1 MHz$ $TA = 25^{\circ}C$                                                                      |
| I <sub>PD</sub>                   | Power Down Current                                           |                           | 20 <sup>(5)</sup><br>10 <sup>(5)</sup> | 50<br>30                                          | μΑ   | $V_{CC} = 2.0 \text{ V to } 5.5 \text{ V}^{(3)}$<br>$V_{CC} = 2.0 \text{ V to } 3.3 \text{ V}^{(3)}$ |
| I <sub>CC</sub><br>under<br>RESET | Power Supply Current Maximum values, X1 mode: <sup>(7)</sup> |                           |                                        | 1 + 0.2 Freq<br>(MHz)<br>@12MHz 3.4<br>@16MHz 4.2 | mA   | $V_{\rm CC} = 3.3 \ V^{(1)}$                                                                         |
| I <sub>CC</sub><br>operating      | Power Supply Current Maximum values, X1 mode: <sup>(7)</sup> |                           |                                        | 1 + 0.3 Freq<br>(MHz)<br>@12MHz 4.6<br>@16MHz 5.8 | mA   | $V_{\rm CC} = 3.3 \ V^{(8)}$                                                                         |



### **10.5. AC Parameters**

### 10.5.1. Explanation of the AC Symbols

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

Example:  $T_{AVLL}$  = Time for Address Valid to ALE Low.  $T_{LLPL}$  = Time for ALE Low to PSEN Low.

TA = 0 to +70°C (commercial temperature range);  $V_{SS} = 0$  V;  $V_{CC} = 5$  V ± 10%; -M and -V ranges. TA = -40°C to +85°C (industrial temperature range);  $V_{SS} = 0$  V;  $V_{CC} = 5$  V ± 10%; -M and -V ranges. TA = 0 to +70°C (commercial temperature range);  $V_{SS} = 0$  V; 2.7 V <  $V_{CC} < 5.5$  V; -L range. TA = -40°C to +85°C (industrial temperature range);  $V_{SS} = 0$  V; 2.7 V <  $V_{CC} < 5.5$  V; -L range.

Table 34. gives the maximum applicable load capacitance for Port 0, Port 1, 2 and 3, and ALE and  $\overline{\text{PSEN}}$  signals. Timings will be guaranteed if these capacitances are respected. Higher capacitance values can be used, but timings will then be degraded.

|              | -M  | -V | -L  |
|--------------|-----|----|-----|
| Port 0       | 100 | 50 | 100 |
| Port 1, 2, 3 | 80  | 50 | 80  |
| ALE / PSEN   | 100 | 30 | 100 |

| Table 34 | . Load | Capacitance | versus | speed | range. | in | рF |
|----------|--------|-------------|--------|-------|--------|----|----|
|          |        | Capacitanee |        | peed  |        |    | r- |

Table 36., Table 39. and Table 42. give the description of each AC symbols.

Table 37., Table 40. and Table 43. give for each range the AC parameter.

Table 38., Table 41. and Table 44. give the frequency derating formula of the AC parameter. To calculate each AC symbols, take the x value corresponding to the speed grade you need (-M, -V or -L) and replace this value in the formula. Values of the frequency must be limited to the corresponding speed grade:

Table 35. Max frequency for derating formula regarding the speed grade

|            | -M X1 mode | -M X2 mode | -V X1 mode | -V X2 mode | -L X1 mode | -L X2 mode |
|------------|------------|------------|------------|------------|------------|------------|
| Freq (MHz) | 40         | 20         | 40         | 30         | 30         | 20         |
| T (ns)     | 25         | 50         | 25         | 33.3       | 33.3       | 50         |

Example:

 $T_{LLIV}$  in X2 mode for a -V part at 20 MHz (T =  $1/20^{E6}$  = 50 ns):

x= 22 (Table 38.)

T=50ns

 $T_{LLIV}$ = 2T - x = 2 x 50 - 22 = 78ns



### **10.5.2. External Program Memory Characteristics**

| Table | 36. | Symbol | Description |
|-------|-----|--------|-------------|
|-------|-----|--------|-------------|

| Symbol            | Parameter                         |
|-------------------|-----------------------------------|
| Т                 | Oscillator clock period           |
| T <sub>LHLL</sub> | ALE pulse width                   |
| T <sub>AVLL</sub> | Address Valid to ALE              |
| T <sub>LLAX</sub> | Address Hold After ALE            |
| T <sub>LLIV</sub> | ALE to Valid Instruction In       |
| T <sub>LLPL</sub> | ALE to PSEN                       |
| T <sub>PLPH</sub> | PSEN Pulse Width                  |
| T <sub>PLIV</sub> | PSEN to Valid Instruction In      |
| T <sub>PXIX</sub> | Input Instruction Hold After PSEN |
| T <sub>PXIZ</sub> | Input Instruction FloatAfter PSEN |
| T <sub>PXAV</sub> | PSEN to Address Valid             |
| T <sub>AVIV</sub> | Address to Valid Instruction In   |
| T <sub>PLAZ</sub> | PSEN Low to Address Float         |

### Table 37. AC Parameters for Fix Clock

| Speed             |     | M<br>MHz | X2 1<br>30 1 | V<br>node<br>MHz<br>z equiv. | standar | V<br>rd mode<br>MHz | X2 r<br>20 M | L<br>node<br>MHz<br>z equiv. | standar | L<br><sup>.</sup> d mode<br>⁄IHz | Units |
|-------------------|-----|----------|--------------|------------------------------|---------|---------------------|--------------|------------------------------|---------|----------------------------------|-------|
| Symbol            | Min | Max      | Min          | Max                          | Min     | Max                 | Min          | Max                          | Min     | Max                              |       |
| Т                 | 25  |          | 33           |                              | 25      |                     | 50           |                              | 33      |                                  | ns    |
| T <sub>LHLL</sub> | 40  |          | 25           |                              | 42      |                     | 35           |                              | 52      |                                  | ns    |
| T <sub>AVLL</sub> | 10  |          | 4            |                              | 12      |                     | 5            |                              | 13      |                                  | ns    |
| T <sub>LLAX</sub> | 10  |          | 4            |                              | 12      |                     | 5            |                              | 13      |                                  | ns    |
| T <sub>LLIV</sub> |     | 70       |              | 45                           |         | 78                  |              | 65                           |         | 98                               | ns    |
| T <sub>LLPL</sub> | 15  |          | 9            |                              | 17      |                     | 10           |                              | 18      |                                  | ns    |
| T <sub>PLPH</sub> | 55  |          | 35           |                              | 60      |                     | 50           |                              | 75      |                                  | ns    |
| T <sub>PLIV</sub> |     | 35       |              | 25                           |         | 50                  |              | 30                           |         | 55                               | ns    |
| T <sub>PXIX</sub> | 0   |          | 0            |                              | 0       |                     | 0            |                              | 0       |                                  | ns    |
| T <sub>PXIZ</sub> |     | 18       |              | 12                           |         | 20                  |              | 10                           |         | 18                               | ns    |
| T <sub>AVIV</sub> |     | 85       |              | 53                           |         | 95                  |              | 80                           |         | 122                              | ns    |
| T <sub>PLAZ</sub> |     | 10       |              | 10                           |         | 10                  |              | 10                           |         | 10                               | ns    |



### **10.5.4. External Data Memory Characteristics**

| Parameter                                     |
|-----------------------------------------------|
| RD Pulse Width                                |
| WR Pulse Width                                |
| RD to Valid Data In                           |
| Data Hold After RD                            |
| Data Float After RD                           |
| ALE to Valid Data In                          |
| Address to Valid Data In                      |
| ALE to $\overline{WR}$ or $\overline{RD}$     |
| Address to $\overline{WR}$ or $\overline{RD}$ |
| Data Valid to $\overline{WR}$ Transition      |
| Data set-up to WR High                        |
| Data Hold After $\overline{WR}$               |
| RD Low to Address Float                       |
| RD or WR High to ALE high                     |
|                                               |

### Table 39. Symbol Description



| Symbol            | Туре | Standard<br>Clock | X2 Clock  | -M | -V | -L | Units |
|-------------------|------|-------------------|-----------|----|----|----|-------|
| T <sub>RLRH</sub> | Min  | 6 T - x           | 3 T - x   | 20 | 15 | 25 | ns    |
| T <sub>WLWH</sub> | Min  | 6 T - x           | 3 T - x   | 20 | 15 | 25 | ns    |
| T <sub>RLDV</sub> | Max  | 5 T - x           | 2.5 T - x | 25 | 23 | 30 | ns    |
| T <sub>RHDX</sub> | Min  | x                 | х         | 0  | 0  | 0  | ns    |
| T <sub>RHDZ</sub> | Max  | 2 T - x           | T - x     | 20 | 15 | 25 | ns    |
| T <sub>LLDV</sub> | Max  | 8 T - x           | 4T -x     | 40 | 35 | 45 | ns    |
| T <sub>AVDV</sub> | Max  | 9 T - x           | 4.5 T - x | 60 | 50 | 65 | ns    |
| T <sub>LLWL</sub> | Min  | 3 T - x           | 1.5 T - x | 25 | 20 | 30 | ns    |
| T <sub>LLWL</sub> | Max  | 3 T + x           | 1.5 T + x | 25 | 20 | 30 | ns    |
| T <sub>AVWL</sub> | Min  | 4 T - x           | 2 T - x   | 25 | 20 | 30 | ns    |
| T <sub>QVWX</sub> | Min  | T - x             | 0.5 T - x | 15 | 10 | 20 | ns    |
| T <sub>QVWH</sub> | Min  | 7 T - x           | 3.5 T - x | 15 | 10 | 20 | ns    |
| T <sub>WHQX</sub> | Min  | T - x             | 0.5 T - x | 10 | 8  | 15 | ns    |
| T <sub>RLAZ</sub> | Max  | x                 | х         | 0  | 0  | 0  | ns    |
| T <sub>WHLH</sub> | Min  | T - x             | 0.5 T - x | 15 | 10 | 20 | ns    |
| T <sub>WHLH</sub> | Max  | T + x             | 0.5 T + x | 15 | 10 | 20 | ns    |

| Table 41. AC | Parameters | for a | Variable | Clock: | derating formula |
|--------------|------------|-------|----------|--------|------------------|
|--------------|------------|-------|----------|--------|------------------|

## 10.5.5. External Data Memory Write Cycle



Figure 26. External Data Memory Write Cycle



### 10.5.6. External Data Memory Read Cycle



Figure 27. External Data Memory Read Cycle

### 10.5.7. Serial Port Timing - Shift Register Mode

### Table 42. 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 43. AC Parameters for a Fix Clock

| Speed             |     | M<br>/IHz | X2 n<br>30 N | V<br>node<br>⁄IHz<br>z equiv. | standar | V<br>rd mode<br>⁄IHz | X2 n<br>20 N | L<br>node<br>⁄IHz<br>z equiv. | standar | L<br>rd mode<br>⁄IHz | Units |
|-------------------|-----|-----------|--------------|-------------------------------|---------|----------------------|--------------|-------------------------------|---------|----------------------|-------|
| Symbol            | Min | Max       | Min          | Max                           | Min     | Max                  | Min          | Max                           | Min     | Max                  |       |
| T <sub>XLXL</sub> | 300 |           | 200          |                               | 300     |                      | 300          |                               | 400     |                      | ns    |
| T <sub>QVHX</sub> | 200 |           | 117          |                               | 200     |                      | 200          |                               | 283     |                      | ns    |
| T <sub>XHQX</sub> | 30  |           | 13           |                               | 30      |                      | 30           |                               | 47      |                      | ns    |
| T <sub>XHDX</sub> | 0   |           | 0            |                               | 0       |                      | 0            |                               | 0       |                      | ns    |
| T <sub>XHDV</sub> |     | 117       |              | 34                            |         | 117                  |              | 117                           |         | 200                  | ns    |



| Symbol            | Туре | Standard<br>Clock | X2 Clock | -М  | -V  | -L  | Units |
|-------------------|------|-------------------|----------|-----|-----|-----|-------|
| T <sub>XLXL</sub> | Min  | 12 T              | 6 T      |     |     |     | ns    |
| T <sub>QVHX</sub> | Min  | 10 T - x          | 5 T - x  | 50  | 50  | 50  | ns    |
| T <sub>XHQX</sub> | Min  | 2 T - x           | T - x    | 20  | 20  | 20  | ns    |
| T <sub>XHDX</sub> | Min  | х                 | х        | 0   | 0   | 0   | ns    |
| T <sub>XHDV</sub> | Max  | 10 T - x          | 5 T- x   | 133 | 133 | 133 | ns    |

| Table 44. AC Parameters | s for a | Variable | Clock: | derating formula |
|-------------------------|---------|----------|--------|------------------|
|-------------------------|---------|----------|--------|------------------|

## 10.5.8. Shift Register Timing Waveforms



Figure 28. Shift Register Timing Waveforms



For timing purposes a port pin is no longer floating when a 100 mV change from load voltage occurs and begins to float when a 100 mV change from the loaded  $V_{OH}/V_{OL}$  level occurs.  $I_{OL}/I_{OH} \ge \pm 20$ mA.

### 10.5.15. Clock Waveforms

Valid in normal clock mode. In X2 mode XTAL2 signal must be changed to XTAL2 divided by two.



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.