# Z86E61/E63 CMOS Z8® 16K/32K EPROM MICROCONTROLLER ### **FEATURES** 8-Bit CMOS Microcontroller ■ 40-Pin DIP, 44-Pin PLCC Style Packages ■ 4.5V to 5.5V Operating Range Clock Speeds: 16 and 20 MHz ■ Low Power Consumption: 275 mW (max) ■ Fast Instruction Pointer: 1.0 ms @ 12 MHz Two Standby Modes: STOP and HALT 32 Input/Output Lines Full-Duplex UART ■ All Digital Inputs are TTL Levels Auto Latches ■ High Voltage Protection on High Voltage Inputs ■ RAM and EPROM Protect EPROM: 16 Kbytes Z86E61 32 Kbytes Z86E63 256 Bytes Register File - 236 Bytes of General-Purpose RAM - 16 Bytes of Control and Status Registers - 4 Bytes for Ports Two Programmable 8-Bit Counter/Timers Each with 6-Bit Programmable Prescaler Six Vectored, Priority Interrupts from Eight Different Sources On-Chip Oscillator that Accepts a Crystal, Ceramic Resonator, LC, or External Clock Drive ### **GENERAL DESCRIPTION** The Z86E61/E63 microcontrollers are members of the Z8® single-chip microcontroller family with 16K/32 Kbytes of EPROM and 236 bytes of general-purpose RAM. Offered in 40-pin DIP or 44-pin PLCC package styles, these devices are pin-compatible EPROM versions of the Z86C61/63. The ROMless pin option is available on the 44-pin versions only. With 4 Kbytes of ROM and 236 bytes of general-purpose RAM, the Z86E61/E63 offers fast execution, efficient use of memory, sophisticated interrupts, input/output bit manipulation capabilities, and easy hardware/software system expansion. For applications demanding powerful I/O capabilities, the Z86E61/E63 offers 32 pins dedicated to input and output. These lines are grouped into four ports. Each port consists of eight lines, and is configurable under software control to provide timing, status signals, serial or parallel I/O with or without handshake, and an address/data bus for interfacing external memory. The Z86E61/E63 can address both external memory and preprogrammed ROM, making it well suited for high-volume applications or where code flexibility is required. 9 ### **GENERAL DESCRIPTION** (Continued) There are three basic address spaces available to support this configuration: Program Memory, Data Memory, and 236 general-purpose registers. To unburden the system from coping with real-time tasks such as counting/timing and serial data communication, the Z86E61/E63 offers two on-chip counter/timers with a large number of user selectable modes (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> | Figure 1. Z86E61/E63 Functional Block Diagram # **PIN DESCRIPTION** Standard Mode Figure 2. 40-Pin DIP Pin Configuration Table 1. 40-Pin DIP Pin Identification | Standa<br>Pin # | ard Mode<br>Symbol | Function | Direction | |-----------------|--------------------|------------------------------|-----------| | 1 | V <sub>cc</sub> | Power Supply | Input | | 2 | XTAL2 | Crystal, Oscillator Clock | Output | | 3 | XTAL1 | Crystal, Oscillator Clock | Input | | 4 | P37 | Port 3, Pin 7 | Output | | 5 | P30 | Port 3, Pin 0 | Input | | 6 | /RESET | Reset | Input | | 7 | R//W | Read/Write | Output | | 8 | /DS | Data Strobe | Output | | 9 | /AS | Address Strobe | Output | | 10 | P35 | Port 3, Pin 5 | Output | | 11 | GND | Ground | Input | | 12 | P32 | Port 3, Pin 2 | Input | | 13-20 | P07-P00 | Port 0, Pins 0,1,2,3,4,5,6,7 | In/Output | | 21-28 | P17-P10 | Port 1, Pins 0,1,2,3,4,5,6,7 | In/Output | | 29 | P34 | Port 3, Pin 4 | Output | | 30 | P33 | Port 3, Pin 3 | Input | | 31-38 | P27-P20 | Port 2, Pins 0,1,2,3,4,5,6,7 | In/Output | | 39 | P31 | Port 3, Pin 1 | Input | | 40 | P36 | Port 3, Pin 6 | Output | # PIN DESCRIPTION (Continued) Standard Mode Figure 3. 44-Pin PLCC Pin Configuration Table 2. 44-Pin PLCC Pin Identification | Standard Mode Pin # Symbol Function Direction | | | | Standa<br>Pin # | rd Mode<br>Symbol | Function | Direction | |-----------------------------------------------|---------------------------------|---------------------------------------------------------------------------|----------------------------------|----------------------------|-----------------------------------------|-------------------------------------------------------------------------------------------------|----------------------------------------------------| | 1 | V | Power Supply | Input | 14-16 | P02-P00 | Port 0, Pins 0,1,2 | In/Output | | 2 | XTAL2 | Crystal, Osc. Clock | Output | 17 | R//RL | ROM/ROMIess control | Input | | 3 | XTAL1 | Crystal, Osc. Clock | Input | 18-22 | P07-P03 | Port 0, Pins 3,4,5,6,7 | In/Output | | 4 | P37 | Port 3, Pin 7 | Output | 23-27 | P10-P14 | Port 1, Pins 0,1,2,3,4 | In/Output | | 5 | P30 | Port 3, Pin 0 | Input | 28 | N/C | Not Connected | Input | | 6 | N/C | Not Connected | Input | 29-31 | P17-P15 | Port 1, Pins 5,6,7 | In/Output | | 7 | /RESET | Reset | Input | 32 | P34 | Port 3, Pin 4 | Output | | 8 | R//W | Read/Write | Output | 33 | P33 | Port 3, Pin 3 | Input | | 9<br>10<br>11<br>12<br>13 | /DS<br>/AS<br>P35<br>GND<br>P32 | Data Strobe<br>Address Strobe<br>Port 3, Pin 5<br>Ground<br>Port 3, Pin 2 | Output Output Output Input Input | 34-38<br>39<br>40-42<br>43 | P24-P20<br>N/C<br>P27-P25<br>P31<br>P36 | Port 2, Pins 0,1,2,3,4<br>Not Connected<br>Port 2, Pins 5,6,7<br>Port 3, Pin 1<br>Port 3, Pin 6 | In/Output<br>Input<br>In/Output<br>Input<br>Output | <sup>9-4 9984043 0027917 385</sup> ### PIN DESCRIPTION EPROM Mode Figure 4. 40-Pin DIP Pin Configuration Table 3. 40-Pin DIP Pin Identification | EPROI<br>Pin # | M Mode<br>Symbol | Function | Direction | |----------------|------------------|----------------------------|-----------| | 1 | V <sub>cc</sub> | Power Supply | Input | | 2 | XTAL2 | Crystal, Osc. Clock | Output | | 3 | XTAL1 | Crystal, Osc. Clock | Input | | 4 | N/C | Not Connected | Input | | 5 | /CE | Chip Enable | Input | | 6 | /RESET | Reset | Input | | 7-10 | N/C | Not Connected | Input | | 11 | GND | Ground | Input | | 12 | EPM | EPROM Prog Mode | Input | | 13-20 | A7-A0 | Address 0,1,2,3,4,5,6,7 | Input | | 21-28 | D7-D0 | Data 0,1,2,3,4,5,6,7 | In/Output | | 29 | N/C | Not Connected | Input | | 30 | V <sub>PP</sub> | Prog Voltage | Input | | 31-37 | A14-A8 | Address 8,9,10,11,12,13,14 | Input | | 38 | /PGM | Prog Mode | Input | | 39 | /OE | Output Enable | Input | | 40 | N/C | Not Connected | Input | # **PIN DESCRIPTION** (Continued) EPROM Mode Figure 5. 44-Pin PLCC Pin Configuration Table 4. 44-Pin PLCC Pin Identification | EPRON | Mode<br>Symbol | Function | Direction | EPRON<br>Pin # | Mode<br>Symbol | Function | Direction | |--------|-----------------|---------------------|-----------|----------------|----------------|----------------------|-----------| | PIII # | Symbol | Function | Direction | FIII # | Symbol | FullClion | Direction | | 1 | V <sub>cc</sub> | Power Supply | Input | 18-22 | A7-A3 | Address 3,4,5,6,7 | Input | | 2 | XŤĂL2 | Crystal, Osc. Clock | Input | 23-27 | D4-D0 | Data 0,1,2,3,4 | In/Output | | 3 | XTAL1 | Crystal, Osc. Clock | Input | 28 | N/C | Not Connected | Input | | 4 | N/C | Not Connected | Input | 29-31 | D7-D5 | Data 5,6,7 | In/Output | | 5 | /CE | Chip Enable | Input | 32 | N/C | Not Connected | Input | | 6 | N/C | Not Connected | Input | 33 | $V_{pp}$ | Prog Voltage | Input | | 7 | /RESET | Reset | Input | 34-38 | A12-A8 | Address 8,9,10,11,12 | Input | | 8-11 | N/C | Not Connected | Input | 39 | N/C | Not Connected | Input | | 12 | GND | Ground | Input | 40-41 | A13-A14 | Address 13, 14 | Input | | 13 | EPM | EPROM Prog Mode | Input | 42 | /PGM | Prog Mode | Input | | 14-16 | A0-A2 | Address 0,1,2 | Input | 43 | /OE | Output Enable | Input | | 17 | N/C | Not Connected | Input | 44 | N/C | Not Connected | Input | ### PIN FUNCTIONS **ROMIess** (input, active Low). Connecting this pin to GND disables the internal ROM and forces the device to function as a Z86C91 ROMIESS Z8 (see the Z86C91 product specification for more information). When left unconnected or pulled High to V<sub>CC</sub>, the device functions as a normal Z86E61/E63 EPROM version. **Note:** This pin is only available on the 44-pin versions of the Z86E61/E63. **/DS** (output, active Low). Data Strobe is activated once for each external memory transfer. For a READ operation, data must be available prior to the trailing edge of /DS. For WRITE operations, the falling edge of /DS indicates that output data is valid. /AS (output, active Low). Address Strobe is pulsed once at the beginning of each machine cycle. Address output is through Port 1 for all external programs. Memory address transfers are valid at the trailing edge of /AS. Under program control, /AS can be placed in the high-impedance state along with Ports 0 and 1, Data Strobe, and Read/Write. **XTAL2, XTAL1** Crystal 2, Crystal 1 (time-based input and output, respectively). These pins connect a parallel-resonant crystal, ceramic resonator, LC, or any external single-phase clock to the on-chip oscillator and buffer. **R//W** (output, write Low). The Read/Write signal is Low when the MCU is writing to the external program or data memory. /RESET (input, active Low). To avoid asynchronous and noisy reset problems, the Z86E61/E63 is equipped with a reset filter of four external clocks (4TpC). If the external /RESET signal is less than 4TpC in duration, no reset occurs. On the fifth clock after the /RESET is detected, an internal RST signal is latched and held for an internal register count of 18 external clocks, or for the duration of the external /RESET, whichever is longer. During the reset cycle, /DS is held active Low while /AS cycles at a rate of TpC/2. When /RESET is deactivated, program execution begins at location 000C (HEX). Power-up reset time must be held low for 50 ms, or until $\rm V_{cc}$ is stable, whichever is longer. **Port 0** (P07-P00). Port 0 is an 8-bit, nibble programmable, bidirectional, TTL compatible port. These eight I/O lines can be configured under software control as a nibble I/O port, or as an address port for interfacing external memory. When used as an I/O port, Port 0 may be placed under handshake control. In this configuration, Port 3, lines P32 and P35 are used as the handshake control /DAV0 and RDY0 (Data Available and Ready). Handshake signal assignment is dictated by the I/O direction of the upper nibble P07-P04. The lower nibble must have the same direction as the upper nibble to be under handshake control. For external memory references, Port 0 can provide address bits A11-A8 (lower nibble) or A15-A8 (lower and upper 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. If one or both nibbles are needed for I/O operation, they must be configured by writing to the Port 0 Mode register. In ROMless mode, after a hardware reset, Port 0 lines are defined as address lines A15-A8, and extended timing is set to accommodate slow memory access. The initialization routine can include reconfiguration to eliminate this extended timing mode (Figure 8). **Port 1** (P17-P10). Port 1 is an 8-bit, byte programmable, bidirectional, TTL compatible port. It has multiplexed Address (A7-A0) and Data (D7-D0) ports. For Z86E61/E63, these eight I/O lines can be programmed as input or output lines or are configured under software control as an address/data port for interfacing external memory. When used as an I/O port, Port 1 can be placed under handshake control. In this configuration, Port 3 lines, P33 and P34, are used as the handshake controls RDY1 and /DAV1. Memory locations greater than 16384 (E61) or 32768 (E63) are referenced through Port 1. To interface external memory, Port 1 must be programmed for the multiplexed Address/ Data mode. If more than 256 external locations are required, Port 0 must output the additional lines. Port 1 can be placed in high-impedance state along with Port 0, /AS, /DS, and R//W, allowing the MCU to share common resources in multiprocessor and DMA applications. Data transfers are controlled by assigning P33 as a Bus Acknowledge input, and P34 as a Bus Request output (Figure 9). # PIN FUNCTIONS (Continued) Figure 6. Port 0 Configuration Figure 7. Port 1 Configuration ### PIN FUNCTIONS (Continued) **Port 2** (P27-P20). Port 2 is an 8-bit, bit programmable, bidirectional, CMOS compatible port. Each of these eight I/O lines can be independently programmed as an input or output, or globally as an open-drain output. Port 2 is always available for I/O operation. When used as an I/O port, Port 2 can be placed under handshake control. In this configuration, Port 3 lines P31 and P36 are used as the handshake control lines /DAV2 and RDY2. The handshake signal assignment for Port 3 lines, P31 and P36, is dictated by the direction (input or output) assigned to P27 (Figure 8 and Table 5). Figure 8. Port 2 Configuration **Port3** (P37-P30). Port 3 is an 8-bit, CMOS compatible four-fixed input and four-fixed output port. These eight I/O lines have four-fixed (P33-P30) input and four-fixed (P37-P34) output ports. Port 3, when used as serial I/O, is programmed as serial in and serial out, respectively (Figure 9). Figure 9. Port 3 Configuration Port 3 is configured under software control to provide the following control functions: handshake for Ports 0 and 2 (/DAV and RDY); four external interrupt request signals (IRQ3-IRQ0); timer input and output signals ( $T_{IN}$ and $T_{OUT}$ ), Data Memory Select (/DM) and EPROM control signals (P30 = /CE, P31 = /OE, P32 = EPM and P33 = $V_{EP}$ ). Table 5. Port 3 Pin Assignments | Pin | ľO | CTC1 | Int. | P0 HS | P1 HS | P2 HS | UART | Ext | EPROM | |-----|-----|-----------------|------|-------|-------|-------|------------|-------|-----------------| | P30 | IN | | IRQ3 | | | | Serial In | | /CE | | P31 | IN | T <sub>IN</sub> | IRQ2 | | | D/R | | | /OE | | P32 | IN | IIN | IRQ0 | D/R | | -, | | | EPM | | P33 | IN | | IRQ1 | -, | D/R | | | | V <sub>PP</sub> | | P34 | OUT | | | | R/D | | | DM | | | P35 | OUT | | | R/D | . , _ | | | D.111 | | | P36 | OUT | Tout | | | | R/D | | | | | P37 | OUT | - 001 | | | | 142 | Serial Out | | | | TO | | | IRQ4 | | | | Jonal Out | | | | T1 | | | IRQ5 | | | | | | | Notes: HS = Handshake Signals D = Data Available R = Ready ### **UART OPERATION** Port 3 lines, P37 and P30, are programmed as serial I/O lines for full-duplex serial asynchronous receiver/transmitter operation. The bit rate is controlled by Counter/Timer0. The Z86E61/E63 automatically adds a start bit and two stop bits to transmitted data (Figure 10). Odd parity is also available as an option. Eight data bits are always transmitted, regardless of parity selection. If parity is enabled, the eighth bit is the odd parity bit. An interrupt request (IRQ4) is generated on all transmitted characters. Received data must have a start bit, eight data bits, and at least one stop bit. If parity is on, bit 7 of the received data is replaced by a parity error flag. Received characters generate the IRQ3 interrupt request. Figure 10. Serial Data Formats **Auto Latch.** The Auto Latch puts valid CMOS levels on all CMOS inputs that are not externally driven. This reduces excessive supply current flow in the input buffer when it is not driven by any source. **Note:** P33-P30 inputs differ from the Z86C61/C63 in that there is no clamping diode to $V_{\rm cc}$ because of the EPROM high voltage detection circuits. Exceeding the $V_{\rm IH}$ maximum specification during standard operating mode may cause the device to enter EPROM mode ### ADDRESS SPACE **Program Memory**. The Z86E61/E63 can address 48 Kbytes (E61) or 32 Kbytes (E63) of external program memory (Figure 11). The first 12 bytes of program memory are reserved for the interrupt vectors. These locations contain six 16-bit vectors that correspond to the six available interrupts. For EPROM mode, byte 13 to byte 16383 (E61) or 32767 (E63) consists of on-chip EPROM. At addresses 16384 (E61) or 32768 (E63) and above, the Z86E61/E63 executes external program memory fetches. In ROMless mode, the Z86E61/E63 can address up to 64 Kbytes of program memory. Program execution begins at external location 000C (HEX) after a reset. 9-12 9984043 0027925 451 Figure 11. Program Memory Configuration Data Memory (/DM). The EPROM version can address up to 48 Kbytes (E61) or 32 Kbytes (E63) of external data memory space beginning at location 16384 (E61) or 32768 (E63). The ROMless version can address up to 64 Kbytes of external data memory. External data memory may be included with, or separated from, the external program memory space. /DM, an optional I/O function that can be programmed to appear on pin P34, is used to distinguish between data and program memory space (Figure 12). The state of the /DM signal is controlled by the type instruction being executed. An LDC opcode references PROGRAM (/DM inactive) memory, and an LDE instruction references DATA (/DM active Low) memory. Register File. The register file consists of four I/O port registers, 236 general-purpose registers, and 16 control and status registers (Figure 13). The instructions can access registers directly or indirectly through an 8-bit address field. The Z86E61/E63 also allows short 4-bit register addressing using the Register Pointer (Figure 14). In the 4-bit mode, the Register File is divided into 16 working register groups, each occupying 16 continuous locations. The Register Pointer addresses the starting location of the active working register group. **Stack.** The Z86E61/E63 has a 16-bit Stack Pointer (R255-R254) used for external stacks that reside anywhere in the data memory for the ROMless mode, but only from 16384 (E61) or 32768 (E63) to 65535 in the EPROM mode. An 8-bit Stack Pointer (R255) is used for the internal stack that resides within the 236 general-purpose registers (R239-R4). The high byte of the Stack Pointer (SPH Bits 15-8) can be use as a general purpose register when using internal stack only. Figure 12. Data Memory Configuration # **ADDRESS SPACE** (Continued) Figure 14. Register Pointer Figure 13. Register File ### FUNCTIONAL DESCRIPTION **Counter/Timers.** There are two 8-bit programmable counter/timers (T0-T1), each driven by its own 6-bit programmable prescaler. The T1 prescaler is driven by internal or external clock sources; however, the T0 prescaler is driven by the internal clock only (Figure 15). The 6-bit prescalers can divide the input frequency of the clock source by any integer number from 1 to 64. Each prescaler drives its counter, which decrements the value (1 to 256) that has been loaded into the counter. When both the counters and prescalers reach the end of the count, a timer interrupt request, IRQ4 (T0) or IRQ5 (T1), is generated. The counter is programmed to start, stop, restart to continue, or restart from the initial value. The counters can also be programmed to stop upon reaching zero (single pass mode) or to automatically reload the initial value and continue counting (modulo-n continuous mode). The counter, but not the prescalers, are read at any time without disturbing their value or count mode. The clock source for T1 is user-definable and is either the internal microprocessor clock divided-by-four, or an external signal input through Port 3. The Timer Mode register configures the external timer input (P31) as an external clock, a trigger input that can be retriggerable or non-retriggerable, or as a gate input for the internal clock. Port 3 line P36 also serves as a timer output $(T_{\rm OuT})$ through which T0, T1, or the internal clock can be output. The counter/timers are cascaded by connecting the T0 output to the input of T1. Figure 15. Counter/Timers Block Diagram 9 ### **FUNCTIONAL DESCRIPTION (Continued)** Interrupts. The Z86E61/E63 has six different interrupts from eight different sources. The interrupts are maskable and prioritized. The eight sources are divided as follows: four sources are claimed by Port 3 lines P33-P30, one in Serial Out, one in Serial In, and two in the counter/timers (Figure 16). The Interrupt Mask Register globally or individually enables or disables the six interrupt requests. When more than one interrupt is pending, priorities are resolved by a programmable priority encoder that is controlled by the Interrupt Priority register (refer to Table 5). All Z86E61/E63 interrupts are vectored through locations in the program memory. When an interrupt machine cycle is activated, an interrupt request is granted. Thus, this disables all of the subsequent interrupts, 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 requests need service. Software initialized interrupts are supported by setting the appropriate bit in the Interrupt Request Register (IRQ). Internal interrupt requests are sampled on the falling edge of the last cycle of every instruction, and the interrupt request must be valid 5TpC before the falling edge of the last clock cycle of the currently executing instruction. For the ROMless mode, when the device samples a valid interrupt request, the next 48 (external) clock cycles are used to prioritize the interrupt, and push the two PC bytes and the FLAG register on the stack. The following nine cycles are used to fetch the interrupt vector from external memory. The first byte of the interrupt service routine is fetched beginning on the 58th TpC cycle following the internal sample point, which corresponds to the 63rd TpC cycle following the external interrupt sample point. Figure 16. Interrupt Block Diagram Clock. The Z86E61/E63 on-chip oscillator has a high gain, parallel resonant amplifier for connection to a crystal, LC, ceramic resonator, or any suitable external clock source (XTAL1 = Input, XTAL2 = Output). The crystal should be AT cut, 1 MHz to 16 MHz max; series resistance (RS) is less than or equal to 100 Ohms. The crystal should be connected across XTAL1 and XTAL2 using the recommended capacitors (10 pF < CL < 100 pF) from each pin to ground (Figure 17). Note: Actual capacitor value specified by crystal manufacturer. Figure 17. Oscillator Configuration HALT. Turns off the internal CPU clock but not the XTAL oscillation. The counter/timers and external interrupts IRQ0, IRQ1, IRQ2, and IRQ3 remain active. The devices are recovered by interrupts, either externally or internally generated. An interrupt request must be executed (enabled) to exit HALT mode. After the interrupt service routine, the program continues from the instruction after the HALT. STOP. This instruction turns off the internal clock and external crystal oscillation, and reduces the standby current to 5 µA (typical) or less. The STOP mode is terminated by a reset, which causes the processor to restart the application program at address 000C (HEX). In order to enter STOP (or HALT) mode, it is necessary to first flush the instruction pipeline to avoid suspending execution in mid-instruction. To do this, the user must execute a NOP (opcode = OFFH) immediately before the appropriate SLEEP instruction. i.e., FF NOP ; clear the pipeline 6F STOP ; enter STOP mode or FF NOP ; clear the pipeline 7F HALT ; enter HALT mode ### **PROGRAMMING** ### Z86E61/E63 User Modes The Z86E61/E63 uses separate AC timing cycles for the different User Modes available. Table 6 shows the Z86E61/ E63 User Modes. Table 7 shows the timing of the programming waveforms. #### User MODE 1 EPROM Read The Z86E61/E63 EPROM read cycle is provided so that the user may read the Z86E61/E63 as a standard 27128 (E61) or 27256 (E63) EPROM. This is accomplished by driving the /EPM pin (P32) to V and activating /CE and /OE. /PGM remains inactive. This mode is not valid after execution of an EPROM protect cycle. Timing for the EPROM read cycle is shown in Figure 18. ### **User MODE 2 EPROM Program** The Z86E61/E63 Program function conforms to the Intelligent programming algorithm. The device is programmed with $V_{cc}$ at 6.0V and $V_{pp} = 12.5V$ . Programming pulses are applied in 1 ms increments to a maximum of 25 pulses before proper verification. After verification, a programming pulse of three times the duration of the cycles necessary to program the device is issued to ensure proper programming. After all addresses are programmed, a final data comparison is executed and the programming cycle is complete. Timing for the Z86E61/E63 programming cycle is shown in Figure 18. 9-17 # **PROGRAMMING** (Continued) ### **User Mode 3: PROM Verify** The Program Verify cycle is used as part of the intelligent programming algorithm to insure data integrity under worst-case conditions. It differs from the EPROM Read cycle in that $V_{PP}$ is active and $V_{CC}$ must be driven to 6.0V. Timing is shown in Figure 18. ### User Modes 4 and 5: EPROM and RAM Protect To extend program security, EPROM and RAM protect cycles are provided for the Z86E61/E63. Execution of the EPROM protect cycle prohibits proper execution of the EPROM Read, EPROM Verify, and EPROM programming cycles. Execution of the RAM protect cycle disables accesses to the upper 128 bytes of register memory (excluding mode and configuration registers), but first the user's program must set bit 6 of the IMR (R251). Timing is shown in Figures 20 and 21. **User Modes.** Table 6 shows the programming voltage of each mode of the Z86E61/E63. **Table 6. OTP Programming Table** | User/Test Mode | - | | Device Pir | | | | | Port 1 | |------------------------------|------------------------|------------|----------------|-----------------|-----------------|------|-----------------|--------------| | Device Pin No.<br>User Modes | P33<br>V <sub>PP</sub> | P32<br>EPM | P30<br>/CE | P31<br>/OE | P20<br>/PGM | ADDR | V <sub>cc</sub> | CNFG<br>Data | | EPROM Read | V <sub>IH</sub> | V | V., | V., | ٧,,, | Addr | 5.0V | Out | | Program | V <sub>PP</sub> | χ̈́ | ٧, ً | V <sub>IH</sub> | ٧ <u>'''</u> | Addr | 6.0V | In | | Program Verify | V <sub>PP</sub> | X | ٧," | V,''' | ٧ | Addr | 6.0V | Out | | EPROM Protect | V <sub>PP</sub> | V | ٧ <u>'</u> '. | V <sub>IH</sub> | V <sub>IL</sub> | XX | 6.0V | XX | | RAM Protect | V <sub>PP</sub> | X | V <sub>H</sub> | V <sub>IH</sub> | V <sub>IL</sub> | XX | 6.0V | XX | #### Notes: # Z86E63 Signal Description for EPROM Program/Read The following signals are required to correctly program or read the Z86E63 device. ADDR. The address must remain stable throughout the program read cycle. DATA. The I/O data bus must be stable during programming (/OE High, /PGM Low, $V_{pp}$ High). During read the data bus outputs data. XCLK. A clock is required to clock the /RESET signal into the registers before programming. A constant clock can be applied, or the XCLK input can be toggled a minimum of 12 cycles before any programming or verify function begins. The maximum clock frequency to be applied when in the EPROM mode is 12 MHz. /RESET. The reset input can be held to a constant Low or High value throughout normal programming. It must be held High to program the EPROM protect option bit. Also, any time the /RESET input changes state the XCLK must be clocked a minimum of 12 times to clock the /RESET through the reset filter. /OE. When the device is placed in EPROM mode, the /OE input also serves as the precharge for the sense amp. The precharge signal should be Low for the first half of the stable address and High for the second half. The PRECHG signal is inverted from the /OE signal so the /OE should be High on the first half and Low on the second half, or stable address. The EPROM output data should be sampled during the second half of stable address. The access time of the EPROM is defined in later sections. This two part calculation of access time is required because this is a precharged sense amp with a precharge clock 9-18 9984043 0027931 755 $V_{pp} = 12.0V \pm 0.5V$ $V_{H} = 12.0V \pm 0.5V$ $V_{IH} = 5V$ V<sub>IL</sub> = 0V XX = Irrelevant Ipp during programming = 40 mA maximum. Icc during programming, verify, or read = 40 mA maximum. **Table 7. Timing of Programming Waveforms** | Parameters | Name | Min | Max | Units | |------------|----------------------------|------|-----|-------| | 1 | Address Setup Time | 2 | | μѕ | | 2 | Data Setup Time | 2 | | μs | | 3 | V <sub>pp</sub> Setup | 2 | | μs | | 4 | V <sub>cc</sub> Setup Time | 2 | | μs | | 5 | Chip Enable Setup Time | 2 | | μs | | 6 | Program Pulse Width | 0.95 | | ms | | 7 | Data Hold Time | 2 | | μs | | 8 | /OE Setup Time | 2 | | μs | | 9 | Data Access Time | | 200 | ns | | 10 | Data Output Float Time | | 100 | ns | | 11 | Overprogram Pulse Width | 2.85 | | ms | | 12 | EPM Setup Time | 2 | | μs | | 13 | /PGM Setup Time | 2 | | μs | | 14 | Address to /OE Setup Time | 2 | | μs | | 15 | Option Program Pulse Width | 78 | | ms | Figure 18. EPROM Read # **PROGRAMMING** (Continued) Figure 19. EPROM Program and Verify Figure 20. Programming EPROM, RAM Protect and 4K Size Selection # **PROGRAMMING** (Continued) Figure 21. Programming EPROM, RAM Protect and 16K Size Selection Figure 22. Intelligent Programming Flowchart ### **ABSOLUTE MAXIMUM RATINGS** | Symbol | Description | Min | Max | Units | |------------------|--------------------------------|------|------------|-------| | V <sub>cc</sub> | Supply Voltage* | -0.3 | + 7.0° | V | | T <sub>stG</sub> | Storage Temp Oper Ambient Temp | –65° | +150°<br>† | C | #### Notes: - Voltages on all pins with respect to GND. - † See Ordering Information Stresses greater than those listed under Absolute Maximum Ratings may cause permanent damage to the device. This is a stress rating only; operation of the device at any condition above those indicated in the operational sections of these specifications is not implied. Exposure to absolute maximum rating conditions for an extended period may affect device reliability. ### STANDARD TEST CONDITIONS The characteristics listed below apply for standard test conditions as noted. All voltages are referenced to GND. Positive current flows into the referenced pin (Figure 23). Figure 23. Test Load Diagram | Sym | Parameter | T <sub>A</sub> = 0°C<br>Min | to +70°C<br>Max | Typical<br>@ 25°C | Units | Conditions | |-------------------|--------------------------|-----------------------------|-----------------------|-------------------|-------|----------------------------------------------------------| | | Max Input Voltage | | 7 | | ٧ | Ι <sub>N</sub> 250 μΑ | | | Max Input Voltage | | 13 | | V | P33-P30 Only | | $V_{CH}$ | Clock Input High Voltage | 3.8 | $V_{cc} + 0.3$ | | V | Driven by External Clock Generator | | V <sub>CL</sub> | Clock Input Low Voltage | -0.3 | 8.0 | | V | Driven by External Clock Generator | | V <sub>IH</sub> | Input High Voltage | 2.0 | V <sub>cc</sub> + 0.3 | | ٧ | | | V,, | Input Low Voltage | -0.3 | 8.0 | | V | | | V <sub>o</sub> H | Output High Voltage | 2.4 | | | ٧ | $I_{OH} = -2.0 \text{ mA}$ | | Vol | Output Low Voltage | | 0.4 | | V | $I_{OL}^{OH} = +2.0 \text{ mA}$ | | V <sub>RH</sub> | Reset Input High Voltage | 3.8 | V <sub>cc</sub> + 0.3 | | V | | | V <sub>RI</sub> | Reset Input Low Voltage | -0.3 | 0.8 | | V | | | I <sub>IL</sub> " | Input Leakage | -10 | 10 | | μΑ | 0V V <sub>IN</sub> + 5.25V | | OL | 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$ | | l <sub>cc</sub> | Supply Current | | 50 | 25 | mΑ | @ 16 MHz | | 00 | | | 60 | 35 | mA | @ 20 MHz | | I <sub>CC1</sub> | Standby Current | | 15 | 5 | mA | HALT Mode V <sub>IN</sub> = 0V, V <sub>CC</sub> @ 16 MHz | | 001 | - | | 20 | 10 | mΑ | HALT Mode $V_{IN} = 0V$ , $V_{CC}$ @ 20 MHz | | $I_{CC2}$ | Standby Current | | 20 | 5 | μA | STOP Mode $V_{IN} = 0V$ , $V_{CC}$ @ 16 MHz | | 002 | - | | 20 | 5 | μΑ | STOP Mode $V_{IN} = 0V$ , $V_{CC}$ @ 20 MHz | ### Notes: local requires loading TMR (%F1H) with any value prior to STOP execution. Use this sequence: LD TMR,#00 NOP STOP External I/O or Memory Read or Write Timing Diagram Figure 24. External I/O or Memory Read/Write Timing External I/O or Memory Read and Write Timing Table | | | | | T, = 0°C t | o +70°C | | | | |----|-----------|--------------------------------------------|------|------------|---------|-----|-------|---------| | | | | 16 N | | 20 F | ИHz | | | | No | Symbol | Parameter | Min | Max | Min | Max | Units | Notes | | 1 | TdA(AS) | Address Valid to /AS Rise Delay | 20 | | 26 | | ns | [2,3] | | 2 | TdAS(A) | /AS Rise to Address Float Delay | 30 | | 28 | | ns | [2,3] | | 3 | TdAS(DR) | /AS Rise to Read Data Reg'd Valid | | 180 | | 160 | ns | [1,2,3] | | 4 | Twas | /AS Low Width | 35 | | 36 | | ns | [2,3] | | 5 | TdAZ(DS) | Address Float to /DS Fall | 0 | | 0 | | ns | | | 6 | TwdsR | /DS (Read) Low Width | 135 | | 130 | | ns | [1,2,3] | | 7 | TwDSW | /DS (Write) Low Width | 80 | | 75 | | ns | [1,2,3] | | 8 | TdDSR(DR) | /DS Fall to Read Data Req'd Valid | | 75 | | 100 | ns | [1,2,3] | | 9 | ThDR(DS) | Read Data to /DS Rise Hold Time | 0 | | 0 | | ns | [2,3] | | 10 | TdDS(A) | /DS Rise to Address Active Delay | 35 | | 48 | | ns | [2,3] | | 11 | TdDS(AS) | /DS Rise to /AS Fall Delay | 30 | | 36 | | ns | [2,3] | | 12 | TdR/W(AS) | R//W Valid to /AS Rise Delay | 20 | | 32 | | ns | [2,3] | | 13 | TdDS(R/W) | /DS Rise to R//W Not Valid | 30 | | 36 | | ns | [2,3] | | 14 | TdDW(DSW) | Write Data Valid to /DS Fall (Write) Delay | 25 | | 40 | | ns | [2,3] | | 15 | TdDS(DW) | /DS Rise to Write Data Not Valid Delay | 30 | | 40 | | ns | [2,3] | | 16 | TdA(DR) | Address Valid to Read Data Req'd Valid | | 200 | | 200 | ns | [1,2,3] | | 17 | TdAS(DS) | /AS Rise to /DS Fall Delay | 40 | | 48 | | ns | [2,3] | | 18 | TdDM(AŚ) | /DM Valid to /AS Fall Delay | 30 | | 36 | | ns | [2,3] | ### Notes: ### **Clock Dependent Formulas** | Number | Symbol | Equation | |----------|-----------------------|-------------------------------------| | 1 | TdA(AS)<br>TdAS(A) | 0.40 TpC + 0.32<br>0.59 TpC - 3.25 | | 2<br>3 | TdAS(DR) | 2.83 TpC + 6.14 | | 4 | TwAS | 0.66 TpC - 1.65 | | 6<br>7 | TwDSR<br>TwDSW | 2.33 TpC - 10.56<br>1.27 TpC + 1.67 | | 8 | TdDSR(DR) | 1.97 TpC - 42.5 | | 10 | TdDS(A) | 0.8 TpC | | 11<br>12 | TdDS(AS)<br>TdR/W(AS) | 0.59 TpC - 3.14<br>0.4 TpC | | 13 | TdDS(R/W) | 0.4 TpC – 15 | | 14 | TdDW(DSW) | 0.4 sTpC | | 15 | TdDS(DW) | 0.88 TpC - 19 | | 16<br>17 | TdA(DR)<br>TdAS(DS) | 4 TpC – 20<br>0.91 TpC – 10.7 | | 18 | TdDM(AS) | 0.9 TpC - 26.3 | | | | | <sup>[1]</sup> When using extended memory timing add 2 TpC.[2] Timing numbers given are for minimum TpC. <sup>[3]</sup> See clock cycle dependent characteristics table. Standard Test Load All timing references use 2.0 V for a logic 1 and 0.8 V for a logic 0. Additional Timing Diagram Figure 25. Additional Timing # **AC CHARACTERISTICS**Additional Timing Table | | | $T_A = 0^{\circ}C \text{ to } +70^{\circ}C$ | | | | | | | | | | | | |----|-------------|---------------------------------------------|--------|------------|------|------|-------|-------|--|--|--|--|--| | No | Symbol | Parameter | 16 Min | ИĤz<br>Мах | | | Units | Notes | | | | | | | 1 | TpC | Input Clock Period | 62.5 | 1000 | 50 | 1000 | ns | [1] | | | | | | | 2 | TrC,TfC | Clock Input Rise & Fall Times | | 10 | | 15 | ns | [1] | | | | | | | 3 | TwC | Input Clock Width | 21 | | 37 | | ns | [1] | | | | | | | 4 | TwTinL | Timer Input Low Width | 50 | | 75 | | ns | [2] | | | | | | | 5 | TwTinH | Timer Input High Width | 5TpC | | 5TpC | | | [2] | | | | | | | 6 | TpTin | Timer Input Period | 8TpC | | 8TpC | | | [2] | | | | | | | 7 | TrTin,TfTin | Timer Input Rise & Fall Times | 100 | | 100 | | пѕ | [2] | | | | | | | 8A | TwiL | Interrupt Request Input Low Times | 70 | | 50 | | ns | [2,4] | | | | | | | 8B | TwlL | Interrupt Request Input Low Times | 5TpC | | 5TpC | | | [2,5] | | | | | | | 9 | TwlH | Interrupt Request Input High Times | 5TpC | | 5TpC | | | [2,3] | | | | | | ### Notes: 9-28 **■** 9984043 0027941 6T4 **■** <sup>[1]</sup> Clock timing references use 3.8V for a logic 1 and 0.8V for a logic 0. <sup>[2]</sup> Timing references use 2.0V for a logic 1 and 0.8V for a logic 0. <sup>[3]</sup> Interrupt references request through Port 3. <sup>[4]</sup> Interrupt request through Port 3 (P33-P31). <sup>[5]</sup> Interrupt request through Port 30. Handshake Timing Diagrams Figure 26. Input Handshake Timing Figure 27. Output Handshake Timing # **AC CHARACTERISTICS** Handshake Timing Table | | | $T_A = 0^{\circ}C \text{ to } +70^{\circ}C$ | | | | | | | | | | | |----|--------------|---------------------------------------------|-------------------|-----|-------------------|-----|-------------------|--|--|--|--|--| | No | Symbol | Parameter | 16 MHz<br>Min Max | | 20 MHz<br>Min Max | | Data<br>Direction | | | | | | | 1 | TsDI(DAV) | Data In Setup Time | 0 | | 0 | | IN | | | | | | | 2 | ThDI(DAV) | Data In Hold Time | 145 | | 145 | | IN | | | | | | | 3 | TwDAV | Data Available Width | 110 | | 110 | | iN | | | | | | | 4 | TdDAVI(RDY) | DAV Fall to RDY Fall Delay | | 115 | 1,10 | 115 | IN | | | | | | | 5 | TdDAVId(RDY) | DAV Rise to RDY Rise Delay | | 115 | | 115 | IN | | | | | | | 6 | TdRDY0(DAV) | RDY Rise to DAV Fall Delay | 0 | | 0 | | iN | | | | | | | 7 | TdD0(DAV) | Data Out to DAV Fall Delay | | TpC | | Τ¤С | OUT | | | | | | | 8 | TdDAV0(RDY) | DAV Fall to RDY Fall Delay | 0 | • | 0 | | OUT | | | | | | | 9 | TdRDY0(DAV) | RDY Fall to DAV Rise Delay | | 115 | | 115 | OUT | | | | | | | 10 | TwRDY | RDY Width | 110 | | 110 | | OUT | | | | | | | 11 | TdRDY0d(DAV) | RDY Rise to DAV Fall Delay | | 115 | | 115 | OUT | | | | | | ### **Z8 CONTROL REGISTER DIAGRAMS** Figure 28. Serial I/O Register (F0,: Read/Write) Figure 29. Timer Mode Register (F1,: Read/Write) Figure 30. Counter/Timer 1 Register (F2\_: Read/Write) Figure 31. Prescaler 1 Register (F3<sub>u</sub>: Write Only) Figure 32. Counter/Timer 0 Register (F4<sub>u</sub>: Read/Write) Figure 33. Prescaler 0 Register (F5,: Write Only) # **Z8 CONTROL REGISTER DIAGRAMS** (Continued) Figure 34. Port 2 Mode Register (F6<sub>u</sub>: Write Only) Figure 35. Port 3 Mode Register (F7<sub>H</sub>: Write Only) Figure 36. Port 0 and 1 Mode Register (F8<sub>H</sub>: Write Only) Figure 37. Interrupt Priority Register (F9<sub>H</sub>: Write Only) Figure 38. Interrupt Request Register (FA<sub>u</sub>: Read/Write) Figure 39. Interrupt Mask Register (FB<sub>u</sub>: Read/Write) Figure 40. Flag Register (FC<sub>H</sub>: Read/Write) Figure 41. Register Pointer Register (FD<sub>u</sub>: Read/Write) Figure 42. Stack Pointer Register (FE<sub>n</sub>: Read/Write) Figure 43. Stack Pointer Register (FF<sub>H</sub>: Read/Write) # DC CHARACTERISTICS Supply Current Figure 44. Typical $I_{\rm cc}$ vs Frequency Standby Current Figure 45. Typical $I_{\rm cc1}$ vs Frequency ### 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 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 | | <b>IR</b> | 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 | |-----------------------|-------------------------------------------------------------------------------------------------| | C<br>Z<br>S<br>V<br>D | Carry flag<br>Zero flag<br>Sign flag<br>Overflow flag<br>Decimal-adjust flag<br>Half-carry flag | | Affected flags | are indicated by: | | 0<br>1<br>*<br>-<br>x | Clear to zero Set to one Set to clear according to operation Unaffected 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) | | # **INSTRUCTION FORMATS** ### **One-Byte Instructions** ### **Two-Byte Instructions** ### Three-Byte Instructions ### **INSTRUCTION SUMMARY** **Note:** Assignment of a value is indicated by the symbol " ←". For example: notation "addr (n)" is used to refer to bit (n) of a given operand location. For example: dst ← dst + src dst (7) indicates that the source data is added to the destination data and the result is stored in the destination location. The refers to bit 7 of the destination operand. 9-38 9984043 0027951 543 ### **INSTRUCTION SUMMARY** | Instruction | Address<br>Mode | Flags Affected | | | | | | | |----------------------------------------------------------------------------------|-----------------|-----------------|---|---|---|---|---|---| | and Operation | dst src | (Hex) | C | Z | S | ٧ | D | H | | ADC dst, src<br>dst←dst + src +C | Ť | 1[] | * | * | * | * | 0 | * | | ADD dst, src<br>dst←dst + src | † | 0[] | * | * | * | * | 0 | * | | AND dst, src<br>dst←dst AND src | † | 5[] | - | * | * | 0 | - | - | | CALL dst<br>SP←SP – 2<br>@SP←PC,<br>PC←dst | DA<br>IRR | D6<br>D4 | - | - | - | - | - | - | | CCF<br>C←NOT C | | EF | * | - | - | - | - | - | | CLR dst<br>dst←0 | R<br>IR | B0<br>B1 | - | - | - | - | - | - | | COM dst<br>dst←NOT dst | R<br>IR | 60<br>61 | - | * | * | 0 | - | - | | CP dst, src<br>dst src | † | A[ ] | * | * | * | * | - | - | | DA dst<br>dst←DA dst | R<br>IR | 40<br>41 | * | * | * | Χ | - | - | | DEC dst<br>dst←dst – 1 | R<br>IR | 00<br>01 | - | * | * | * | - | - | | <b>DECW</b> dst<br>dst←dst – 1 | rr<br>Ir | 80<br>81 | - | * | * | * | - | - | | <b>DI</b><br>IMR(7)←0 | | 8F | - | - | - | ~ | - | - | | <b>DJNZ</b> r, dst<br>r←r – 1<br>if r ≠ 0<br>PC←PC + dst<br>Range: +127,<br>–128 | RA | rA<br>r = 0 - F | - | - | - | - | - | - | | EI<br>IMR(7)←1 | | 9F | - | - | - | - | - | - | | HALT | | 7F | | - | _ | - | _ | _ | | Instruction<br>and Operation | Mo | dress<br>de<br>src | Opcode<br>Byte<br>(Hex) | FI<br>C | ags<br>Z | Aff<br>S | ect<br>V | | н | |---------------------------------------------------------------------|---------------------------------------------|---------------------------------------------------------------|-----------------------------------------------------------------------------------|---------|----------|----------|----------|---|---| | INC dst<br>dst←dst + 1 | r<br>R<br>IR | - | rE<br>r = 0 - F<br>20<br>21 | - | * | * | * | - | - | | INCW dst<br>dst←dst + 1 | RR<br>IR | | A0<br>A1 | - | * | * | * | - | - | | IRET FLAGS←@SP; SP←SP + 1 PC←@SP; SP←SP + 2; IMR(7)←1 | | | BF | * | * | * | * | * | * | | JP cc, dst<br>if cc is true,<br>PC←dst | DA<br>IRR | | cD<br>c=0-F<br>30 | - | • | _ | - | - | - | | JR cc, dst<br>if cc is true,<br>PC←PC + dst<br>Range: +127,<br>–128 | RA | | cB<br>c=0-F | - | _ | _ | - | - | - | | L <b>D</b> dst, src<br>dst←src | r<br>R<br>r<br>X<br>Ir<br>R<br>R<br>R<br>IR | IM<br>R<br>r<br>X<br>r<br>Ir<br>r<br>R<br>IR<br>IM<br>IM<br>R | rC<br>r8<br>r9<br>r = 0 - F<br>C7<br>D7<br>E3<br>F3<br>E4<br>E5<br>E6<br>E7<br>F5 | _ | _ | - | - | - | - | | LDC dst, src<br>dst←src | r | Irr | C2 | - | - | - | - | - | - | | LDCI dst, src<br>dst←src<br>r←r + 1;<br>rr←rr + 1 | lr | Irr | C3 | _ | - | - | - | - | - | # **INSTRUCTION SUMMARY (Continued)** | Instruction<br>and Operation | Address<br>Mode<br>dst src | Opcode<br>Byte<br>(Hex) | Fla<br>C | ags<br>Z | Aff<br>S | ecte<br>V | | Н | |-----------------------------------|----------------------------|-------------------------|----------|----------|----------|-----------|---|---| | NOP | | FF | - | - | - | - | - | - | | OR dst, src<br>dst←dst OR src | † | 4[] | - | * | * | 0 | - | - | | POP dst<br>dst←@SP;<br>SP←SP + 1 | R<br>IR | 50<br>51 | - | - | - | - | - | - | | PUSH src<br>SP←SP – 1;<br>@SP←src | R<br>IR | 70<br>71 | - | - | - | • | - | - | | RCF<br>C←0 | | CF | 0 | - | - | - | - | - | | RET<br>PC←@SP;<br>SP←SP+2 | | AF | - | - | - | - | - | - | | RL dst | R | 90 | * | * | * | * | - | - | | C 7 0 4 | IR | 91 | | | | | | | | RLC dst | R | 10 | * | * | * | * | - | - | | 7 0 | IR | 11 | | | | | | | | RR dst | R | E0 | * | * | * | * | - | - | | -C -7 0 | IR | E1 | | | | | | | | RRC dst | R | CO | * | * | * | * | - | - | | C 7 0 | IR | C1 | | | | | | | | SBC dst, src<br>dst←dst←src←C | t | 3[] | * | * | * | * | 1 | * | | SCF<br>C←1 | | DF | 1 | - | - | - | - | - | | SRA dst | R | D0 | * | * | * | 0 | - | - | | 7 0 | IR | D1 | | | | | | | | SRP dst<br>RP←src | <b>i</b> m | 31 | - | - | - | - | - | - | | Instruction | Address<br>Mode | Opcode<br>Byte | Flags Affected | | | | | | | |--------------------------------------|-----------------|----------------|----------------|---|---|---|---|---|--| | and Operation | dst src | (Hex) | C | Z | S | V | D | Н | | | STOP | <del>-</del> | 6F | 1 | - | - | - | - | - | | | SUB dst, src<br>dst←dst←src | † | 2[] | [ | [ | [ | [ | 1 | [ | | | <b>SWAP</b> dst | R<br>IR | F0<br>F1 | Х | * | * | X | - | - | | | TCM dst, src<br>(NOT dst)<br>AND src | † | 6[] | - | * | * | 0 | - | - | | | TM dst, src<br>dst AND src | † | 7[] | - | * | * | 0 | - | - | | | XOR dst, src<br>dst←dst<br>XOR src | † | B[ ] | - | * | * | 0 | - | - | | <sup>†</sup> These instructions have an identical set of addressing modes, which are encoded for brevity. The first opcode nibble is found in the instruction set table above. The second nibble is expressed symbolically by a '[ ]' in this table, and its value is found in the following table to the left of the applicable addressing mode pair. For example, the opcode of an ADC instruction using the addressing modes r (destination) and Ir (source) is 13. | Addre<br>dst | ss Mode<br>src | Lower<br>Opcode Nibble | |--------------|----------------|------------------------| | r | r | [2] | | r | lr | [3] | | R | R | [4] | | R | IR | [5] | | R | iM | [6] | | IR | IM | [7] | Lower Nibble (Hex) # **OPCODE MAP** | | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | ын (пе<br>В | ^,<br>9 | A | В | С | D | E | F | |---------------------------|---------------------------|------------------|----------------------|----------------------|----------------------|-------------------|-------------------|-------------------|-------------|---------|---------------|-----------------------|------------|----------|-------------------|-------------------| | | 6.5 | 6.5 | 6.5 | 6.5 | 10.5 | 10.5 | 10.5 | 10.5 | 6.5 | 6.5 | 12/10.5 | 12/10.0 | 6.5 | 12.10.0 | | | | 0 | DEC | DEC | ADD | ADD | ADD | ADD | ADD | ADD | LD | LD | DJNZ | JR | LD | JP | 6.5<br><b>INC</b> | | | | R1 | IR1 | r1, r2 | r1, lr2 | R2, R1 | IR2, R1 | R1, IM | IR1, IM | r1, R2 | r2, R1 | r1, RA | cc, RA | r1, IM | cc, DA | ŗ1 | $\square$ | | 1 | 6.5<br>RLC | 6.5<br>RLC | 6.5<br>ADC | 6.5<br>ADC | 10.5<br>ADC | 10.5<br>ADC | 10.5<br>ADC | 10.5<br>ADC | | | 11 | 11 | 1 I | 1 1 1 | | 1 1 | | | R1 | IR1 | r1, r2 | r1, lr2 | R2, R1 | IR2, R1 | R1, IM | IR1, IM | | | 1 | | | | | | | 2 | 6.5 | 6.5 | 6.5 | 6.5 | 10.5 | 10.5 | 10.5 | 10.5 | | | 1 | | Ιİ | | | | | 2 | INC<br>R1 | INC<br>IR1 | SUB<br>r1, r2 | SUB<br>r1, lr2 | SUB<br>R2, R1 | SUB<br>IR2, R1 | SUB<br>R1, IM | SUB<br>IR1, IM | | | | | <b>!</b> | | | | | | 8.0 | 6.1 | 6.5 | 6.5 | 10.5 | 10.5 | 10.5 | 10.5 | 1 | | | | 1 I | | - | | | 3 | JP | SRP | SBC | SBC | SBC | SBC | SBC | SBC | | | 1 1 | | | | - | | | | IRR1<br>8.5 | IM<br>8.5 | r1, r2<br>6.5 | r1, lr2 | R2, R1 | IR2, R1<br>10.5 | R1, IM | IR1, IM<br>10.5 | | | 1 1 | | | | | | | 4 | DA | DA | OR | OR | OR | OR | OR | OR | | ! I | | 1 | ļ <b>i</b> | <b> </b> | | | | | R1<br>10.5 | IR1 | r1, r2 | r1, lr2 | R2, R1 | IR2, R1 | R1, IM | IR1, IM | | | | | | | ļ | | | 5 | POP | 10.5<br>POP | 6.5<br>AND | 6.5<br>AND | 10.5<br>AND | 10.5<br>AND | 10.5<br>AND | 10.5<br>AND | | | 11 | | 1 | | | 1 1 | | | R1 | IR1 | r1, r2 | r1, lr2 | R2, R1 | IR2, R1 | R1, IM | IR1, IM | | | | | | 111 | 1 | | | 6 | 6.5<br><b>COM</b> | 6.5<br>COM | 6.5 | 6.5 | 10.5 | 10.5 | 10.5 | 10.5 | | | 11 | | | | 1 | 6.0 | | | R1 | IR1 | <b>TCM</b><br>r1, r2 | r1, lr2 | TCM<br>R2, R1 | TCM<br>IR2, R1 | TCM<br>R1, IM | TCM<br>IR1, IM | | | 1 1 | | 1 1 | | 1 | STOP | | <b>£</b> | 10/12.1 | 12/14.1 | 6.5 | 6.5 | 10.5 | 10.5 | 10.5 | 10.5 | | | | 1 1 | 1 1 | | | 7.0 | | 9 7<br>2 7 | PUSH<br>R2 | PUSH<br>IR2 | TM | TM | TM | TM | TM | TM | | | | l I | | | | HALT | | <u>g</u> | 10.5 | 10.5 | r1, r2<br>12.0 | r1, lr2 | R2, R1 | IR2, R1 | R1, IM | IR1, IM | | | | | | | | 6.1 | | Upper Nibble (Hex)<br>& 4 | DECW | DECW | LDE | LDEI | İ | | | | | | 11 | ! I | | | | DI | | ᅙ | RR1<br>6.5 | IR1<br>6.5 | r1, lrr2 | Ir1, Irr2 | | | | | | | | l I | | | | | | 9 | RL. | RL | 12.0<br><b>LDE</b> | 18.0<br>L <b>DEI</b> | | } | | | | | 11 | | | 111 | | 6.1<br><b>E</b> I | | | R1 | IR1 | r2, Irr1 | Ir2, irr1 | | | | | | | | I I | | | | | | A | 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>RET | | | RR1 | IR1 | r1, r2 | r1, lr2 | R2, R1 | IR2, R1 | R1, IM | IR1, IM | | | 11 | | | | | n=' | | | 6.5 | 6.5 | 6.5 | 6.5 | 10.5 | 10.5 | 10.5 | 10.5 | | | 11 | | <b> </b> | | | 16.0 | | В | CLR<br>R1 | CLR<br>IR1 | <b>XOR</b><br>r1, r2 | xon<br>r1, lr2 | <b>XOR</b><br>R2, R1 | XOR<br>IR2, R1 | XOR<br>R1, IM | XOR<br>IR1, IM | | | 11 | <b>!</b> | | | | IRET | | | 6.5 | 6.5 | 12.0 | 18.0 | N2, N1 | 152, 61 | nı, iivi | 10.5 | | | | i I | | | | 6.5 | | C | RRC | RRC | LDC | LDCI | | | | LD | | | 11 | | <b> </b> | | | RCF | | | R1<br>6.5 | IR1<br>6.5 | r1, lrr2<br>12.0 | Ir1, Irr2<br>18.0 | 20.0 | | 20.0 | r1,x,R2<br>10.5 | | | | I I | | | | 6.5 | | D | SRA | SRA | LDC | LDCI | CALL | | CALL | LD | | | | | | 1 1 1 | | SCF | | | R1 | IR1 | r1, lrr2 | Ir1, Irr2 | IRR1 | | DA | r2,x,R1 | | | | | | | 1 | | | E | 6.5<br>RR | 6.5<br><b>RR</b> | | 6.5<br><b>LD</b> | 10.5<br>LD | 10.5<br>LD | 10.5<br><b>LD</b> | 10.5<br><b>LD</b> | | | | | | 1 | | 6.5<br>CCF | | | R1 | IR1 | | r1, IR2 | R2, R1 | IR2, R1 | R1, IM | IR1, IM | | | | 11 | 1 1 | 1 I I | | | | F | 8.5<br><b>SWAP</b> | 8.5 | | 6.5 | | 10.5 | | | | | | | | | 1 | 6.0 | | • | R1 | SWAP<br>IR1 | } | lr1, r2 | | LD<br>R2, IR1 | | | • | ♥ | ♥ | ♥ | ♥ | 🛊 | * | NOP | | | | | $\overline{}$ | | | = | _ | | | | $\overline{}$ | | | | = | | | | | : | 2 | | | | 3 | | | | 2 | | | 3 | | 1 | | | | | | | | | Ву | tes per | Instruct | ion | | | | | | | | | | | | Lo | wer | | | | | | | | | | | | | | Opcode | | | | | | | | | | Legen | u:<br>oit Addre | 200 | | | | | | Execution Nibble Pipeline | | | | | | | | | | | it Addre | | | | | | | Cycles | | | | | | | | | | | r1 = Dst | | S | | | | | 4 Oyulas | | | | | | | | | | | r2 = Src | | | | | | | Upper 10.5 | | | | | | | | | | 0 | | | | | | | | Opcode A CP Mnemonic | | | | | | | | | | Seque | | `nerene | 1 | | | | | Nibble R1, R2 | | | | | | | | | | | e, First (<br>d Opera | | ١, | | | | | | | | | ` | | | | | | 5500110 | - opcia | | | | | | | | 0- | First | | | | ond | | | | Note: 6 | Blank are | eas not o | defined. | | | | | Operand Operand | | | | | | | | | | *0 5.4- | | | | | | 9-41 \*2-byte instruction appears as a 3-byte instruction ### **PACKAGE INFORMATION** 40-Pin DIP Package Diagram CONTROLLING DIMENSIONS : INCH 44-Pin PLCC Package Diagram NOTES: 1. CONTROLLING DIMENSIONS : MILLIMETER 2. LEAD COPLANARITY : MAX .10 mm .004" | SYMBOL | MILLIMETER | | INCH | | |-------------|------------|-------|-------------------|------| | | MIN | MAX | MIN | MAX | | A1 | 0.05 | 0.25 | .002 | -010 | | SA | 2.00: | 2,25 | .078 | .089 | | b | 0.25 - | 0.45 | .010 | .018 | | L | 0.13 | 0.20 | .005 | .008 | | HD | 13.70 | 14.30 | .539 | .563 | | D | 9.90 | 10.10 | .390 | .398 | | HE | 13.70 | 14.30 | .539 | .563 | | E | 9.90 | 10.10 | .3 <del>9</del> 0 | .398 | | <b>62</b> 0 | 0.80 TYP | | .031 TYP | | | L. | 0.60 | 1.20 | .024 | .047 | 44-Pin QFP Package Diagram # ORDERING INFORMATION Z86E61 16 MHz 20 MHz **40-Pin DIP** Z86E6116PSC 44-Pin PLCC Z86E6116VSC **40-Pin DIP** Z86E6120PSC 44-Pin PLCC Z86E6120VSC **Z86E63** 16 MHz 20 MHz 40-Pin DIP 44-Pin PLCC 40-Pin DIP 44-Pin PLCC Z86E6316PSC Z86E6316VSC Z86E6320PSC Z86E6320VSC For fast results, contact your local Zilog sales office for assistance in ordering the part desired. ### CODES ### Preferred Package P = Plastic DIP V = Plastic Chip Carrier ### **Temperature** $S = 0^{\circ}C$ to $+70^{\circ}C$ # Speeds 12 = 16 MHz 16 = 20 MHz # Environmental C = Plastic Standard Example: Z 86E61 16 P S C is an Z86E61, 16 MHz, DIP, 0°C to +70°C, Plastic Standard Flow Environmental Flow Temperature Package Speed Product Number Zilog Prefix