



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

| Details                    |                                                                         |
|----------------------------|-------------------------------------------------------------------------|
| Product Status             | Obsolete                                                                |
| Core Processor             | 80C51                                                                   |
| Core Size                  | 8-Bit                                                                   |
| Speed                      | 30/20MHz                                                                |
| Connectivity               | UART/USART                                                              |
| Peripherals                | POR                                                                     |
| Number of I/O              | 32                                                                      |
| Program Memory Size        | -                                                                       |
| Program Memory Type        | ROMIess                                                                 |
| EEPROM Size                | -                                                                       |
| RAM Size                   | 256 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             | 44-LCC (J-Lead)                                                         |
| Supplier Device Package    | 44-PLCC (16.6x16.6)                                                     |
| Purchase URL               | https://www.e-xfl.com/product-detail/microchip-technology/ts80c32x2-lcb |
|                            |                                                                         |

Email: info@E-XFL.COM

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



#### Table 1. Memory Size

|           | ROM (bytes) | ROM (bytes) EPROM (bytes) |     |
|-----------|-------------|---------------------------|-----|
| TS80C32X2 | 0           | 0                         | 256 |
| TS80C52X2 | 8k          | 0                         | 256 |
| TS87C52X2 | 0           | 8k                        | 256 |

# **Block Diagram**



2. Alternate function of Port 3

2



#### Table 2. All SFRs with their address and their reset value

|         | Bit<br>Addressable |                    | Non Bit Addressable |                     |                  |                  |                  |                    |     |  |
|---------|--------------------|--------------------|---------------------|---------------------|------------------|------------------|------------------|--------------------|-----|--|
|         | 0/8                | 1/9                | 2/A                 | 3/B                 | 4/C              | 5/D              | 6/E              | 7/F                |     |  |
| F8h     |                    |                    |                     |                     |                  |                  |                  |                    | FFh |  |
| F0h     | B<br>0000 0000     |                    |                     |                     |                  |                  |                  |                    | F7h |  |
| E8h     |                    |                    |                     |                     |                  |                  |                  |                    | EFh |  |
| E0h     | ACC<br>0000 0000   |                    |                     |                     |                  |                  |                  |                    | E7h |  |
| D8<br>h |                    |                    |                     |                     |                  |                  |                  |                    | DFh |  |
| D0<br>h | PSW<br>0000 0000   |                    |                     |                     |                  |                  |                  |                    | D7h |  |
| C8<br>h | T2CON<br>0000 0000 | T2MOD<br>XXXX XX00 | RCAP2L<br>0000 0000 | RCAP2H<br>0000 0000 | TL2<br>0000 0000 | TH2<br>0000 0000 |                  |                    | CFh |  |
| C0<br>h |                    |                    |                     |                     |                  |                  |                  |                    | C7h |  |
| B8h     | IP<br>XX00 0000    | SADEN<br>0000 0000 |                     |                     |                  |                  |                  |                    | BFh |  |
| B0h     | P3<br>1111 1111    |                    |                     |                     |                  |                  |                  | IPH<br>XX00 0000   | B7h |  |
| A8h     | IE<br>0X00 0000    | SADDR<br>0000 0000 |                     |                     |                  |                  |                  |                    | AFh |  |
| A0h     | P2<br>1111 1111    |                    | AUXR1<br>XXXX XXX0  |                     |                  |                  |                  |                    | A7h |  |
| 98h     | SCON<br>0000 0000  | SBUF<br>XXXX XXXX  |                     |                     |                  |                  |                  |                    | 9Fh |  |
| 90h     | P1<br>1111 1111    |                    |                     |                     |                  |                  |                  |                    | 97h |  |
| 88h     | TCON<br>0000 0000  | TMOD<br>0000 0000  | TL0<br>0000 0000    | TL1<br>0000 0000    | TH0<br>0000 0000 | TH1<br>0000 0000 | AUXR<br>XXXXXXX0 | CKCON<br>XXXX XXX0 | 8Fh |  |
| 80h     | P0<br>1111 1111    | SP<br>0000 0111    | DPL<br>0000 0000    | DPH<br>0000 0000    |                  |                  |                  | PCON<br>00X1 0000  | 87h |  |
|         | 0/8                | 1/9                | 2/A                 | 3/B                 | 4/C              | 5/D              | 6/E              | 7/F                |     |  |

Reserved



| Mnemonic        | Pin Number |                  |              | Pin Number 7 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  | Pin Number Type Name and Function |  |  |  |
|-----------------|------------|------------------|--------------|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|-----------------------------------|--|--|--|
|                 | DIL        | LCC              | VQFP<br>1.4  |              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |                                   |  |  |  |
| V <sub>SS</sub> | 20         | 22               | 16           | I            | Ground: 0V reference                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |                                   |  |  |  |
| Vss1            |            | 1                | 39           | I            | Optional Ground: Contact the Sales Office for ground connection.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |                                   |  |  |  |
| V <sub>CC</sub> | 40         | 44               | 38           | I            | <b>Power Supply:</b> This is the power supply voltage for normal, idle and power-down operation                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |                                   |  |  |  |
| P0.0-P0.7       | 39-<br>32  | 43-<br>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.<br>Port 0 is also the multiplexed low-order address and data bus<br>during access to external program and data memory. In this<br>application, it uses strong internal pull-up when emitting 1s.<br>Port 0 also inputs the code bytes during EPROM<br>programming. External pull-ups are required during program<br>verification during which P0 outputs the code bytes.                                                                                                                                                                                |  |                                   |  |  |  |
| P1.0-P1.7       | 1-8        | 2-9              | 40-44<br>1-3 | I/O          | Port 1: 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<br>current because of the internal pull-ups. Port 1 also receives<br>the low-order address byte during memory programming and<br>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           | I            | <b>T2EX (P1.1):</b> Timer/Counter 2 Reload/Capture/Direction Control                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |                                   |  |  |  |
| P2.0-P2.7       | 21-<br>28  | 24-<br>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<br>current because of the internal pull-ups. Port 2 emits the high-<br>order address byte during fetches from external program<br>memory and during accesses to external data memory that<br>use 16-bit addresses (MOVX atDPTR). In this application, it<br>uses strong internal pull-ups emitting 1s. During accesses to<br>external data memory that use 8-bit addresses (MOVX atRi),<br>port 2 emits the contents of the P2 SFR. Some Port 2 pins<br>receive the high order address bits during EPROM<br>programming and verification: P2.0 to P2.4 |  |                                   |  |  |  |
| P3.0-P3.7       | 10-<br>17  | 11,<br>13-<br>19 | 5,<br>7-13   | I/O          | Port 3: Port 3 is an 8-bit bidirectional I/O port with internal pull-ups. Port 3 pins that have 1s written to them are pulled high by the internal pull-ups and can be used as inputs. As inputs, Port 3 pins that are externally pulled low will source                                                                                                                                                                                                                                                                                                                                                              |  |                                   |  |  |  |
|                 |            |                  |              |              | current because of the internal pull-ups. Port 3 also serves<br>the special features of the 80C51 family, as listed below.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |                                   |  |  |  |
|                 | 10         | 11               | 5            | I            | RXD (P3.0): Serial input port                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |                                   |  |  |  |
|                 | 11         | 13               | 7            | 0            | TXD (P3.1): Serial output port                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |                                   |  |  |  |
|                 | 12         | 14               | 8            | Ι            | INT0 (P3.2): External interrupt 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |                                   |  |  |  |

TS8xCx2X2

6

## Application

Software can take advantage of the additional data pointers to both increase speed and reduce code size, for example, block operations (copy, compare, search ...) are well served by using one data pointer as a 'source' pointer and the other one as a "destination" pointer.

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 0000 909000MOV DPTR,#SOURCE ; address of SOURCE 0003 05A2 INC AUXR1 ; switch data pointers 0005 90A000 MOV DPTR,#DEST ; address of DEST 0008 LOOP: 0008 05A2 INC AUXR1 ; switch data pointers 000A E0 MOVX A, atDPTR ; get a byte from SOURCE 000B A3 INC DPTR ; increment SOURCE address 000C 05A2 INC AUXR1 ; switch data pointers 000E F0 MOVX atDPTR, A ; write the byte to DEST 000F A3 INC DPTR ; increment DEST address 0010 70F6JNZ LOOP ; check for 0 terminator 0012 05A2 INC AUXR1 ; (optional) restore DPS

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



| Timer 2          | The timer 2 in the TS80C52X2 is compatible with the timer 2 in the 80C52.<br>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 5) and T2MOD register (See Table 6). 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 <u>Generator</u> . These modes are selected by the combination of RCLK, TCLK and CP/RL2 (T2CON), as described in the Atmel 8-bit Microcontroller Hardware description.                                                                                                                                                                                                                                                                                      |
|                  | Refer to the Atmel 8-bit Microcontroller Hardware description for the description of Cap-<br>ture and Baud Rate Generator Modes.                                                                                                                                                                                                                                                                                                                                                                                             |
|                  | In TS80C52X2 Timer 2 includes the following enhancements:                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|                  | Auto-reload mode with up or down counter                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|                  | Programmable clock-output                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| Auto-reload Mode | The Auto-reload mode configures timer 2 as a 16-bit timer or event counter with auto-<br>matic reload. If DCEN bit in T2MOD is cleared, timer 2 behaves as in 80C52 (refer to the<br>Atmel 8-bit Microcontroller Hardware description). If DCEN bit is set, timer 2 acts as an<br>Up/down timer/counter as shown in Figure 4. In this mode the T2EX pin controls the<br>direction of count.                                                                                                                                  |
|                  | When T2EX is high, timer 2 counts up. Timer overflow occurs at FFFFh which sets the TF2 flag and generates an interrupt request. The overflow also causes the 16-bit value in RCAP2H and RCAP2L registers to be loaded into the timer registers TH2 and TL2.                                                                                                                                                                                                                                                                 |
|                  | When T2EX is low, timer 2 counts down. Timer underflow occurs when the count in the timer registers TH2 and TL2 equals the value stored in RCAP2H and RCAP2L registers. The underflow sets TF2 flag and reloads FFFFh into the timer registers.                                                                                                                                                                                                                                                                              |
|                  | The EXF2 bit toggles when timer 2 overflows or underflows according to the the direc-<br>tion of the count. EXF2 does not generate any interrupt. This bit can be used to provide                                                                                                                                                                                                                                                                                                                                            |

17-bit resolution.

12 **TS8xCx2X2** 

| Table 5 | T2CON | Register |
|---------|-------|----------|
|---------|-------|----------|

T2CON - Timer 2 Control Register (C8h)

| 7             | 6               | 5                                                                                | 4                                                                                                                                                                                                                                                                                                                                    | 3                                | 2              | 1        | 0       |  |  |
|---------------|-----------------|----------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------|----------------|----------|---------|--|--|
| TF2           | EXF2            | RCLK                                                                             | TCLK                                                                                                                                                                                                                                                                                                                                 | EXEN2                            | TR2            | C/T2#    | CP/RL2# |  |  |
| Bit<br>Number | Bit<br>Mnemonic | Description                                                                      |                                                                                                                                                                                                                                                                                                                                      |                                  |                |          |         |  |  |
| 7             | TF2             | Timer 2 overf<br>Must be cleare<br>Set by hardwa                                 | d by software                                                                                                                                                                                                                                                                                                                        |                                  | CLK = 0 and T  | CLK = 0. |         |  |  |
| 6             | EXF2            | Set when a ca<br>EXEN2=1.<br>When set, cau<br>interrupt is ena<br>Must be cleare | Timer 2 External Flag<br>Set when a capture or a reload is caused by a negative transition on T2EX pin if<br>EXEN2=1.<br>When set, causes the CPU to vector to timer 2 interrupt routine when timer 2<br>interrupt is enabled.<br>Must be cleared by software. EXF2 doesn't cause an interrupt in Up/down counter<br>mode (DCEN = 1) |                                  |                |          |         |  |  |
| 5             | RCLK            | Receive Clock<br>Clear to use time<br>Set to use time                            | mer 1 overflov                                                                                                                                                                                                                                                                                                                       |                                  |                | •        |         |  |  |
| 4             | TCLK            | Transmit Cloc<br>Clear to use tin<br>Set to use time                             | mer 1 overflov                                                                                                                                                                                                                                                                                                                       |                                  |                | •        |         |  |  |
| 3             | EXEN2           | Timer 2 Exter<br>Clear to ignore<br>Set to cause a<br>detected, if tim           | e events on Ta<br>capture or re                                                                                                                                                                                                                                                                                                      | 2EX pin for tim<br>load when a n | egative transi |          | pin is  |  |  |
| 2             | TR2             | Clear to turn o                                                                  | Timer 2 Run control bit<br>Clear to turn off timer 2.<br>Set to turn on timer 2.                                                                                                                                                                                                                                                     |                                  |                |          |         |  |  |
| 1             | C/T2#           | Clear for timer<br>Set for counter                                               | <b>Timer/Counter 2 select bit</b><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<br>for clock out mode.                                                                                                 |                                  |                |          |         |  |  |
| 0             | CP/RL2#         | If RCLK=1 or 7<br>timer 2 overflo<br>Clear to Auto-r<br>EXEN2=1.                 | Timer 2 Capture/Reload bit<br>If RCLK=1 or TCLK=1, CP/RL2# is ignored and timer is forced to Auto-reload on<br>timer 2 overflow.<br>Clear to Auto-reload on timer 2 overflows or negative transitions on T2EX pin if                                                                                                                 |                                  |                |          |         |  |  |

Reset Value = 0000 0000b Bit addressable







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.

18 **TS8xCx2X2** 

**Table 10.** PCON RegisterPCON - Power Control Register (87h)

| 7             | 6               | 5                                                                                             | 4                                                                                                            | 3                                | 2               | 1              | 0             |  |
|---------------|-----------------|-----------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------|----------------------------------|-----------------|----------------|---------------|--|
| SMOD1         | SMOD0           | -                                                                                             | POF                                                                                                          | GF1                              | GF0             | PD             | IDL           |  |
| Bit<br>Number | Bit<br>Mnemonic | Descriptio                                                                                    | n                                                                                                            |                                  |                 |                |               |  |
| 7             | SMOD1           |                                                                                               | t <b>Mode bit 1</b><br>ect double bau                                                                        | ud rate in mode                  | e 1, 2 or 3.    |                |               |  |
| 6             | SMOD0           | Clear to se                                                                                   |                                                                                                              | n SCON regist<br>SCON registe    |                 |                |               |  |
| 5             | -               | Reserved<br>The value                                                                         | read from this                                                                                               | bit is indeterm                  | ninate. Do not  | set this bit.  |               |  |
| 4             | POF             |                                                                                               | cognize next i<br>dware when V                                                                               | reset type.<br>/CC rises from    | 0 to its nomina | al voltage. Ca | n also be set |  |
| 3             | GF1             | Cleared by                                                                                    |                                                                                                              | eral purpose us<br>purpose usage |                 |                |               |  |
| 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             | Idle mode bit<br>Clear by hardware when interrupt or reset occurs.<br>Set to enter idle mode. |                                                                                                              |                                  |                 |                |               |  |

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.





### **Interrupt System**

The TS80C52X2 has a total of 6 interrupt vectors: two external interrupts (INT0 and INT1), three timer interrupts (timers 0, 1 and 2) and the serial port interrupt. These interrupts are shown in Figure 9.

#### Figure 9. 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 12.). 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 13.) and in the Interrupt Priority High register (See Table 14.). shows the bit values and priority levels associated with each combination.

| Table 11. | Priority | Level Bit | Values |
|-----------|----------|-----------|--------|
|           |          |           |        |
|           |          |           |        |

| IPH.x | IP.x | Interrupt Level Priority |
|-------|------|--------------------------|
| 0     | 0    | 0 (Lowest)               |
| 0     | 1    | 1                        |
| 1     | 0    | 2                        |
| 1     | 1    | 3 (Highest)              |

A low-priority interrupt can be interrupted by a high priority interrupt, but not by another low-priority interrupt. A high-priority interrupt can't be interrupted by any other interrupt source.

If two interrupt requests of different priority levels are received simultaneously, the request of higher priority level is serviced. If interrupt requests of the same priority level



**Table 13.** IP RegisterIP - Interrupt Priority Register (B8h)

| 7             | 6               | 5                     | 4                                                                            | 3                                 | 2              | 1             | 0   |
|---------------|-----------------|-----------------------|------------------------------------------------------------------------------|-----------------------------------|----------------|---------------|-----|
| -             | -               | PT2                   | PS                                                                           | PT1                               | PX1            | PT0           | PX0 |
| Bit<br>Number | Bit<br>Mnemonic | Descriptio            | n                                                                            |                                   |                |               |     |
| 7             | -               | Reserved<br>The value | read from this                                                               | bit is indetern                   | ninate. Do not | set this bit. |     |
| 6             | -               | Reserved<br>The value | read from this                                                               | bit is indetern                   | ninate. Do not | set this bit. |     |
| 5             | PT2             |                       | erflow interr<br>2H for priority                                             | <b>upt Priority b</b><br>y level. | it             |               |     |
| 4             | PS              |                       | t <b>Priority bit</b><br>SH for priority                                     | level.                            |                |               |     |
| 3             | PT1             |                       | erflow interr                                                                | <b>upt Priority b</b><br>y level. | it             |               |     |
| 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             |                       | nterrupt 0 Pri                                                               |                                   |                |               |     |

Reset Value = XX00 0000b Bit addressable

# Table 14.IPH RegisterIPH - Interrupt Priority High Register (B7h)

| 7             | 6               | 5                                                                                                                                | 4                                                                  | 3                       | 2              | 1           | 0    |
|---------------|-----------------|----------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------|-------------------------|----------------|-------------|------|
| -             | -               | PT2H                                                                                                                             | PSH                                                                | PT1H                    | PX1H           | РТОН        | РХОН |
| Bit<br>Number | Bit<br>Mnemonic | Description                                                                                                                      |                                                                    |                         |                |             |      |
| 7             | -               | <b>Reserved</b><br>The value rea                                                                                                 | d from this bit                                                    | is indetermina          | ate. Do not se | t this bit. |      |
| 6             | -               | <b>Reserved</b><br>The value rea                                                                                                 | d from this bit                                                    | is indetermina          | ate. Do not se | t this bit. |      |
| 5             | PT2H            | Timer 2 over           PT2H         PT2           0         0           1         0           1         1                        | f <b>low interrup</b><br><u>Priority Leve</u><br>Lowest<br>Highest | t Priority High<br>한    | n bit          |             |      |
| 4             | PSH             | Serial port P           PSH         PS           0         0           0         1           1         0           1         1   | riority High b<br><u>Priority Leve</u><br>Lowest<br>Highest        |                         |                |             |      |
| 3             | PT1H            | Timer 1 over           PT1H         PT1           0         0           0         1           1         0           1         1  |                                                                    | t Priority High<br>키    | n bit          |             |      |
| 2             | PX1H            | External inte           PX1H         PX1           0         0           1         0           1         1           1         1 | rrupt 1 Priori<br>Priority Leve<br>Lowest<br>Highest               |                         |                |             |      |
| 1             | РТОН            | Timer 0 over           PT0H         PT0           0         0           1         0           1         1                        |                                                                    | t Priority High<br>한    | n bit          |             |      |
| 0             | РХОН            | External inte           PX0H         PX0           0         0           1         1           1         1                       | <b>rrupt 0 Priori</b><br><u>Priority Leve</u><br>Lowest<br>Highest | ty High bit<br><u>키</u> |                |             |      |

Reset Value = XX00 0000b Not bit addressable



Exit from power-down by reset redefines all the SFRs, exit from power-down by external interrupt does no affect the SFRs.

Exit from power-down by either reset or external interrupt does not affect the internal RAM content.

Note: If idle mode is activated with power-down mode (IDL and PD bits set), the exit sequence is unchanged, when execution is vectored to interrupt, PD and IDL bits are cleared and idle mode is not entered.

| Mode          | Program<br>Memory | ALE | PSEN | PORT0                       | PORT1     | PORT2     | PORT3     |
|---------------|-------------------|-----|------|-----------------------------|-----------|-----------|-----------|
| Idle          | Internal          | 1   | 1    | Port<br>Data <sup>(1)</sup> | Port Data | Port Data | Port Data |
| Idle          | External          | 1   | 1    | Floating                    | Port Data | Address   | Port Data |
| Power<br>Down | Internal          | 0   | 0    | Port<br>Data <sup>(1)</sup> | Port Data | Port Data | Port Data |
| Power<br>Down | External          | 0   | 0    | Floating                    | Port Data | Port Data | Port Data |

**Table 15.** The State of Ports During Idle and Power-down Modes

Note: 1. Port 0 can force a "zero" level. A "one" will leave port floating.





### ONCE<sup>™</sup> Mode (ON Chip Emulation)

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

- Pull ALE low while the device is in reset (RST high) and PSEN is high.
- Hold ALE low as RST is deactivated.

While the TS80C52X2 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 16. External Pin Status during ONCE Mode

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

# **Power-off Flag**

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

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

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

The POF value is only relevant with a Vcc range from 4.5V to 5.5V. For lower Vcc value, reading POF bit will return indeterminate value.

| 7             | 6               | Register<br>5           | 4                                                                                                                                                                  | 3   | 2   | 1  | 0   |  |  |  |
|---------------|-----------------|-------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|-----|----|-----|--|--|--|
| SMOD1         | SMOD0           | -                       | POF                                                                                                                                                                | GF1 | GF0 | PD | IDL |  |  |  |
| Bit<br>Number | Bit<br>Mnemonic | Descript                | Description                                                                                                                                                        |     |     |    |     |  |  |  |
| 7             | SMOD1           |                         | Serial port Mode bit 1<br>Set to select double baud rate in mode 1, 2 or 3.                                                                                        |     |     |    |     |  |  |  |
| 6             | SMOD0           | Clear to s              | Serial port Mode bit 0<br>Clear to select SM0 bit in SCON register.<br>Set to to select FE bit in SCON register.                                                   |     |     |    |     |  |  |  |
| 5             | -               |                         | Reserved<br>The value read from this bit is indeterminate. Do not set this bit.                                                                                    |     |     |    |     |  |  |  |
| 4             | POF             | Clear to r<br>Set by ha | <b>Power-off Flag</b><br>Clear to recognize next reset type.<br>Set by hardware when $V_{CC}$ rises from 0 to its nominal voltage. Can also be<br>set by software. |     |     |    |     |  |  |  |
| 3             | GF1             | Cleared b               | General purpose Flag<br>Cleared by user for general purpose usage.<br>Set by user for general purpose usage.                                                       |     |     |    |     |  |  |  |
| 2             | GF0             | Cleared b               | General purpose Flag<br>Cleared by user for general purpose usage.<br>Set by user for general purpose usage.                                                       |     |     |    |     |  |  |  |
| 1             | PD              | Cleared b               | <b>Power-down mode bit</b><br>Cleared by hardware when reset occurs.<br>Set to enter power-down mode.                                                              |     |     |    |     |  |  |  |
| 0             | IDL             | Clear by                | Ile mode bit<br>lear by hardware when interrupt or reset occurs.<br>et to enter idle mode.                                                                         |     |     |    |     |  |  |  |

 Table 17.
 PCON Register

PCON - Power Control Register (87h)

Reset Value = 00X1 0000b Not bit addressable





#### **Reduced EMI Mode**

The ALE signal is used to demultiplex address and data buses on port 0 when used with external program or data memory. Nevertheless, during internal code execution, ALE signal is still generated. In order to reduce EMI, ALE signal can be disabled by setting AO bit.

The AO bit is located in AUXR register at bit location 0. As soon as AO is set, ALE is no longer output but remains active during MOVX and MOVC instructions and external fetches. During ALE disabling, ALE pin is weakly pulled high.

#### Table 18. AUXR Register

AUXR - Auxiliary Register (8Eh)

| 7             | 6               | 5                                | 4                                                                               | 3                                  | 2              | 1            | 0  |  |  |
|---------------|-----------------|----------------------------------|---------------------------------------------------------------------------------|------------------------------------|----------------|--------------|----|--|--|
| -             | -               | -                                | -                                                                               | -                                  | -              | -            | AO |  |  |
| Bit<br>Number | Bit<br>Mnemonic | Description                      |                                                                                 |                                    |                |              |    |  |  |
| 7             | -               | Reserved<br>The value rea        | ad from this b                                                                  | it is indetermi                    | nate. Do not s | et this bit. |    |  |  |
| 6             | -               | <b>Reserved</b><br>The value rea | Reserved<br>The value read from this bit is indeterminate. Do not set this bit. |                                    |                |              |    |  |  |
| 5             | -               | <b>Reserved</b><br>The value rea | Reserved<br>The value read from this bit is indeterminate. Do not set this bit. |                                    |                |              |    |  |  |
| 4             | -               | <b>Reserved</b><br>The value rea | ad from this b                                                                  | it is indetermi                    | nate. Do not s | et this bit. |    |  |  |
| 3             | -               | Reserved<br>The value rea        | ad from this b                                                                  | it is indetermi                    | nate. Do not s | et this bit. |    |  |  |
| 2             | -               | Reserved<br>The value rea        | Reserved<br>The value read from this bit is indeterminate. Do not set this bit. |                                    |                |              |    |  |  |
| 1             | -               | Reserved<br>The value rea        | Reserved<br>The value read from this bit is indeterminate. Do not set this bit. |                                    |                |              |    |  |  |
| 0             | AO              |                                  | ore ALE operation                                                               | ation during in<br>ion during inte |                |              |    |  |  |

Reset Value = XXXX XXX0b Not bit addressable



#### 

Table 23. DC 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 (6)                        |                           |                                        | 0.45                                                 | V    | I <sub>OL</sub> = 0.8 mA <sup>(4)</sup>                                                             |
| V <sub>OL1</sub>                  | Output Low Voltage, port 0, ALE, PSEN (6)                    |                           |                                        | 0.45                                                 | V    | I <sub>OL</sub> = 1.6 mA <sup>(4)</sup>                                                             |
| V <sub>OH</sub>                   | Output High Voltage, ports 1, 2, 3                           | 0.9 V <sub>CC</sub>       |                                        |                                                      | V    | I <sub>OH</sub> = -10 μA                                                                            |
| V <sub>OH1</sub>                  | Output High Voltage, port 0, ALE, PSEN                       | 0.9 V <sub>CC</sub>       |                                        |                                                      | V    | I <sub>OH</sub> = -40 μA                                                                            |
| I <sub>IL</sub>                   | Logical 0 Input Current ports 1, 2 and 3                     |                           |                                        | -50                                                  | μA   | Vin = 0.45V                                                                                         |
| ILI                               | Input Leakage Current                                        |                           |                                        | ±10                                                  | μA   | $0.45V < Vin < V_{CC}$                                                                              |
| I <sub>TL</sub>                   | Logical 1 to 0 Transition Current, ports 1, 2, 3             |                           |                                        | -650                                                 | μA   | 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<br>T <sub>A</sub> = 25°C                                                                 |
| I <sub>PD</sub>                   | Power Down Current                                           |                           | 20 <sup>(5)</sup><br>10 <sup>(5)</sup> | 50<br>30                                             | μA   | $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>at12MHz 3.4<br>at16MHz 4.2  | mA   | $V_{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>at12MHz 4.6<br>at16MHz 5.8  | mA   | V <sub>CC</sub> = 3.3 V <sup>(8)</sup>                                                              |
| I <sub>CC</sub><br>idle           | Power Supply Current Maximum values, X1 mode: <sup>(7)</sup> |                           |                                        | 0.15 Freq<br>(MHz) + 0.2<br>at12MHz 2<br>at16MHz 2.6 | mA   | V <sub>CC</sub> = 3.3 V <sup>(2)</sup>                                                              |

Notes: 1. I<sub>CC</sub> under reset is measured with all output pins disconnected; XTAL1 driven with T<sub>CLCH</sub>, T<sub>CHCL</sub> = 5 ns (see Figure 17.), V<sub>IL</sub> = V<sub>SS</sub> + 0.5V,

 $V_{IH} = V_{CC} - 0.5V$ ; XTAL2 N.C.;  $\overline{EA} = RST = Port 0 = V_{CC}$ .  $I_{CC}$  would be slightly higher if a crystal oscillator used..

2. Idle I<sub>CC</sub> is measured with all out<u>put</u> pins disconnected; XTAL1 driven with  $T_{CLCH}$ ,  $T_{CHCL} = 5$  ns,  $V_{IL} = V_{SS} + 0.5V$ ,  $V_{IH} = V_{CC} - 0.5V$ ; XTAL2 N.C; Port 0 =  $V_{CC}$ ; EA = RST =  $V_{SS}$  (see Figure 15.).

Power Down I<sub>CC</sub> is measured with all output pins disconnected; EA = V<sub>SS</sub>, PORT 0 = V<sub>CC</sub>; XTAL2 NC.; RST = V<sub>SS</sub> (see Figure 16.).

4. Capacitance loading on Ports 0 and 2 may cause spurious noise pulses to be superimposed on the V<sub>OL</sub>s of ALE and Ports 1 and 3. The noise is due to external bus capacitance discharging into the Port 0 and Port 2 pins when these pins make 1 to 0 transitions during bus operation. In the worst cases (capacitive loading 100pF), the noise pulse on the ALE line may exceed 0.45V with maxi V<sub>OL</sub> peak 0.6V. A Schmitt Trigger use is not necessary.

5. Typicals are based on a limited number of samples and are not guaranteed. The values listed are at room temperature and 5V.

 Under steady state (non-transient) conditions, I<sub>OL</sub> must be externally limited as follows: Maximum I<sub>OL</sub> per port pin: 10 mA Maximum I<sub>OL</sub> per 8-bit port: Table 28., Table 31. and Table 34. 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 25. 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<sup>E6</sup> = 50 ns):

```
x= 22 (Table 28.)
```

T= 50ns

T<sub>LLIV</sub>= 2T - x = 2 x 50 - 22 = 78ns

#### External Program Memory Characteristics

#### Table 26. 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         |



#### External Program Memory Read Cycle

Figure 18. External Program Memory Read Cycle



#### External Data Memory Characteristics

 Table 29.
 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 WR or RD         |
| T <sub>QVWX</sub> | Data Valid to 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   |





# External Data Memory Read Cycle



Figure 20. External Data Memory Read Cycle

### Serial Port Timing - Shift Register Mode

Table 32. 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    |

| Speed             | -I<br>40 I | M<br>MHz |     | ИНz | stan<br>mod | V<br>dard<br>le 40<br>Hz |     | node<br>MHz<br>MHz | stan<br>mo | L<br>dard<br>ode<br>MHz | 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_{XHDV}$        |            | 117      |     | 34  |             | 117                      |     | 117                |            | 200                     | ns    |



#### **EPROM Programming and** Verification Characteristics

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

 Table 35.
 EPROM Programming Parameters

| Symbol              | Parameter                         | Min                  | Мах                  | 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> |       |

# EPROM Programming and Verification Waveforms

#### Figure 22. 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