

# **8-BIT MICROCONTROLLER**

#### GENERAL DESCRIPTION

The W78C54 is a derivative of the W78C52 microcontroller family that provides extended internal ROM. The chip has 16K bytes of mask ROM and 256 bytes of RAM.

This device provides an enhanced architecture that makes it more powerful and suitable for a variety of applications for general control systems. It provides on-chip 16KB mask ROM to accommodate large program codes, 256-bytes of non-volatile on-chip RAM, four 8-bit I/O ports, one 4-bit I/O port, three 16-bit timer/counters, eight sources with two-level interrupt structures, and on-chip oscillator clock circuits.

#### **FEATURES**

- Joraich pad RAM Jork-byte on-chip mask ROM 64K-byte address space for external Program Memory 64K-byte address space for external Data Memory Three 16-bit timer/counters Four 8-bit bit-addres

- One extra 4-bit bit-addressable I/O port, additional INT2/ INT3 (Available on 44-pin PLCC/QFP package)
- Eight-source, two priority-level interrupts
- Low EMI emission mode
- · Built-in programmable power-saving modes Idle mode & Power-down mode
- · Packages:
  - DIP 40: W78C54-16/24/40
  - PLCC 44: W78C54P-16/24/40
  - QFP 44: W78C54F-16/24/40
  - TQFP 44: W78C54M-16/24/40



## **PIN CONFIGURATIONS**





## **PIN DESCRIPTION**

| SYMBOL      | TYPE  | DESCRIPTIONS                                                                                                                                                                                                                                                                  |
|-------------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| EA          | I     | EXTERNAL ACCESS ENABLE: This pin forces the processor to execute out of external ROM. The ROM address and data will not be present on the bus if the $\overline{EA}$ pin is high and the program counter is within the 16 KB area. Otherwise they will be present on the bus. |
| PSEN        | ОН    | PROGRAM STORE ENABLE: PSEN enables the external ROM data in the Port 0 address/data bus.                                                                                                                                                                                      |
|             |       | When internal ROM access is performed, no PSEN strobe signal outputs originate from this pin.                                                                                                                                                                                 |
| ALE         | ОН    | ADDRESS LATCH ENABLE: ALE is used to enable the address latch that separates the address from the data on Port 0. ALE runs at 1/6th of the oscillator frequency. An ALE pulse is omitted during external data memory accesses.                                                |
| RST         | ΙL    | RESET: A high on this pin for two machine cycles while the oscillator is running resets the device.                                                                                                                                                                           |
| XTAL1       | Ι     | CRYSTAL 1: This is the crystal oscillator input. This pin may be driven by an external clock.                                                                                                                                                                                 |
| XTAL2       | 0     | CRYSTAL 2: This is the crystal oscillator output. It is the inversion of XTAL1.                                                                                                                                                                                               |
| Vss         |       | GROUND: ground potential.                                                                                                                                                                                                                                                     |
| Vdd         |       | POWER SUPPLY: Supply voltage for operation.                                                                                                                                                                                                                                   |
| P0.0-P0.7   | I/O D | PORT 0: Function is the same as that of the standard 8052.                                                                                                                                                                                                                    |
| P1.0-P1.7   | I/O H | PORT 1: Function is the same as that of the standard 8052.                                                                                                                                                                                                                    |
| P2.0-P2.7   | I/O H | PORT 2: Function is the same as that of the standard 8052.                                                                                                                                                                                                                    |
| P3.0-P3.7   | I/O H | PORT 3: Function is the same as that of the standard 8052.                                                                                                                                                                                                                    |
| P4.0-P4.3   | I/O H | PORT 4: A 4-bit bi-directional parallel port and bit-addressable with internal pull-ups. Pin P4.3 and P4.2 have alternative function as external interrupt (INT2/INT3) source input.                                                                                          |
| INT2 (P4.3) | ΙH    | External interrupt 2: An extra interrupt input source. It cascades to pin P4.3 internally.                                                                                                                                                                                    |
| INT3 (P4.2) | ΙH    | External interrupt 3: An extra interrupt input source. It cascades to pin P4.2 internally.                                                                                                                                                                                    |

\* Note : TYPE I: input, O: output, I/O: bi-directional, H: pull-high, L: pull-low, D: open drain



## **BLOCK DIAGRAM**



Figure 2. Architecture of the W78C54



## FUNCTIONAL DESCRIPTION

The W78C54 is pin-to-pin compatible with the W78C52, except that the internal 8K mask ROM has been replaced with 16K of internal mask ROM. The processor supports 111 different opcodes and references both 64K program address space and 64K data storage space.

#### Clock

The W78C54 is designed to be used with either a crystal oscillator or an external clock. Internally, the clock is divided by two before it is used. This makes the W78C54 relatively insensitive to duty cycle variations in the clock.

## Crystal Oscillator

The W78C54 incorporates a built-in crystal oscillator. To make the oscillator work, a crystal is connected across pins XTAL1 and XTAL2. In addition, a load capacitance of 30 pf (typically) must be connected from each pin to ground. Resistor must also be connected from XTAL1 to XTAL2 to provide a DC bias when the crystal frequency is above 24 MHz.

## External Clock

An external clock should be connected to pin XTAL1. Pin XTAL2 should be left unconnected. The XTAL1 input is a CMOS-type input, as required by the crystal oscillator. As a result, the external clock signal should have an input one level greater than 3.5 volts.

#### **Power Management**

#### Idle Mode

The idle mode is entered by setting the IDLE bit in the PCON register. In the idle mode, the internal clock to the processor is stopped. The peripherals and the interrupt logic continue to be clocked. The processor will exit idle mode when either an interrupt or a reset occurs.

#### Power-down Mode

When the PD bit of the PCON register is set, the processor enters the power-down mode. In this mode all of the clocks are stopped, including the oscillator. The only way to exit power-down mode is by a reset.

#### Reset

The external RESET signal is sampled at S5P2. To take effect, it must be held high for at least two machine cycles while the oscillator is running.

An internal trigger circuit in the reset line is used to deglitch the reset line when the W78C54 is used with an external RC network. The reset logic also has a special glitch removal circuit that ignores glitches on the reset line.

During reset, the ports are initialized to FFH, the stack pointer to 07H, PCON (with the exception of bit 4) to 00H, and all of the other SFR registers except SBUF to 00H. SBUF is not reset.

## New Defined Peripheral

In order to be more suitable for I/O, an extra 4-bit bit-addressable port P4 and two external interrupt INT2, INT3 has been added to either the PLCC or QFP 44 pin package. And description follows:



#### 1. INT2 / INT3

Two additional external interrupts, INT2 and INT3, whose functions are similar to those of external interrupt 0 and 1 in the standard 80C52. The functions/status of these interrupts are determined/shown by the bits in the XICON (External Interrupt Control) register. The XICON register is bit-addressable but is not a standard register in the standard 80C52. Its address is at 0C0H. To set/clear bits in the XICON register, one can use the "SETB (/CLR) bit" instruction. For example, "SETB 0C2H" sets the EX2 bit of XICON.

#### 2. PORT4

Another bit-address port P4 is also available except only 4 bits (P4<3:0>) can be used. This port address is located at 0D8H with the same function as that of port P1,except the P4.3 and P4.2 are alternative function pins. It can be used as general I/O pins or external interrupt input sources (INT2/INT3).

\$

Example:

| inpie. |          |                                      |
|--------|----------|--------------------------------------|
| P4     | REG      | 0D8H                                 |
| MOV    | P4, #0AH | ; Output data "A" through P4.0–P4.3. |
| MOV    | A, P4    | Read P4 status to Accumulator.       |
| SETB   | P4.0     | ; Set bit P4.0                       |
| CLR    | P4.1     | ; Clear bit P4.1                     |
|        |          |                                      |

#### **Reduce EMI Emission**

Because of the large on-chip mask-ROM, when a program is running in internal ROM space, the ALE will be unused. The transition of ALE will cause noise, so it can be turned off to reduce the EMI emission if it is useless. Turning off the ALE signal transition only requires setting the bit 0 of the AUXR SFR, which is located at 08Eh. When ALE is turned off, it will be reactivated when the program accesses external ROM/RAM data or jumps to execute an external ROM code. The ALE signal will turn off again after it has been completely accessed or the program returns to internal ROM code space.

#### **POF Flag**

The Power-Off-Reset flag is set by on-chip circuitry when the Vcc level rises from 0 to 5V. The POF bit can be set/cleared by software allowing a user to determine if the reset is the result of a power-on or a warm up by external reset. To avoid effect of POF flag, the power voltage must remain above 3V.

#### Timers 0, 1, and 2

Timers 0, 1, and 2 each consist of two 8-bit data registers. These are called TL0 and TH0 for Timer 0, TL1 and TH1 for Timer 1, and TL2 and TH2 for Timer 2. The TCON and TMOD registers provide control functions for timers 0, 1. The T2CON register provides control functions for Timer 2. RCAP2H and RCAP2L are used as reload/capture registers for Timer 2.

The operations of Timer 0 and Timer 1 are the same as in the W78C51. Timer 2 is a special feature of the W78C52C: it is a 16-bit timer/counter that is configured and controlled by the T2CON register. Like Timers 0 and 1, Timer 2 can operate as either an external event counter or as an internal timer, depending on the setting of bit C/T2 in T2CON. Timer 2 has three operating modes: capture, autoreload, and baud rate generator. The clock speed at capture or auto-reload mode is the same as that of Timers 0 and 1.



## DESCRIPTIONS OF THE SPECIAL FUNCTION REGISTERS (SFRS)

| SYM.   | DEFINITION          | ADDR. | MS     | В     | BIT ADD | DRESS, | SYMBO |      |      | LSB    | RESET     |
|--------|---------------------|-------|--------|-------|---------|--------|-------|------|------|--------|-----------|
| В      | B register          | F0H   | (F7)   | (F6)  | (F5)    | (F4)   | (F3)  | (F2) | (F1) | (F0)   | 00000000B |
| ACC    | Accumulator         | E0H   | (E7)   | (E6)  | (E5)    | (E4)   | (E3)  | (E2) | (E1) | (E0)   | 00000000B |
| P4*    | Port 4              | D8H   | -      | -     | -       | -      | (DB)  | (DA) | (D9) | (D8)   | xxxx0000B |
|        |                     |       |        |       |         |        | INT2  | INT3 |      |        |           |
| PSW    | Program status word | D0H   | (D7)   | (D6)  | (D5)    | (D4)   | (D3)  | (D2) | (D1) | (D0)   | 00000000B |
|        | 5                   |       | CY     | AC    | F0      | RS1    | RS0   | OV   | -    | P      |           |
| TH2    | T2 reg. high        | CDH   |        |       |         |        |       |      |      |        | 0000000B  |
| TL2    | T2 reg. low         | ССН   |        |       |         |        |       | -    |      |        | 00000000B |
| RCAP2H | T2 capture high     | СВН   |        |       |         |        |       |      |      |        | 00000000B |
| RCAP2L | T2 capture low      | CAH   |        |       |         |        |       | - 5  |      |        | 00000000B |
| T2CON  | Timer 2 control     | C8H   | (CF)   | (CE)  | (CD)    | (CC)   | (CB)  | (CA) | (C9) | (C8)   | 00000000B |
|        |                     |       | TF2    | EXF2  | RCLK    | TCLK   | EXEN2 | TR2  | C/T2 | CP/RL2 |           |
| XICON* | External interrupt  | C0H   | (C7)   | (C6)  | (C5)    | (C4)   | (C3)  | (C2) | (C1) | (C0)   | 00000000B |
|        | control             |       | PX3    | EX3   | IE3     | IT3    | PX2   | EX2  | IE2  | IT2    |           |
| IP     | Interrupt priority  | B8H   |        | -     | PT2     | PS     | PT1   | PX1  | PT0  | PX0    | xx000000B |
| P3     | Port 3              | BOH   | (B7)   | (B6)  | (B5)    | (B4)   | (B3)  | (B2) | (B1) | (B0)   | 11111111B |
|        |                     |       | RD     | WR    | T1      | то     | INT1  | INT0 | TXD  | RXD    |           |
| IE     | Interrupt enable    | A8H   | (AF)   | (AE)  | (AD)    | (AC)   | (AB)  | (AA) | (A9) | (A8)   | 0000000B  |
|        |                     |       | EA     | -     | ET2     | ES     | ET1   | EX1  | ET0  | EX0    |           |
| P2     | Port 2              | A0H   | (A7)   | (A6)  | (A5)    | (A4)   | (A3)  | (A2) | (A1) | (A0)   | 11111111B |
| . –    |                     |       | A15    | A14   | A13     | A12    | A11   | A10  | A9   | A8     |           |
| SBUF   | Serial buffer       | 99H   |        |       |         |        |       |      | 7.0  | 7.0    | xxxxxxxB  |
| SCON*  | Serial control      | 98H   | (9F)   | (9E)  | (9D)    | (9C)   | (9B)  | (9A) | (99) | (98)   | 00000000B |
|        |                     |       | SM0/FE | SM1   | SM2     | REN    | TB8   | RB8  | TÍ   | RÍ     |           |
| P1*    | Port 1              | 90H   | (97)   | (96)  | (95)    | (94)   | (93)  | (92) | (91) | (90)   | 11111111B |
|        |                     |       |        |       |         |        |       |      | T2EX | T2     |           |
| AUXR*  | Auxiliary           | 8EH   | -      | -     | •       | -      | -     | -    | -    | AO     | xxxxxxx0B |
| TH1    | Timer high 1        | 8DH   |        |       |         |        |       |      |      |        | 0000000B  |
| TH0    | Timer high 0        | 8CH   |        |       |         |        |       |      |      |        | 0000000B  |
| TL1    | Timer low 1         | 8BH   |        |       |         |        |       |      |      |        | 0000000B  |
| TL0    | Timer low 0         | 8AH   |        |       |         |        |       |      |      |        | 0000000B  |
| TMOD   | Timer mode          | 89H   | GATE   | C/T   | M1      | MO     | GATE  | C/T  | M1   | MO     | 0000000B  |
| TCON   | Timer control       | 88H   | (8F)   | (8E)  | (8D)    | (8C)   | (8B)  | (8A) | (89) | (88)   | 00000000B |
|        |                     |       | TF1    | TR1   | TF0     | TR0    | IE1   | IT1  | IE0  | IT0    |           |
| PCON*  | Power control       | 87H   | SMOD   | SMOD0 | -       | POF+   | GF1   | GF0  | PD   | IDL    | 00xxxx00B |
| DPH    | Data pointer high   | 83H   |        |       |         |        |       |      |      |        | 00000000B |
| DPL    | Data pointer low    | 82H   |        |       |         |        |       |      |      |        | 00000000B |
| SP     | Stack pointer       | 81H   |        |       |         |        |       |      |      |        | 00000111B |
| P0     | Port 0              | 80H   | (87)   | (86)  | (85)    | (84)   | (83)  | (82) | (81) | (80)   | 11111111B |



Note: In column BIT\_ADDRESS, SYMBOL, containing () item means the bit address.

\* SFRs modified or added to the W78C52. + Reset value depends on reset condition.

| F8 |        |      |        |        |     |         |      |      | FF |
|----|--------|------|--------|--------|-----|---------|------|------|----|
| F0 | + B    |      |        |        |     |         |      |      | F7 |
| E8 |        |      |        |        |     |         |      |      | EF |
| E0 | + ACC  |      |        |        |     |         |      |      | E7 |
| D8 | +P4    |      |        |        |     |         |      |      | DF |
| D0 | + PSW  |      |        |        |     |         |      |      | D7 |
| C8 | +T2CON |      | RCAP2L | RCAP2H | TL2 | TH2     |      |      | CF |
| C0 | +XICON |      |        |        |     |         |      |      | C7 |
| B8 | + IP   |      |        |        |     |         | 2    |      | BF |
| B0 | + P3   |      |        |        |     | 1.15    | P    |      | B7 |
| A8 | + IE   |      |        |        |     | 3 - 3 + | -1   |      | AF |
| A0 | + P2   |      |        |        | x   | 72      |      |      | A7 |
| 98 | + SCON | SBUF |        |        | 32  | - C.    |      |      | 9F |
| 90 | + P1   |      |        |        | C   | 0.      |      |      | 97 |
| 88 | + TCON | TMOD | TL0    | TL1    | TH0 | TH1     | AUXR |      | 8F |
| 80 | +P0    | SP   | DPL    | DPH    |     |         |      | PCON | 87 |

#### W78C54 SFRs address location map:

Notes:

1. + SFR is bit-addressable. is additional defined function

## Power-off Flag

2.

#### \*\*\*PCON - Power Control (87H)

| SMOD SMODO - POF GF1 GF0 PD IDL |
|---------------------------------|
|---------------------------------|

- SMOD: Double baud rate bit. When set to a 1, the baud rate is doubled when the serial port is being used in either modes 1, 2, 3. SMOD0: Enable FE bit in SCON. This bit is an alternative switch of SM0 and FE (Frame Error) When set to a 1, SCON.7 means a FE bit, otherwise a SM0 bit. bit. POF: Power off flag. Bit is set by hardware when power on reset. It can be cleared by software to determine chip reset is a warm boot or cold boot. GF1, GF0: These two bits are general-purpose flag bits for the user. PD: Power down mode bit. Set it to enter power down mode.
- IDL: Idle mode bit. Set it to enter idle mode.

The power-off flag is located at PCON.4. This bit is set when VDD has been applied to the part. It can be used to determine if a reset is a warm boot or a cold boot if it is subsequently reset by software.



#### \* Interrupts

#### \*\*\*IE - Interrupt Enable (A8H)

|    | • | · / |    |     |     |     |     |
|----|---|-----|----|-----|-----|-----|-----|
| EA | - | ET2 | ES | ET1 | EX1 | ET0 | EX0 |

- EA: Lobal interrupt enable flag
- ET2: Timer 2 overflow interrupt enable
- ES: Serial port interrupt enable
- EX1: External interrupt 1 enable
- ET1: Timer 1 overflow interrupt enable
- EX0: External interrupt 0 enable

## \*\*\*IP - Interrupt Priority (B8H)

|            | i apri non    | ·) (=•··)     |          |     |     | E /10 |     |
|------------|---------------|---------------|----------|-----|-----|-------|-----|
| -          | -             | PT2           | PS       | PT1 | PX1 | PT0   | PX0 |
| PT2: Timer | 2 interrupt   | priority high | n if set | 35  | 3   |       |     |
| PS: Serial | port priority | y high if set |          |     | c01 |       |     |
| PT1: Timer | 1 interrupt   | priority high | n if set |     |     |       |     |

- PT2: Timer 2 interrupt priority high if set
- PS: Serial port priority high if set
- PT1: Timer 1 interrupt priority high if set
- PX1: External interrupt 1 priority high if set
- PT0: Timer 0 interrupt priority high if set
- PX0: External interrupt 0 priority high if set

## \*\*\*XICON - External Interrupt Control (C0H)

| PX3 EX3 IE3 IT3 PX2 EX2 IE2 IT2 |
|---------------------------------|
|---------------------------------|

- PX3: External interrupt 3 priority high if set
- EX3: External interrupt 3 enable if set
- IE3: If IT3 = 1, IE3 is set/cleared automatically by hardware when interrupt is detected/serviced
- IT3: External interrupt 3 is falling-edge/low-level triggered when this bit is set/cleared by software
- PX2: External interrupt 2 priority high if set
- EX2: External interrupt 2 enable if set
- IE2: If IT2 = 1, IE2 is set/cleared automatically by hardware when interrupt is detected/serviced
- IT2: External interrupt 2 is falling-edge/low-level triggered when this bit is set/cleared by software

The W78C54 supports an eight-source and a four-priority-level interrupt architectures. Besides the SFRs of IP and IE to control the six-source of the standard 8052 interrupt functions. There is an another SFR (XICON) to control the extra two-source of the external interrrupt (INT2 and INT3). This priority scheme is formed by combining IPH with IP to determine the priority of each interrupt. Except the INT2 and INT3, they are not defined in IP SFR but in XICON.



Following tables show the interrupt informations and priority definitions.

Eight-source interrupt informations:

| INTERRUPT<br>SOURCE                        | VECTOR<br>ADDRESS | POLLING<br>SEQUENCE WITHIN<br>PRIORITY LEVEL | ENABLE<br>REQUIRED<br>SETTINGS | INTERRUPT<br>TYPE<br>EDGE/LEVEL |
|--------------------------------------------|-------------------|----------------------------------------------|--------------------------------|---------------------------------|
| External Interrupt 0                       | 03H               | 0 (highest)                                  | IE.0                           | TCON.IT0                        |
| Timer/Counter 0                            | 0BH               | 1                                            | IE.1                           | -                               |
| External Interrupt 1                       | 13H               | 2                                            | IE.2                           | TCON.IT1                        |
| Timer/Counter 1                            | 1BH               | 3                                            | IE.3                           | -                               |
| Serial Port                                | 23H               | 4                                            | IE.4                           | -                               |
| Timer/Counter 2                            | 2BH               | 5                                            | IE.5                           | -                               |
| External Interrupt 2                       | 33H               | 6                                            | XICON.EX2                      | XICON.IT2                       |
| External Interrupt 3                       | 3BH               | 7 (lowest)                                   | XICON.EX3                      | XICON.IT3                       |
| *Timer/Counter<br>***TL0, TH0, TL1, TH1, 1 | [L2. TH2. RGA     | P2L. RCAP2H                                  | m.c                            |                                 |

## \*Timer/Counter

## \*\*\*TL0, TH0, TL1, TH1, TL2, TH2, RCAP2L, RCAP2H

\*\*\*TMOD - Timer 0, 1 mode (89H)

| GATE | C//T | M1  | <b>M</b> 0 | GATE | C//T | M1  | M0 |
|------|------|-----|------------|------|------|-----|----|
|      | TIN  | ERO |            |      | TIN  | ÆR1 |    |

GATE: Gating control. When set, Timer/counter x is enabled only while INTx pin is high and TRx control pin is set. When cleared, Timer x is enabled whenever the TRx conrol bit is set.

C//T: Timer or Counter Selector. Cleared for timer operation. Set for counter operation.

## M1 M0: Operating Mode

- 0 0: 13-bit Timer/Counter.
- 0 1: 16-bit Timer/Counter.
- 1 0: 8-bit auto-reload Timer/Counter. THx holds a value which is to be reloaded into TLx each time it overflows.
- 1 1: Timer 0: TL0 is an 8-bit timer/counter controlled by the standard Timer 0 control bits. TH0 is an 8-bit timer only controlled by Timer 1 control bits.

Timer 1: Timer/counter 1 stopped.

#### \*\*\*TCON - Timer 0, 1 Control (88H)

| TF1 TR1 TF0 TR0 | IE1 IT1 | IE0 | IT0 |
|-----------------|---------|-----|-----|
|-----------------|---------|-----|-----|

TF1: Timer 1 overflow flag. Set by hardware on timer/counter overflow. cleared by hardware when processor vectors to interrupt routine.



TR1: Timer 1 run control bit. Set/cleared by software to turn timer/counter on or off.

- TF0: Timer 0 overflow flag. Set by hardware on timer/counter overflow. Cleared by hardware when processor vectors to interrupt routine.
- TR0: Timer 0 run control bit. Set/cleared by software to turn timer/counter on or off.
- IE1: Interrupt 1 edge flag. Set by hardware when external interrupt edge detected. Cleared when interrupt processed.
- IT1: Interrupt 1 type control bit. Set/cleared by software to specify falling edge/low level triggered external interrupt.
- IE0: Interrupt 0 edge flag. Set by hardware when external interrupt edge detected. Cleared when interrupt processed.
- ITO: Interrupt 0 type control bit. Set/cleared by software to specify falling edge/low level triggered external interrupt. 上海部は常

#### \*\*\*T2CON - Timer 2 Control (C8H)

| TF2 | EXF2 | RCLK | TCLK | EX | EN2 | TR2 | 5 | C//T | CP//RL2 |
|-----|------|------|------|----|-----|-----|---|------|---------|
|     |      |      |      |    |     |     |   |      |         |

- Timer 2 overflow flag. Set by a Timer 2 overflow and must be cleared by software. TF2 will TF2: not be set when RCLK = 1 or TCLK = 1.
- Timer2 external flag. Set when either a capture or reload is caused by a negative transition EXF2: on T2EX and EXEN2 = 1. When Timer 2 interrupt is enabled, EXF2 = 1 will cause the CPU to vector to the Timer 2 interrupt routine. EXF2 must be cleared by software.
- Receive clock flag, RCLK = 1 causes the serial port to use Timer 2 overflow pulses for its RCLK: receive clock in mode 1 and 3. RCLK = 0 causes Timer 1 overflow to be used for the receive clock
- TCLK: Transmit clock flag. TCLK = 1 causes the serial port to use Timer 2 overflow pulses for its transmit clock in mode 1 and 3. TCLK = 0 causes Timer 1 overflow to be used for the transmit clock.
- EXEN2: Timer 2 external enable flag. EXEN2 = 1 allows a capture or reload to occur as a result of a negative transition on T2EX if Timer 2 is not used to clock the serial port. EXEN2 = 0 causes Timer 2 to ignore events at T2EX.

TR2: TR2 = 1/0: turns on/off Timer 2.

C//T: Timer or Counter select. Set 1/0 for external event counter(falling edge triggered)/inter timer.

CP//RL2: Capture/reload flag.

#### \*Reduced EMI Mode

The AO bit in the AUXR register, when set, disables the ALE output.

#### \*\*\*AUXR - Auxiliary Register (8EH)

| AO |
|----|
|----|

AO: Turn off ALE output.



## **ABSOLUTE MAXIMUM RATINGS**

| PARAMETER             | SYMBOL  | MIN.     | MAX.     | UNIT |
|-----------------------|---------|----------|----------|------|
| DC Power Supply       | Vcc-Vss | -0.3     | +7.0     | V    |
| Input Voltage         | Vin     | Vss -0.3 | Vcc +0.3 | V    |
| Operating Temperature | ТА      | 0        | 70       | °C   |
| Storage Temperature   | Tst     | -55      | +150     | °C   |

- 8-

Note: Exposure to conditions beyond those listed under Absolute Maximum Ratings may adversely affect the life and reliability of the device.

## **DC CHARACTERISTICS**

| PARAMETER               | SYM.     | SPECIF |      | UNIT | TEST CONDITIONS |
|-------------------------|----------|--------|------|------|-----------------|
|                         |          | MIN.   | MAX. |      |                 |
| Operating Voltage       | Vdd      | 4.5    | 5.5  | V    |                 |
| Operating Current       | IDD      |        | 20   | mA   | No load         |
|                         |          |        |      |      | VDD = 5.5V      |
| Idle Current            | lidle    | -      | 6    | mA   | Idle mode       |
|                         |          |        |      |      | VDD = 5.5V      |
| Power Down Current      | IPWDN    | -      | 50   | μA   | Power-down mode |
|                         |          |        |      |      | VDD = 5.5V      |
| Input Current           | lin1     | -50    | +10  | μA   | VDD = 5.5V      |
| P1, P2, P3, P4          |          |        |      |      | VIN = 0V or VDD |
| Input Current           | lin2     | -10    | +300 | μA   | VDD = 5.5V      |
| RST                     |          |        |      |      | 0 < VIN < VDD   |
| Input Leakage Current   | Ilk      | -10    | +10  | μA   | VDD = 5.5V      |
| P0, EA                  |          |        |      |      | 0V < VIN < VDD  |
| Logic 1 to 0 Transition | I⊤∟ [*4] | -500   | -200 | μA   | VDD = 5.5V      |
| Current                 |          |        |      |      | VIN = 2.0V      |
| P1, P2, P3, P4          |          |        |      |      |                 |
| Input Low Voltage       | VIL1     | 0      | 0.8  | V    | VDD = 4.5V      |
| P0, P1, P2, P3, P4, EA  |          |        |      |      |                 |
| Input Low Voltage       | VIL2     | 0      | 0.8  | V    | VDD = 4.5V      |
| RST                     |          |        |      |      |                 |
| Input Low Voltage       | VIL3     | 0      | 0.8  | V    | VDD = 4.5V      |
| XTAL1[*4]               |          |        |      |      |                 |



| PARAMETER              | SYM. | SPECIF | ICATION  | UNIT | TEST CONDITIONS |
|------------------------|------|--------|----------|------|-----------------|
|                        |      | MIN.   | MAX.     |      |                 |
| Input High Voltage     | VIH1 | 2.4    | Vdd +0.2 | V    | Vdd = 5.5V      |
| P0, P1, P2, P3, P4, EA |      |        |          |      |                 |
| Input High Voltage     | VIH2 | 3.5    | Vdd +0.2 | V    | Vdd = 5.5V      |
| RST                    |      |        |          |      |                 |
| Input High Voltage     | Vінз | 3.5    | Vdd +0.2 | V    | Vdd = 5.5V      |
| XTAL1 [*4]             |      |        |          |      |                 |
| Output Low Voltage     | VOL1 | -      | 0.45     | V    | VDD = 4.5V      |
| P1, P2, P3, P4         |      |        |          | - 8- | IOL = +2 mA     |
| Output Low Voltage     | VOL2 | -      | 0.45     | V    | VDD = 4.5V      |
| P0, ALE, PSEN [*3]     |      |        | 23       | C.   | IoL = +4 mA     |
| Sink Current           | ISK1 | 4      | 8        | mA   | VDD = 4.5V      |
| P1, P2, P3, P4         |      |        | 0        |      | Vs = 0.45V      |
| Sink Current           | ISK2 | 10     | 14       | mA   | VDD = 4.5V      |
| P0, ALE, PSEN          |      |        |          |      | Vs = 0.45V      |
| Output High Voltage    | VOH1 | 2.4    | -        | V    | VDD = 4.5V      |
| P1, P2, P3, P4         |      |        |          |      | Іон = -100 μА   |
| Output High Voltage    | VOH2 | 2.4    | -        | V    | VDD = 4.5V      |
| P0, ALE, PSEN [*3]     |      |        |          |      | Іон = -400 μА   |
| Source Current         | ISR1 | -120   | -180     | μA   | VDD = 4.5V      |
| P1, P2, P3, P4         |      |        |          | •    | Vs = 2.4V       |
| Source Current         | ISR2 | -10    | -14      | mA   | Vdd = 4.5V      |
| P0, ALE, PSEN          |      |        |          |      | Vs = 2.4V       |

DC Characteristics, continued

Notes:

\*1. RST pin is a Schmitt trigger input. RST has internal pull-low resistors of about 30 K $\Omega$ .

\*3. P0, ALE and /PSEN are tested in the external access mode.

\*4. XTAL1 is a CMOS input.

\*5. Pins of P1, P2, P3, P4 can source a transition current when they are being externally driven from 1 to 0. The transition current reaches its maximum value when VIN approximates to 2V.

## AC CHARACTERISTICS

The AC specifications are a function of the particular process used to manufacture the part, the ratings of the I/O buffers, the capacitive load, and the internal routing capacitance. Most of the specifications can be expressed in terms of multiple input clock periods (TCP), and actual parts will usually experience less than a  $\pm 20$  nS variation. The numbers below represent the performance expected from a 0.8 micron CMOS process when using 2 and 4 mA output buffers.



## **Clock Input Waveform**



#### Continued

| SYMBOL | MIN.              | TYP.                                                                                     | MAX.                                                                                                                             | UNIT                                                                                                                                                                      | NOTES                                                                                                                                                                                    |
|--------|-------------------|------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Fop    | 0                 | 3                                                                                        | 40                                                                                                                               | MHz                                                                                                                                                                       | 1                                                                                                                                                                                        |
| Тср    | 25                | 4. 3                                                                                     | -                                                                                                                                | nS                                                                                                                                                                        | 2                                                                                                                                                                                        |
| Тсн    | 10                | 12-                                                                                      | 0                                                                                                                                | nS                                                                                                                                                                        | 3                                                                                                                                                                                        |
| Tc∟    | 10                |                                                                                          | -                                                                                                                                | nS                                                                                                                                                                        | 3                                                                                                                                                                                        |
|        | C C               |                                                                                          |                                                                                                                                  |                                                                                                                                                                           |                                                                                                                                                                                          |
|        | Fop<br>Тср<br>Тсн | Fop         0           Tcp         25           TcH         10           TcL         10 | Fop         0         -           Tcp         25         -           Tcн         10         -           TcL         10         - | Fop         0         -         40           Tcp         25         -         -           TcH         10         -         -           TcL         10         -         - | FOP         0         -         40         MHz           TCP         25         -         nS           TCH         10         -         nS           TCL         10         -         nS |

2. The TCP specification is used as a reference in other specifications.

3. There are no duty cycle requirements on the XTAL1 input.

## Program Fetch Cycle

#### External Program Memory Fetch Cycle (see Figure 6)

| PARAMETER                  | SYMBOL | MIN.            | TYP. | MAX.            | UINT | NOTES |
|----------------------------|--------|-----------------|------|-----------------|------|-------|
| Address Valid to ALE Low   | TAAS   | 1Tcp - $\Delta$ | -    | -               | nS   |       |
| Address Hold After ALE Low | Таан   | 1Tcp - $\Delta$ | -    | -               | nS   | 1     |
| ALE Low to PSEN Low        | TAPL   | 1Тср -∆         | 1Тср | 1Тср+∆          | nS   |       |
| PSEN Low to Data Valid     | Tpda   | -               | -    | 2Тср            | nS   | 2     |
| Data Hold After PSEN High  | Tpdh   | 0               | -    | 1Тср            | nS   | 3     |
| Data Float After PSEN High | Tpdz   | 0               | -    | 1Тср            | nS   |       |
| ALE Pulse Width            | TALW   | 2Tcp - $\Delta$ | 2TCP | 2Tcp + $\Delta$ | nS   | 4     |
| PSEN Pulse Width           | TPSW   | ЗТср - $\Delta$ | 3Тср | ЗТср + $\Delta$ | nS   | 4     |

Notes:

1. P00-P07, P20-P27 remain stable through entire memory cycle.

2. Memory access time is 3 Tcp.

3. Data has been latched internally prior to /PSEN going high.

4.  $\Delta$  is 20 ns (due to buffer driving delay and wire loading).



## **Data Read Cycle**

#### External Data Memory Read Cycle (see Figure 7)

| PARAMETER                | SYMBOL | MIN.            | TYP.  | MAX.            | UINT | NOTES |
|--------------------------|--------|-----------------|-------|-----------------|------|-------|
| ALE Low to RD Low        | Tdar   | 3 Тср- $\Delta$ | 3 Тср | 3 Тср+ $\Delta$ | nS   | 1, 2  |
| RD Low to Data Valid     | Tdda   | -               | -     | 4 Тср           | nS   | 1     |
| Data hold After RD High  | Tddh   | 0               | -     | 2 Тср           | nS   |       |
| Data Float After RD High | Tddz   | 0               | -     | 2 Тср           | nS   |       |
| RD Pulse Width           | Tdrd   | 6 Tcp- $\Delta$ | 6 Тср | 6 Tcp+ $\Delta$ | nS   | 2     |

## **Data Write Cycle**



| Notes:                                                              |                                                                                                                                                                                                             |                 |       |                 |      |      |  |  |  |
|---------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|-------|-----------------|------|------|--|--|--|
| 1. Data Memory access time is 5 Tcp.                                | 1. Data Memory access time is 5 Tcp.                                                                                                                                                                        |                 |       |                 |      |      |  |  |  |
| 2. $\Delta$ is 20 ns (due to buffer driving delay and wire loading. |                                                                                                                                                                                                             |                 |       |                 |      |      |  |  |  |
|                                                                     |                                                                                                                                                                                                             |                 |       |                 |      |      |  |  |  |
| Data Write Cycle                                                    | <ol> <li>Data Memory access time is 5 Tcp.</li> <li>Δ is 20 ns (due to buffer driving delay and wire loading.</li> <li>Data Write Cycle</li> <li>External Data Memory Write Cycle (see Figure 8)</li> </ol> |                 |       |                 |      |      |  |  |  |
| External Data Memory Write Cycle (see Figure 8)                     |                                                                                                                                                                                                             |                 |       |                 |      |      |  |  |  |
| PARAMETER                                                           | SYMBOL                                                                                                                                                                                                      | MIN.            | TYP.  | MAX.            | UINT | NOTE |  |  |  |
| ALE Low to WR Low                                                   | TDAW                                                                                                                                                                                                        | 3 Тср-∆         | 3 Тср | 3 Тср+ $\Delta$ | nS   | *    |  |  |  |
| Data Valid to WR Low                                                | TDAD                                                                                                                                                                                                        | 1 Tcp-∆         | -     | -               | nS   |      |  |  |  |
| Data hold After WR High                                             | Towd                                                                                                                                                                                                        | 1 Tcp- $\Delta$ | -     | -               | nS   |      |  |  |  |
| WR Pulse Width                                                      | Tdwr                                                                                                                                                                                                        | 6 Tcp- $\Delta$ | 6 Тср | 6 Tcp+ $\Delta$ | nS   | *    |  |  |  |

\*Note:  $\Delta$  is 20 ns (due to buffer driving delay and wire loading)

## **Port Access Cycle**

Port Access Cycle (see Figure 9)

| PARAMETER                     | SYMBOL | MIN.           | TYP. | MAX. | UINT |
|-------------------------------|--------|----------------|------|------|------|
| Port Input Setup to ALE Low   | TPDS   | 1Тср           | -    | -    | nS   |
| Port Input Hold After ALE Low | Трдн   | 0              | -    | -    | nS   |
| Port Output to ALE High       | Tpda   | 1Тср- $\Delta$ | -    | -    | nS   |

Note: Ports are read during S5P2, and output data becomes available at the end of S6P2. The timing data are referenced to ALE, since it provides a convenient reference.



## TIMING WAVEFORMS

## **Program Fetch Cycle**



Figure 6. External Program Memory Fetch Cycle



Figure7. External Data Memory Read Cycle



Timing Waveforms, continued

## **Data Write Cycle**



Figure 8. External Data Memory Write Cycle

## Port Access Cycle



Figure 9. Port Access Cycle



## **APPLICATION CIRCUIT**

## **Expanded External Program Memory and Crystal**



Table 1 Shows the typical values of off-chip components to configure the on-chip oscillator. Table 1. Off-chip components list

| CRYSTAL FREQ. | C1    | C2    | R      |
|---------------|-------|-------|--------|
| 12 MHz        | 30 pF | 30 pF | -      |
| 16 MHz        | 30 pF | 30 pF | -      |
| 20 MHz        | 15 pF | 15 pF | -      |
| 24 MHz        | 15 pF | 15 pF | -      |
| 33 MHz        | 10 pF | 10 pF | 6.8 KΩ |
| 40MHz         | 5 pF  | 5 pF  | 4.3 KΩ |

Notes:

1. Refer to Figure 10 for C1, C2 and R.

2. It is recommended that an oscillator be used as external clock source when operating freq. is above 35MHz. Apply the external clock signal to XTAL1, and leave XTAL2 float, as shown in Figure 10.



Application Circuit, continued

## **Expanded External Data Memory and Oscillator**





## PACKAGE DIMENSIONS

40-pin DIP





Package Dimensions, continued

#### 44-pin QFP



## 44-pin TQFP









HeadquartersWinNo. 4, Creation Rd. III,RmScience-Based Industrial Park,123Hsinchu, TaiwanKooTEL: 886-3-5770066TELFAX: 886-3-5792697FAXhttp://www.winbond.com.tw/Voice & Fax-on-demand: 886-2-27197006

 Taipei Office

 11F, No. 115, Sec. 3, Min-Sheng East Rd.,

 Taipei, Taiwan

 TEL: 886-2-27190505

 FAX: 886-2-27197502

Note: All data and specifications are subject to change without notice.

Winbond Electronics (H.K.) Ltd.Winbond Electronics NRm. 803, World Trade Square, Tower II, Winbond Memory Lab.123 Hoi Bun Rd., Kwun Tong,<br/>Kowloon, Hong Kong<br/>TEL: 852-27513100Winbond MicroelectronFAX: 852-275520642727 N. First Street, San July<br/>CA 95134 LLS A

Winbond Electronics North America Corp. Winbond Memory Lab. Winbond Microelectronics Corp. Winbond Systems Lab. 2727 N. First Street, San Jose, CA 95134, U.S.A. TEL: 408-9436666 FAX: 408-5441798