

# Z8681/82 Z8® ROMIess MCU

#### **FEATURES**

- Complete microcomputer, 24 I/O lines, and up to 64K bytes of addressable external space each for program and data memory.
- 143-byte register file, including 124 general-purpose registers, 3 I/O port registers, and 16 status and control registers.
- Vectored, priority interrupts for I/O, counter/timers, and UART.
- On-chip oscillator that accepts crystal or external clock drive.
- Full-duplex UART and two programmable 8-bit counter/timers, each with a 6-bit programmable prescaler.
- Register Pointer so that short, fast instructions can access any one of the nine working-register groups.
- Single +5V power supply—all I/O pins TTL compatible.
- Z8681/82 available in 8 MHz. Z8681 also available in 12 MHz.

#### **GENERAL DESCRIPTION**

The Z8681 and Z8682 are ROMless versions of the Z8 single-chip microcomputer. The Z8682 is usually more cost effective. These products differ only slightly and can be used interchangeably with proper system design to provide maximum flexibility in meeting price and delivery needs.

The Z8681/82 offers all the outstanding features of the Z8 family architecture except an on-chip program ROM. Use of external memory rather than a preprogrammed ROM enables this Z8 microcomputer to be used in low volume applications or where code flexibility is required.



Figure 1. Pin Functions



Figure 2a. 40-pin Dual-In-Line Package (DIP), Pin Assignments

The Z8681/82 can provide up to 16 output address lines, thus permitting an address space of up to 64K bytes of data or program memory. Eight address outputs (AD $_0$ -AD $_7$ ) are provided by a multiplexed, 8-bit, Address/Data bus. The remaining 8 bits can be provided by the software configuration of Port 0 to output address bits A $_8$ -A $_15$ .

Available address space can be doubled (up to 128K bytes for the Z8681 and 124K bytes for the Z8682) by programming bit 4 of Port 3 (P3 $_4$ ) to act as a data memory select output ( $\overline{DM}$ ). The two states of  $\overline{DM}$  together with the 16 address outputs can define separate data and memory address spaces of up to 64K/62Kbytes each.

There are 143 bytes of RAM located on-chip and organized as a register file of 124 general-purpose registers, 16 control and status registers, and three I/O port registers. This register file can be divided into nine groups of 16 working registers each. Configuring the register file in this manner allows the use of short format instructions; in addition, any of the individual registers can be accessed directly.

The pin functions and the pin assignments of the Z8681/82 40— and 44—pin packages are illustrated in Figures 1 and 2, respectively.



Figure 2b. 44-pin Chip Carrier, Pin Assignments



Figure 3. Functional Block Diagram

#### **ARCHITECTURE**

Z8681/82 architecture is characterized by a flexible I/O scheme, an efficient register and address space structure and a number of ancillary features that are helpful in many applications.

Microcomputer applications demand powerful I/O capabilities. The Z8681/82 fulfills this with 24 pins available for input and output. These lines are grouped into three ports of eight lines each and are configurable under software control to provide timing, status signals, serial or parallel I/O with or without handshake, and an Address bus for interfacing external memory.

Three basic address spaces are available: program

memory, data memory and the register file (internal). The 143-byte random-access register file is composed of 124 general-purpose registers, three I/O port registers, and 16 control and status registers.

To unburden the program from coping with real-time problems such as serial data communication and counting/timing, an asynchronous receiver/transmitter (UART) and two counter/timers with a large number of user-selectable modes are offered on-chip. Hardware support for the UART is minimized because one of the on-chip timers supplies the bit rate. Figure 3 shows the Z8681/82 block diagram.

#### PIN DESCRIPTION

**AS.** Address Strobe (output, active Low). Address Strobe is pulsed once at the beginning of each machine cycle. Addresses output via Port 1 for all external program or data memory transfers are valid at the trailing edge of AS.

**DS.** Data Strobe (output, active Low). Data Strobe is activated once for each external memory transfer.

**P0<sub>0</sub>-P0<sub>7</sub>, P2<sub>0</sub>-P2<sub>7</sub>, P3<sub>0</sub>-P3<sub>7</sub>.** I/O Port Lines (input/outputs, TTL-compatible). These 24 lines are divided into three 8-bit I/O ports that can be configured under program control for I/O or external memory interface (Figure 3)

**P1**<sub>0</sub>-**P1**<sub>7</sub>. Address/Data Port (bidirectional). Multiplexed address (A<sub>0</sub>-A<sub>7</sub>) and data (D<sub>0</sub>-D<sub>7</sub>) lines used to interface with

program and data memory.

**RESET** . Reset (input, active Low). RESET initializes the Z8681/82. After RESET the Z8681 is in the extended memory mode. When RESET is deactivated, program execution begins from program location 000C<sub>H</sub> for the Z8681 and 0812<sub>H</sub> for the Z8682.

**R/W**. Read/Write (output). R/W is Low when the Z8681/82 is writing to external program or data memory.

**XTAL1, XTAL2.** Crystal 1, Crystal 2 (time-base input and output). These pins connect a parallel-resonant crystal to the on-chip clock oscillator and buffer.

#### **SUMMARY OF Z8681 AND Z8682 DIFFERENCES**

| Feature                                           | Z8681                                                        | Z8682                                                                                                  |  |  |  |
|---------------------------------------------------|--------------------------------------------------------------|--------------------------------------------------------------------------------------------------------|--|--|--|
| Address of first instruction executed after Reset | 12                                                           | 2066                                                                                                   |  |  |  |
| Addressable memory space                          | 0-64K                                                        | 2K-64K                                                                                                 |  |  |  |
| Address of interrupt vectors                      | 0-11                                                         | 2048-2065                                                                                              |  |  |  |
| Reset input high voltage                          | TTL levels *                                                 | 7.35-8.0V                                                                                              |  |  |  |
| Port 0 configuration after Reset                  | Input, float after reset. Can be programmed as Address bits. | Output, configured as Address bit A <sub>8</sub> -A <sub>15</sub> .                                    |  |  |  |
| External memory timing start-up configurations    | Extended Timing                                              | Normal Timing                                                                                          |  |  |  |
| Interrupt vectors                                 | 2 byte vectors point directly to service routines.           | 2 byte vectors in internal ROM point to<br>byte Jump instructions, which point to<br>service routines. |  |  |  |
| Interrupt response time                           | 26 clocks                                                    | 36 clocks                                                                                              |  |  |  |

<sup>\* 8.0</sup>V V<sub>IN</sub> max

#### ADDRESS SPACES

**Program Memory\*.** The Z8681/82 addresses 64K/62K bytes of external program memory space (Figure 4).

For the Z8681, 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. Program execution begins at location 000C<sub>H</sub> after a reset.

The Z8682 has six 24-bit interrupt vectors beginning at address 0800<sub>H</sub>. The vectors consist of Jump Absolute instructions. After a reset, program execution begins at location 0812<sub>H</sub> for the Z8682.

**Data Memory\*.** The Z8681/82 can address 64K/62K bytes of external data memory. External data memory may be included with or separated from the external program memory space.  $\overline{\rm DM}$ , an optional I/O function that can be programmed to appear on pin P3<sub>4</sub>, is used to distinguish between data and program memory space.

Register File. The 143-byte register file includes three I/O

port registers (R0, R2, R3), 124 general-purpose registers (R4-R127) and 16 control and status registers (R240-R255). These registers are assigned the address locations shown in Figure 5.

Z8681/82 instructions can access registers directly or indirectly with an 8-bit address field. This also allows short 4-bit register addressing using the Register Pointer (one of the control registers). In the 4-bit mode, the register file is divided into nine working-register groups, each occupying 16 contiguous locations (Figure 5). The Register Pointer addresses the starting location of the active working-register group (Figure 6).

**Stacks.** Either the internal register file or the external data memory can be used for the stack. A 16-bit Stack Pointer (R254 and R255) is used for the external stack, which can reside anywhere in data memory. An 8-bit Stack Pointer (R255) is used for the internal stack that resides within the 124 general-purpose registers (R4-R127).



Figure 4. Z8681/82 Program Memory Map



Figure 5. The Register File

Figure 6. The Register Pointer

#### **SERIAL INPUT/OUTPUT**

Port 3 lines P3<sub>0</sub> and P3<sub>7</sub> can be programmed as serial I/O lines for full-duplex serial asynchronous receiver/transmitter operation. The bit rate is controlled by Counter/Timer 0.

The Z8681/82 automatically adds a start bit and two stop bits to transmitted data (Figure 7). Odd parity is also available as an option. Eight data bits are always transmitted, regardless of parity selection. If parity is enabled, the eighth data bit is used as 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.



943

#### COUNTER/TIMERS

The Z8681/82 contains two 8-bit programmable counter/timers ( $T_0$  and  $T_1$ ), each driven by its own 6-bit programmable prescaler. The  $T_1$  prescaler can be driven by internal or external clock sources; however, the  $T_0$  prescaler is driven by the internal clock only.

The 6-bit prescalers can divide the input frequency of the clock source by any 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 the counter reaches the end of count, a timer interrupt request—IRQ4 ( $T_0$ ) or IRQ5 ( $T_1$ )—is generated.

The counters can be started, stopped, restarted to continue, or restarted 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 counters, but not the prescalers, can be read any time without disturbing their value or count mode.

The clock source for  $T_1$  is user-definable; it can be either the internal microprocessor clock divided by four, or an external signal input via Port 3. The Timer Mode register configures the external timer input as an external clock, a trigger input that can be retriggerable or nonretriggerable, or as a gate input for the internal clock. The counter/timers can be programmably cascaded by connecting the  $T_0$  output to the input of  $T_1$ . Port 3 line  $P_{36}$  also serves as a timer output  $(T_{OUT})$  through which  $T_0$ ,  $T_1$  or the internal clock can be output.

#### I/O PORTS

The Z8681/82 has 24 lines available for input and output. These lines are grouped into three ports of eight lines each and are configurable as input, output or address. Under software control, the ports can be programmed to provide

address outputs, timing, status signals, serial I/O, and parallel I/O with or without handshake. All ports have active pull-ups and pull-downs compatible with TTL loads.

**Port 1** is a dedicated Z-BUS compatible memory interface. The operations of Port 1 are supported by the Address Strobe  $(\overline{AS})$  and Data Strobe  $(\overline{DS})$  lines, and by the Read/Write  $(R/\overline{W})$  and Data Memory  $(\overline{DM})$  control lines. The low-order program and data memory addresses  $(A_0 \cdot A_7)$  are output through Port 1 (Figure 8) and are multiplexed with data in/out  $(D_0 \cdot D_7)$ . Instruction fetch and data memory read/write operations are done through this port.

Port 1 cannot be used as a register nor can a handshake mode be used with this port.

Both the Z8681 and Z8682 wake up with the 8 bits of Port 1 configured as address outputs for external memory. If more than eight address lines are required with the Z8681, additional lines can be obtained by programming Port 0 bits as address bits. The least-significant four bits of Port 0 can

be configured to supply address bits  $A_8 \cdot A_{11}$  for 4K byte addressing or both nibbles of Port 0 can be configured to supply address bits  $A_8 \cdot A_{15}$  for 64K byte addressing.



Figure 8, Port 1

**Port 0\*** can be programmed as a nibble I/O port, or as an address port for interfacing external memory (Figure 9). When used as an I/O port, Port 0 can be placed under handshake control. In this configuration, Port 3 lines P3<sub>2</sub> and P3<sub>5</sub> are used as the handshake controls DAV<sub>0</sub> and RDY<sub>0</sub>. Handshake signal assignment is dictated by the I/O direction of the upper nibble P0<sub>4</sub>-P0<sub>7</sub>.

For external memory references, Port 0 can provide address bits  $A_8$ - $A_{11}$  (lower nibble) or  $A_8$ - $A_{15}$  (lower and upper nibbles) depending on the required address space. If the address range requires 12 bits or less, the upper nibble of Port 0 can be programmed independently as I/O while the lower nibble is used for addressing.

In the Z8681\*, Port 0 lines float after reset; their logic state is unknown until the execution of an initialization routine that configures Port 0.

\*This feature differs in the Z8681 and Z8682.

Such an initialization routine must reside within the first 256 bytes of executable code and must be physically mapped into memory by forcing the Port 0 address lines to a known state (Figure 10). The proper port initialization sequence is:

- Write initial address (A<sub>8</sub>-A<sub>15</sub>) of initialization routine to Port 0 address lines.
- 2. Configure Port 0 Mode register to output  $A_8\text{-}A_{15}$  (or  $A_8\text{-}A_{11}$ ).

To permit the use of slow memory, an automatic wait mode of two oscillator clock cycles is configured for the bus timing of the Z8681 after each reset. The initialization routine could include reconfiguration to eliminate this extended timing mode. The following example illustrates the manner in which an initialization routine can be mapped in a Z8681 system with 4K of memory.

Example. In Figure 10, the initialization routine is mapped to the first 256 bytes of program memory. Pull-down resistors maintain the address lines at a logic 0 level when these lines are floating. The leakage current caused by fanout must be taken into consideration when selecting the value of the pulldown resistors. The resistor value must be large enough to allow the Port 0 output driver to pull the line to a logic 1. Generally, pulldown resistors are incompatible with TTL loads. If Port 0 drives into TTL input loads (I<sub>LOW</sub> = 1.6 mA) the external resistors should be tied to V<sub>CC</sub> and the initialization routine put in address space FF00<sub>H</sub>–FFFF<sub>H</sub>.

In the  $Z8682^*$ , Port 0 lines are configured as address lines  $A_8$ - $A_{15}$  after a Reset. If one or both nibbles are needed for

I/O operation, they must be configured by writing to the Port 0 Mode register. The Z8682 is in the fast memory timing mode after Reset, so the initialization routine must be in fast memory.



Figure 9. Port 0



Figure 10. Port 0 Address Lines Tied to Logic 0

**Port 2** bits can be programmed independently as input or output (Figure 11). This port is always available for I/O operations. In addition, Port 2 can be configured to provide open-drain outputs.

Like Port 0, Port 2 may also be placed under handshake control. In this configuration, Port 3 lines  $P3_1$  and  $P3_6$  are used as the handshake controls lines  $\overline{DAV}_2$  and  $RDY_2$ . The handshake signal assignment for Port 3 lines  $P3_1$  and  $P3_6$  is dictated by the direction (input or output) assigned to bit 7 of Port 2.

**Port 3** lines can be configured as I/O or control lines (Figure 12). In either case, the direction of the eight lines is fixed as four input (P3<sub>0</sub>-P3<sub>3</sub>) and four output (P3<sub>4</sub>-P3<sub>7</sub>). For serial I/O, lines P3<sub>0</sub> and P3<sub>7</sub> are programmed as serial in and serial out, respectively.

Port 3 can also provide the following control functions: handshake for Ports 0 and 2 ( $\overline{DAV}$  and RDY); four external interrupt request signals (IRQ0-IRQ3); timer input and output signals ( $T_{IN}$  and  $T_{OUT}$ ) and Data Memory Select ( $\overline{DM}$ ).



Figure 11. Port 2



Figure 12. Port 3

<sup>\*</sup>This feature differs in the Z8681 and Z8682

#### INTERRUPTS\*

The Z8681/82 allows six different interrupts from eight sources: the four Port 3 lines P3<sub>0</sub>-P3<sub>3</sub>. Serial In. Serial Out. and the two counter/timers. These interrupts are both maskable and prioritized. 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.

All Z8681 and Z8682 interrupts are vectored through locations in program memory. When an interrupt request is granted, an interrupt machine cycle is entered. This disables all subsequent interrupts, saves the Program Counter and status flags, and accesses the program memory vector location reserved for that interrupt. In the Z8681, this memory location and the next byte contain the 16-bit address of the interrupt service routine for that particular interrupt request. The Z8681 takes 63 crystal cycles to enter an interrupt subroutine.

The Z8682 has a small internal ROM that contains six 2-byte interrupt vectors pointing to addresses 2048-2065, where 3-byte jump absolute instructions are located (Figure 4 and Table 1). These jump instructions each contain a 1-byte opcode and a 2-byte starting address for the interrupt service routine.

Table 1. Z8682 Interrupt Processing

| Hex<br>Address | Contains Jump Instruction and<br>Subroutine Address For |
|----------------|---------------------------------------------------------|
| 800-802        | IRQ0                                                    |
| 803-805        | IRQ1                                                    |
| 806-808        | IRQ2                                                    |
| 809-80B        | IRQ3                                                    |
| 80C-80E        | IRQ4                                                    |
| 80F-811        | IRQ5                                                    |

Polled interrupt systems are also supported. To accommodate a polled structure, any or all of the interrupt inputs can be masked and the Interrupt Request register polled to determine which of the interrupt requests needs service.

#### **CLOCK**

The on-chip oscillator has a high-gain, parallel-resonant amplifier for connection to a crystal or to any suitable external clock source (XTAL1 = Input, XTAL2 = Output).

The crystal source is connected across XTAL1 and XTAL2, using the recommended capacitance ( $C_1 = 15 \text{ pf}$ maximum) from each pin to ground. The specifications for the crystal are as follows:

- AT cut, parallel-resonant
- Fundamental type
- Series resistance, R<sub>s</sub> ≤ 100Ω
- For Z8682, 8 MHz maximum
- For Z8681-12, 16 MHz maximum

#### Z8681/Z8682 INTERCHANGEABILITY

Although the Z8681 and Z8682 have minor differences, a system can be designed for compatibility with both ROMless versions. To achieve interchangeability, the design must take into account the special requirements of each device in the external interface, initialization, and memory mapping.



Figure 13. Z8682 RESET Pin Input Waveform

External Interface. The Z8682 requires a 7.5V positive logic level on the RESET pin for at least 6 clock periods immediately following reset, as shown in Figure 13. The Z8681 requires a 3.8V or higher positive logic level, but is compatible with the Z8682 RESET waveform. Figure 14 shows a simple circuit for generating the 7.5V level.



Figure 14. RESET Circuit

<sup>\*</sup>This feature differs in the Z8681 and Z8682

**Initialization.** The Z8681 wakes up after reset with Port 0 configured as an input, which means Port 0 lines are floating in a high-impedance state. Because of this pullup or pulldown, resistors must be attached to Port 0 lines to force them to a valid logic level until Port 0 is configured as an address port.

Port 0 initialization is discussed in the section on ports. An example of an initialization routine for Z8681/Z8682 compatibility is shown in Table 2. Only the Z8681 need execute this program.

**Table 2. Initialization Routine** 

| Address | Opcodes  | Instruction         | Comments                                                                                |
|---------|----------|---------------------|-----------------------------------------------------------------------------------------|
| 000C    | E6 00 00 | LD PO #%00          | Set A <sub>8</sub> -A <sub>15</sub> to 0.                                               |
| 000F    | E6 F8 96 | LD P01M #%96        | Configure Port 0 as A <sub>8</sub> -A <sub>15</sub> . Eliminate extended memory timing. |
| 0012    | 8D 08 12 | JP START<br>ADDRESS | Execute application program.                                                            |



Figure 15. Z8681/82 Logical Program Memory Mapping

**Memory Mapping.** The Z8681 and Z8682 lower memory boundaries are located at 0 and 2048, respectively. A single program ROM can be used with either product if the logical program memory map shown in Figure 15 is followed. The Z8681 vectors and initialization routine must be starting at

address 0 and the Z8682 3-byte vectors (jump instructions) must be at address 2048 and higher. Addresses in the range 21-2047 are not used. Figure 16 shows practical schemes for implementing this memory map using 4K and 2K ROMs.



a. Logical to Physical Memory Mapping for 4K ROM



b. Logical to Physical Memory Mapping for 2K ROM

Figure 16. Practical Schemes for Implementing Z8681 and Z8682 Compatible Memory Map

#### INSTRUCTION SET NOTATION

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

IRR Indirect register pair or indirect working-register pair address

Irr Indirect working-register pair only

X Indexed address
DA Direct address
RA Relative address
IM Immediate

R Register or working-register address
r Working-register address only

IR Indirect-register or indirect working-register

address

Ir Indirect working-register address only
RR Register pair or working register pair address

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

 dst
 Destination location or contents

 src
 Source location or contents

 cc
 Condition code (see list)

 @
 Indirect address prefix

SP Stack pointer (control registers 254-255)

PC Program counter

FLAGS Flag register (control register 252)

RP Register pointer (control register 253)

IMR Interrupt mask register (control register 251)

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

dst ← dst + src

indicates that the source data is added to the destination data and the result is stored in the destination location. The notation "addr(n)" is used to refer to bit "n" of a given location. For example,

dst (7)

refers to bit 7 of the destination operand.

Flags. Control Register R252 contains the following six flags:

C Carry flag
Z Zero flag
S Sign flag
V Overflow flag
D Decimal-adjust flag
H Half-carry flag

Affected flags are indicated by:

O Cleared to zero

1 Set to one

Set or cleared according to operation

UnaffectedUndefined

### **CONDITION CODES**

| Value | Mnemonic | Meaning                        | Flags Set             |
|-------|----------|--------------------------------|-----------------------|
| 1000  |          | Always true                    |                       |
| 0111  | С        | Carry                          | C = 1                 |
| 1111  | NC       | No carry                       | C = 0                 |
| 0110  | Z        | 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) = 0 |
| 0011  | ULE      | Unsigned less than or equal    | (C OR Z) = 1          |
| 0000  |          | Never true                     | ==                    |



CCF, DI, EI, IRET, NOP, RCF, RET, SCF

OPC

Figure 17. Instruction Formats

#### INSTRUCTION SUMMARY

**INSTRUCTION FORMATS** 

|                                                     | Addr      | Mode  | Opcode        | F | lag | s A | lffe | cte | d |
|-----------------------------------------------------|-----------|-------|---------------|---|-----|-----|------|-----|---|
| Instruction and Operation                           | dst       | src   | Byte<br>(Hex) | С | z   | s   | ٧    | D   | н |
| ADC dst.src<br>dst ← dst + src + C                  | (No       | te 1) | 1!.           | * | *   | *   | *    | 0   | * |
| ADD dst.src<br>dst ← dst + src                      | (No       | te 1) | 0.            | * | *   | *   | *    | 0   | * |
| AND dst,src<br>dst ← dst AND src                    | (No       | te 1) | 5 .           |   | *   | *   | 0    | ~.  |   |
| <b>CALL</b> dst<br>SP ← SP - 2<br>@SP ← PC: PC ← ds | 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                             | (No       | te 1) | Ai            | * | *   | *   | *    |     |   |
| DA dst<br>dst ← DA ast                              | R<br>!R   |       | 40<br>41      | * | *   | *   | Х    |     |   |

|                           | Addr | Mode | Opcode            | Flags Affected |   |   |   |   |   |
|---------------------------|------|------|-------------------|----------------|---|---|---|---|---|
| Instruction and Operation | dst  | src  | Byte<br>(Hex)     | С              | Z | s | ٧ | D | Н |
| DEC dst                   | R    |      | 00                |                | * | * | * | _ | _ |
| dst ← dst – 1             | IR   |      | 01                |                |   |   |   |   |   |
| DECW dst                  | RR   |      | 80                | _              | * | * | * | _ | _ |
| dst ← dst - 1             | IR   |      | 81                |                |   |   |   |   |   |
| DI                        |      |      |                   |                |   |   |   |   |   |
| IMR (7) ← 0               |      |      | 8F                | -              |   |   | - | - |   |
| DJNZ r,dst                | RA   |      | rA.               |                | _ |   |   | _ | _ |
| r←r - 1                   |      |      | $r \approx 0 - F$ |                |   |   |   |   |   |
| if r ≠ 0                  |      |      |                   |                |   |   |   |   |   |
| PC ← PC + ast             |      |      |                   |                |   |   |   |   |   |
| Range: + 127, - 128       |      |      |                   |                |   |   | _ |   |   |
| Εl                        |      |      | 9F                |                |   | _ | _ |   |   |
| IMR (7) ← 1               |      |      |                   |                |   |   |   |   |   |
| INC dst                   |      |      | rE                |                | * | * | * | _ |   |
| ast ← dst + 1             |      |      | r = 0 - F         |                |   |   |   |   |   |
|                           | R    |      | 20                |                |   |   |   |   |   |
|                           | 1R   |      | 21                |                |   |   |   |   |   |
| INCW dst                  | RR   |      | A0                |                | * | * | * | _ |   |
| ast ← dst + 1             | iB   |      | A1                |                |   |   |   |   |   |

# **INSTRUCTION SUMMARY** (Continued)

| Instruction                                                                  | Addr N              | /lode   | Opcode<br>Byte  | Flags Affected |   |   |   |   |   |
|------------------------------------------------------------------------------|---------------------|---------|-----------------|----------------|---|---|---|---|---|
| and Operation                                                                | dst                 | src     | (Hex)           | С              | z | s | ٧ | D | ۲ |
| IRET                                                                         |                     |         | BF              | *              | * | * | * | * | * |
| FLAGS ← @SP; SP ←<br>PC ← @SP; SP ← SP                                       |                     |         | <b>←</b> 1      |                |   |   |   |   |   |
| JP cc.dst                                                                    | DA                  |         | ¢D              |                |   |   | _ |   |   |
| of cc is true                                                                | 100                 |         | c = C - F       |                |   |   |   |   |   |
| PC ← dst                                                                     | IRR                 |         | 30              |                |   |   |   |   | _ |
| <b>JR</b> cc.dst<br>if cc is true,<br>- PC ← PC + dst<br>Range: + 127, - 128 | RA<br>i             |         | cB<br>c = 0 - F |                |   |   |   |   |   |
| LD dst.src                                                                   | r                   | lm      | rC              |                |   |   |   |   |   |
| dst ← src                                                                    | r                   | R       | r8              |                |   |   |   |   |   |
|                                                                              | R                   | ſ       | r9              |                |   |   |   |   |   |
|                                                                              | r                   | Χ       | r = 0 - F<br>C7 |                |   |   |   |   |   |
|                                                                              | X                   | r       | D7              |                |   |   |   |   |   |
|                                                                              | r                   | 10      | E3              |                |   |   |   |   |   |
|                                                                              | lr                  | 1       | F3              |                |   |   |   |   |   |
|                                                                              | R<br>R              | R<br>IR | E4<br>E5        |                |   |   |   |   |   |
|                                                                              | R                   | IM      | E6              |                |   |   |   |   |   |
|                                                                              | iR                  | IM      | E7              |                |   |   |   |   |   |
|                                                                              | IR                  | R       | F5              |                |   |   |   |   |   |
| LDC dst.src                                                                  | r                   | Irr     | C2              |                |   |   |   |   |   |
| dst ← src                                                                    | Irr                 | ŗ       | D2              |                |   |   |   |   |   |
| LDCI dst.src                                                                 | ir                  | Irr     | C3              |                |   |   |   |   |   |
| dst ← src<br>r ← r + 1; rr ← rr + 1                                          | lrr                 | İr      | Đ3              |                |   |   |   |   |   |
| LDE dst.src                                                                  | r                   | Irr     | 82              |                |   |   |   |   |   |
| dst ← src                                                                    | Irr                 | r       | 92              |                |   |   |   |   |   |
| LDEI dst,src                                                                 | lr                  | Irr     | 83              |                |   |   |   |   |   |
| dst ← src                                                                    | Irr                 | lr.     | 93              |                |   |   |   |   |   |
| r ← r + 1; rr ← rr + 1                                                       |                     |         |                 |                |   |   |   |   | _ |
| NOP                                                                          |                     |         | FF              |                |   |   |   |   |   |
| OR dst.src<br>dst ← dst OR src                                               | (Note               | ÷ 1)    | 4.              |                | * | * | 0 |   |   |
| POP dst                                                                      | R                   |         | 50              |                |   |   |   |   |   |
| dst ← @SP:<br>SP ← SP + 1                                                    | ¹R                  |         | 51              |                |   |   |   |   |   |
| PUSH src                                                                     |                     | R       | 70              |                |   |   |   |   |   |
| SP ← SP - 1; @SP ←                                                           | - src               | IR      | 71              |                |   |   |   |   |   |
| RCF<br>C ← 0                                                                 |                     |         | CF              | О              |   |   |   |   |   |
| <b>RET</b><br>PC ← @SP: SP ← SP                                              | + 2                 |         | AF              |                |   |   |   |   |   |
| RL dst                                                                       | R                   |         | 90              | *              | * | * | * |   |   |
| C + 7 0                                                                      | l <del>*</del> ′ IR |         | 91              |                |   |   |   |   |   |

| Instruction                        | Addr      | Mode  | Opcode            | F | lag | s A | Affe | cte | d |
|------------------------------------|-----------|-------|-------------------|---|-----|-----|------|-----|---|
| and Operation                      | dst       | src   | Byte<br>(Hex)     | С | z   | s   | ٧    | D   | Н |
| RLC dst                            | ⊒ R<br>IR |       | 10<br>11          | * | *   | *   | *    |     | _ |
| RR dst                             | P IR      |       | E0<br>E1          | * | *   | *   | *    | _   | _ |
| RRC dst                            | R<br>IR   |       | C0<br>C1          | * | *   | *   | *    | -   | _ |
| SBC ast.src<br>dst ← dst ← src ← C | (No:      | te 1) | 31                | * | *   | *   | *    | 1   | * |
| <b>SCF</b><br>C ← 1                |           |       | DF                | 1 | _   | _   | -    | _   | _ |
| SRA dst                            | P R<br>IR |       | D0<br>D1          | * | *   | *   | 0    | _   | _ |
| SRP src<br>RP ← src                |           | lm    | 31                | _ |     |     |      | -   | _ |
| SUB dst.src<br>ast ← dst ← src     | (Not      | e 1)  | 21"               | * | *   | *   | *    | 1   | * |
| SWAP dst 7 43                      | ■ R<br>IR |       | F0<br>F1          | Х | *   | *   | Χ    |     | _ |
| TCM dst.src<br>(NOT dst) AND src   | (Not      | e 1)  | 6:                |   | *   | *   | 0    | -   | _ |
| TM dst.src<br>dst AND src          | (Not      | e 1)  | 71.               | _ | *   | *   | 0    | -   |   |
| XOR dst,src<br>dst ← dst XOR src   | (Not      | e 1)  | B <sup>····</sup> | _ | *   | *   | 0    |     | _ |
|                                    |           |       |                   |   |     |     |      |     | _ |

NOTE. These instructions have an identical set of addressing modes, which are encoded for brevity. The first opcode hibble is found in the instruction set table above. The second hibble is expressed symbolically by a first 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 if (destination) and it (source) is 13.

| Addr | Mode | Lower         |
|------|------|---------------|
| dst  | src  | Opcode Nibble |
| r    | r    | 2             |
| r    | lr   | 3             |
| R    | R    | 4             |
| R    | IR   | 5             |
| R    | IM   | 6             |
| IR   | ΙM   | 7             |

### REGISTERS **R240 SIO R244 TO** Serial I/O Register Counter/Timer 0 Register (F0H. Read/Write) (F4H; Read/Write) D, D, D, D, D, D, D, D<sub>7</sub> D<sub>6</sub> D<sub>5</sub> D<sub>4</sub> D<sub>3</sub> D<sub>2</sub> D<sub>1</sub> D<sub>0</sub> - SERIAL DATA (Do = LSB) T<sub>0</sub> INITIAL VALUE (WHEN WRITTEN) (RANGE: 1 256 DECIMAL 01 D0 HEX) T<sub>0</sub> CURRENT VALUE (WHEN READ) **R241 TMR R245 PRE0 Time Mode Register** Prescaler 0 Register (F1<sub>H</sub>; Read/Write) (F5H; Write Only) D7 D6 D5 D4 D3 D2 D1 D0 D, D, D, D, D, D, D, D, TOUT MODES NOT USED = 00 TO OUT = 01 T, OUT = 10 INTERNAL CLOCK OUT = 11 0 = NO FUNCTION COUNT MODE - 0 = T<sub>0</sub> SINGLE-PASS 1 = T<sub>0</sub> MODULO-N 0 = DISABLE To COUNT 1 = ENABLE To COUNT TIM MODES EXTERNAL CLOCK INPUT = 00 GATE INPUT = 01 TRIGGER INPUT = 01 (NON-RETRIGGERABLE) TRIGGER INPUT = 11 (RETRIGGERABLE) 0 = NO FUNCTION 1 = LOAD T. RESERVED (MUST BE 0) 0 = DISABLE T, COUNT 1 = ENABLE T, COUNT PRESCALER MODULO (RANGÉ: 1-64 DECIMAL 01-00 HEX) R242 T1 R246 P2M Counter Timer 1 Register Port 2 Mode Register (F2H; Read/Write) (F6<sub>H</sub>: Write Only) D, D, D, D, D, D, D, D, D<sub>6</sub> D<sub>5</sub> D<sub>4</sub> D<sub>3</sub> D<sub>2</sub> D, D<sub>0</sub> P2<sub>0</sub> P2<sub>7</sub> I/O DEFINITION - 0 DEFINES BIT AS OUTPUT 1 DEFINES BIT AS INPUT T, INITIAL VALUE (WHEN WRITTEN) (RANGE 1 256 DÉCIMAL 01 (10 HEX) T, CURRENT VALUE (WHEN READ) **R243 PRE1** R247 P3M Prescaler 1 Register Port 3 Mode Register (F3H; Write Only) (F7H; Write Only) D<sub>7</sub> D<sub>8</sub> D<sub>5</sub> D<sub>4</sub> D<sub>3</sub> D<sub>2</sub> D<sub>1</sub> D<sub>6</sub> D2 D6 D5 D4 D3 D2 D, D0

Figure 18. Control Registers

0 PORT 2 PULL-UPS OPEN DRAIN 1 PORT 2 PULL-UPS ACTIVE - RESERVED (MUST BE 0)

01 10 P3 INPUT

\_0 PARITY OFF

0 P32 - INPUT P35 - OUTPUT
1 P32 - DAVORDYO P35 - RDYO/DAVO
0 0 P33 - INPUT P34 - OUTPUT

0 P31 · INPUT (T<sub>IN</sub>) P36 · OUTPUT (T<sub>OUT</sub>)
1 P31 · DĀVZIRDY2 P36 · RDYZIDĀV2
0 P30 · INPUT P37 · OUTPUT
1 P30 · SERIAL IOUT

P34 : DM

COUNT MODE

1 = T, MODULO:N
0 = T, SINGLE:PASS

CLOCK SOURCE

1 T, INTERNAL

0 T, EXTERNAL
TIMING INPUT
(T<sub>IN</sub>) MODE

PRESCALER MODULO (RANGE: 1-64 DECIMAL 01-00 HEX)



Figure 18. Control Registers (Continued)

# Z8681/82 OPCODE MAP

|                    |                                     |                                      |                                                     |                                                         |                                                      |                                                           | L                                        | ower Nib                                  | ble (He                               | <b>(</b> )                                         |                                                      |                                                                                    |                                        |                               |                  |                   |
|--------------------|-------------------------------------|--------------------------------------|-----------------------------------------------------|---------------------------------------------------------|------------------------------------------------------|-----------------------------------------------------------|------------------------------------------|-------------------------------------------|---------------------------------------|----------------------------------------------------|------------------------------------------------------|------------------------------------------------------------------------------------|----------------------------------------|-------------------------------|------------------|-------------------|
|                    | 0                                   | 1                                    | 2                                                   | 3                                                       | 4                                                    | 5                                                         | 6                                        | 7                                         | 8                                     | 9                                                  | Α                                                    | В                                                                                  | С                                      | D                             | E                | F                 |
| 0                  | 6.5<br><b>DEC</b>                   | 6.5<br>DEC                           | 6.5<br><b>ADD</b>                                   | 6.5<br><b>ADD</b><br>r <sub>1</sub> .lr <sub>2</sub>    | 10.5<br><b>ADD</b><br>R <sub>2</sub> .R <sub>1</sub> | 10.5<br><b>ADD</b><br>IR <sub>2</sub> .R <sub>1</sub>     | 10.5<br><b>ADD</b><br>R <sub>1</sub> .IM | 10.5<br><b>ADD</b><br>IR <sub>1</sub> .IM | 6.5<br><b>LD</b><br>r+.R <sub>2</sub> | 6.5<br><b>LD</b><br>r <sub>2</sub> .R <sub>1</sub> | 12/10.5<br>DJNZ<br>'1.RA                             | 12/10,0<br><b>JR</b><br>cc.RA                                                      | 6.5<br><b>LD</b><br>r <sub>1</sub> .IM | 12/10.0<br><b>JP</b><br>cc.DA | 6.5<br>INC<br>r1 | <u> </u>          |
| 1                  | 6.5<br><b>RLC</b><br>R <sub>1</sub> | 6.5<br>RLC<br>IR <sub>1</sub>        | 6.5<br><b>ADC</b>                                   | 6.5<br>ADC<br>'1.lr <sub>2</sub>                        | 10 5<br><b>ADC</b><br>R <sub>2</sub> .R <sub>1</sub> | 10.5<br><b>ADC</b><br>IR <sub>2</sub> .R <sub>1</sub>     | 10.5<br><b>ADC</b><br>R <sub>1</sub> :M  | 10,5<br><b>ADC</b><br>IR <sub>1</sub> ,IM |                                       |                                                    |                                                      |                                                                                    |                                        |                               |                  |                   |
| 2                  | 6.5<br>INC<br>R <sub>1</sub>        | 6.5<br>INC<br><sup>IR</sup> 1        | 6.5<br><b>SUB</b><br>r <sub>1.</sub> r <sub>2</sub> | 6.5<br><b>SUB</b>                                       | 10.5<br><b>SUB</b><br>R <sub>2</sub> .P              | 10.5<br><b>SUB</b><br>IR <sub>2</sub> .R <sub>1</sub>     | 10,5<br><b>SUB</b><br>R+,IM              | 10 5<br>SUB<br>IR <sub>1</sub> ,IM        |                                       |                                                    |                                                      |                                                                                    |                                        |                               |                  |                   |
| 3                  | 8.0<br>JP<br>IRR <sub>1</sub>       | 6.1.<br><b>SRP</b><br>IM             | 6.5<br><b>SBC</b><br>r <sub>1.</sub> r <sub>2</sub> | 6.5<br><b>SBC</b><br>r+.lrp                             | 10.5<br><b>SBC</b><br>R <sub>2</sub> .R <sub>1</sub> | 10 5<br><b>SBC</b><br>IR <sub>2</sub> .R <sub>1</sub>     | 10.5<br><b>SBC</b><br>R <sub>1</sub> ,IM | 10.5<br><b>SBC</b><br>iR <sub>1</sub> IM  |                                       |                                                    |                                                      |                                                                                    | i                                      |                               |                  |                   |
| 4                  | 8.5<br><b>DA</b><br>R <sub>1</sub>  | 8.5<br><b>DA</b><br>iR <sub>1</sub>  | 6.5<br><b>OR</b><br>11.72                           | 6.5<br><b>OR</b><br>r <sub>1.</sub> l' <sub>2</sub>     | 10.5<br><b>OR</b><br>R <sub>2</sub> R <sub>1</sub>   | 10,5<br><b>OR</b><br>IR <sub>2</sub> .R-                  | 10,5<br><b>OR</b><br>R <sub>1</sub> ,IM  | 10.5<br><b>OR</b><br>IR <sub>1</sub> ,IM  |                                       |                                                    |                                                      |                                                                                    |                                        |                               |                  | ļ. — -            |
| 5                  | 10 5<br><b>POP</b><br>R+            | 10 5<br><b>POP</b><br>IR-            | 6.5<br><b>AND</b><br>11 fg                          | 6.5<br><b>AND</b><br>r <sub>1.</sub> lr <sub>2</sub>    | 10.5<br><b>AND</b><br>R <sub>2</sub> .R <sub>1</sub> | 10.5<br>AND<br>IR <sub>2</sub> .R <sub>1</sub>            | 10.5<br>AND<br>R <sub>1</sub> .IM        | 10,5<br>AND<br>IR <sub>1</sub> .:M        |                                       |                                                    |                                                      |                                                                                    |                                        |                               |                  |                   |
| 6                  | 6.5<br><b>COM</b><br>R <sub>1</sub> | 6.5<br>COM<br>IR <sub>1</sub>        | 6.5<br>TCM<br>'1.12                                 | 6.5<br>TCM<br>'1.lr <sub>2</sub>                        | 10 5<br><b>TCM</b><br>R <sub>2</sub> ,R <sub>1</sub> | 10.5<br>TCM<br><sub>1</sub> R <sub>2</sub> R <sub>1</sub> | 10.5<br>TCM<br>R <sub>1</sub> IM         | 10.5<br>TCM<br>IR·,IM                     | 1                                     |                                                    |                                                      |                                                                                    |                                        |                               |                  |                   |
| Upper Nibble (Hex) | 10/12.1<br>PUSH<br>R <sub>2</sub>   | 12/14.1<br>PUSH<br>IRg               | 6.5<br><b>TM</b><br>r <sub>1.</sub> r <sub>2</sub>  | 6.5<br>TM<br>r1 lr2                                     | 10.5<br><b>TM</b><br>P <sub>2</sub> .Fi              | 10.5<br><b>TM</b><br>IR <sub>2</sub> .R <sub>1</sub>      | 10.5<br><b>TM</b><br>R <sub>1</sub> ,IM  | 10.5<br><b>TM</b><br>IR <sub>1</sub> .IM  |                                       |                                                    |                                                      |                                                                                    |                                        |                               |                  | 6.1               |
| Upper Ni           | 10.5<br>DECW<br>RR <sub>1</sub>     | 10.5<br>DECW<br>IR <sub>1</sub>      | 12.0<br><b>LDE</b>                                  | 18.0<br><b>LDEI</b><br>lr <sub>1</sub> .lr <sub>2</sub> |                                                      |                                                           |                                          | ļ <u>-</u>                                |                                       |                                                    |                                                      |                                                                                    |                                        |                               |                  | <b>DI</b> 6 1     |
| 9                  | 6.5<br><b>RL</b><br>R <sub>1</sub>  | 6.5<br><b>RL</b>                     | 12.0<br>LDE                                         | 18.0<br>LDEI<br>Ir <sub>2</sub> ,Irr-                   |                                                      |                                                           | 105                                      |                                           |                                       |                                                    |                                                      |                                                                                    |                                        |                               |                  | EI 14,0           |
| A                  | RR <sub>1</sub>                     | INCW                                 | 6.5<br><b>CP</b>                                    | 6.5<br><b>CP</b>                                        | 10.5<br><b>CP</b><br>R <sub>2</sub> ,R <sub>1</sub>  | 10.5<br><b>CP</b><br>IR <sub>2</sub> .R <sub>1</sub>      | 10.5<br><b>CP</b><br>R <sub>1</sub> .IM  | 10.5<br><b>CP</b><br>R <sub>1</sub> .IM   |                                       |                                                    |                                                      |                                                                                    |                                        |                               |                  | 16 0              |
| В                  | R <sub>1</sub>                      | 6.5<br><b>CLR</b><br>IR <sub>1</sub> | 6.5<br><b>XOR</b>                                   | 6.5<br><b>XOR</b><br>r <sub>1</sub> lr <sub>2</sub>     | 10,5<br><b>XOR</b><br>R <sub>2</sub> R <sub>1</sub>  | 10.5<br><b>XOR</b><br>IR <sub>2</sub> .H                  | XOR<br>R-JM                              | XOR<br>IR <sub>1</sub> .IM                | _                                     |                                                    |                                                      |                                                                                    |                                        |                               |                  | 6.5               |
| c                  | R,                                  | RAC                                  | 12.0<br>LDC<br>r · .lm <sub>2</sub>                 | 18.0<br>LDCI<br>Ir <sub>1.</sub> lrr <sub>2</sub>       | 20.0                                                 | <u> </u>                                                  | 20.0                                     | LD<br>r <sub>1</sub> .x,R <sub>2</sub>    | ,                                     |                                                    |                                                      |                                                                                    |                                        |                               |                  | <b>RCF</b><br>65  |
| 0                  | R <sub>1</sub>                      | 6.5<br>SRA<br>IR <sub>1</sub>        | 12.0<br>LDC                                         | Ir <sub>2</sub> -r <sub>1</sub><br>6.5                  | CALL*                                                | 10.5                                                      | DA 10 5                                  |                                           |                                       |                                                    |                                                      |                                                                                    |                                        |                               |                  | SCF<br>6,5        |
| E                  | 6.5<br><b>RR</b><br>91              | RR<br>IR-                            |                                                     | LD<br>rlH <sub>2</sub><br>6.5                           | LD<br>Fig.R1                                         | LD<br>  IR <sub>2</sub> ,R <sub>1</sub><br>  10.5         | R <sub>1</sub> .IM                       | LD                                        |                                       |                                                    |                                                      |                                                                                    |                                        |                               |                  | CCF<br>6.0<br>NOP |
| F                  |                                     | SWAP<br>IR <sub>1</sub>              | i<br>i                                              | LD<br>1 / 1/2                                           |                                                      | B <sub>2</sub> 'R <sub>1</sub>                            | <u> </u>                                 | . L                                       | <u> </u>                              | <u> </u>                                           | _   <b>↓</b>                                         |                                                                                    | <u> </u>                               | _                             |                  | NOP               |
|                    | _                                   |                                      | 2                                                   |                                                         |                                                      |                                                           | 3                                        |                                           |                                       |                                                    | 2                                                    |                                                                                    |                                        | 3                             |                  | 1                 |
|                    |                                     |                                      |                                                     | 1.6                                                     | OWER                                                 |                                                           |                                          | Bytes pe                                  | er Instru                             | uction                                             |                                                      |                                                                                    |                                        |                               |                  |                   |
|                    |                                     |                                      |                                                     | OF                                                      | BBLE                                                 |                                                           |                                          |                                           |                                       |                                                    |                                                      |                                                                                    |                                        |                               |                  |                   |
|                    |                                     | (                                    | EXECUTIO<br>CYCLE                                   |                                                         | ¥<br>4                                               | PIPELI                                                    |                                          |                                           |                                       |                                                    |                                                      | nd:<br>3-bit addre<br>-bit addres                                                  |                                        |                               |                  |                   |
|                    |                                     | OPC                                  | PER<br>ODE                                          | <b>→</b> A                                              | 10.5<br><b>CP</b>                                    | MNEM                                                      | IONIC                                    |                                           |                                       |                                                    | R <sub>1</sub> or<br>R <sub>2</sub> or<br><b>Seq</b> | r <sub>1</sub> = Dst a<br>r <sub>2</sub> = Src a<br><b>uence:</b><br>page, First C | daress<br>daress                       | Second Or                     | neranci          |                   |
|                    |                                     |                                      | FIF<br>OPERA                                        | AST AND                                                 | *                                                    | SECO!<br>OPER.                                            |                                          |                                           |                                       |                                                    |                                                      | E The blan                                                                         |                                        |                               |                  |                   |

<sup>12</sup> byte instruction, fetch cycle annears as a 3 tiyle instruction

#### **ABSOLUTE MAXIMUM RATINGS**

Voltages on all pins except RESET

| with respect to GND  |                          |
|----------------------|--------------------------|
| Operating Ambient    |                          |
| Temperature          | See Ordering Information |
| Storage Temperature. |                          |

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 extended periods may affect device reliability.

#### STANDARD TEST CONDITIONS

The DC characteristics listed below apply for the following standard test conditions, unless otherwise noted. All voltages are referenced to GND. Positive current flows into the referenced pin.

Standard conditions are as follows:

- $+4.75V \le V_{CC} \le +5.25V$
- GND = 0V
- $0^{\circ}$ C  $\leq T_A \leq +70^{\circ}$ C for S (Standard temperature)
- -40 °C  $\leq$  T<sub>A</sub>  $\leq$  +100 °C for E (Extended temperature)



Figure 19. Test Load 1

#### DC CHARACTERISTICS

| Symbol              | Parameter                      | Min  | Max             | Unit | Condition                          |
|---------------------|--------------------------------|------|-----------------|------|------------------------------------|
| V <sub>CH</sub>     | Clock Input High Voltage       | 3.8  | V <sub>CC</sub> | V    | Driven by External Clock Generator |
| VCL                 | Clock Input Low Voltage        | -0.3 | 0.8             | V    | Driven by External Clock Generator |
| V <sub>IH</sub>     | Input High Voltage             | 2.0  | V <sub>CC</sub> | V    |                                    |
| $V_{IL}$            | Input Low Voltage              | -0.3 | 0.8             | V    |                                    |
| V <sub>RH</sub>     | Reset Input High Voltage       | 3.8  | Vcc             | V    | See Note                           |
| $V_{RL}$            | Reset Input Low Voltage        | -0.3 | 0.8             | V    |                                    |
| <br>V <sub>ОН</sub> | Output High Voltage            | 2.4  |                 | V    | I <sub>OH</sub> = -250 μA          |
| $V_{OL}$            | Output Low Voltage             |      | 0.4             | V    | $I_{OL} = +2.0 \text{mA}$          |
| hL.                 | Input Leakage                  | - 10 | 10              | μΑ   | 0V € V <sub>IN</sub> € + 5.25V     |
| loL                 | Output Leakage                 | - 10 | 10              | μΑ   | 0V € V <sub>IN</sub> € +5.25V      |
| I <sub>IR</sub>     | Reset Input Current            |      | -50             | μΑ   | $V_{CC} = +5.25V, V_{RL} = 0V$     |
| Icc                 | V <sub>CC</sub> Supply Current |      | 150             | mA   | All outputs and I/O pins floating  |

<sup>\*</sup>The Reset line (pin 6) is used to place the Z8682 in external memory mode. This is accomplished as shown in Figure 13.



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

### **AC CHARACTERISTICS**

External I/O or Memory Read and Write Timing

|       |           |                                           |     | Z8681/82<br>8 MHz |     | Z8681<br>12 MHz |     | Z8681<br>16 MHz |       |
|-------|-----------|-------------------------------------------|-----|-------------------|-----|-----------------|-----|-----------------|-------|
| Numbe | er Symbol | Parameter                                 | Min | Max               | Min | Max             | Min | Max             | Notes |
| 1     | TdA(AS)   | Address Valid to AS ↑Delay                | 50  |                   | 35  |                 | 20  |                 | 2,3   |
| 2     | TdAS(A)   | AS ↑ to Address Float Delay               | 70  |                   | 45  |                 | 30  |                 | 2,3   |
| 3     | TdAS(DR)  | —<br>AS ↑ to Read Data Required Valid     |     | 360               |     | 220             |     | 180             | 1,2,3 |
| 4     | TwAS      | AS Low Width                              | 80  |                   | 55  |                 | 35  |                 | 2,3   |
| 5     | TdAz(DS)  | Address Float to DS ↓                     | 0   |                   | 0   |                 | 0   |                 |       |
| 6     | Twdsr     | DS (Read) Low Width                       | 250 |                   | 185 |                 | 135 |                 | 1,2,3 |
| 7     | TwDSW     | DS (Write) Low Width                      | 160 |                   | 110 |                 | 80  |                 | 1,2,3 |
| 8     | TdDSR(DR) | <br>DS ↓ to Read Data Required Valid      |     | 200               |     | 130             |     | 75              | 1,2,3 |
| 9     | ThDR(DS)  | Read Data to DS ↑ Hold Time               | 0   |                   | 0   |                 | 0   |                 | 2,3   |
| 10    | TdDS(A)   | DS ↑ to Address Active Delay              | 70  |                   | 45  |                 | -   |                 | 2,3   |
| 11    | TdDS(AS)  | DS ↑ to AS ↓Delay                         | 70  |                   | 55  |                 | 30  |                 | 2,3   |
| 12    | TdR/W(AS) | R/W Valid to AS ↑ Delay                   | 50  |                   | 30  |                 | 20  |                 | 2,3   |
| 13    | TdDS(R/W) | <br>DS ↑ to R/W Not Valid                 | 60  |                   | 35  |                 | 30  |                 | 2,3   |
| 14    | TdDW(DSW) | Write Data Valid to DS (Write) ↓ Delay    | 50  |                   | 35  |                 | 25  |                 | 2,3   |
| 15    | TdDS(DW)  | DS ↑ to Write Data Not Valid Delay        | 60  |                   | 35  |                 | 30  |                 | 2,3   |
| 16    | TdA(DR)   | Address Valid to Read Data Required Valid |     | 410               |     | 255             |     | 200             | 1,2,3 |
| 17    | TdAS(DS)  | AS ↑ to DS ↓ Delay                        | 80  |                   | 55  |                 | 40  |                 | 2,3   |

<sup>1.</sup> When using extended memory timing add 2 TpC.

<sup>2.</sup> Timing numbers given are for minimum TpC.

See clock cycle time dependent characteristics table.
 16 MHz timing is preliminary and subject to change.

<sup>\*</sup> All units in nanoseconds (ns).

<sup>†</sup> Test Load 1

<sup>°</sup> All timing references use 2.0V for a logic "1" and 0.8V for a logic "0".



Figure 21. Additional Timing

## **AC CHARACTERISTICS**

Additional Timing Table

|               |             |                                   | Z8681/82<br>8 MHz |      | Z8681<br>12 MHz |      | Z8681<br>16 MHz |      |       |
|---------------|-------------|-----------------------------------|-------------------|------|-----------------|------|-----------------|------|-------|
| Number Symbol |             | Parameter                         | Min               | Max  | Min             | Max  | Min             | Max  | Notes |
| 1             | ТрС         | Input Clock Period                | 125               | 1000 | 83              | 1000 | 62.5            | 1000 | 1     |
| 2             | TrC,TfC     | Clock Input Rise and Fall Times   |                   | 25   |                 | 15   |                 | 10   | 1     |
| 3             | TwC         | Input Clock Width                 | 37                |      | 70              |      | 21              |      | 1     |
| 4             | TwTinL      | Timer Input Low Width             | 100               |      | 70              |      | 50              |      | 2     |
| 5             | TwTinH      | Timer Input High Width            | 3ТрС              |      | 3ТрС            |      | 3ТрС            |      | 2     |
| 6             | TpTin       | Timer Input Period                | 8ТрС              |      | 8ТрС            |      | 8ТрС            |      | 2     |
| 7             | TrTin,TfTin | Timer Input Rise and Fall Times   |                   | 100  |                 | 100  |                 | 100  | 2     |
| 8A            | TwiL        | Interrupt Request Input Low Time  | 100               |      | 70              |      | 50              |      | 2,4   |
| 8B            | TwlL        | Interrupt Request Input Low Time  | ЗТрС              |      | 3ТрС            |      | ЗТрС            |      | 2,5   |
| 9             | TwlH        | Interrupt Request Input High Time | 3ТрС              |      | 3ТрС            |      | 3ТрС            |      | 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 request via Port 3.
- 4. Interrupt request via Port 3 (P3<sub>1</sub>-P3<sub>3</sub>)
- 5. Interrupt request via Port 3 (P3<sub>0</sub>)
  6. 16 MHz timing is preliminary and subject to change.

  \* Units in nanoseconds (ns).



Figure 22a. Input Handshake Timing



Figure 22b. Output Handshake Timing

# **AC CHARACTERISTICS**

Handshake Timing

| Number Symbol Parameter |              | Z8681/82<br>8 MHz           |     | Z8681<br>12 MHz |         | Z8681<br>16 MHz |     |      |       |
|-------------------------|--------------|-----------------------------|-----|-----------------|---------|-----------------|-----|------|-------|
|                         |              | Parameter                   | Min | Max             | Max Min | Max             | Min | Max_ | Notes |
| 1                       | TsDI(DAV)    | Data In Setup Time          | 0   |                 | 0       |                 | 0   |      |       |
| 2                       | ThDI(DAV)    | Data In Hold Time           | 230 |                 | 160     |                 | 145 |      |       |
| 3                       | TwDAV        | Data Available Width        | 175 |                 | 120     |                 | 110 |      |       |
| 4                       | TdDAVIf(RDY) | DAV ↓ Input to RDY ↓ Delay  |     | 175             |         | 120             |     | 115  | 1,2   |
| 5                       | TdDAVOf(RDY) | DAV ↓ Output to RDY ↓ Delay | 0   |                 | 0       |                 | 0   |      | 1,3   |
| 6                       | TdDAVir(RDY) | DAV ↑ Input to RDY ↑ Delay  |     | 175             |         | 120             |     | 115  | 1,2   |
| 7                       | TdDAVOr(RDY) | DAV ↑ Output to RDY ↑ Delay | 0   |                 | 0       |                 | 0   |      | 1,3   |
| 8                       | TdDO(DAV)    | Data Out to DAV ↓ Delay     | 50  |                 | 30      |                 | 30  |      | 1     |
| 9                       | TdRDY(DAV)   | Rdy ↓ Input to DAV ↑ Delay  | 0   | 200             | 0       | 140             | 0   | 130  | 1     |

#### NOTES:

<sup>1.</sup> Test load 1

<sup>2.</sup> Input handshake

<sup>3.</sup> Output handshake4. 16 MHz timing is preliminary and subject to change.

<sup>†</sup> All timing references use 2.0V for a logic "1" and 0.8V for a logic "0".

\* Units in nanoseconds (ns).

# CLOCK CYCLE TIME-DEPENDENT CHARACTERISTICS

| Number | Symbol    | Z8681/82<br>8 MHz<br>Equation | Z8681/82<br>12 MHz<br>Equation |
|--------|-----------|-------------------------------|--------------------------------|
| 1      | TdA(AS)   | TpC-75                        | TpC-50                         |
| 2      | TdAS(A)   | TpC-55                        | TpC-40                         |
| 3      | TdAS(DR)  | 4TpC-140*                     | 4TpC-110*                      |
| 4      | TwAS      | TpC-45                        | TpC-30                         |
| 6      | TwDSR     | 3TpC-125*                     | 3TpC-65 *                      |
| 7      | TwDSW     | 2TpC-90*                      | 2TpC-55 *                      |
| 8      | TdDSR(DR) | 3TpC-175*                     | 3TpC-120*                      |
| 10     | Td(DS)A   | TpC-55                        | TpC-40                         |
| 11     | TdDS(AS)  | TpC-55                        | TpC-30                         |
| 12     | TdR/W(AS) | TpC-75                        | TpC-55                         |
| 13     | TdDS(R/W) | TpC-65                        | TpC-50                         |
| 14     | TdDW(DSW) | TpC-75                        | TpC-50                         |
| 15     | TdDS(DW)  | TpC-55                        | TpC-40                         |
| 16     | TdA(DR)   | 5TpC-215 *                    | 5TpC-160*                      |
| 17     | TdAS(DS)  | TpC-45                        | TpC-30                         |

<sup>\*</sup> Add 2TpC when using extended memory timing