



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                      | 40/20MHz                                                                 |
| Connectivity               | UART/USART                                                               |
| Peripherals                | POR, PWM, WDT                                                            |
| Number of I/O              | 32                                                                       |
| Program Memory Size        | 32KB (32K x 8)                                                           |
| Program Memory Type        | ОТР                                                                      |
| EEPROM Size                | -                                                                        |
| RAM Size                   | 512 x 8                                                                  |
| Voltage - Supply (Vcc/Vdd) | 4.5V ~ 5.5V                                                              |
| Data Converters            | -                                                                        |
| Oscillator Type            | Internal                                                                 |
| Operating Temperature      | -40°C ~ 85°C (TA)                                                        |
| Mounting Type              | Surface Mount                                                            |
| Package / Case             | 44-QFP                                                                   |
| Supplier Device Package    | 44-VQFP                                                                  |
| Purchase URL               | https://www.e-xfl.com/product-detail/microchip-technology/ts87c51rc2-mie |

Email: info@E-XFL.COM

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



| PDIL40<br>PLCC44<br>VQFP44 1.4 | ROM (bytes) | EPROM (bytes) | XRAM (bytes) | TOTAL RAM<br>(bytes) | I/O |
|--------------------------------|-------------|---------------|--------------|----------------------|-----|
| TS80C51RA2                     | 0           | 0             | 256          | 512                  | 32  |
| TS80C51RD2                     | 0           | 0             | 768          | 1024                 | 32  |
| TS83C51RB2                     | 16k         | 0             | 256          | 512                  | 32  |
| TS83C51RC2                     | 32k         | 0             | 256          | 512                  | 32  |
| TS83C51RD2                     | 64k         | 0             | 768          | 1024                 | 32  |
| TS87C51RB2                     | 0           | 16k           | 256          | 512                  | 32  |
| TS87C51RC2                     | 0           | 32k           | 256          | 512                  | 32  |
| TS87C51RD2                     | 0           | 64k           | 768          | 1024                 | 32  |

| PLCC68<br>VQFP64 1.4 | ROM (bytes) | EPROM (bytes) | XRAM (bytes) | TOTAL RAM<br>(bytes) | I/O |
|----------------------|-------------|---------------|--------------|----------------------|-----|
| TS80C51RD2           | 0           | 0             | 768          | 1024                 | 48  |
| TS83C51RD2           | 64k         | 0             | 768          | 1024                 | 48  |
| TS87C51RD2           | 0           | 64k           | 768          | 1024                 | 48  |

# 3. Block Diagram





### ASSEMBLY LANGUAGE

; Block move using dual data pointers ; Destroys DPTR0, DPTR1, A and PSW ; note: DPS exits opposite of entry state ; unless an extra INC AUXR1 is added

| 00A2                                         | AUXR1 EQU 0A2H                                  |                                                                    |
|----------------------------------------------|-------------------------------------------------|--------------------------------------------------------------------|
| ;<br>0000 909000<br>0003 05A2<br>0005 004000 | MOV DPTR,#SOURCE<br>INC AUXR1<br>MOV DPTR #DEST | ; address of SOURCE<br>; switch data pointers<br>; address of DEST |
| 0003 90A000<br>0008<br>0008 05A2             | LOOP:<br>INC AUXR1                              | ; switch data pointers                                             |
| 000A E0                                      | MOVX A, @DPTR                                   | ; get a byte from SOURCE                                           |
| 000B A3                                      | INC DPTR                                        | ; increment SOURCE address                                         |
| 000C 05A2                                    | INC AUXRI                                       | ; switch data pointers                                             |
| 000E F0                                      | MOVX @DPTR,A                                    | ; write the byte to DEST                                           |
| 000F A3                                      | INC DPTR                                        | : increment DEST address                                           |
| 0010 70F6                                    | JNZ LOOP                                        | ; check for 0 terminator                                           |
| 0012 05A2                                    | INC AUXR1                                       | ; (optional) restore DPS                                           |

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



### 6.4. Timer 2

The timer 2 in the TS80C51RX2 is compatible with the timer 2 in the 80C52.

It is a 16-bit timer/counter: the count is maintained by two eight-bit timer registers, TH2 and TL2, connected in cascade. It is controlled by T2CON register (See Table 6) and T2MOD register (See Table 7). 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 be incremented 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/\overline{RL2}$  (T2CON), as described in the Atmel Wireless & Microcontrollers 8-bit Microcontroller Hardware description.

Refer to the Atmel Wireless & Microcontrollers 8-bit Microcontroller Hardware description for the description of Capture and Baud Rate Generator Modes.

In TS80C51RX2 Timer 2 includes the following enhancements:

- Auto-reload mode with up or down counter
- Programmable clock-output

#### 6.4.1. Auto-Reload Mode

The auto-reload mode configures timer 2 as a 16-bit timer or event counter with automatic reload. If DCEN bit in T2MOD is cleared, timer 2 behaves as in 80C52 (refer to the Atmel Wireless & Microcontrollers 8-bit Microcontroller Hardware description). If DCEN bit is set, timer 2 acts as an Up/down timer/counter as shown in Figure 5. In this mode the T2EX pin controls the 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.



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$ 



#### Table 6. 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 Number | Bit<br>Mnemonic |                                                                                          |                                                                                                                                                                                                                                                                                                                    | Descrip                                                          | tion                                                   |                                         |                 |  |
| 7          | TF2             | Timer 2 overflow Fla<br>Must be cleared<br>Set by hardware                               | Fimer 2 overflow Flag<br>Must be cleared by software.<br>Set by hardware on timer 2 overflow, if RCLK = 0 and TCLK = 0.                                                                                                                                                                                            |                                                                  |                                                        |                                         |                 |  |
| 6          | EXF2            | Timer 2 External Fl<br>Set when a captu<br>When set, causes<br>Must be cleared           | Fimer 2 External Flag Set when a capture or a reload is caused by a negative transition on T2EX pin if EXEN2=1. When set, causes the CPU to vector to timer 2 interrupt routine when timer 2 interrupt is enabled. Must be cleared by software. EXF2 doesn't cause an interrupt in Up/down counter mode (DCEN = 1) |                                                                  |                                                        |                                         |                 |  |
| 5          | RCLK            | Receive Clock bit<br>Clear to use time<br>Set to use timer 2                             | r 1 overflow as rec<br>2 overflow as recei                                                                                                                                                                                                                                                                         | eive clock for seria                                             | al port in mode 1 or<br>port in mode 1 or              | or 3.<br>3.                             |                 |  |
| 4          | TCLK            | Transmit Clock bit<br>Clear to use time<br>Set to use timer 2                            | Transmit Clock bit<br>Clear to use timer 1 overflow as transmit clock for serial port in mode 1 or 3.<br>Set to use timer 2 overflow as transmit clock for serial port in mode 1 or 3.                                                                                                                             |                                                                  |                                                        |                                         |                 |  |
| 3          | EXEN2           | Timer 2 External En<br>Clear to ignore e<br>Set to cause a caj<br>clock the serial port. | <b>Timer 2 External Enable bit</b><br>Clear 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 detected, if timer 2 is not used to lock the serial port.                                                                            |                                                                  |                                                        |                                         |                 |  |
| 2          | TR2             | Timer 2 Run contro<br>Clear to turn off<br>Set to turn on tim                            | l <b>bit</b><br>timer 2.<br>ter 2.                                                                                                                                                                                                                                                                                 |                                                                  |                                                        |                                         |                 |  |
| 1          | C/T2#           | Timer/Counter 2 sel<br>Clear for timer of<br>Set for counter of                          | Timer/Counter 2 select bit<br>Clear for timer operation (input from internal clock system: F <sub>OSC</sub> ).<br>Set for counter operation (input from T2 input pin, falling edge trigger). Must be 0 for clock out mode.                                                                                         |                                                                  |                                                        |                                         |                 |  |
| 0          | CP/RL2#         | Timer 2 Capture/Re<br>If RCLK=1 or To<br>Clear to auto-relo<br>Set to capture on         | load bit<br>CLK=1, CP/RL2#<br>ad on timer 2 ove<br>negative transition                                                                                                                                                                                                                                             | is ignored and time<br>rflows or negative<br>ns on T2EX pin if ! | er is forced to auto<br>transitions on T2E<br>EXEN2=1. | o-reload on timer 2<br>X pin if EXEN2=1 | overflow.<br>l. |  |

Reset Value = 0000 0000b Bit addressable



#### Table 7. T2MOD Register

T2MOD - Timer 2 Mode Control Register (C9h)

|   |   |   | , |   |   |      |      |
|---|---|---|---|---|---|------|------|
| 7 | 6 | 5 | 4 | 3 | 2 | 1    | 0    |
|   |   |   |   |   |   |      |      |
| - | - | - | - | - | - | T2OE | DCEN |

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

Reset Value = XXXX XX00b Not bit addressable



#### 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 | 1111 1100b |
| 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                |
|      | 0101<br>1111<br>1111 |

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.7. Interrupt System

The TS80C51Rx2 has a total of 7 interrupt vectors: two external interrupts ( $\overline{INT0}$  and  $\overline{INT1}$ ), three timer interrupts (timers 0, 1 and 2), the serial port interrupt and the PCA global interrupt. These interrupts are shown in Figure 16.

WARNING: Note that in the first version of RC devices, the PCA interrupt is in the lowest priority. Thus the order in INTO, TF0, INT1, TF1, RI or TI, TF2 or EXF2, PCA.



#### Figure 16. Interrupt Control System

Each of the interrupt sources can be individually enabled or disabled by setting or clearing a bit in the Interrupt Enable register (See Table 19.). This register also contains a global disable bit, which must be cleared to disable all interrupts at once.

Each interrupt source can also be individually programmed to one out of four priority levels by setting or clearing a bit in the Interrupt Priority register (See Table 20.) and in the Interrupt Priority High register (See Table 21.). shows the bit values and priority levels associated with each combination.

The PCA interrupt vector is located at address 0033H. All other vector addresses are the same as standard C52 devices.



#### Table 20. IP Register

#### **IP - Interrupt Priority Register (B8h)**

| 7 | 6   | 5   | 4  | 3   | 2   | 1   | 0   |
|---|-----|-----|----|-----|-----|-----|-----|
| - | PPC | PT2 | PS | PT1 | PX1 | PT0 | PX0 |

| Dit Numbor   | Bit      | Description                                                                            |
|--------------|----------|----------------------------------------------------------------------------------------|
| bit Nulliber | Mnemonic | Description                                                                            |
| 7            | -        | <b>Reserved</b><br>The value read from this bit is indeterminate. Do not set this bit. |
| 6            | PPC      | PCA interrupt priority bit<br>Refer to PPCH for priority level.                        |
| 5            | PT2      | Timer 2 overflow interrupt Priority bit<br>Refer to PT2H for priority level.           |
| 4            | PS       | Serial port Priority bit<br>Refer to PSH for priority level.                           |
| 3            | PT1      | Timer 1 overflow interrupt Priority bit<br>Refer to PT1H for priority level.           |
| 2            | PX1      | External interrupt 1 Priority bit<br>Refer to PX1H for priority level.                 |
| 1            | PT0      | Timer 0 overflow interrupt Priority bit<br>Refer to PT0H for priority level.           |
| 0            | PX0      | External interrupt 0 Priority bit<br>Refer to PX0H for priority level.                 |

Reset Value = X000 0000b Bit addressable



# 6.11. ONCE<sup>TM</sup> Mode (ON Chip Emulation)

The ONCE mode facilitates testing and debugging of systems using TS80C51Rx2 without removing the circuit from the board. The ONCE mode is invoked by driving certain pins of the TS80C51Rx2; the following sequence must be exercised:

- Pull ALE low while the device is in reset (RST high) and  $\overline{\text{PSEN}}$  is high.
- Hold ALE low as RST is deactivated.

While the TS80C51Rx2 is in ONCE mode, an emulator or test CPU can be used to drive the circuit Table 26. shows the status of the port pins during ONCE mode.

Normal operation is restored when normal reset is applied.

#### Table 25. External Pin Status during ONCE Mode

| ALE          | PSEN         | Port 0 | Port 1       | Port 2       | Port 3       | XTAL1/2 |
|--------------|--------------|--------|--------------|--------------|--------------|---------|
| Weak pull-up | Weak pull-up | Float  | Weak pull-up | Weak pull-up | Weak pull-up | Active  |



# 7. TS83C51RB2/RC2/RD2 ROM

### 7.1. ROM Structure

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

| • | the code array:       | es. |
|---|-----------------------|-----|
| • | the encryption array: | s.  |
| • | the signature array:  | es. |

### 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 |
|-------|-----|---------|------|------|
|-------|-----|---------|------|------|

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. TS87C51RB2/RC2/RD2 EPROM

### 8.1. EPROM Structure

The TS87C51RB2/RC2/RD2 EPROM is divided in two different arrays:

| •  | the code array:                                         |
|----|---------------------------------------------------------|
| •  | the encryption array:                                   |
| In | addition a third non programmable array is implemented: |
| •  | the signature array:                                    |

### 8.2. EPROM Lock System

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

### 8.2.1. Encryption Array

Within the EPROM 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.

#### 8.2.2. Program Lock Bits

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

| Program Lock Bits |     |     |     | Protection description                                                                                                                                                                                                |  |  |  |  |
|-------------------|-----|-----|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| Security level    | LB1 | LB2 | LB3 |                                                                                                                                                                                                                       |  |  |  |  |
| 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, and further programming of the EPROM is disabled. |  |  |  |  |
| 3                 | U   | Р   | U   | Same as 2, also verify is disabled.                                                                                                                                                                                   |  |  |  |  |
| 4                 | U   | U   | Р   | Same as 3, also external execution is disabled.                                                                                                                                                                       |  |  |  |  |

| Table 29 | . Program | Lock | bits |
|----------|-----------|------|------|
|----------|-----------|------|------|

U: unprogrammed,

P: programmed

WARNING: Security level 2 and 3 should only be programmed after EPROM and Core verification.

### 8.2.3. Signature bytes

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





\* 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.





All other pins are disconnected.





All other pins are disconnected.

Figure 22. I<sub>CC</sub> Test Condition, Idle Mode



Figure 23. I<sub>CC</sub> Test Condition, Power-Down Mode



Figure 24. Clock Signal Waveform for  $I_{\mbox{\scriptsize CC}}$  Tests in Active and Idle Modes



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

| Table 36. Symbol Description | Table 3 | 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>40 MHz |     | -M -V<br>40 MHz X2 m<br>30 M<br>60 MHz |     | -V<br>standard mode<br>40 MHz<br>v. |     | -L<br>X2 mode<br>20 MHz<br>40 MHz equiv. |     | -L<br>ode standard mode<br>Hz 30 MHz<br>equiv. |     | 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**

|                   | Table 57. Symbol Description                  |
|-------------------|-----------------------------------------------|
| Symbol            | Parameter                                     |
| T <sub>RLRH</sub> | RD Pulse Width                                |
| T <sub>WLWH</sub> | WR Pulse Width                                |
| T <sub>RLDV</sub> | RD to Valid Data In                           |
| T <sub>RHDX</sub> | Data Hold After RD                            |
| T <sub>RHDZ</sub> | Data Float After RD                           |
| T <sub>LLDV</sub> | ALE to Valid Data In                          |
| T <sub>AVDV</sub> | Address to Valid Data In                      |
| T <sub>LLWL</sub> | ALE to WR or RD                               |
| T <sub>AVWL</sub> | Address to $\overline{WR}$ or $\overline{RD}$ |
| T <sub>QVWX</sub> | Data Valid to $\overline{WR}$ Transition      |
| T <sub>QVWH</sub> | Data set-up to WR High                        |
| T <sub>WHQX</sub> | Data Hold After WR                            |
| T <sub>RLAZ</sub> | RD Low to Address Float                       |
| T <sub>WHLH</sub> | 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                 | 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 | <b>Clock:</b> | derating | formula |
|-------------------------|-----|---|----------|---------------|----------|---------|
|-------------------------|-----|---|----------|---------------|----------|---------|

### 10.5.5. External Data Memory Write Cycle



Figure 26. External Data Memory Write Cycle



| 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  | X                 | Х        | 0   | 0   | 0   | ns    |
| T <sub>XHDV</sub> | Max  | 10 T - x          | 5 T- x   | 133 | 133 | 133 | ns    |

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

### 10.5.8. Shift Register Timing Waveforms



Figure 28. Shift Register Timing Waveforms



#### **10.5.9. EPROM Programming and Verification Characteristics**

TA = 21°C to 27°C;  $V_{SS} = 0V$ ;  $V_{CC} = 5V \pm 10\%$  while programming.  $V_{CC}$  = operating range while verifying

| Symbol              | Parameter                         | Min                  | Max                  | Units |
|---------------------|-----------------------------------|----------------------|----------------------|-------|
| V <sub>PP</sub>     | Programming Supply Voltage        | 12.5                 | 13                   | V     |
| I <sub>PP</sub>     | Programming Supply Current        |                      | 75                   | mA    |
| 1/T <sub>CLCL</sub> | Oscillator Frquency               | 4                    | 6                    | MHz   |
| T <sub>AVGL</sub>   | Address Setup to PROG Low         | 48 T <sub>CLCL</sub> |                      |       |
| T <sub>GHAX</sub>   | Adress Hold after PROG            | 48 T <sub>CLCL</sub> |                      |       |
| T <sub>DVGL</sub>   | Data Setup to PROG Low            | 48 T <sub>CLCL</sub> |                      |       |
| T <sub>GHDX</sub>   | Data Hold after PROG              | 48 T <sub>CLCL</sub> |                      |       |
| T <sub>EHSH</sub>   | (Enable) High to V <sub>PP</sub>  | 48 T <sub>CLCL</sub> |                      |       |
| T <sub>SHGL</sub>   | V <sub>PP</sub> Setup to PROG Low | 10                   |                      | μs    |
| T <sub>GHSL</sub>   | V <sub>PP</sub> Hold after PROG   | 10                   |                      | μs    |
| T <sub>GLGH</sub>   | PROG Width                        | 90                   | 110                  | μs    |
| T <sub>AVQV</sub>   | Address to Valid Data             |                      | 48 T <sub>CLCL</sub> |       |
| T <sub>ELQV</sub>   | ENABLE Low to Data Valid          |                      | 48 T <sub>CLCL</sub> |       |
| T <sub>EHQZ</sub>   | Data Float after ENABLE           | 0                    | 48 T <sub>CLCL</sub> |       |

#### Table 45. EPROM Programming Parameters

#### 10.5.10. EPROM Programming and Verification Waveforms



\* 8KB: up to P2.4, 16KB: up to P2.5, 32KB: up to P3.4, 64KB: up to P3.5

#### Figure 29. EPROM Programming and Verification Waveforms



## 11. Ordering Information



(\*) Check with Atmel Wireless & Microcontrollers Sales Office for availability. Ceramic packages (J, K, N) are available for proto typing, not for volume production. Ceramic packages are available for OTP only.

| Table | 47. | Maximum | Clock | Frequency |
|-------|-----|---------|-------|-----------|
|-------|-----|---------|-------|-----------|

| Code                                   | -M | -V        | -L        | Unit |
|----------------------------------------|----|-----------|-----------|------|
| Standard Mode, oscillator frequency    | 40 | 40        | 30        | MHz  |
| Standard Mode, internal frequency      | 40 | 40        | 30        |      |
| X2 Mode, oscillator frequency          | 20 | 30        | 20        | MHz  |
| X2 Mode, internal equivalent frequency | 40 | <b>60</b> | <b>40</b> |      |