# PRODUCT SPECIFICATION



# **Z86C21**8K ROM Z8® CMOS MICROCONTROLLER

# **FEATURES**

- 8-Bit CMOS MCU with 8 Kbytes of ROM
- 256 Byte Register File
  - 236 Bytes of General-Purpose RAM
  - 16 Bytes Control/Status Registers
  - 4 Bytes for Ports
- 40-Pin DIP, 44-Pin PLCC or 44-Pin QFP Package
- 4.5V to 5.5V Operating Range
- Low Power Consumption: 220 mW (max) @ 16 MHz
- Fast instruction pointer: 1.0 µs @ 12 MHz
- Two Standby Modes: STOP and HALT
- 32 Input/Output Lines

- Full-Duplex UART
- All Digital Inputs are TTL Levels
- Auto Latches
- RAM and ROM Protect
- Two Programmable 8-Bit Counter/Timers each with 6-Bit Programmable Prescaler.
- Six Vectored, Priority Interrupts from Eight Different Sources
- Clock Speeds: 12 and 16 MHz
- On-Chip Oscillator that Accepts a Crystal, Ceramic Resonator, LC, or External Clock Drive.

# GENERAL DESCRIPTION

The Z86C21 microcontroller is a member of the Z8 single-chip microcontroller family with 8 Kbytes of ROM and 236 bytes of RAM. The device is packaged in a 40-pin DIP, 44-pin PLCC, or a 44-pin QFP with a ROMless pin option available on the 44-pin versions only. With the ROM/ROMless feature selectively, the Z86C21 offers both external memory and preprogrammed ROM, making it well-suited for high-volume applications or where code flexibility is required.

Zilog's CMOS microcontroller offers fast execution, efficient use of memory, sophisticated interrupts, input/output bit manipulation capabilities, and easy hardware/software system expansion along with low cost and low power consumption.

The Z86C21 architecture is characterized by Zilog's 8-bit microcontroller core. The device offers a flexible I/O scheme, an efficient register and address space structure, multiplexed capabilities between address/data, I/O, and a number of ancillary features that are useful in many industrial and advanced scientific applications.

For applications demanding powerful I/O capabilities, the Z86C21 provides 32 pins dedicated to input and output. These lines are grouped into four ports. Each port consists of eight lines, and is configurable under software control to provide timing, status signals, serial or parallel I/O with or without handshake, and an address/data bus for interfacing external memory. There are three basic address spaces available to support this configuration: Program Memory, Data Memory, and 236 general-purpose registers.

# **GENERAL DESCRIPTION** (Continued)

To unburden the program from coping with the real-time tasks, such as counting/timing and serial data communication, the Z86C21 offers two on-chip counter/timers with a large number of user selectable modes, and an on-board UART.

### Notes:

All Signals with a preceding front slash, "/", are active Low, e.g., B//W (WORD is active Low); /B/W (BYTE is active Low, only).

Power connections follow conventional descriptions below:

| Connection      | Circuit                | Device                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|-----------------|------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Power<br>Ground | V <sub>cc</sub><br>GND | $egin{array}{c} egin{array}{c} \egin{array}{c} \egin{array}{c} \egin{array}{c} \egin{array}{c} \egin{array}{c} \egin{array}$ |



Figure 1. Z86C21 Functional Block Diagram

# **PIN DESCRIPTION**



Figure 2. 40-Pin DIP Pin Assignments

Table 1. 40-Pin DIP Pin Identification

| Pin# | Symbol          | Function                  | Direction | Pin#  | ; |
|------|-----------------|---------------------------|-----------|-------|---|
| 1    | V <sub>CC</sub> | Power Supply              | Input     | 11    | ( |
| 2    | XTAL2           | Crystal, Oscillator Clock | Output    | 12    | ŀ |
| 3    | XTAL1           | Crystal, Oscillator Clock | Input     | 13-20 | - |
| 4    | P37             | Port 3, Pin 7             | Output    | 21-28 | - |
| 5    | P30             | Port 3, Pin 0             | Input     | 29    | - |
| 6    | /RESET          | Reset                     | Input     | 30    | I |
| 7    | R//W            | Read/Write                | Output    | 31-38 | ŀ |
| 8    | /DS             | Data Strobe               | Output    | 39    | - |
| 9    | /AS             | Address Strobe            | Output    | 40    | - |
| 10   | P35             | Port 3, Pin 5             | Output    |       |   |

| Pin#                             | Symbol                                  | Function                                                                                     | Direction                             |  |  |  |
|----------------------------------|-----------------------------------------|----------------------------------------------------------------------------------------------|---------------------------------------|--|--|--|
| 11<br>12<br>13-20<br>21-28<br>29 | GND<br>P32<br>P00-P07<br>P10-P17<br>P34 | Ground Port 3, Pin 2 Port 0, Pins 0,1,2,3,4,5,6,7 Port 1, Pins 0,1,2,3,4,5,6,7 Port 3, Pin 4 |                                       |  |  |  |
| 30<br>31-38<br>39<br>40          | P33<br>P20-P27<br>P31<br>P36            | Port 3, Pin 3<br>Port 2, Pins 0,1,2,3,4,5,6,7<br>Port 3, Pin 1<br>Port 3, Pin 6              | Input<br>In/Output<br>Input<br>Output |  |  |  |

# PIN DESCRIPTION (Continued)



Figure 3. 44-Pin PLCC Pin Assignments

Table 2. 44-Pin PLCC Pin Identification

| Pin # | Symbol   | Function                  | Direction | Pin # | Symbol   | Function               | Direc |
|-------|----------|---------------------------|-----------|-------|----------|------------------------|-------|
| ———   | Syllibol | - unction                 | Direction |       | Syllibol | - unction              | Direc |
| 1     | $V_{CC}$ | Power Supply              | Input     | 14-16 | P00-P02  | Port 0, Pins 0,1,2     | In/O  |
| 2     | XTAL2    | Crystal, Oscillator Clock | Output    | 17    | R//RL    | ROM/ROMless control    | Inpu  |
| 3     | XTAL1    | Crystal, Oscillator Clock | Input     | 18-22 | P03-P07  | Port 0, Pins 3,4,5,6,7 | In/O  |
| 4     | P37      | Port 3, Pin 7             | Output    | 23-27 | P10-P14  | Port 1, Pins 0,1,2,3,4 | In/O  |
| 5     | P30      | Port 3, Pin 0             | Input     | 28    | N/C      | Not Connected          | Inpu  |
| 6     | N/C      | Not Connected             | Input     | 29-31 | P15-P17  | Port 1, Pins 5,6,7     | In/O  |
| 7     | /RESET   | Reset                     | Input     | 32    | P34      | Port 3, Pin 4          | Outp  |
| 8     | R//W     | Read/Write                | Output    | 33    | P33      | Port 3, Pin 3          | Inpu  |
| 9     | /DS      | Data Strobe               | Output    | 34-38 | P20-P24  | Port 2, Pins 0,1,2,3,4 | In/O  |
| 10    | /AS      | Address Strobe            | Output    | 39    | N/C      | Not Connected          | Inpu  |
| 11    | P35      | Port 3, Pin 5             | Output    | 40-42 | P25-P27  | Port 2, Pins 5,6,7     | In/O  |
| 12    | GND      | Ground                    | Input     | 43    | P31      | Port 3, Pin 1          | Inpu  |
| 13    | P32      | Port 3, Pin 2             | Input     | 44    | P36      | Port 3, Pin 6          | Outp  |



Figure 4. 44-Pin QFP Pin Assignments

Table 3. 44-Pin QFP Pin Identification

| Pin#  | Symbol Function Direction |                           |           |  |  |
|-------|---------------------------|---------------------------|-----------|--|--|
| 1-5   | P03-P07                   | Port 0, Pins 3,4,5,6,7    | In/Output |  |  |
| 6     | GND                       | Ground                    | Input     |  |  |
| 7-14  | P10-P17                   | Port 1, Pins 0 through 7  | In/Output |  |  |
| 15    | P34                       | Port 3, Pin 4             | Output    |  |  |
| 16    | P33                       | Port 3, Pin 3             | Input     |  |  |
| 17-21 | P20-P24                   | Port 2, Pins 0,1,2,3,4    | In/Output |  |  |
| 22    | GND                       | Ground                    | Input     |  |  |
| 23-25 | P25-P27                   | Port 2, Pins 5,6,7        | In/Output |  |  |
| 26    | P31                       | Port 3, Pin 1             | Input     |  |  |
| 27    | P36                       | Port 3, Pin 6             | Output    |  |  |
| 28    | GND                       | Ground                    | Input     |  |  |
| 29    | V <sub>cc</sub>           | Power Supply              | Input     |  |  |
| 30    | XTAL2                     | Crystal, Oscillator Clock | Output    |  |  |

| Pin#  | Symbol  | Function                  | Direction |
|-------|---------|---------------------------|-----------|
| 31    | XTAL1   | Crystal, Oscillator Clock | Input     |
| 32    | P37     | Port 3, Pin 7             | Output    |
| 33    | P30     | Port 3, Pin 0             | Input     |
| 34    | /RESET  | Reset                     | Input     |
| 35    | R//W    | Read/Write                | Output    |
| 36    | /DS     | Data Strobe               | Output    |
| 37    | /AS     | Address Strobe            | Output    |
| 38    | P35     | Port 3, Pin 5             | Output    |
| 39    | GND     | Ground                    | Input     |
| 40    | P32     | Port 3, Pin 2             | Input     |
| 41-43 | P00-P02 | Port 0, Pins 0,1,2        | In/Output |
| 44    | R//RL   | ROM/ROMIess control       | Input     |

**PIN FUNCTIONS** 

**/ROMIess** (input, active Low). This pin, when connected to GND, disables the internal ROM and forces the device to function as a Z86C91 ROMless Z8. For more details on the ROMless version, refer to the Z86C91 product specification. (**Note:** When left unconnected or pulled high to  $V_{\rm cc'}$  the part functions as a normal Z86C21 ROM version). This pin is only available on the 44-pin versions of the Z86C21.

**/DS** (output, active Low). Data Strobe is activated once for each external memory transfer. For a READ operation, data must be available prior to the trailing edge of /DS. For WRITE operations, the falling edge of /DS indicates that output data is valid.

/AS (output, active Low). Address Strobe is pulsed once at the beginning of each machine cycle. Address output is through Port 1 for all external programs. Memory address transfers are valid at the trailing edge of /AS. Under program control, /AS is placed in the high-impedance state along with Ports 0 and 1, Data Strobe, and Read/Write.

**XTAL1, XTAL2** *Crystal 1, Crystal 2* (time-based input and output, respectively). These pins connect a parallel-resonant crystal, ceramic resonator, LC, or any external single-phase clock to the on-chip oscillator and buffer.

**R//W** (output, write Low). The Read/Write signal is Low when the MCU is writing to the external program or data memory.

**/RESET** (input, active Low). To avoid asynchronous and noisy reset problems, the Z86C21 is equipped with a reset filter of four external clocks (4TpC). If the external /RESET signal is less than 4TpC in duration, no reset occurs.

On the fifth clock after the /RESET is detected, an internal RST signal is latched and held for an internal register count of 18 external clocks, or for the duration of the external /RESET, whichever is longer. During the reset cycle, /DS is held active Low while /AS cycles at a rate of TpC2. When /RESET is deactivated, program execution begins at location 000C (HEX). Power-up reset time must be held Low for 50 ms, or until  $V_{\rm CC}$  is stable, whichever is longer.

**Port 0** (P07-P00). Port 0 is an 8-bit, nibble programmable, bidirectional, TTL compatible port. These eight I/O lines can be configured under software control as a nibble I/O port, or as an address port for interfacing external memory. When used as an I/O port, Port 0 may be placed under handshake control. In this configuration, Port 3, lines P32 and P35 are used as the handshake control /DAV0 and RDY0 (Data Available and Ready). Handshake signal assignment is dictated by the I/O direction of the upper nibble P07-P04. The lower nibble must have the same direction as the upper nibble to be under handshake control.

For external memory references, Port 0 can provide address bits A11-A8 (lower nibble) or A15-A8 (lower and upper nibble) depending on the required address space. If the address range requires 12 bits or less, the upper nibble of Port 0 is programmed independently as I/O while the lower nibble is used for addressing. If one or both nibbles are needed for I/O operation, they must be configured by writing to the Port 0 Mode register.

In ROMless mode, after a hardware reset, Port 0 lines are defined as address lines A15-A8, and extended timing is set to accommodate slow memory access. The initialization routine includes reconfiguration to eliminate this extended timing mode (Figure 5).





Figure 5. Port 0 Configuration

# **PIN FUNCTIONS** (Continued)

**Port 1** (P17-P10). Port 1 is an 8-bit, byte programmable, bidirectional, TTL compatible port. It has multiplexed Address (A7-A0) and Data (D7-D0) ports. For Z86C21, these eight I/O lines can be programmed as Input or Output lines or can be configured under software control as an address/data port for interfacing external memory. When used as an I/O port, Port 1 can be placed under handshake control. In this configuration, Port 3 line P33 and P34 are used as the handshake controls RDY1 and /DAV1.

Memory locations greater than 8192 are referenced through Port 1. To interface external memory, Port 1 is programmed for the multiplexed Address/Data mode. If more than 256 external locations are required, Port 0 must output the additional lines.

Port 1 can be placed in a high-impedance state along with Port 0, /AS, /DS and R//W, allowing the MCU to share common resource in multiprocessor and DMA applications. Data transfers are controlled by assigning P33 as a Bus Acknowledge input, and P34 as a Bus request output (Figure 6).



Figure 6. Port 1 Configuration

-----

**Port 2** (P27-P20). Port 2 is an 8-bit, bit programmable, bidirectional, CMOS compatible port. Each of these eight I/O lines can be independently programmed as an input or output or globally as an open-drain output. Port 2 is always available for I/O operation. When used as an I/O port, Port 2 may be placed under handshake control. In this

configuration, Port 3 lines P31 and P36 are used as the handshake control lines /DAV2 and RDY2. The handshake signal assignment for Port 3 lines P31 and P36 is dictated by the direction (input or output) assigned to P27 (Figure 7).



Figure 7. Port 2 Configuration

# **PIN FUNCTIONS** (Continued)

**Port 3** (P37-P30). Port 3 is an 8-bit, CMOS compatible four-fixed-input and four-fixed-output port. These eight I/O lines have four-fixed input (P33-P30) and four fixed output (P37-P34) ports. Port 3, when used as serial I/O, is programmed as serial in and serial out, respectively (Figure 8 and Table 4) Port 3 pins have Auto Latches only.

Port 3 is configured under software control to provide the following control functions: handshake for Ports 0 and 2 (/DAV and RDY); four external interrupt request signals (IRQ3-IRQ0); timer input and output signals ( $T_{IN}$  and  $T_{OUT}$ ), and Data Memory Select (/DM).

**UART Operation.** Port 3 lines P30 and P37, are be programmed as serial I/O lines for full-duplex serial asynchro-

nous receiver/transmitter operation. The bit rate is controlled by the Counter/Timer0.

The Z86C21 automatically adds a start bit and two stop bits to transmitted data (Figure 9). Odd parity is also available as an option. Eight data bits are always transmitted, regardless of parity selection. If parity is enabled, the eighth bit is the odd parity bit. An interrupt request (IRQ4) is generated on all transmitted characters.

Received data must have a start bit, eight data bits and at least one stop bit. If parity is on, bit 7 of the received data is replaced by a parity error flag. Received characters generate the IRQ3 interrupt request.



Figure 8. Port 3 Configuration

| T.I. 4 B (0B) 4 :               | _ |
|---------------------------------|---|
| Table 4. Port 3 Pin Assignments |   |

|     | Table 4. For 3 Fill Assignments |           |      |       |       |       |            |     |  |  |
|-----|---------------------------------|-----------|------|-------|-------|-------|------------|-----|--|--|
| Pin | I/O                             | CTC1      | Int. | P0 HS | P1 HS | P2 HS | UART       | Ext |  |  |
| P30 | IN                              |           | IRQ3 |       |       |       | Serial In  |     |  |  |
| P31 | IN                              | $T_{IN}$  | IRQ2 |       |       | D/R   |            |     |  |  |
| P32 | IN                              | IIV       | IRQ0 | D/R   |       |       |            |     |  |  |
| P33 | IN                              |           | IRQ1 |       | D/R   |       |            |     |  |  |
| P34 | OUT                             |           |      |       | R/D   |       |            | DM  |  |  |
| P35 | OUT                             |           |      | R/D   |       |       |            |     |  |  |
| P36 | OUT                             | $T_{OUT}$ |      |       |       | R/D   |            |     |  |  |
| P37 | OUT                             |           |      |       |       |       | Serial Out |     |  |  |
| TO  |                                 |           | IRQ4 |       |       |       |            |     |  |  |
| T1  |                                 |           | IRQ5 |       |       |       |            |     |  |  |

### Notes:

HS = Handshake Signals; D = Data Available; R = Ready

**Auto Latch.** The Auto Latch puts valid CMOS levels on all CMOS inputs that are not externally driven. This reduces excessive supply current flow in the input buffer when it is not been driven by any source.

**Low EMI Option.** The Z86C21 is available in a Low EMI option. This option is mask-programmable, to be selected by the customer at the time when the ROM code is submitted. Use of this feature results in:

- The pre-drivers slew rate reduced to 10 ns typical.
- Low EMI output drivers have resistance of 200 Ohms typical.
- Oscillator divide-by-two circuitry is eliminated.
- Internal SCLK/TCLK operation is limited to a maximum of 4 MHz (250 ns cycle time)



Figure 9. Serial Data Formats

FUNCTIONAL DESCRIPTION Address Space

**Program Memory.** The Z86C21 can address up to 56K bytes of external program memory (Figure 10). The first 12 bytes of program memory are reserved for the interrupt vectors. These locations contain six 16-bit vectors that correspond to the six available interrupts. For ROM mode, byte 13 to byte 8191 consists of on-chip ROM. At addresses 8192 and greater, the Z86C21 executes external program memory fetches. In the ROMless mode, the Z86C21 can address up to 64K bytes of external program memory. Program execution begins at external location 000C (HEX) after a reset.



Figure 10. Program Memory Configuration

**Data Memory** (/DM). The ROM version can address up to 56K bytes of external data memory space beginning at location 8192. The ROMless version can address up to 64K bytes of external data memory. External data memory can be included with, or separated from, the external program memory space. /DM, an optional I/O function that can be programmed to appear on P34, is used to distinguish between data and program memory space (Figure 11). The state of the /DM signal is controlled by the type instruction being executed. An LDC opcode references PROGRAM (/DM inactive) memory, and an LDE instruction references DATA (/DM active Low) memory.



Figure 11. Data Memory Configuration

**Register File.** The Register File consists of four I/O port registers, 236 general-purpose registers and 16 control and status registers (Figure 12). The instructions can access registers directly or indirectly through an 8-bit address field. The Z86C21 also allows short 4-bit register addressing using the Register Pointer (Figure 13). In the 4-bit mode, the Register File is divided into 16 working

register groups, each occupying 16 continuous locations. The Register Pointer addresses the starting location of the active working-register group. For the reset and power-up conditions of the Register File, see Figure 14.

**Note:** Register Bank E0-EF can only be accessed through working registers and indirect addressing modes.



Figure 12. Register File



Figure 13. Register Pointer

# **FUNCTIONAL DESCRIPTION** (Continued)



Figure 14. RAM Register File Reset Condition

**RAM Protect.** The upper portion of the RAM's address spaces 80FH to EFH (excluding the control registers) can be protected from reading and writing. The RAM Protect bit option is mask-programmable and is selected by the customer when the ROM code is submitted. After the mask option is selected, the user activates from the internal ROM code to turn off/on the RAM Protect by loading a bit D6 in the IMR register to either a 0 or a 1, respectively. A 1 in D6 indicates RAM Protect enabled.

**ROM Protect.** The first 8 Kbytes of program memory is mask programmable. A ROM protect feature prevents dumping of the ROM contents by inhibiting execution of LDC, LDCI, LDE, and LDEI instructions to Program Memory in all modes.

The ROM Protect option is mask-programmable, to be selected by the customer at the time when the ROM code is submitted.

**Note:** With RAM/ROM protect on, the Z86C21 cannot access the memory space.

**Stack.** The Z86C21 has a 16-bit Stack Pointer (R254-R255) used for external stack that resides anywhere in the data memory for the ROMless mode, but only from 8192 to 65535 in the ROM mode. An 8-bit Stack Pointer (R255) is used for the internal stack that resides within the 236 general-purpose registers (R4-R239). The high byte of the Stack Pointer (SPH-Bit 8-15) is used as a general-purpose register when using internal stack only.

----

**Counter/Timers.** There are two 8-bit programmable counter/timers (T0-T1), each driven by its own 6-bit programmable prescaler. The T1 prescaler is driven by internal or external clock sources; however, the T0 prescaler is driven by the internal clock only (Figure 15).

The 6-bit prescalers divides the input frequency of the clock source by any integer number from 1 to 64. Each prescaler drives its counter, which decrements the value (1 to 256) that has been loaded into the counter. When both the counter and prescaler reach the end of the count, a timer interrupt request, IRQ4 (T0) or IRQ5 (T1), is generated.

The counter can be programmed to start, stop, restart to continue, or restart from the initial value. The counters can

also be programmed to stop upon reaching zero (single pass mode) or to automatically reload the initial value and continue counting (modulo-n continuous mode).

The counter, but not the prescalers, can be read at any time without disturbing their value or count mode. The clock source for T1 is user-definable and can be either the internal microprocessor clock divided by four, or an external signal input through Port 3. The Timer Mode register configures the external timer input (P31) as an external clock, a trigger input that is retriggerable or non-retriggerable, or as a gate input for the internal clock. Port 3, line P36, also serves as a timer output ( $T_{\rm out}$ ) through which T0, T1 or the internal clock is output. The counter/timers are cascaded by connecting the T0 output to the input of T1.



Figure 15. Counter/Timers Block Diagram

# **FUNCTIONAL DESCRIPTION** (Continued)

**Interrupts.** The Z86C21 has six different interrupts from eight different sources. The interrupts are maskable and prioritized. The eight sources are divided as follow: four sources are claimed by Port 3, lines P33-P30; one in Serial Out, one in Serial In, and two in the counter/timers (Figure 16). The Interrupt Mask Register globally or individually enables or disables the six interrupt requests. When more than one interrupt is pending, priorities are resolved by a programmable priority encoder that is controlled by the Interrupt Priority register. (Refer to Table 4.)

All Z86C21 interrupts are vectored through locations in the program memory. When an interrupt machine cycle is activated, an interrupt request is granted. Thus, this disables all of the subsequent interrupts, save the Program Counter and Status Flags, and then branches to the program memory vector location reserved for that interrupt. This memory location and the next byte contain the 16-bit address of the interrupt service routine for that particular interrupt request.

To accommodate polled interrupt systems, interrupt inputs are masked and the Interrupt Request register is polled to determine which of the interrupt requests need service. Software initialed interrupts are supported by setting the appropriate bit in the Interrupt Request Register (IRQ).

Internal interrupt requests are sampled on the falling edge of the last cycle of every instruction, and the interrupt request must be valid 5TpC before the falling edge of the last clock cycle of the currently executing instruction.

For the ROMless mode, when the device samples a valid interrupt request, the next 48 (external) clock cycles are used to prioritize the interrupt, and push the two PC bytes and the FLAG register on the stack. The following nine cycles are used to fetch the interrupt vector from external memory. The first byte of the interrupt service routine is fetched beginning on the 58th TpC cycle following the internal sample point, which corresponds to the 63rd TpC cycle following the external interrupt sample point.



Figure 16. Interrupt Block Diagram

**Clock.** The Z86C21 on-chip oscillator has a high-gain, parallel-resonant amplifier for connection to a crystal, LC, ceramic resonator, or any suitable external clock source (XTAL1 = Input, XTAL2 = Output). The crystal should be AT cut, 1 MHz to 16 MHz max, and series resistance (RS) is less than or equal to 100 Ohms. The crystal should be connected across XTAL1 and XTAL2 using the recom-

mended capacitors (10 pF < CL < 300 pF) from each pin 11, ground instead of just system ground. This prevents noise injection into the clock input (Figure 17).

**Note:** Actual capacitor value is specified by the crystal manufacturer.



Figure 17. Oscillator Configuration

**HALT.** Turns off the internal CPU clock but not the XTAL oscillation. The counter/timers and the external interrupts IRQ0, IRQ1, IRQ2, and IRQ3 remain active. The device is recovered by interrupts, either externally or internally generated. An interrupt request must be executed (enabled) to exit HALT mode. After the interrupt service routine, the program continues from the instruction after the HALT.

**STOP.** This instruction turns off the internal clock and external crystal oscillation and reduces the standby current to 5  $\mu$ A (typical) or less. The STOP mode is terminated by a reset which causes the processor to restart the application program at address 000C (HEX).

In order to enter STOP (or HALT) mode, it is necessary to first flush the instruction pipeline to avoid suspending execution in mid-instruction. To do this, the user must execute a NOP (opcode=0FFH) immediately before the appropriate sleep instruction. i.e.,

FF NOP ; clear the pipeline 6F STOP ; enter STOP mode

or

FF NOP ; clear the pipeline 7F HALT ; enter HALT mode

# **ABSOLUTE MAXIMUM RATINGS**

| Symbol                                                | Description                                          | Min         | Max               | Units         |
|-------------------------------------------------------|------------------------------------------------------|-------------|-------------------|---------------|
| V <sub>CC</sub><br>T <sub>STG</sub><br>T <sub>A</sub> | Supply Voltage*<br>Storage Temp<br>Oper Ambient Temp | -0.3<br>-65 | +7.0<br>+150<br>† | °C<br>°C<br>V |

### Notes:

Stresses greater than those listed under Absolute Maximum Ratings may cause permanent damage to the device. This is a stress rating only; operation of the device at any condition above those indicated in the operational sections of these specifications is not implied. Exposure to absolute maximum rating conditions for an extended period may affect device reliability.

# STANDARD TEST CONDITIONS

The characteristics listed below apply for standard test conditions as noted. All voltages are referenced to GND. Positive current flows into the referenced pin (Figure 18).



Figure 18. Test Load Diagram

<sup>\*</sup> Voltages on all pins with respect to GND.

<sup>†</sup> See Ordering Information

|                     |                          | T <sub>A</sub> = to +7  |                      | T <sub>A</sub> = -      |                      | Typical |       |                                                              |
|---------------------|--------------------------|-------------------------|----------------------|-------------------------|----------------------|---------|-------|--------------------------------------------------------------|
| Sym                 | Parameter                | Min                     | Max                  | Min                     | Max                  | @ 25°C  | Units | Conditions                                                   |
|                     | Max Input Voltage        |                         | 7                    |                         | 7                    |         | V     | I <sub>IN</sub> < 250 μA                                     |
| $V_{\rm CH}$        | Clock Input High Voltage | 3.8                     | $V_{CC} + 0.3$       | 3.8                     | $V_{CC} + 0.3$       |         | V     | Driven by External Clock Generator                           |
| V <sub>CL</sub>     | Clock Input Low Voltage  | -0.3                    | 8.0                  | -0.3                    | 8.0                  |         | V     | Driven by External Clock Generator                           |
| V <sub>IH</sub>     | Input High Voltage       | 2                       | V <sub>cc</sub> +0.3 | 2.0                     | V <sub>cc</sub> +0.3 |         | V     |                                                              |
| V <sub>IL</sub>     | Input Low Voltage        | -0.3                    | 8.0                  | -0.3                    | 8.0                  |         | V     |                                                              |
| V <sub>OH</sub>     | Output High Voltage      | 2.4                     |                      | 2.4                     |                      |         | V     | $I_{OH} = -2.0 \text{ mA}$                                   |
| $\overline{V}_{OH}$ | Output High Voltage      | V <sub>cc</sub> –100 mV |                      | V <sub>cc</sub> –100 mV |                      |         | V     | $I_{OH} = -100  \mu A$                                       |
| V <sub>OL</sub>     | Output Low Voltage       |                         | 0.4                  |                         | 0.4                  |         | V     | $I_{OL} = +5.0 \text{ mA}$                                   |
| $V_{RH}^{ol}$       | Reset Input High Voltage | 3.8                     | $V_{CC} + 0.3$       | 3.8                     | V <sub>CC</sub> +0.3 |         | V     | 02                                                           |
| $V_{RI}$            | Reset Input Low Voltage  | -0.3                    | 0.8                  | -0.3                    | 0.8                  |         | V     |                                                              |
| $I_{\parallel}$     | Input Leakage            | -2                      | 2                    | -2                      | 2                    |         | μΑ    | $V_{IN} = 0V, V_{CC}$                                        |
| l <sub>OL</sub>     | Output Leakage           | -2                      | 2                    | -2                      | 2                    |         | μΑ    | $V_{IN} = 0V, V_{CC}$                                        |
| I <sub>IR</sub>     | Reset Input Current      |                         | -80                  |                         | -80                  |         | μΑ    | $V_{RI} = 0V$                                                |
| Icc                 | Supply Current           |                         | 30                   |                         | 30                   | 20      | mA    | [1] @ 12 MHz                                                 |
|                     |                          |                         | 35                   |                         | 35                   | 24      | mA    | [1] @ 16 MHz                                                 |
| I <sub>CC1</sub>    | Standby Current          |                         | 6.5                  |                         | 6.5                  | 4       | mA    | [1] HALT mode V <sub>IN</sub> = OV, V <sub>CC</sub> @ 12 MHz |
|                     |                          |                         | 7                    |                         | 7                    | 4.5     | mA    | [1] HALT mode $V_{IN} = OV$ , $V_{CC}$ @ 16 MHz              |
| $I_{CC2}$           | Standby Current          |                         | 10                   |                         | 20                   | 1       | μΑ    | [1] STOP mode $V_{IN} = OV$ , $V_{CC}$                       |
| I <sub>ALL</sub>    | Auto Latch Low Current   | -10                     | 10                   | -14                     | 14                   | 5       | μΑ    | -                                                            |

### Note

[1] All inputs driven to either 0V or  $\rm V_{\rm cc'}$  outputs floating.

**AC CHARACTERISTICS**External I/O or Memory Read or Write Timing Diagram



Figure 19. External I/O or Memory Read/Write Timing

**AC CHARACTERISTICS**External I/O or Memory Read or Write Timing Table

|    |           |                                            |     | = 0°C 1<br>MHz |     | °C<br>MHz |     | = -40°<br>2 MHz |     | 105°C<br>MHz |       |         |
|----|-----------|--------------------------------------------|-----|----------------|-----|-----------|-----|-----------------|-----|--------------|-------|---------|
| No | Symbol    | Parameter                                  | Min | Max            | Min | Max       | Min | Max             | Min | Max          | Units | Notes   |
| 1  | TdA(AS)   | Address Valid to /AS Rise Delay            | 35  |                | 25  |           | 35  |                 | 25  |              | ns    | [2,3]   |
| 2  | TdAS(A)   | /AS Rise to Address Float Delay            | 45  |                | 35  |           | 45  |                 | 35  |              | ns    | [2,3]   |
| 3  | TdAS(DR)  | /AS Rise to Read Data Reg'd Valid          |     | 250            |     | 180       |     | 250             |     | 180          | ns    | [1,2,3] |
| 4  | TwAS      | /AS Low Width                              | 55  |                | 40  |           | 55  |                 | 40  |              | ns    | [2,3]   |
| 5  | TdAZ(DS)  | Address Float to /DS Fall                  | 0   |                | 0   |           | 0   |                 | 0   |              | ns    |         |
| 6  | TwDSR     | /DS (Read) Low Width                       | 185 |                | 135 |           | 185 |                 | 135 |              | ns    | [1,2,3] |
| 7  | TwDSW     | /DS (Write) Low Width                      | 110 |                | 80  |           | 110 |                 | 80  |              | ns    | [1,2,3] |
| 8  | TdDSR(DR) | /DS Fall to Read Data Req'd Valid          |     | 130            |     | 75        |     | 130             |     | 75           | ns    | [1,2,3] |
| 9  | ThDR(DS)  | Read Data to /DS Rise Hold Time            | 0   |                | 0   |           | 0   |                 | 0   |              | ns    | [2,3]   |
| 10 | TdDS(A)   | /DS Rise to Address Active Delay           | 65  |                | 50  |           | 65  |                 | 50  |              | ns    | [2,3]   |
| 11 | TdDS(AS)  | /DS Rise to /AS Fall Delay                 | 45  |                | 35  |           | 45  |                 | 35  |              | ns    | [2,3]   |
| 12 | TdR/W(AS) | R//W Valid to /AS Rise Delay               | 30  |                | 20  |           | 33  |                 | 25  |              | ns    | [2,3]   |
| 13 | TdDS(R/W) | /DS Rise to R//W Not Valid                 | 50  |                | 35  |           | 50  |                 | 35  |              | ns    | [2,3]   |
| 14 | TdDW(DSW) | Write Data Valid to /DS Fall (Write) Delay | 35  |                | 25  |           | 35  |                 | 25  |              | ns    | [2,3]   |
| 15 | TdDS(DW)  | /DS Rise to Write Data Not Valid Delay     | 55  |                | 35  |           | 55  |                 | 35  |              | ns    | [2,3]   |
| 16 | TdA(DR)   | Address Valid to Read Data Req'd Valid     |     | 310            |     | 230       |     | 310             |     | 230          | ns    | [1,2,3] |
| 17 | TdAS(DS)  | /AS Rise to /DS Fall Delay                 | 65  |                | 45  |           | 65  |                 | 45  |              | ns    | [2,3]   |
| 18 | TdDM(AS)  | /DM Valid to /AS Rise Delay                | 50  |                | 30  |           | 50  |                 | 30  |              | ns    | [2,3]   |

# Notes:

- [1] When using extended memory timing add 2 TpC.
- [2] Timing numbers given are for minimum TpC.
  [3] See clock cycle dependent characteristics table.

# Standard Test Load

All timing references use 2.0V for a logic 1 and 0.8V for a logic 0.

# **Clock Dependent Formulas**

| Number | Symbol    | Equation        |
|--------|-----------|-----------------|
| 1      | TdA(AS)   | 0.40TpC + 0.32  |
| 2      | TdAS(A)   | 0.59TpC - 3.25  |
| 3      | TdAS(DR)  | 2.83TpC + 6.14  |
| 4      | TwAS      | 0.66TpC - 1.65  |
| 6      | TwDSR     | 2.33TpC - 10.56 |
| 7      | TwDSW     | 1.27TpC + 1.67  |
| 8      | TdDSR(DR) | 1.97TpC - 42.5  |
| 10     | TdDS(A)   | 0.8TpC          |
| 11     | TdDS(AS)  | 0.59TpC - 3.14  |
| 12     | TdR/W(AS) | 0.4TpC          |
| 13     | TdDS(R/W) | 0.8TpC - 15     |
| 14     | TdDW(DSW) | 0.4TpC          |
| 15     | TdDS(DW)  | 0.88TpC - 19    |
| 16     | TdA(DR)   | 4TpC -20        |
| 17     | TdAS(DS)  | 0.91TpC -10.7   |
| 18     | TdDM(AS)  | 0.9TpC - 26.3   |

.....

# **AC CHARACTERISTICS**

Additional Timing Diagram



Figure 20. Additional Timing

# **AC CHARACTERISTICS**

Additional Timing Table

|               |                                |                                                                                                              | T <sub>A</sub>      | = 0°C to   | +70°C               |            | T <sub>A</sub> =    | = -40°C    | to +105             | °C         |          |                         |
|---------------|--------------------------------|--------------------------------------------------------------------------------------------------------------|---------------------|------------|---------------------|------------|---------------------|------------|---------------------|------------|----------|-------------------------|
| No            | Sym                            | Parameter                                                                                                    | 12 Min              | ИНz<br>Max | 16 Min              | ИНz<br>Max | 12 M<br>Min         | IHz<br>Max | 16 ľ<br>Min         | MHz<br>Max | Units    | Notes                   |
| 1 2           | TpC<br>TrC,TfC                 | Input Clock Period<br>Clock Input Rise & Fall Times                                                          | 83                  | 1000<br>15 | 62.5                | 1000<br>10 | 83                  | 1000<br>15 | 62.5                | 1000<br>10 | ns<br>ns | [1]<br>[1]              |
| 3<br>4        | TwC<br>TwTinL                  | Input Clock Width<br>Timer Input Low Width                                                                   | 35<br>75            |            | 25<br>75            |            | 35<br>75            |            | 25<br>75            |            | ns<br>ns | [1]<br>[2]              |
| 5<br>6<br>7   | TwTinH<br>TpTin<br>TrTin,TfTin | Timer Input High Width<br>Timer Input Period<br>Timer Input Rise & Fall Times                                | 3TpC<br>8TpC<br>100 |            | 3TpC<br>8TpC<br>100 |            | 3TpC<br>8TpC<br>100 |            | 3TpC<br>8TpC<br>100 |            | ns       | [2]<br>[2]<br>[2]       |
| 8A<br>8B<br>9 | TwIL<br>TwIL<br>TwIH           | Interrupt Request Input Low Times<br>Interrupt Request Input Low Times<br>Interrupt Request Input High Times | 70<br>3TpC<br>3TpC  |            | 70<br>3TpC<br>3TpC  |            | 70<br>3TpC<br>3TpC  |            | 50<br>3TpC<br>3TpC  |            | ns       | [2,4]<br>[2,5]<br>[2,3] |

### Notes:

- [1] Clock timing references use 3.8V for a logic 1 and 0.8V for a logic 0.
- [2] Timing references use 2.0V for a logic 1 and 0.8V for a logic 0.
- [3] Interrupt references request through Port 3.
- [4] Interrupt request through Port 3 (P33-P31).
- [5] Interrupt request through Port 30.

# **AC CHARACTERISTICS**

Handshake Timing Diagrams



Figure 21. Input Handshake Timing



Figure 22. Output Handshake Timing

# **AC CHARACTERISTICS**

Handshake Timing Table

|    |              |                            | Т         | <sub>A</sub> = 0°C | to +70°( | )          | T <sub>A</sub> = | –40°C t    | o +105°   | C          |                   |
|----|--------------|----------------------------|-----------|--------------------|----------|------------|------------------|------------|-----------|------------|-------------------|
| No | Sym          | Parameter                  | 12<br>Min | MHz<br>Max         | 16 Min   | MHz<br>Max | 12 N<br>Min      | ЛНz<br>Max | 16<br>Min | MHz<br>Max | Data<br>Direction |
| 1  | TsDI(DAV)    | Data In Setup Time         | 0         |                    | 0        |            | 0                |            | 0         |            | IN                |
| 2  | ThDI(DAV)    | Data In Hold Time          | 145       |                    | 145      |            | 145              |            | 145       |            | IN                |
| 3  | TwDAV        | Data Available Width       | 110       |                    | 110      |            | 110              |            | 110       |            | IN                |
| 4  | TdDAVI(RDY)  | DAV Fall to RDY Fall Delay |           | 115                |          | 115        |                  | 115        |           | 115        | IN                |
| 5  | TdDAVId(RDY) | DAV Rise to RDY Rise Delay |           | 115                |          | 115        |                  | 115        |           | 115        | IN                |
| 6  | TdRDYO(DAV)  | RDY Rise to DAV Fall Delay | 0         |                    | 0        |            | 0                |            | 0         |            | IN                |
| 7  | TdD0(DAV)    | Data Out to DAV Fall Delay |           | TpC                |          | TpC        |                  | TpC        |           | TpC        | OUT               |
| 8  | TdDAV0(RDY)  | DAV Fall to RDY Fall Delay | 0         | ·                  | 0        | ·          | 0                |            | 0         | ·          | OUT               |
| 9  | TdRDY0(DAV)  | RDY Fall to DAV Rise Delay |           | 115                |          | 115        |                  | 115        |           | 115        | OUT               |
| 10 | TwRDY        | RDY Width                  | 110       |                    | 110      |            | 110              |            | 110       |            | OUT               |
| 11 | TdRDY0d(DAV) | RDY Rise to DAV Fall Delay |           | 115                |          | 115        |                  | 115        |           | 115        | OUT               |

# **Z8 CONTROL REGISTER DIAGRAMS**

# R240 SIO D7 D6 D5 D4 D3 D2 D1 D0 Serial Data (D0 = LSB)

Figure 23. Serial I/O Register (F0<sub>u</sub>: Read/Write)



Figure 24. Timer Mode Register (F1<sub>H</sub>: Read/Write)



Figure 25. Counter/Timer 1 Register (F2<sub>H</sub>: Read/Write)



Figure 26. Prescaler 1 Register (F3<sub>H</sub>: Write Only)



Figure 27. Counter/Timer 0 Register (F4<sub>"</sub>: Read/Write)



Figure 28. Prescaler 0 Register (F5<sub>H</sub>: Write Only)



Figure 29. Port 2 Mode Register (F6<sub>H</sub>: Write Only)



Figure 30. Port 3 Mode Register (F7<sub>H</sub>: Write Only)



Figure 31. Port 0 and 1 Mode Register (F8<sub>n</sub>: Write Only)



Figure 32. Interrupt Priority Register (F9<sub>H</sub>: Write Only)

# **Z8 CONTROL REGISTER DIAGRAMS** (Continued)



Figure 33. Interrupt Request Register (FA<sub>H</sub>: Read/Write)



Figure 36. Register Pointer Register (FD<sub>n</sub>: Read/Write)



Figure 34. Interrupt Mask Register (FB<sub>H</sub>: Read/Write)



Figure 37. Stack Pointer Register (FE<sub>H</sub>: Read/Write)



Figure 35. Flag Register (FC<sub>H</sub>: Read/Write)



Figure 38. Stack Pointer Register (FF<sub>H</sub>: Read/Write)

----- .....<del>-</del>----

# INSTRUCTION SET NOTATION

**Addressing Modes.** The following notation is used to describe the addressing modes and instruction operations as shown in the instruction summary.

**Symbol** Meaning **IRR** Indirect register pair or indirect workingregister pair address Indirect working-register pair only Irr Χ Indexed address DA Direct address Relative address RA IM Immediate Register or working-register address R Working-register address only Indirect-register or indirect IR working-register address Indirect working-register address only lr Register pair or working register pair RR address

**Symbols.** The following symbols are used in describing the instruction set.

| Symbol | Meaning                              |
|--------|--------------------------------------|
| dst    | Destination location or contents     |
| src    | Source location or contents          |
| CC     | Condition code                       |
| @      | Indirect address prefix              |
| SP     | Stack Pointer                        |
| PC     | Program Counter                      |
| FLAGS  | Flag register (Control Register 252) |
| RP     | Register Pointer (R253)              |
| IMR    | Interrupt mask register (R251)       |

**Flags.** Control register (R252) contains the following six flags:

| Symbol        | Meaning                             |
|---------------|-------------------------------------|
| С             | Carry flag                          |
| Z             | Zero flag                           |
| S             | Sign flag                           |
| V             | Overflow flag                       |
| D             | Decimal-adjust flag                 |
| Н             | Half-carry flag                     |
| Affected flag | gs are indicated by:                |
| 0             | Clear to zero                       |
| 1             | Set to one                          |
| *             | Set to clear according to operation |
| _             | Unaffected                          |
| X             | Undefined                           |

# <del>----</del>

# **CONDITION CODES**

| Value | Mnemonic | Meaning                        | Flags Set             |
|-------|----------|--------------------------------|-----------------------|
| 1000  |          | Always True                    |                       |
| 0111  | С        | Carry                          | C = 1                 |
| 1111  | NC       | No Carry                       | C = 0                 |
| 0110  | Ζ        | Zero                           | Z = 1                 |
| 1110  | NZ       | Not Zero                       | Z = 0                 |
| 1101  | PL       | Plus                           | S = 0                 |
| 0101  | MI       | Minus                          | S = 1                 |
| 0100  | OV       | Overflow                       | V = 1                 |
| 1100  | NOV      | No Overflow                    | V = 0                 |
| 0110  | EQ       | Equal                          | Z = 1                 |
| 1110  | NE       | Not Equal                      | Z = 0                 |
| 1001  | GE       | Greater Than or Equal          | (S XOR V) = 0         |
| 0001  | LT       | Less than                      | (S XOR V) = 1         |
| 1010  | GT       | Greater Than                   | [Z OR (S XOR V)] = 0  |
| 0010  | LE       | Less Than or Equal             | [Z OR (S XOR V)] = 1  |
| 1111  | UGE      | Unsigned Greater Than or Equal | C = 0                 |
| 0111  | ULT      | Unsigned Less Than             | C = 1                 |
| 1011  | UGT      | Unsigned Greater Than          | (C = 0 AND Z = 0) = 1 |
| 0011  | ULE      | Unsigned Less Than or Equal    | (C OR Z) = 1          |
| 0000  | F        | Never True (Always False)      |                       |

# **INSTRUCTION FORMATS**



### **One-Byte Instructions**



# **Two-Byte Instructions**

# **Three-Byte Instructions**

# INSTRUCTION SUMMARY

**Note:** Assignment of a value is indicated by the symbol "  $\leftarrow$  ". For example:

notation "addr (n)" is used to refer to bit (n) of a given operand location. For example:

dst ← dst + src

dst (7)

indicates that the source data is added to the destination data and the result is stored in the destination location. The

refers to bit 7 of the destination operand.

# **INSTRUCTION SUMMARY** (Continued)

| Instruction and Operation                                                                      | Address<br>Mode<br>dst src | Opcode<br>Byte (Hex) |   | ags<br>Z |   |   |   | Н |
|------------------------------------------------------------------------------------------------|----------------------------|----------------------|---|----------|---|---|---|---|
| <b>ADC</b> dst, src<br>dst←dst + src + C                                                       | †                          | 1[]                  | * | *        | * | * | 0 | * |
| <b>ADD</b> dst, src<br>dst←dst + src                                                           | Ť                          | 0[]                  | * | *        | * | * | 0 | * |
| AND dst, src<br>dst←dst AND src                                                                | Ť                          | 5[]                  | - | *        | * | 0 | - | - |
| CALL dst<br>SP←SP - 2<br>@SP←PC,<br>PC←dst                                                     | DA<br>IRR                  | D6<br>D4             | - | -        | - | - | - | - |
| CCF<br>C←NOT C                                                                                 |                            | EF                   | * | -        | - | - | - | - |
| CLR dst<br>dst←0                                                                               | R<br>IR                    | B0<br>B1             | - | -        | - | - | - | - |
| COM dst<br>dst←NOT dst                                                                         | R<br>IR                    | 60<br>61             | - | *        | * | 0 | - | - |
| CP dst, src<br>dst – src                                                                       | Ť                          | A[ ]                 | * | *        | * | * | - | - |
| <b>DA</b> dst dst←DA dst                                                                       | R<br>IR                    | 40<br>41             | * | *        | * | Χ | - | - |
| <b>DEC</b> dst dst←dst - 1                                                                     | R<br>IR                    | 00<br>01             | - | *        | * | * | - | - |
| <b>DECW</b> dst dst←dst – 1                                                                    | RR<br>IR                   | 80<br>81             | - | *        | * | * | - | - |
| <b>DI</b> IMR(7)←0                                                                             |                            | 8F                   | - | -        | - | - | - | - |
| <b>DJNZ</b> r, dst $r\leftarrow r-1$ if $r\neq 0$ $PC\leftarrow PC+dst$ Range: $+127$ , $-128$ | RA                         | rA<br>r = 0 - F      | - | -        | - | - | - | - |
| <b>EI</b> IMR(7)←1                                                                             |                            | 9F                   | - | -        | - | - | - | - |
| HALT                                                                                           |                            | 7F                   | - | -        | - | - | - | - |

| Instruction                                                         | Add<br>Mod                                             | lress<br>de                                                   | Opcode                                                                      | FI | ags | Af | fect | ted |   |
|---------------------------------------------------------------------|--------------------------------------------------------|---------------------------------------------------------------|-----------------------------------------------------------------------------|----|-----|----|------|-----|---|
| and Operation                                                       |                                                        | src                                                           | Byte (Hex)                                                                  |    |     |    |      |     | Н |
| INC dst<br>dst←dst + 1                                              | r<br>R<br>IR                                           |                                                               | rE<br>r = 0 - F<br>20<br>21                                                 | -  | *   | *  | *    | -   | - |
| INCW dst<br>dst←dst + 1                                             | RR<br>IR                                               |                                                               | A0<br>A1                                                                    | -  | *   | *  | *    | -   | - |
| IRET FLAGS←@SP; SP←SP + 1 PC←@SP; SP←SP + 2; IMR(7)←1               |                                                        |                                                               | BF                                                                          | *  | *   | *  | *    | *   | * |
| <b>JP</b> cc, dst<br>if cc is true<br>PC←dst                        | DA<br>IRR                                              |                                                               | cD<br>c = 0 - F<br>30                                                       | -  | -   | -  | -    | -   | - |
| JR cc, dst<br>if cc is true,<br>PC←PC + dst<br>Range: +127,<br>–128 | RA                                                     |                                                               | cB<br>c = 0 - F                                                             | -  | -   | -  | -    | -   | - |
| <b>LD</b> dst, src<br>dst←src                                       | r<br>R<br>R<br>X<br>r<br>Ir<br>R<br>R<br>R<br>IR<br>IR | Im<br>R<br>r<br>X<br>r<br>Ir<br>r<br>R<br>IR<br>IM<br>IM<br>R | rC<br>r8<br>r9<br>r = 0 - F<br>C7<br>D7<br>E3<br>F3<br>E4<br>E5<br>E6<br>E7 | -  | -   | -  | -    | -   | - |
| LDC dst, src                                                        | r                                                      | Irr                                                           | C2                                                                          | -  | -   | -  | -    | -   | - |
| LDCI dst, src<br>dst←src<br>r←r +1;<br>rr←rr + 1                    | Ir                                                     | Irr                                                           | C3                                                                          | -  | -   | -  | -    | -   | - |

# **INSTRUCTION SUMMARY** (Continued)

| Instruction and Operation         | Address<br>Mode<br>dst src | Opcode<br>Byte (Hex) |   | ags<br>Z |   |   | ted<br>D | н |
|-----------------------------------|----------------------------|----------------------|---|----------|---|---|----------|---|
| NOP                               |                            | FF                   | - | -        | - | - | -        | - |
| OR dst, src<br>dst←dst OR src     | †                          | 4[]                  | - | *        | * | 0 | -        | - |
| POP dst<br>dst←@SP;<br>SP←SP + 1  | R<br>IR                    | 50<br>51             | - | -        | - | - | -        | - |
| PUSH src<br>SP←SP – 1;<br>@SP←src | R<br>IR                    | 70<br>71             | - | -        | - | - | -        | - |
| <b>RCF</b><br>C←0                 |                            | CF                   | 0 | -        | - | - | -        | - |
| RET<br>PC←@SP;<br>SP←SP + 2       |                            | AF                   | - | -        | - | - | -        | - |
| RL dst                            | R<br>IR                    | 90<br>91             | * | *        | * | * | -        | - |
| RLC dst                           | R<br>IR                    | 10<br>11             | * | *        | * | * | -        | - |
| RR dst                            | R<br>IR                    | E0<br>E1             | * | *        | * | * | -        | - |
| RRC dst                           | R<br>IR                    | C0<br>C1             | * | *        | * | * | -        | - |
| <b>SBC</b> dst, src dst←dst←src←C | †                          | 3[]                  | * | *        | * | * | 1        | * |
| <b>SCF</b><br>C←1                 |                            | DF                   | 1 | -        | - | - | -        | - |
| SRA dst                           | R<br>IR                    | D0<br>D1             | * | *        | * | 0 | -        | - |
| SRP src<br>RP←src                 | lm                         | 31                   | - | -        | - | - | -        | - |

| Instruction                          | Address<br>Mode | Opcode     | Fla | ags | Af | fec | ted |   |
|--------------------------------------|-----------------|------------|-----|-----|----|-----|-----|---|
| and Operation                        | dst src         | Byte (Hex) | С   | Z   | S  | ٧   | D   | Н |
| STOP                                 |                 | 6F         | -   | -   | -  | -   | -   | - |
| SUB dst, src<br>dst←dst←src          | †               | 2[]        | *   | *   | *  | *   | 1   | * |
| <b>SWAP</b> dst                      | R<br>IR         | F0<br>F1   | X   | *   | *  | X   | -   | - |
| TCM dst, src<br>(NOT dst)<br>AND src | †               | 6[]        | -   | *   | *  | 0   | -   | - |
| TM dst, src<br>dst AND src           | †               | 7[]        | -   | *   | *  | 0   | -   | - |
| XOR dst, src<br>dst←dst<br>XOR src   | †               | B[ ]       | -   | *   | *  | 0   | -   | - |

† These instructions have an identical set of addressing modes, which are encoded for brevity. The first opcode nibble is found in the instruction set table above. The second nibble is expressed symbolically by a '[ ]' in this table, and its value is found in the following table to the left of the applicable addressing mode pair.

For example, the opcode of an ADC instruction using the addressing modes  $\bf r$  (destination) and  $\bf lr$  (source) is 13.

| Addres<br>dst | ss Mode<br>src | Lower<br>Opcode Nibble |
|---------------|----------------|------------------------|
| r             | r              | [2]                    |
| r             | Ir             | [3]                    |
| R             | R              | [4]                    |
| R             | IR             | [5]                    |
| R             | IM             | [6]                    |
| IR            | IM             | [7]                    |
|               |                |                        |

# **OPCODE MAP**

# Lower Nibble (Hex)

.....

|                    |   | 0                 | 1                 | 2                 | 3                 | 4                  | 5                  | 6                  | 7                  | 8      | 9        | Α             |    | В       | С        | D          |    | E       | F                  |
|--------------------|---|-------------------|-------------------|-------------------|-------------------|--------------------|--------------------|--------------------|--------------------|--------|----------|---------------|----|---------|----------|------------|----|---------|--------------------|
|                    |   | 6.5               | 6.5               | 6.5               | 6.5               | 10.5               | 10.5               | 10.5               | 10.5               | 6.5    | 6.5      | 12/1          |    | 12/10.0 | 6.5      | 12.1       |    | 6.5     |                    |
|                    | 0 | DEC               | DEC               | ADD               | ADD               | ADD                | ADD                | ADD                | ADD                | LD     | LD       | DJN           |    | JR      | LD       | JF         |    | INC     |                    |
|                    |   | R1                | IR1               | r1, r2            | r1, lr2           | R2, R1             | IR2, R1            | R1, IM             | IR1, IM            | r1, R2 | r2, R1   | r1, F         | RA | cc, RA  | r1, IM   | cc, [      | DA | r1<br>∎ |                    |
|                    | 1 | 6.5<br><b>RLC</b> | 6.5<br><b>RLC</b> | 6.5<br><b>ADC</b> | 6.5<br><b>ADC</b> | 10.5<br><b>ADC</b> | 10.5<br><b>ADC</b> | 10.5<br><b>ADC</b> | 10.5<br><b>ADC</b> |        |          |               |    |         |          |            |    |         |                    |
|                    |   | R1                | IR1               | r1, r2            | r1, lr2           | R2, R1             | IR2, R1            | R1, IM             | IR1, IM            |        |          |               |    |         |          |            |    |         |                    |
|                    |   | 6.5               | 6.5               | 6.5               | 6.5               | 10.5               | 10.5               | 10.5               | 10.5               |        |          |               |    |         |          |            |    |         |                    |
|                    | 2 | INC               | INC               | SUB               | SUB               | SUB                | SUB                | SUB                | SUB                |        |          |               |    |         |          |            |    |         |                    |
|                    |   | R1                | IR1               | r1, r2            | r1, lr2           | R2, R1             | IR2, R1            | R1, IM             | IR1, IM            |        |          |               |    |         |          |            |    |         |                    |
|                    | 3 | 8.0<br><b>JP</b>  | 6.1<br><b>SRP</b> | 6.5<br><b>SBC</b> | 6.5<br><b>SBC</b> | 10.5<br><b>SBC</b> | 10.5<br><b>SBC</b> | 10.5<br><b>SBC</b> | 10.5<br><b>SBC</b> |        |          |               |    |         |          |            |    |         |                    |
|                    | • | IRR1              | IM                | r1, r2            | r1, lr2           | R2, R1             | IR2, R1            | R1, IM             | IR1, IM            |        |          |               |    |         |          |            |    |         |                    |
|                    |   | 8.5               | 8.5               | 6.5               | 6.5               | 10.5               | 10.5               | 10.5               | 10.5               |        |          |               |    |         |          |            |    |         |                    |
|                    | 4 | DA                | DA                | OR                | OR                | OR                 | OR                 | OR                 | OR                 |        |          |               |    |         |          |            |    |         |                    |
|                    |   | R1                | IR1               | r1, r2            | r1, lr2           | R2, R1             | IR2, R1            | R1, IM             | IR1, IM            |        |          |               |    |         |          |            |    |         |                    |
|                    | 5 | 10.5              | 10.5              | 6.5               | 6.5               | 10.5               | 10.5               | 10.5               | 10.5               |        |          |               |    |         |          |            |    |         |                    |
|                    | 3 | POP               | POP               | AND               | AND               | AND                | AND                | AND                | AND                |        |          |               |    |         |          |            |    |         |                    |
|                    |   | R1<br>6.5         | IR1<br>6.5        | r1, r2<br>6.5     | r1, lr2<br>6.5    | R2, R1<br>10.5     | IR2, R1<br>10.5    | R1, IM<br>10.5     | IR1, IM<br>10.5    |        |          |               |    |         |          |            |    |         | 6.0                |
|                    | 6 | СОМ               | СОМ               | тсм               | TCM               | TCM                | TCM                | TCM                | TCM                |        |          |               |    |         |          |            |    |         | STOP               |
| 8                  |   | R1                | IR1               | r1, r2            | r1, Ir2           | R2, R1             | IR2, R1            | R1, IM             | IR1, IM            |        |          |               |    |         |          |            |    |         |                    |
| Ĕ                  | _ | 10/12.1           | 12/14.1           | 6.5               | 6.5               | 10.5               | 10.5               | 10.5               | 10.5               |        |          |               |    |         |          |            |    |         | 7.0                |
| Se                 | 7 | PUSH              | PUSH              | TM                | TM                | TM                 | TM                 | TM                 | TM                 |        |          |               |    |         |          |            |    |         | HALT               |
| Upper Nibble (Hex) |   | R2<br>10.5        | IR2<br>10.5       | r1, r2<br>12.0    | r1, lr2<br>18.0   | R2, R1             | IR2, R1            | R1, IM             | IR1, IM            |        |          |               |    |         |          |            |    |         | 6.1                |
| 7                  | 8 | DECW              | DECW              | LDE               | LDEI              |                    |                    |                    |                    |        |          |               |    |         |          |            |    |         | DI                 |
| 훒                  |   | RR1               | IR1               | r1, lrr2          | Ir1, Irr2         |                    |                    |                    |                    |        |          |               |    |         |          |            |    |         |                    |
|                    | _ | 6.5               | 6.5               | 12.0              | 18.0              |                    |                    |                    |                    |        |          |               |    |         |          |            |    |         | 6.1                |
|                    | 9 | RL                | RL                | LDE               | LDEI              |                    |                    |                    |                    |        |          |               |    |         |          |            |    |         | EI                 |
|                    |   | R1<br>10.5        | IR1<br>10.5       | r2, lrr1<br>6.5   | Ir2, Irr1         | 10.5               | 10.5               | 10.5               | 10.5               |        |          |               |    |         |          |            |    |         | 140                |
|                    | Α | INCW              | INCW              | CP                | 6.5<br><b>CP</b>  | 10.5<br><b>CP</b>  | CP                 | CP                 | CP                 |        |          |               |    |         |          |            |    |         | 14.0<br><b>RET</b> |
|                    |   | RR1               | IR1               | r1, r2            | r1, lr2           | R2, R1             | IR2, R1            | R1, IM             | IR1, IM            |        |          |               |    |         |          |            |    |         |                    |
|                    | _ | 6.5               | 6.5               | 6.5               | 6.5               | 10.5               | 10.5               | 10.5               | 10.5               |        |          |               |    |         |          |            |    |         | 16.0               |
|                    | В | CLR               | CLR               | XOR               | XOR               | XOR                | XOR                | XOR                | XOR                |        |          |               |    |         |          |            |    |         | IRET               |
|                    |   | R1<br>6.5         | IR1               | r1, r2<br>12.0    | r1, lr2<br>18.0   | R2, R1             | IR2, R1            | R1, IM             | IR1, IM<br>10.5    |        |          |               |    |         |          |            |    |         | 4 5                |
| (                  | С | RRC               | 6.5<br><b>RRC</b> | LDC               | LDCI              |                    |                    |                    | 10.5<br><b>LD</b>  |        |          |               |    |         |          |            |    |         | 6.5<br><b>RCF</b>  |
|                    |   | R1                | IR1               | r1, Irr2          | Ir1, Irr2         |                    |                    |                    | r1,x,R2            |        |          |               |    |         |          |            |    |         |                    |
|                    |   | 6.5               | 6.5               | 12.0              | 18.0              | 20.0               |                    | 20.0               | 10.5               |        |          |               |    |         |          |            |    |         | 6.5                |
|                    | D | SRA               | SRA               | LDC               | LDCI              | CALL*              |                    | CALL               | LD                 |        |          |               |    |         |          |            |    |         | SCF                |
|                    |   | R1                | IR1               | r1, Irr2          | Ir1, Irr2         | IRR1               | 10.5               | DA                 | r2,x,R1            |        |          |               |    |         |          |            |    |         |                    |
| ı                  | E | 6.5<br><b>RR</b>  | 6.5<br><b>RR</b>  |                   | 6.5<br><b>LD</b>  | 10.5<br><b>LD</b>  | 10.5<br><b>LD</b>  | 10.5<br><b>LD</b>  | 10.5<br><b>LD</b>  |        |          |               |    |         |          |            |    |         | 6.5<br><b>CCF</b>  |
|                    |   | R1                | IR1               |                   | r1, IR2           | R2, R1             | IR2, R1            | R1, IM             |                    |        |          |               |    |         |          |            |    |         | ""                 |
|                    |   | 8.5               | 8.5               |                   | 6.5               | 1                  | 10.5               | ,                  | ,                  |        |          |               |    |         |          |            |    |         | 6.0                |
|                    | F | SWAP              | SWAP              |                   | LD                |                    | LD                 |                    |                    | ┪      | 🖶        |               | ,  | ₩       | ₩        | 🖢          |    | ₩       | NOP                |
|                    |   | R1                | IR1               |                   | Ir1, r2           |                    | R2, IR1            |                    |                    |        | <u> </u> | 1             |    |         | <u> </u> | <u>, 1</u> |    |         | لِلل               |
|                    |   |                   | $\overline{}$     |                   |                   |                    | $\overline{}$      |                    |                    | _      |          | $\overline{}$ | _  |         |          |            |    |         | <b></b>            |
|                    |   |                   | :                 | 2                 |                   |                    | ;                  | 3                  |                    |        |          | 2             | 2  |         |          | 3          | •  |         | 1                  |

# Bytes per Instruction



# Legend:

R = 8-bit Address r = 4-bit Address R1 or r1 = Dst Address R2 or r2 = Src Address

# Sequence:

Opcode, First Operand, Second Operand

Note: Blank areas not defined.

\*2-byte instruction appears as a 3-byte instruction

# **PACKAGE INFORMATION**



# 40-Pin PDIP Package Diagram



| SYMBOL      | MILLI       | METER | INCH  |       |  |  |  |  |
|-------------|-------------|-------|-------|-------|--|--|--|--|
| STIMBUL     | MIN         | MAX   | MIN   | MAX   |  |  |  |  |
| A           | 4.27        | 4.57  | 0.168 | 0.180 |  |  |  |  |
| A1          | 2.41        | 2.92  | 0.095 | 0.115 |  |  |  |  |
| D/E         | 17.40 17.65 |       | 0.685 | 0.695 |  |  |  |  |
| D1/E1       | 16.51       | 16.66 | 0.650 | 0.656 |  |  |  |  |
| D2          | 15.24       | 16.00 | 0.500 | 0.630 |  |  |  |  |
| <b>(9</b> ) | 1.27        | TYP   | 0,050 | TYP   |  |  |  |  |

- 1. CONTROLLING DIMENSION: INCH 2. LEADS ARE COPLANAR WITHIN 0.004". 3. DIMENSION: MM INCH

44-Pin PLCC Package Diagram

# PACKAGE INFORMATION (Continued)



| SYMBOL | MILLIMETER |       | INCH      |      |
|--------|------------|-------|-----------|------|
|        | MIN        | MAX   | MIN       | MAX  |
| A1     | 0.05       | 0.25  | .002      | .010 |
| A2     | 2.00       | 2.25  | .078      | .089 |
| b      | 0.25       | 0.45  | .010      | .018 |
| С      | 0.13       | 0.20  | .005      | .008 |
| HD     | 13.70      | 14.15 | .539      | .557 |
| D      | 9.90       | 10.10 | .390      | .398 |
| HE     | 13.70      | 14.15 | .539      | .557 |
| E      | 9.90       | 10.10 | .390      | .398 |
| 0      | 0.80 TYP   |       | .0315 TYP |      |
| L      | 0.60       | 1.20  | .024      | .047 |

44-Pin QFP Package Diagram

# ORDERING INFORMATION

### Z86C21

12 MHz 16 MHz

 40-pin DIP
 44-pin PLCC
 44-pin QFP
 40-pin DIP
 44-pin PLCC
 44-pin QFP

 Z86C2112PSC
 Z86C2112VSC
 Z86C2112FSC
 Z86C2116PSC
 Z86C2116VSC
 Z86C2116FSC

 Z86C2112PEC
 Z86C2112FEC
 Z86C2112FEC
 Z86C2116PSC
 Z86C2116FSC

For fast results, contact your local Zilog Sales Office for assistance in ordering the part desired.

# **CODES**

# **Preferred Package**

P = Plastic DIP

V = Plastic Chip Carrier

# **Longer Lead Time**

F = Plastic Quad Flat Pack

# **Preferred Temperature**

 $S = 0^{\circ}C \text{ to } +70^{\circ}C$ 

# **Longer Lead Time**

 $E = -40^{\circ}C \text{ to } +105^{\circ}C$ 

# **Speeds**

12 = 12 MHz

16 = 16 MHz

### **Environmental**

C = Plastic Standard

### **Example:**



© 1997 by Zilog, Inc. All rights reserved. No part of this document may be copied or reproduced in any form or by any means without the prior written consent of Zilog, Inc. The information in this document is subject to change without notice. Devices sold by Zilog, Inc. are covered by warranty and patent indemnification provisions appearing in Zilog, Inc. Terms and Conditions of Sale only.

ZILOG, INC. MAKES NO WARRANTY, EXPRESS, STATUTORY, IMPLIED OR BY DESCRIPTION, REGARDING THE INFORMATION SET FORTH HEREIN OR REGARDING THE FREEDOM OF THE DESCRIBED DEVICES FROM INTELLECTUAL PROPERTY INFRINGEMENT. ZILOG, INC. MAKES NO WARRANTY OF MERCHANTABILITY OR FITNESS FOR ANY PURPOSE.

Zilog, Inc. shall not be responsible for any errors that may appear in this document. Zilog, Inc. makes no commitment to update or keep current the information contained in this document.

Zilog's products are not authorized for use as critical components in life support devices or systems unless a specific written agreement pertaining to such intended use is executed between the customer and Zilog prior to use. Life support devices or systems are those which are intended for surgical implantation into the body, or which sustains life whose failure to perform, when properly used in accordance with instructions for use provided in the labeling, can be reasonably expected to result in significant injury to the user.

Zilog, Inc. 210 East Hacienda Ave. Campbell, CA 95008-6600 Telephone (408) 370-8000 Telex 910-338-7621 FAX 408 370-8056

Internet: http://www.zilog.com