CUSTOMER PROCUREMENT SPECHCA TON

**Z08617** NMOS Z8<sup>®</sup> 8-BIT MCU KEYBOARD CONTROLLER

### FEATURES

- Low Power Consumption 750 mW
- 32 Input/Output Lines
- Digital Inputs NMOS Levels with Internal Pull-Up Resistors
- 4 Kbytes ROM
- Four Direct Connect LED Drive Pins
- 124 Bytes of RAM

- Hardware Watch-Dog Timer (WDT)
- Two Programmable 8-Bit Counter/Timers, Each with 6-Bit Programmable Prescaler
- Six Vectored, Priority Interrupts from Six Different Sources
- On-Chip RC Oscillator
- Clock Frequency: Up to 5MHz
- Low EMI Emission

#### **GENERAL DESCRIPTION**

The Z08617 Keyboard Controller is a member of the Z8<sup>®</sup> single-chip microcontroller family with 4 Kbytes of ROM. The device is housed in a 40-pin DIP package, and is manufactured in NMOS technology. The Z08617 microcontroller offers fast execution, efficient use of memory, sophisticated interrupt, input/output bit-manipulation capabilities, and easy hardware/software system expansion along with low cost and low power consumption.

The Z08617 architecture is characterized by a flexible I/O scheme, an efficient register, I/O, and a number of ancillary features that are useful in many industrial and advanced scientific applications.

For applications which demand powerful I/O capabilities, the Z08617 provides 32 pins dedicated to input and output. These lines are grouped into four ports, each port consists of 8 lines, and are configurable under software control to provide timing, status signals, and serial or parallel I/O ports. The Z08617 offers low EMI emission which is achieved by means of several modifications in the output drivers and clock circuitry of the device.

There are two basic address spaces which are available to support this wide range of configurations: Program Memory and 124 General-Purpose Registers.

The Z08617 offers two on-chip counter/timers with a large number of user-selectable modes. This unburdens the program from coping with real-time problems such as counting/timing (Figure 1).

#### 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      | V <sub>cc</sub> | V <sub>DD</sub> |
| Ground     | GND             | V <sub>SS</sub> |

# **GENERAL DESCRIPTION** (Continued)



Figure 1. Z08617 Functional Block Diagram

## **PIN IDENTIFICATION**

| VCC     | 1  | $\bigcirc$ | 40 | P36 |
|---------|----|------------|----|-----|
| CLK Out | 2  |            | 39 | P31 |
| RC In   | 3  |            | 38 | P27 |
| P37     | 4  |            | 37 | P26 |
| P30     | 5  |            | 36 | P25 |
| /RESET  | 6  |            | 35 | P24 |
| *GND    | 7  |            | 34 | P23 |
| *N/C    | 8  |            | 33 | P22 |
| /WDTOUT | 9  |            | 32 | P21 |
| P35     | 10 | Z08617     | 31 | P20 |
| GND     | 11 | DIP        | 30 | P33 |
| P32     | 12 |            | 29 | P34 |
| P00     | 13 |            | 28 | P17 |
| P01     | 14 |            | 27 | P16 |
| P02     | 15 |            | 26 | P15 |
| P03     | 16 |            | 25 | P14 |
| P04     | 17 |            | 24 | P13 |
| P05     | 18 |            | 23 | P12 |
| P06     | 19 |            | 22 | P11 |
| P07     | 20 |            | 21 | P10 |

#### Note:

 \* Pin 8 is connected to the chip, although used only for testing. This pin *must* float. Pin 7 is a test pin and *must* be grounded.

### Figure 2. 40-Pin DIP Pin Configuration

#### Table 1. 40-Pin DIP Pin Identification

| Pin # | Symbol          | Function        | Direction | Pin #    | Symbol     | Function                       | Direction       |
|-------|-----------------|-----------------|-----------|----------|------------|--------------------------------|-----------------|
| 1     | V <sub>cc</sub> | Power Supply    | Input     | 11       | GND        | Ground                         |                 |
| 2     | CĽK Out         | Clock Out       | Output    | 12       | P32        | Port 3, Pin 2                  | Input           |
| 3     | RC In           | Z8 Clock        | Input     | 13-20    | P07-P00    | Port 0, Pins 0,1,2,3,4,5,6,7   | In/Output       |
| 4     | P37             | Port 3, Pin 7   | Output    | 21-28    | P17-P10    | Port 1, Pins 0,1,2,3,4,5,6,7   | In/Output       |
| 5     | P30             | Port 3, Pin 0   | Input     | 29       | P34        | Port 3, Pin 4                  | Output          |
| 6     | /RESET          | Reset           | Input     | 30       | P33        | Port 3, Pin 3                  | Input           |
| *7    | GND             | Ground          | -         | 31-38    | P27-P20    | Port 2, Pins 0,1,2,3,4,5,6,7   | In/Output       |
| *8    | N/C             | Not Connected   |           | -        |            |                                | · / 0 · · ·     |
| 9     | /WDTOUT         | Watch-Dog Timer | Output    | 34-38    | P24-P20    | Port 2, Pins 0, 1, 2, 3, 4     | In/Output       |
| 10    | P35             | Port 3, Pin 5   | Output    | 39<br>40 | P31<br>P36 | Port 3, Pin 1<br>Port 3, Pin 6 | Input<br>Output |

### **ABSOLUTE MAXIMUM RATINGS**

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

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.

#### Notes:

\* Voltage on all pins with respect to GND.

† See ordering information

### STANDARD TEST CONDITIONS

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



Figure 17. Test Load Diagram

## STANDARD TEST CONDITIONS

 $T_{A} = 25^{\circ}C$ ,  $V_{CC} = GND = 0V$ , f = 1.0 MHz, unmeasured pins returned to ground.

| Parameter          | Max   |
|--------------------|-------|
| Input capacitance  | 12 pF |
| Output capacitance | 12 pF |
| I/O capacitance    | 12 pF |

**DC CHARACTERISTICS**  $V_{cc} = 4.75V$  to 5.25V @ 0°C to -55°C

| Sym             | Parameter                      | Min  | Max             | Тур* | Unit | Condition                                       |
|-----------------|--------------------------------|------|-----------------|------|------|-------------------------------------------------|
| V <sub>IH</sub> | Input High Voltage             | 2.0  | V <sub>cc</sub> |      | V    |                                                 |
| V               | Input Low Voltage              | -0.3 | 0.8             |      | V    |                                                 |
| V <sub>RH</sub> | Reset Input High Voltage       | 3.8  | V <sub>cc</sub> |      | V    |                                                 |
| V <sub>RL</sub> | Reset Input Low Voltage        | -0.3 | 0.8             |      | V    |                                                 |
| V <sub>OH</sub> | Output High Voltage            | 2.0  |                 |      | V    | $I_{OH} = -250 \ \mu A$ (Port 2 only)           |
| On              | Output High Voltage            | 2.4  |                 |      | V    | $I_{OH} = -250 \ \mu A$ (Port 3 only)           |
| V <sub>OL</sub> | Output Low Voltage             |      | 0.8             |      | V    | I <sub>OL</sub> = 10.0 mA (See note [1] below.) |
| I L             | Input Leakage                  | -10  | 10              |      | μA   | $V_{IN} = 0V, 5.25V$ (See note [3] below.)      |
| I <sub>OL</sub> | Output Leakage                 | -10  | 10              |      | μA   | $V_{IN} = 0V, 5.25V$ (See note [2] below.)      |
| I <sub>IR</sub> | Reset Input Current            | -335 | -775            | -477 | μΑ   | V <sub>IN</sub> = 0V, 5.25V                     |
| I <sub>R1</sub> | Input Current                  | -335 | -775            |      | μΑ   | Pull-up resistor=10.4 Kohms, $V_{IN}$ =0.0V     |
| I <sub>R2</sub> | Input Current                  | -1.6 | -2.9            |      | mA   | Pull-up resistor = 2.4 Kohms, $V_{IN}$ =0.0V    |
| I <sub>cc</sub> | V <sub>cc</sub> Supply Current |      | 160             |      | mA   |                                                 |
| WDT             | Watch-Dog Timer                |      | 2.0             |      | mA   | V <sub>oL</sub> =0.4 Volt                       |

#### Notes:

\* Typical @ 25°C

- [1] Ports P37-P34 may be used to sink 12 mA. These may be used for LEDs or as general-purpose outputs requiring high sink current.
- [2] P00-P07, P10-P17, P20-P25, P30-P33 as output mode opendrain as a logic one.
- [3] P00-P07, P10-P17, P20-P25, P30-P33 as output mode opendrain as a logic one.

# **PIN FUNCTIONS**

**RCIN** This pin is connected between a precision resistor on the power supply from the precision RC Oscillator.

**CLK Out** This pin is the syste m clock of the Z8 and runs at the frequency of the RC Oscillator. Any load on this pin will effect the RC Oscillator frequency.

**Port 0** (P07-P00). Port 0 is an 8-bit, nibble programmable, bi-directional, NMOS compatible I/O port. These eight I/O lines can be configured under software control as a nibble input port, or as a nibble open-drain output port. When used as an I/O port, inputs are standard NMOS (Figure 5). Port P03-P00 has 10.4 Kohms (±35%) pull-up resistors when configured as inputs.



Figure 5. Port 0 Configuration

# PIN FUNCTIONS (Continued)

**Port 1** (P17-P10). Port 1 is an 8-bit, byte programmable, bidirectional, NMOS compatible I/O port. These eight I/O lines are configured under software control program as a

byte input port or as an open-drain output port. When used as an I/O port, inputs are standard NMOS (Figure 6).



Figure 6. Port 1 Configuration

<sup>®</sup>Silœ

**Port 2** (P27-P20). Port 2 is an 8-bit, bit programmable, bidirectional, NMOS compatible I/O port. These eight I/O lines are configured under the software control program for I/O. Port 2 can be programmed as bit-by-bit independently, as input or output, or configured to provide opendrain outputs (Figure 7). P26 and P27 have 2.4 Kohms ( $\pm$ 25%) pull-up resistors and are capable of sourcing 2.4 mA. P24 and P25 have 10.4 Kohms ( $\pm$ 35%) pull-up when configured as inputs.





# PIN FUNCTIONS (Continued)

**Port 3** (P37-P30). Port 3 is an 8-bit, NMOS compatible fourfixed-input and four-fixed-output I/O port. These eight I/O lines have four-fixed-input (P33-P30) and four-fixed-output (P37-P34) ports. Port 3 inputs have 10.4 Kohms (±35%) pull-up resistors and port 3 outputs are capable of driving up to four LEDs.

Port 3 is configured under software control to provide the following control functions: four external interrupt request signals (IRQ3-IRQ0); timer input and output signals (T\_{\_{\rm IN}} and T\_{\_{\rm OUT}} - Figure 8).

**/RESET** (input, active Low). When activated, /RESET initializes the Z08617. When /RESET is deactivated, program execution begins from the internal program location at 000CH. Reset pin has a 10.4 Kohms pull-up resistor. Once this pin is pulled Low, it takes about 150 ms for microcon-troller initialization.



Figure 8. Port 3 Configuration

# FUNCTIONAL DESCRIPTION

The device incorporates special functions to enhance Zilog's Z8 applications as a keyboard controller, scientific research and advanced technologies applications.

**Program Memory.** The 16-bit program counter addresses 4 Kbytes of program memory space at internal locations (Figure 9).

The first 12 bytes of program memory are reserved for the interrupt vectors. These locations have six 16-bit vectors that correspond to the six available interrupts.

Byte 12 to byte 4095 consists of on-chip, mask programmed ROM. Addresses 4096 and greater are reserved.



Figure 9. Program Memory Map

# FUNCTIONAL DESCRIPTION (Continued)

**Register File.** The register file (Figure 10) consists of four I/O port registers, 124 general-purpose registers and 16 control and status registers (R3-R0, R127-R4, and R255-R240, respectively). The instructions can access registers directly or indirectly through an 8-bit address field. This allows short, 4-bit register addressing using the Register

Pointer (Figure 11). In the 4-bit mode, the register file is divided into nine working-register groups, each occupying 16 continuous locations. The Register Pointer addresses the starting location of the active working-register group.

| LOCATION |                                     | IDENTIFIERS |
|----------|-------------------------------------|-------------|
| R255     | Stack Pointer (Bits 7-0)            | SPL         |
| R254     | General-Purpose Register (Bits 7-0) | GPR         |
| R253     | Register Pointer                    | RP          |
| R252     | Program Control Flags               | FLAGS       |
| R251     | Interrupt Mask Register             | IMR         |
| R250     | Interrupt Request Register          | IRQ         |
| R249     | Interrupt Priority Register         | IPR         |
| R248     | Ports 1-0 Mode                      | P01M        |
| R247     | Port 3 Mode                         | P3M         |
| R246     | Port 2 Mode                         | P2M         |
| R245     | T0 Prescaler                        | PREQ        |
| R244     | Timer/Counter0                      | то          |
| R243     | T1 Prescaler                        | PRE1        |
| R242     | Timer/Counter1                      | T1          |
| R241     | Timer Mode                          | TMR         |
| R240     | Reserved                            |             |
|          | Not Implemented                     |             |
| R127     | General-Purpose<br>Registers        |             |
| R4       |                                     |             |
| R3       | Port 3                              | P3          |
| R2       | Port 2                              | P2          |
| R1       | Port 1                              | P1          |
| R0       | Port 0                              | P0          |
|          |                                     |             |

Figure 10. Register File Configuration



Figure 11. Register Pointer Configuration

**Stack.** The Z08617 internal register files are used for the stack. An 8-bit Stack Pointer (R255) is used for the internal stack that resides within the 124 general-purpose registers.

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

The 6-bit prescalers can further divide the input frequency of the clock source by any integer number from 1 to 64. Each prescaler drives its own 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 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 (modulon continuous mode).

The counters, but not the prescalers, are read at any time without disturbing their value or count mode. The clock source for T1 is user-definable and are 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 as an external clock, a trigger input that can be retriggerable or non-triggerable, or as a gate input for the internal clock. The counter/timers can be programmable cascaded by connecting the T0 output to the input of T1. Port 3 lines P36 also serves as a timer output ( $T_{out}$ ) through which T0, T1 or the internal clock are output.



Figure 12. Counter/Timers Block Diagram

# FUNCTIONAL DESCRIPTION (Continued)

**Interrupts.** The Z08617 has six different interrupts from six different sources. These interrupts are maskable and prioritized (Figure 13). The six sources are divided as follows: four sources are claimed by Port 3 lines P33-P30, and two are claimed by the counter/timers. The Interrupt Masked Register globally or individually enables or disables the six interrupts 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 interrupts are vectored through locations in the program memory. When an interrupt machine cycle is activated an interrupt request is granted. This disables all of the subsequent interrupts, saves 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 request needs service.



Figure 13. Interrupt Block Diagram

**RC Oscillator.** The Z08617 provides an internal capacitor to accommodate an RC oscillator configuration. A 1% precision resistor is necessary to achieve  $\pm$  10% accurate frequency oscillation.

**EMI.** The Z08617 offers low EMI emission due to circuit modifications to improve EMI performance. The internal divide-by-two circuit has been removed to improve EMI performance.



**RC Oscillator** 

Figure 14. Oscillator Configuration

# FUNCTIONAL DESCRIPTION (Continued)

**Watch-Dog Timer.** The Z08617 is equipped with a hardware Watch-Dog Timer which will be turned on automatically by power-on (Figure 15). The Watch-Dog Timer must be refreshed at least once every 50 ms by executing the instruction WDT (Opcode = %5F), otherwise the Z08617 will reset itself if /WDTOUT pin 9 is connected to /RESET (Pin 6). Figure 16 shows the block diagram of WDT.

The Watch-Dog Timer is automatically enabled upon power-up of the microcontroller and /RESET going High. The /WDTOUT pin can be connected to the /RESET pin to provide an automatic reset upon WDT time-out. During WDT time-out, the /WDTOUT pin goes Low for approximately 8-15  $\mu s.$ 

**WDT Hot Bit.** Bit 7 of the Interrupt Request Register (IRR register FAH) determines whether a hot start or cold start occurred. A cold start is defined as a rest occurring from the power-up of the Z08617 (bit 7 is set to zero upon power-up). A hot start occurs when a WDT timeout has occurred (bit 7 is set to 1). Bit 7 of the IRQ register is read-only and is automatically reset to 0 when accessed.

**Power-On Reset.** Upon power-up of the microcontroller, a reset condition is enabled. A delay of 150 ms  $\pm 20\%$  is used to assist in initializing the microcontroller.



Figure 15. WDT Turn-On Timing After Reset



Figure 16. WDT Block Diagram

# **Z8® CONTROL REGISTER DIAGRAMS**



# Z8® CONTROL REGISTER DIAGRAMS (Continued)



#### Figure 25. Port 0 and 1 Mode Register (F8H: Write Only)







#### Figure 27. Interrupt Request Register (FAH: Read/Write)



#### Figure 28. Interrupt Mask Register (FBH: Read/Write)

# & Sirae



#### Figure 29. Flag Register (FCH: Read/Write)



Figure 31. General-Purpose Register (FEH: Read/Write)



Figure 32. Stack Pointer (FFH: Read/Write)



Figure 30. Register Pointer (FDH: Read/Write)

# 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 work- |
| ing-   | register pair address                    |
| Irr    | Indirect working-register pair only      |
| Х      | 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                 |
| lr     | Indirect working-register address only   |
| RR     | Register pair or working register pair   |
|        | 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

# **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) = 1    |
| 0011  | ULE      | Unsigned Less Than or Equal    | (C  OR  Z) = 1           |
| 0000  | F        | Never True (Always False)      |                          |

# & Sirue

# INSTRUCTION FORMATS

| OPC |     |  |
|-----|-----|--|
|     |     |  |
| dst | OPC |  |

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

#### **One-Byte Instructions**



### **INSTRUCTION SUMMARY**

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

 $dst \gets 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 operand location.

# **INSTRUCTION SUMMARY** (Continued)

| Instruction<br>and Operation                                                             | Address<br>Mode<br>dst src | Opcode<br>Byte (Hex) | Af |   | ted |   | D | н | Instruction<br>and Operation                                                                                                  | Мо                | dress<br>de<br>src | Opcode<br>Byte (Hex)  | Af | ags<br>fect<br>Z | ed |   | D | н |
|------------------------------------------------------------------------------------------|----------------------------|----------------------|----|---|-----|---|---|---|-------------------------------------------------------------------------------------------------------------------------------|-------------------|--------------------|-----------------------|----|------------------|----|---|---|---|
| ADC dst, src<br>dst ← dst + src +                                                        | †<br>C                     | 1[]                  | *  | * | *   | * | 0 | * | INC dst<br>dst ← dst + 1                                                                                                      | r<br>R            |                    | rE<br>r = 0 – F<br>20 | _  | *                | *  | * | _ | _ |
| <b>ADD</b> dst, src dst $\leftarrow$ dst + src                                           | †                          | 0[]                  | *  | * | *   | * | 0 | * |                                                                                                                               | IR                |                    | 21                    |    |                  |    |   |   |   |
| AND dst, src                                                                             | +                          | 5[]                  |    | * | *   | 0 | _ | _ | <b>INCW</b> dst<br>dst ← dst + 1                                                                                              | RR<br>IR          |                    | A 0<br>A 1            | -  | *                | *  | * | - | - |
| dst ← dst AND sr                                                                         |                            | <b>D</b> 0           |    |   |     |   |   |   | IRET                                                                                                                          |                   |                    | BF                    | *  | *                | *  | * | * | * |
| <b>CALL</b> dst<br>SP $\leftarrow$ SP - 2<br>@SP $\leftarrow$ PC,<br>PC $\leftarrow$ dst | DA<br>IRR                  | D6<br>D4             | _  | _ | _   | _ | _ | _ | $FLAGS \leftarrow @SP;$<br>$SP \leftarrow SP + 1$<br>$PC \leftarrow @SP;$<br>$SP \leftarrow SP + 2;$<br>$IMR(7) \leftarrow 1$ |                   |                    |                       |    |                  |    |   |   |   |
| <b>CCF</b><br>C ← NOT C                                                                  |                            | EF                   | *  | - | -   | - | _ | - | JP cc, dst<br>if cc is true                                                                                                   | DA                |                    | CD<br>C = 0 - F       | _  | _                | -  | _ | _ | _ |
| CLR dst<br>dst ← 0                                                                       | R<br>IR                    | B0<br>B1             | -  | - | -   | - | - | - | $PC \leftarrow dst$                                                                                                           | IRR               |                    | 30                    |    |                  |    |   |   |   |
| <b>COM</b> dst<br>dst ← NOT dst                                                          | R<br>IR                    | 60<br>61             | -  | * | *   | 0 | - | _ | <b>JR</b> cc, dst<br>if cc is true,<br>PC $\leftarrow$ PC + dst<br>Range: +127,-12                                            | RA<br>28          |                    | CB<br>C = 0 - F       | _  | _                | -  | _ | _ | _ |
| CP dst, src<br>dst – src                                                                 | †                          | A[ ]                 | *  | * | *   | * | _ | - | LD dst, src                                                                                                                   | r                 | Im                 | rC                    | _  | _                | _  | _ | _ | _ |
| <b>DA</b> dst<br>dst ← DA dst                                                            | R<br>IR                    | 4 0<br>4 1           | *  | * | *   | Х | _ | _ | dst ← src                                                                                                                     | r<br>R            | R<br>r             | r8<br>r9<br>r = 0 – F |    |                  |    |   |   |   |
| DEC dst<br>dst ← dst - 1                                                                 | R<br>IR                    | 0 0<br>0 1           | -  | * | *   | * | _ | _ |                                                                                                                               | r<br>X<br>r<br>Ir | X<br>r<br>Ir<br>r  | C7<br>D7<br>E3<br>F3  |    |                  |    |   |   |   |
| <b>DECW</b> dst<br>dst ← dst - 1                                                         | RR<br>IR                   | 80<br>81             | _  | * | *   | * | _ | _ |                                                                                                                               | R<br>R<br>R       | R<br>IR<br>IM      | E4<br>E5<br>E6        |    |                  |    |   |   |   |
| <b>DI</b><br>IMR(7) ← 0                                                                  |                            | 8F                   | -  | _ | -   | _ | _ | - |                                                                                                                               | IR<br>IR          | IM<br>R            | E7<br>F5              |    |                  |    |   |   |   |
| <b>DJNZ</b> r, dst<br>r ← r - 1                                                          | RA                         | rA<br>r = 0 – F      | -  | - | -   | - | - | _ | LDC dst, src                                                                                                                  | r                 | Irr                | C2                    | _  | _                | _  | _ | _ | _ |
| if $r \neq 0$<br>PC $\leftarrow$ PC + dst<br>Range: +127,-12                             | 28                         |                      |    |   |     |   |   |   | <b>LDCI</b> dst, src<br>dst $\leftarrow$ src<br>r $\leftarrow$ r + 1;                                                         | lr                | lrr                | <u>C3</u>             | _  | _                | _  | _ | _ | _ |
| <b>EI</b><br>IMR(7) ← 1                                                                  |                            | 9F                   | _  | _ | _   | _ | _ | _ | rr ← rr + 1                                                                                                                   |                   |                    |                       |    |                  |    |   |   |   |

# **INSTRUCTION SUMMARY** (Continued)

| Instruction                                                  | Мос          |         | Opcode<br>Byte | Af | ags<br>fec | ted |     | _ |   | Instruction                                                                                              | Address<br>Mode                                    | Byte                                          | A                     |                     | ted                 |                     | _                 | _                  |
|--------------------------------------------------------------|--------------|---------|----------------|----|------------|-----|-----|---|---|----------------------------------------------------------------------------------------------------------|----------------------------------------------------|-----------------------------------------------|-----------------------|---------------------|---------------------|---------------------|-------------------|--------------------|
| and Operation                                                | dst          | src     | (Hex)          | С  | Z          | S   | V   | D | н | and Operation                                                                                            | dst src                                            | (Hex)                                         | С                     | Z                   | S                   | V                   | D                 | Н                  |
| NOP                                                          |              |         | FF             | -  | _          | -   | _   | _ | - | <b>SUB</b> dst, src<br>dst ← dst - src                                                                   | +                                                  | 2[ ]                                          | [                     | [                   | [                   | [                   | 1                 | [                  |
| <b>OR</b> dst, src<br>dst ← dst OR src                       | †            |         | 4[ ]           | _  | *          | *   | 0   | _ | - | SWAP dst                                                                                                 | R<br>IR                                            | F0<br>F1                                      | Х                     | *                   | *                   | Х                   | _                 | _                  |
| POP dst                                                      | R            |         | 50             | _  | _          | _   | _   | _ | - |                                                                                                          |                                                    |                                               |                       |                     |                     |                     |                   |                    |
| dst $\leftarrow$ @SP;<br>SP $\leftarrow$ SP + 1              | IR           |         | 51             |    |            |     |     |   |   | <b>TCM</b> dst, src<br>(NOT dst)                                                                         | †                                                  | 6[]                                           | _                     | *                   | *                   | 0                   | _                 | -                  |
| <b>PUSH</b> src SP $\leftarrow$ SP – 1;                      |              | R<br>IR | 70<br>71       | _  | _          | -   | -   | _ | _ | AND src                                                                                                  |                                                    |                                               |                       |                     |                     |                     |                   |                    |
| @SP ← src                                                    |              |         |                |    |            |     |     |   |   | <b>TM</b> dst, src<br>dst AND src                                                                        | †                                                  | 7[]                                           | -                     | *                   | *                   | 0                   | _                 | -                  |
| <b>RCF</b><br>C ← 0                                          |              |         | CF             | 0  | -          | _   | -   | - | - | WDT                                                                                                      |                                                    | 5F                                            | _                     | Х                   | Х                   | Х                   | _                 | _                  |
| <b>RET</b><br>PC $\leftarrow$ @SP;<br>SP $\leftarrow$ SP + 2 |              |         | AF             | _  | -          | _   | _   | - | _ | XOR dst, src<br>dst ← dst XOR s                                                                          | †<br>src                                           | B[ ]                                          | _                     | *                   | *                   | 0                   | _                 | _                  |
| RL dst                                                       | R<br>IR<br>R |         | 90<br>91<br>10 |    |            |     | * * |   | _ | † These instructio<br>which are encode<br>the instruction set<br>symbolically by a<br>following table to | d for brevity.<br>t table above<br>'[]' in this ta | The first opo<br>. The secon<br>able, and its | code<br>d nil<br>valu | din<br>eldo<br>i eu | ble<br>e is<br>s fc | is f<br>exp<br>ounc | oun<br>ores<br>in | d ir<br>sec<br>the |
|                                                              | IR           |         | 11             |    |            |     |     |   |   | For example, the o<br>modes r (destinat                                                                  |                                                    |                                               |                       | ing                 | the                 | adc                 | res               | sing               |
| RR dst                                                       | R<br>IR      |         | E0<br>E1       | *  | *          | *   | *   | _ | _ | Address Moo<br>dst si                                                                                    |                                                    |                                               | 0                     |                     | _ow<br>ode          |                     | ble               |                    |
| RRC dst                                                      | R<br>IR      |         | C0<br>C1       | *  | *          | *   | *   | _ | _ | r r                                                                                                      |                                                    |                                               |                       |                     | [2                  | ]                   |                   |                    |
|                                                              |              |         |                |    |            |     |     |   |   | r Ir                                                                                                     |                                                    |                                               |                       |                     | [3                  | ]                   |                   |                    |
| <b>SBC</b> dst, src dst $\leftarrow$ dst $-$ src -           | †<br>- C     |         | 3[]            | *  | *          | *   | *   | 1 | * | R R                                                                                                      |                                                    |                                               |                       |                     | [4                  | ]                   |                   |                    |
| SCF                                                          |              |         | DF             | 1  | _          | -   | -   | - | _ | r ir                                                                                                     |                                                    |                                               |                       |                     | [5                  | ]                   |                   |                    |
| C ← 1                                                        |              |         |                |    |            |     |     |   |   | R IN                                                                                                     | 1                                                  |                                               |                       |                     | [6                  | 1                   |                   |                    |
| SRA dst                                                      | R<br>IR      |         | D0<br>D1       | *  | *          | *   | 0   | _ | _ | IR IN                                                                                                    |                                                    |                                               |                       |                     | [7                  |                     |                   |                    |
| SRP src<br>RP ← src                                          |              | Im      | 31             | -  | _          | -   | -   | - | _ |                                                                                                          |                                                    |                                               |                       |                     |                     |                     |                   |                    |

# & Sirue

# OPCODE MAP

|                    |   |                        |                        |                      |                       |                      |                       | Lo                   | wer Nib              | ble (He          | x)                                       |                        |                          |                  |               |                   |                    |  |
|--------------------|---|------------------------|------------------------|----------------------|-----------------------|----------------------|-----------------------|----------------------|----------------------|------------------|------------------------------------------|------------------------|--------------------------|------------------|---------------|-------------------|--------------------|--|
|                    |   | 0                      | 1                      | 2                    | 3                     | 4                    | 5                     | 6                    | 7                    | 8                | 9                                        | Α                      | В                        | С                | D             | Е                 | F                  |  |
|                    | 0 | 6.5<br><b>DEC</b>      | 6.5<br><b>DEC</b>      | 6.5<br><b>ADD</b>    | 6.5<br><b>ADD</b>     | 10.5<br><b>ADD</b>   | 10.5<br><b>ADD</b>    | 10.5<br><b>ADD</b>   | 10.5<br><b>ADD</b>   | 6.5<br><b>LD</b> | 6.5<br><b>LD</b>                         | 12/10.5<br><b>DJNZ</b> | 12/10.0<br>JR            | 6.5<br><b>LD</b> | 12.10.0<br>JP | 6.5<br><b>INC</b> |                    |  |
|                    |   | 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      | r1, R2           | r2, R1                                   | r1, RA                 | cc, RA                   | r1, IM           | cc, DA        | r1<br>∎           |                    |  |
|                    | 1 | RLC                    | RLC                    | ADC                  | ADC                   | ADC                  | ADC                   | ADC                  | ADC                  |                  |                                          |                        |                          |                  |               |                   |                    |  |
|                    |   | 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      |                  |                                          |                        |                          |                  |               |                   |                    |  |
|                    | 2 | INC<br>R1              | INC<br>IR1             | <b>SUB</b><br>r1, r2 | <b>SUB</b><br>r1, lr2 | <b>SUB</b><br>R2, R1 | SUB<br>IR2, R1        | SUB<br>R1, IM        | SUB<br>IR1, IM       |                  |                                          |                        |                          |                  |               |                   |                    |  |
|                    | 3 | 8.0<br>JP              | 6.1<br>SRP             | 6.5                  | 6.5<br>SBC            | 10.5                 | 10.5                  | 10.5<br>SBC          | 10.5<br>SBC          |                  |                                          |                        |                          |                  |               |                   |                    |  |
|                    | 5 | IRR1                   | IM                     | <b>SBC</b><br>r1, r2 | r1, lr2               | <b>SBC</b><br>R2, R1 | SBC<br>IR2, R1        | R1, IM               | IR1, IM              |                  |                                          |                        |                          |                  |               |                   |                    |  |
|                    | 4 | 8.5<br><b>DA</b>       | 8.5<br><b>DA</b>       | 6.5<br><b>OR</b>     | 6.5<br><b>OR</b>      | 10.5<br><b>OR</b>    | 10.5<br><b>OR</b>     | 10.5<br><b>OR</b>    | 10.5<br><b>OR</b>    |                  |                                          |                        |                          |                  |               |                   |                    |  |
|                    |   | R1<br>10.5             | IR1<br>10.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                |  |
|                    | 5 | POP                    | POP                    | AND                  | AND                   | AND                  | AND                   | AND                  | AND                  |                  |                                          |                        |                          |                  |               |                   | WDT                |  |
|                    |   | 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      |                  |                                          |                        |                          |                  |               |                   |                    |  |
| (Xi                | 6 | COM<br>R1              | IR1                    | <b>TCM</b><br>r1, r2 | <b>TCM</b><br>r1, lr2 | <b>TCM</b><br>R2, R1 | <b>TCM</b><br>IR2, R1 | <b>TCM</b><br>R1, IM | TCM<br>IR1, IM       |                  |                                          |                        |                          |                  |               |                   |                    |  |
| e (He              | 7 | 10/12.1<br><b>PUSH</b> | 12/14.1<br><b>PUSH</b> | 6.5<br><b>TM</b>     | 6.5<br><b>TM</b>      | 10.5<br><b>TM</b>    | 10.5<br><b>TM</b>     | 10.5<br><b>TM</b>    | 10.5<br><b>TM</b>    |                  |                                          |                        |                          |                  |               |                   |                    |  |
| lddil              |   | R2                     | IR2                    | r1, r2               | r1, lr2               | R2, R1               | IR2, R1               | R1, IM               | IR1, IM              |                  |                                          |                        |                          |                  |               |                   | 6.1                |  |
| Upper Nibble (Hex) | 8 | 10.5<br><b>DECW</b>    | 10.5<br><b>DECW</b>    |                      |                       |                      |                       |                      |                      |                  |                                          |                        |                          |                  |               |                   | 6.1<br><b>DI</b>   |  |
| Up                 |   | RR1<br>6.5             | IR1<br>6.5             |                      |                       |                      |                       |                      |                      |                  |                                          |                        |                          |                  |               |                   | 6.1                |  |
|                    | 9 | RL<br>R1               | RL<br>IR1              |                      |                       |                      |                       |                      |                      |                  |                                          |                        |                          |                  |               |                   | EI                 |  |
|                    | А | 10.5<br>INCW           | 10.5<br>INCW           | 6.5<br><b>CP</b>     | 6.5<br><b>CP</b>      | 10.5<br><b>CP</b>    | 10.5<br><b>CP</b>     | 10.5<br><b>CP</b>    | 10.5<br><b>CP</b>    |                  |                                          |                        |                          |                  |               |                   | 14.0<br><b>RET</b> |  |
|                    |   | RR1                    | IR1                    | r1, r2               | r1, lr2               | R2, R1               | IR2, R1               | R1, IM               | IR1, IM              |                  |                                          |                        |                          |                  |               |                   |                    |  |
|                    | в | 6.5<br><b>CLR</b>      | 6.5<br>CLR             | 6.5<br><b>XOR</b>    | 6.5<br><b>XOR</b>     | 10.5<br><b>XOR</b>   | 10.5<br><b>XOR</b>    | 10.5<br><b>XOR</b>   | 10.5<br><b>XOR</b>   |                  |                                          |                        |                          |                  |               |                   | 16.0<br>IRET       |  |
|                    |   | R1<br>6.5              | IR1<br>6.5             | r1, r2<br>12.0       | r1, lr2<br>18.0       | R2, R1               | IR2, R1               | R1, IM               | IR1, IM<br>10.5      |                  |                                          |                        |                          |                  |               |                   | 6.5                |  |
|                    | С | RRC<br>R1              | RRC<br>IR1             | LDC<br>r1, lrr2      | LDCI<br>lr1, lrr2     |                      |                       |                      | <b>LD</b><br>r1,x,R2 |                  |                                          |                        |                          |                  |               |                   | RCF                |  |
|                    | D | 6.5<br>SRA             | 6.5<br>SRA             | ,                    | ,                     | 20.0<br>CALL*        |                       | 20.0<br>CALL         | 10.5<br>LD           |                  |                                          |                        |                          |                  |               |                   | 6.5<br><b>SCF</b>  |  |
|                    | 5 | R1                     | IR1                    |                      |                       | IRR1                 |                       | DA                   | r2,x,R1              |                  |                                          |                        |                          |                  |               |                   |                    |  |
|                    | Е | 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>CCF         |  |
|                    |   | R1<br>8.5              | IR1<br>8.5             |                      | r1, IR2<br>6.5        | R2, R1               | IR2, R1<br>10.5       | R1, IM               | IR1, IM              |                  |                                          |                        |                          |                  |               |                   | 6.0                |  |
|                    | F | SWAP<br>R1             | SWAP<br>IR1            |                      | <b>LD</b><br>lr1, r2  |                      | <b>LD</b><br>R2, IR1  |                      |                      | V                |                                          |                        | 🛉                        |                  | 🛉             | ¥                 | NOP                |  |
|                    |   |                        |                        |                      |                       |                      |                       |                      |                      |                  |                                          |                        |                          |                  | $\leftarrow$  |                   |                    |  |
|                    |   |                        | :                      | 2                    |                       |                      | ;                     | 3<br>Bv              | tes per              | Instruct         | ion                                      | 2                      |                          |                  | 3             |                   | 1                  |  |
|                    |   |                        |                        |                      | Lo                    | ower                 |                       | _,                   |                      |                  |                                          |                        |                          |                  |               |                   |                    |  |
|                    |   |                        |                        |                      | Op                    | code                 |                       |                      |                      |                  |                                          | <b>Legen</b><br>R = 8- | <b>d:</b><br>bit Addre   | ess              |               |                   |                    |  |
|                    |   |                        | Ex                     | ecution<br>Cycles    | INI                   |                      | Pipe                  |                      |                      |                  |                                          |                        | it Addres                |                  | _             |                   |                    |  |
|                    |   |                        |                        | _ ,                  | \                     | 4                    | / Cycl                | es                   |                      |                  |                                          |                        | r1 = Dst<br>r2 = Src     |                  |               |                   |                    |  |
|                    |   |                        | Upp                    |                      |                       | 10.5                 | N.4-                  |                      |                      |                  |                                          | Seque                  | nce:                     |                  |               |                   |                    |  |
|                    |   |                        |                        |                      |                       | 1, R2                | IVII                  | nemonic              |                      |                  | Opcode, First Operand,<br>Second Operand |                        |                          |                  |               |                   |                    |  |
|                    |   |                        | Op                     | First /<br>perand    |                       |                      |                       | ond<br>erand         |                      |                  | Note: Blank areas not defined.           |                        |                          |                  |               |                   |                    |  |
|                    |   |                        |                        |                      |                       |                      |                       |                      |                      |                  |                                          |                        | e instruct<br>yte instru |                  | ears as       |                   |                    |  |

# **PACKAGE INFORMATION**



E

| SYMBOL | MILLI | METER | INCH     |       |  |  |  |
|--------|-------|-------|----------|-------|--|--|--|
|        | MIN   | MAX   | MIN      | MAX   |  |  |  |
| A1     | 0.51  | 0.81  | .020     | .032  |  |  |  |
| A2     | 3.25  | 3.43  | .128     | .135  |  |  |  |
| B      | 0.38  | 0.53  | .015     | .021  |  |  |  |
| B1     | 1.02  | 1.52  | .040     | .060  |  |  |  |
| С      | 0:63  | 0.38  | .009     | .015  |  |  |  |
| D      | 52.07 | 52.58 | 2.050    | 2.070 |  |  |  |
| Ε      | 15.24 | 15.75 | .600     | .620  |  |  |  |
| E1     | 13.59 | 14.22 | .535     | .560  |  |  |  |
| e      | 2.54  | TYP   | .100 TYP |       |  |  |  |
| eA     | 15.49 | 16.51 | .610     | .650  |  |  |  |
| L      | 3.18  | 3.81  | .125     | .150  |  |  |  |
| - Q1   | 1.52  | 1.91  | .060     | .075  |  |  |  |
| S      | 1.52  | 2.29  | .060     | .090  |  |  |  |

CONTROLLING DIMENSIONS . INCH



# & Sirue

# **ORDERING INFORMATION**

### 5 MHz Z0861705PSC

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

#### Package

P = Plastic DIP V = Plastic Leaded Chip Carrier

#### Speed

05 = 5 MHz

### Environmental

C = Plastic Standard

#### Temperature

S =  $0^{\circ}$ C to +70°C (standard temp for the Z8615 is 0 to -55°C)

#### Example:

