# **Z80 CPU Central Process Unit** - The instruction set contains 158 instructions. The 78 instructions of the 8080A are included as a subset; 8080A and Z80\* software compatibility is maintained. - 8MHz, 6MHz, 4MHz and 2.5 MHz clocks for the Z80H, Z80B, Z80A and Z80 CPU result in rapid instruction execution with consequent high data throughput. - The extensive instruction set includes string, bit, byte, and word operations. Block searches and block transfers together with indexed and relative addressing result in the most powerful data handling capabilities in the microcomputer industry. - The Z80 microprocessors and associated family of peripheral controllers are linked by a vectored interrupt system. This - system may be daisy-chained to allow implementation of a priority interrupt scheme. Little, if any, additional logic is required for daisy-chaining. - Duplicate sets of both general-purpose and flag registers are provided, easing the design and operation of system software through single-context switching, background-foreground programming, and single-level interrupt processing. In addition, two 16-bit index registers facilitate program processing of tables and arrays. - There are three modes of high speed interrupt processing: 8080 similar, non-Z80 peripheral device, and Z80 Family peripheral with or without daisy chain. - On-chip dynamic memory refresh counter. #### General Description The Z80, Z80A, Z80B and Z80H CPUs are third-generation single-chip microprocessors with exceptional computational power. They offer higher system throughput and more efficient memory utilization than comparable second-and third-generation microprocessors. The internal registers contain 208 bits of read/write memory that are accessible to the programmer. These registers include two sets of six general-purpose registers which may be used individually as either 8-bit registers or as 16-bit register pairs. In addition, there are two sets of accumulator and flag registers. A group of "Exchange" instructions makes either set of main or alternate registers accessible to the programmer. The alternate set ælows operation in foreground- background mode or it may be reserved for very fast interrupt response. The Z80 also contains a Stack Pointer, Program Counter, two index registers, a Refresh register (counter), and an Interrupt register. The CPU is easy to incorporate into a system since it requires only a single +5 V power source. All output signals are fully decoded and timed to control standard memory or peripheral circuits, and it is supported by an extensive family of peripheral controllers. The internal block diagram (Figure 3) shows the primary functions of the Z80 processors. Subsequent text provides more detail on the Z80 I/O controller family, registers, • instruction set, interrupts and daisy chaining, and CPU timing. Figure 2. Pin Configuration Figure 2a. Chip Carrier Pin Configuration ### General Description (Continued) 18-1862 166464 Figure 3. CPU Block Diagram #### Z80 Microprocessor Family The Z80, Z80A, Z80B and Z80H microprocessor is the central element of a comprehensive microprocessor product family. This family works together in most applications with minimum requirements for additional logic, facilitating the design of efficient and cost-effective microcomputerbase systems. Five components to provide extensive support for the Z80 microprocessor. These are: - The CTC (Couter/Timer Circuit) features four programmable 8-bit counter/timers, each of which has an 8-bit prescaler. Each of the four channels may be configurated to operate in either counter or timer mode. - The PIO (Parallel Input/Output) operates in both data-byte I/O transfer mode (with handshaking) and in bit mode (without handshaking). The PIO may be configured to interface with standard parallel periperal devices such as printers, tape punches, and keyboards. - The DMA (Direct Memory Access) controller provides dual port data transfer operations and the ability to teminate data transfer as a result of a pattern match. - The SIO (Serial Input/Output) controller offers two channels. It is capable of operating in a variety of programmable medes for both synchronous and asynchronous communication, including Bi-Synch and SDLC. - The DART (Dual Asynchronous Receiver/Transmitter) device provides low cost asynchronous serial communication. It has two channels and a full modem control interface. 12 ### Z80 CPU Registers Figure 4 shows three groups of registers within the Z80 CPU. The first group consists of duplicate sets of 8-bit registers: a principal set and an alternate set (designated by 'Iprime), e.g., A'). Both sets consist of the Accumulator Register, the Flag Register, and six general-purpose registers. Transfer of data between these duplicate sets of registers is accomplished by use of "Exchange" instructions. The result is faster response to interrupts and easy, efficient implementation of such versatile programming techniques as background- MAIN REGISTER SET foreground data processing. The second set of registers consists of six registers with assigned functions. These are the I (Interrupt Register), the R (Refresh Register), the IX and IY (Index Registers), the SP (Stack Pointer), and the PC (Program Counter). The third group consists of two interrupt status flip-flops, plus and additional pair of flip-flops which assists in identifying the interrupt mode at any particular time. Table 1 provides further information on these registers. registers. ALTERNATE REGISTER SET | F FLAG REGISTER | A' ACCUMULATOR | F' FLAG REGISTER | |-------------------|------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------| | C GENERAL PURPOSE | B' GENERAL PURPOSE | C' GENERAL PURPOSE | | E GENERAL PURPOSE | D' GENERAL PURPOSE | E' GENERAL PURPOSE | | L GENERAL PURPOSE | H' GENERAL PURPOSE | L' GENERAL PURPOSE | | REGISTER | Ì | INTERRUPT FLIP-FLOPS STATUS | | REGISTER | | INTERRUPTS DISABLED STORES IFF1 | | POINTER | | INTERRUPT MODE FLIP-FLOPS | | M COUNTER | | IMF <sub>b</sub> IMF <sub>b</sub> | | R MEMORY REFRESH | | 0 0 INTERRUPT MODE 0 0 1 NOT USED 1 0 INTERRUPT MODE 1 1 1 INTERRUPT MODE 2 | | | C GENERAL PURPOSE E GENERAL PURPOSE L GENERAL PURPOSE 175 REGISTER REGISTER POINTER M COUNTER | C GENERAL PURPOSE E GENERAL PURPOSE L GENERAL PURPOSE H' GENERAL PURPOSE ITS REGISTER ACGUSTER M COUNTER | Fig. 4. CPU Registers #### CPU Registers (Continued) | | Register | Size (Bits) | Remarks | |------------------------------------|--------------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | A, A' | Accumulator | 8 | Stores an operand or the results of an operation | | F. F' | Flags | 8 | See Instruction Set. | | В. В' | General Purpose | 8 | Can be used separately or as a 16-bit register with C | | C, C' | General Purpose | 8 | See B, above. | | D, D' | General Purpose | 8 | Can be used separately or as a 16-bit register with E. | | E. E' | General Purpose | 8 | See D, above | | H, H' | General Purpose | 8 | Can be used separately or as a 16-bit register with L. | | L. L' | General Purpose | 8 | See H, above. | | | | | Note: The (B,C), (D,E), and (H,L) sets are combined as follows: B—High byte C—Low byte H—High byte E—Low byte H—High byte L—Low byte | | I | Interrupt Register | 8 | Stores upper eight bits of memory address for vectored interrupt processing. | | R | Refresh Register | 8 | Provides user-trasparent dynamic memory refresh. Lower seven bits are<br>automatically incremented and all eight are placed on the address bus<br>during each instruction fetch cycle refresh time. | | IX | Index Register | 16 | Used for indexed addressing. | | IY | Index Register | 16 | Same as IX, above. | | SP | Stack Pointer | 16 | Holds address of the top of the stack. See Push or Pop in instruction set. | | PC | Program Counter | 16 | Holds address of next instruction. | | IFF <sub>1</sub> -IFF <sub>2</sub> | Interrupt Enable | Flip-Flops | Set or reset to indicate interrupt status (see Figure 4). | | IMFa-IMFb | Interrupt Mode | Flip-Flops | Reflect Interrupt mode (see Figure 4). | Table 1. CPU Registers 14 #### Interrupts: General Operation The CPU accepts two interrupt input signals: $\overline{\text{NMI}}$ and $\overline{\text{INT}}$ . The $\overline{\text{NMI}}$ is a non-maskable interrupt and has the highest priority. INT is a lower priority interrupt and it requires that interrupts be enabled in software in order to operate. $\overline{\text{INT}}$ can be connected to multiple peripheral devices in a wired-OR configuration. The Z80 has a single response mode for interrupt service for the non-maskable interrupt. The maskable interrupt, INT, has three programmable response modes available. These are: - Mode 0 similar with the 8080 microprocessor. - Mode 1 Peripheral Interrupt service, for use with non-8080/Z80 systems. - Mode 2 a vectored interrupt scheme, usually daisy-chained, for use with Z80 Family and compatible peripheral devices. The CPU services interrupts by sampling the NMI and INT signals at the rising edge of the last clock of an instruction. Further interrupt service processing depends upon the type of interrupt that was detected. Details on interrupt responses are shown in the CPU Timing Section. Non-Maskable Interrupt (NMI). The non-maskable interrupt cannot be disabled by program control and therefore will be accepted at all times by the CPU. NMI is usually reserved for servicing only the highest priority type interrupts, such as that for orderly shut-down after power failure has been detected. peen detected. After recognition of the NMI signal (providing BUSREQ is not active), the CPU jumps to restart location 0066H. Normally, software starting at this address contains the interrupt service routine. Maskable Interrupt (INT). Regardless of the interrupt mode set by the user, the Z80 response to a maskable interrupt input follows a common timing cycle. After the interrupt has been detected by the CPU (provided that interrupts are enabled and BUSREQ is not active) a special interrupt processing cycle begins. This is a special fetch (MI) cycle in which $\overline{\text{IORO}}$ becomes active rather than $\overline{\text{MREO}}$ , as in normal MI cycle. In addition, this special $\overline{\text{MI}}$ cycle is automatically extended by two $\overline{\text{WAIT}}$ states, to allow for the time required to acknowledge the interrupt request. Mode 0 Interrupt Operation. This mode is similar to the 8080 microprocessor interrupt service procedures. The interrupting device places an instruction on the data bus. This is normally a Restart Instruction, which will initiate a call to the selected one of eight restart locations in page zero of memory. Unlike the 8080, the Z80 CPU responds to the Call instruction with only one interrupt acknowledge cycle followed by two memory read cycles. $\label{eq:model} \begin{tabular}{ll} \textbf{Mode 1 Interrupt Operation.} & Mode 1 \\ operation is very similar to that for the $\overline{\text{NMI}}$. The principal difference is that the Mode 1 \\ interrupt has a restart location of 0038H only. \end{tabular}$ Mode 2 Interrupt Operation. This interrupt mode has been designed to utilize most effectively the capabilities of the Z80 microprocessor and its associated peripheral family. The interrupting peripheral device selects the starting address of the interrupt service routine. It does this by placing an 8-bit vector on the data bus during the interrupt acknowledge cycle. The CPU forms a pointer using this byte as the lower 8-bits and the contents of the I register as the upper 8-bits. This points to an entry in a table of addresses for interrupt service routines. The CPU then jumps to the routine at that address. This flexibility in selecting the interrupt service routine address allows the peripheral device to use several different types of service routines. These routines may be located at any available location in memory. Since the interrupting device supplies the low-order byte of the 2-byte vector, bit 0 (A<sub>0</sub>) must be a zero. Interrupt Priority (Daisy Chaining and Nested Interrupts). The interrupt priority of each peripheral device is determined by its physical location within a daisy-chain Interrupts: General Operation (Continued) configuration. Each device in the chain has an interrupt enable input line (IEI) and an interrupt enable output line (IEO), which is fed to the next lower priority device. The first device in the daisy chain has its IEI input hardwired to a High level. The first device has highest priority, while each succeding device has a corresponding lower priority. This arrangement permits the CPU to select the highest priority interrupt from several simultaneously interrupting peripherals. The interrupting device disables its IEO line to the next lower priority peripheral until it has been serviced. After servicing, its IEO line is raised, allowing lower priority peripherals to demand interrupt servicing. The Z80 CPU will nest (queue) any pending interrupts or interrupts received while a selected peripheral is being serviced. Interrupt Enable/Disable Operation. Two flip-flops, ${\rm IFF_1}$ and ${\rm IFF_2}$ , referred to in the register description are used to signal the CPU interrupt status. Operation of the two flip-flops is described in Table 2. For more details, refer to the Z80 CPU Technical Manual. | Action | IFF <sub>2</sub> | IFF <sub>2</sub> | Comments | |-------------------------------|------------------|------------------|----------------------------------------------------------------------------| | CPU Reset | 0 | 0 | Maskable interrupt<br>INT disabled | | DI instruction<br>execution | 0 | 0 | Maskable interrupt<br>INT disabled | | EI instruction execution | 1 | 1 | Maskable interrupt<br>INT enabled | | LD A, I instruction execution | • | • | IFF <sub>2</sub> →Parity flag | | LD A, R instruction execution | • | • | IFF <sub>2</sub> →Parity flag | | Accept NMI | 0 | IFF <sub>1</sub> | IFF <sub>1</sub> →IFF <sub>2</sub><br>(Maskable interrupt<br>INTdisabled) | | RETN instruction execution | IFF <sub>2</sub> | • | IFF <sub>2</sub> →IFF <sub>1</sub> at completion of an Ni service routine. | Table 2. State of Flip-Flops 17 #### Instruction Set The Z80 microprocessor has one of the most powerful and versatile instruction sets available in any 8-bit microprocessor. It includes such unique operations as a block move for fast, efficient data transfers within memory or between memory and I/O. It also allows operations on any bit in any location in memory. allows operations on any bit in any location in memory. The following is a summary of the Z80 instruction set and shows the assembly language mnemonic, the operation, the flag status, and gives comments on each instruction. The Z80 CPU Technical Manual and Z80 CPU Programming Manual contain significantly more details for programming use. The instructions are divided into the following categories: - □ 8-bit loads - □ 16-bit loads - □ Exchanges, block transfers, and searches - $\hfill\Box$ 8-bit arithmetic and logic operations - General-purpose arithmetic and CPU - □ 16-bit arithmetic operations - □ Rotates and shift - m Bit set, reset, and test operations - □ Jumps - Calls, returns, and restarts - □ Input and output operations A variety of addressing modes are implemented to permit efficient and fast data transfer between various registers, memory locations, and input/output devices. These addressing modes include: - Immediate - □ Immediate extended - □ Modified page zero - Relative - □ Extended - □ Indexed - □ Register - Register indirect - □ Implied - □ Bit #### 8-Bit Load Group | | Symbolic | | | | Fle | 101 | | | | Opcode | | No.of | No.of M | No.of T | | |----------------------------------------|---------------------------------------------|---|---|-------------|-----|-------------|-----|---|---|--------------------------------------------|----------------|-------------|-------------|--------------|----------------------------------| | Mnemonic | Operation | s | Z | | H | • | P/V | N | С | 76 543 210 | Hex | Bytes | Cycles | States | Comments | | LD r, r'<br>LD r, n | r - r'<br>r - n | : | : | X | : | X | : | | : | 01 r r'<br>00 r 110 | | 1 2 | 1 2 | 4 7 | r, r' Req.<br>000 B<br>001 C | | LD r. (HL)<br>LD r. (IX + d) | $r \leftarrow (HL)$ $r \leftarrow (IX + d)$ | : | : | X | : | X | : | : | : | 01 r 110<br>11 011 101<br>01 r 101 | DD | 1<br>3 | 2<br>5 | 7<br>19 | 010 D<br>011 E<br>100 H<br>101 L | | LD r, (IY + d) | r - ([Y + d) | • | • | x | • | x | • | • | • | 11 111 101<br>01 r 110 | FD | 3 | 5 | 19 | 111 A | | LD (HL), r<br>LD (IX + d), r | $(HL) = r$ $(IX + d) \leftarrow r$ | : | : | X | : | X | : | : | : | 01 110 r<br>11 011 101<br>01 110 r | DD | 3 | 2<br>5 | 7<br>19 | | | LD (iY + d), r | (IY+d) + r | • | • | x | • | х | • | ٠ | • | 11 111 101<br>01 110 r<br>- d - | FD | 3 | 5 | 19 | , | | LD (HL), n | (HL) - n | • | • | X | ٠ | Х | • | ٠ | • | 00 110 110 | 36 | 2 | 3 | 10 | | | LD ([X+d), n | (1X + d) - n | • | • | х | • | x | • | • | • | 11 011 101<br>00 110 110<br>- d - | | 4 | 5 | 19 | | | LD (IY+d), n | (IY+d) - n | • | • | х | • | X | • | • | • | - n -<br>11 111 101<br>00 110 110<br>- d - | | 4 | 5 | 19 | | | LD A, (BC) | A - (BC) | | | х | • | х | | | | 00 001 010 | 0A | 1 | 2 | 7 | | | .D A, (DE)<br>.D A, (nn) | A - (DE)<br>A - (nn) | : | : | X | : | X | : | : | : | 00 011 010<br>00 111 010<br>- n - | 1A<br>3A | 3 | 4 | 7<br>13 | | | LD (BC), A<br>LD (DE), A<br>LD (an), A | (BC) - A<br>(DE) - A<br>(nn) - A | : | : | X<br>X<br>X | : | X<br>X<br>X | : | : | : | 00 000 010<br>00 010 010<br>00 110 010 | 02<br>12<br>32 | 1<br>1<br>3 | 2<br>2<br>4 | 7<br>7<br>13 | | | LD A. I | A - I | 1 | 1 | x | ٥ | x | IFF | 0 | | - n -<br>- n -<br>11 101 101 | | 2 | 2 | 9 | | | DA, R | A - R | 1 | : | х | 0 | х | IFF | 0 | | 01 010 111 | 57<br>ED | 2 | 2 | 9 | | | DI. A | I - A | | | х | | x | | | | 01 011 111 . | 5F<br>ED | 2 | 2 | 9 | | | .D R, A | R - A | | | | | x | | • | | 01 000 111<br>11 101 101<br>01 001 111 | 47<br>ED | 2 | 2 | 9 | | NOTES: r, r' means any of the registers A, B, C, D, E, H, L, IFF the content of the interrupt enable flip-flop, (IFF) is copied into the PVI log. For at explanation of liag notation and symbols for mnemonic tables, see Symbolic Notation section. #### 16-Bit Load Group | Mnomonic | Symbolic<br>Operation | 1 | , , | z | | Flags<br>H | P/1 | , x | c | 76 543 210 Hex | | No.of M<br>Cycles | | | |----------------------|----------------------------------------------------------|---|-----|---|---|------------|-----|-----|---|--------------------------------------------------|-----|-------------------|----------------|---------------------------| | LD dd, nn | dd - nn | • | • | Х | • | х | • | • | • | 00 dd0 001 | 3 | 3 | 10 | dd Pair<br>00 BC | | LD IX, nn | IX – nn | • | • | х | • | х | • | • | • | 11 011 101 DD<br>00 100 001 21 | 4 | 4 | 14 | 01 DE<br>10 HL<br>11 SP | | LD IY, na | IY — nn | • | • | × | • | х | • | • | • | - n -<br>11 111 101 FD<br>00 100 001 21<br>- n - | 1 | 4 | 14 | | | LD HL, (nn) | H - (nn + 1)<br>L - (nn) | • | • | x | • | x | • | • | • | 00 101 010 2A | 3 | 5 | 16 | | | LD dd. (nn) | ddH - (nn+1)<br>ddL - (nn) | • | • | x | • | X | • | • | • | - n -<br>11 101 101 ED<br>01 dd1 011<br>- n - | 4 | 6 | 20 | | | LD IX, (nn) | IX <sub>H</sub> - (nn+1)<br>IX <sub>L</sub> - (nn) | ٠ | • | x | • | x | • | • | • | 11 011 101 DD<br>00 101 010 2A | 4 | 6 | 20 | , <b>•</b> | | LD IY, (nn) | 17H + (nn+1)<br>17L - (nn) | • | • | x | • | x | • | • | • | 11 111 101 FD<br>00 101 010 2A | 4 | 6 | 20 | | | LD (nn), HL | (nn + 1) - H<br>(nn) - L | • | • | x | • | x | • | • | • | 00 100 010 22<br>- n - | 3 | 5 | 16 | | | LD (nn), dd | (nn+1) - dd <sub>H</sub><br>(nn) - dd <sub>L</sub> | • | • | x | • | x | • | • | • | 11 101 101 ED<br>01 de0 011 | 4 | 6 | 20 | | | LD (nn), IX | (nn) - IXL<br>(nn) - IXH | • | • | X | • | x | • | • | • | - n -<br>11 011 101 DD<br>00 100 010 22<br>- n - | 4 | 6 | 20 | | | LD (nn), IY | (nn + 1) - IY <sub>L</sub><br>(nn) - IY <sub>L</sub> | • | • | х | • | X | • | • | • | - n -<br>11 111 101 FD<br>00 100 010 22<br>- n - | 4 | 6 | 20 | | | D SP, HL<br>D SP, IX | SP - HL<br>SP - IX | : | : | X | : | X<br>X | : | : | : | 11 111 001 F9<br>11 011 101 DD | 1 2 | 1 2 | <b>6</b><br>10 | | | .D SP, IY | SP - IY | | | x | • | х | | | | 11 111 001 F9<br>11 111 101 FD | 2 | 2 | 10 | | | PUSH qq | (SP - 2) - qqL<br>(SP - 1) - qqH | • | • | x | • | x | • | • | | 11 111 001 F9<br>11 qq0 101 | 1 | 3 | 11 | 99 Pair<br>00 BC<br>01 DE | | PUSH IX | SP - SP - 2<br>(SP - 2) - IXL<br>(SP - 1) - IXH | • | • | X | • | X | • | • | • | 11 011 101 DD<br>11 100 101 E5 | 2 | 4 | 15 | IO HL<br>II AF | | USH IY | SP - SP - 2<br>(SP - 2) - IYL<br>(SP - 1) - IYH | • | • | X | • | x | • | • | • | 11 111 101 FD<br>11 100 101 E5 | 2 | 4 | 15 | | | OP qq | SP - SP - 2<br>qqH - (SP+1)<br>qqL - (SP)<br>SP - SP + 2 | • | • | x | • | X | • | • | • | 11 qq0 001 | 1 | 3 | 10 | - | | OP IX | IXH - (SP+1)<br>IXL - (SP)<br>SP - SP +2 | • | • | x | • | X | • | • | • | II 011 101 DD<br>II 100 001 E1 | 2 | 4 | 14 | | | OP IY | IYH - (SP+1)<br>IYL - (SP)<br>SP - SP +2 | • | • | x | • | X | • | • | • | 11 111 101 FD<br>11 100 001 E1 | 2 | 4 | 14 | | 20 NOTES: dd is any of the requirer pairs BC, DE, HL, SP, qu is any of the requirer pairs AF, BC, DE, HL, SP, qu is any of the requirer pairs AF, BC, DE, HL, (PAIR), (PAIR), eafer to high order and low order eight bits of the early BCL = C, AFH = A. Exchange, Block Transfer, Block Search Groups | EX DE, HL<br>EX AF, AF<br>EXX | DE HL<br>AF AF'<br>BC BC'<br>DE DE' | : | : | X<br>X | : | X<br>X | : | : | : | 00 | 001 | 011<br>000<br>001 | 08 | 1 1 | 1 1 | 4 4 | Register bank and<br>auxiliary register<br>bank exchange | |-------------------------------|---------------------------------------------------------------|---|----------|--------|---|--------|--------|---|---|----|-----|-------------------|------------|-----|--------|----------|---------------------------------------------------------------------------------------------| | X (SP), HL | HL - HL'<br>H - (SP+1)<br>L - (SP) | ٠ | • | x | • | x | • | • | • | 11 | 100 | 011 | <b>E</b> 3 | 1 | 5 | 19 | Dank exchange | | EX (SP), IX | IX <sub>H</sub> - (SP + 1)<br>IX <sub>L</sub> - (SP) | • | ٠ | X | • | X | ٠ | ٠ | ; | | | 101 | | 2 | 6 | 23 | | | X (SP), IY | IYH - (SP+1)<br>IYL - (SP) | • | • | x | • | X | •<br>0 | • | • | 11 | 111 | 101<br>011 | FD | 2 | 6 | 23 | | | DI | (DE) (HL)<br>DE DE + 1<br>HL HL + 1<br>BC BC - 1 | • | • | X | 0 | x | 0 | 0 | • | | | 000 | | 2 | 4 | 16 | Load (HL) into<br>(DE), increment<br>the pointers and<br>decrement the byte<br>counter (BC) | | DIR | (DE) - (HL) DE - DE+1 HL - HL+1 BC - BC-1 Repeat until BC = 0 | ٠ | • | X | 0 | X | 0 | 0 | • | | | 101<br>000 | | 2 2 | 5 4 | 21<br>16 | If BC ≠ 0<br>If BC = 0 | | LDD | (DE) - (HL)<br>DE - DE - 1<br>HL - HL - 1<br>BC - BC - 1 | • | • | x | 0 | х | Ī | 0 | • | | | 101 | | 2 | 4 | 16 | | | LDDR | (DE) (HL) DE DE 1 HL HL 1 BC BC 1 Repeat until BC =- 0 | • | • | x | 0 | x | 0 | 0 | • | | | 103 | | 2 2 | 5<br>4 | 21<br>16 | If BC ≠ 0<br>If BC = 0 | | CPI | A - (HL) | : | 3 | х | | х | 0 | 1 | | | .10 | 101 | FD | 2 | 4 | 16 | | | >r: | HL - HL+1<br>BC - BC-1 | ٠ | _ | ^ | • | ^ | | • | - | | | 001 | | • | • | | | | CPIR | A - (HL) | 1 | ②<br>1 | x | ı | x | 0 | 1 | | il | 10 | 101 | ED | 2 | 5 | 21 | If BC ≠ 0 and<br>A ≠ (HL) | | | HL HL + 1 BC BC - 1 Repeat until A = (HL) or BC = 0 | | <b>②</b> | | | | 0 | | | 10 | 110 | 001 | BI | 2 | 4 | 16 | If BC = 0 or<br>A = (HL) | | CPD | A - (HL)<br>HL - HL-1<br>BC - BC-1 | 1 | ĩ | х | • | | 1 | 1 | • | | | 101 | | 2 | 4 | 16 | | | CPDR | A - (HL) | 1 | <b>@</b> | x | 1 | x | 0 | 1 | | 11 | 10 | 101 | ED | 2 | 5 | 21 | If BC ≠ 0 and | | | HL - HL-1 BC - BC-1 Repeat until A = (HL) or BC = 0 | • | • | - | • | | • | | | | | 001 | | 2 | 4 | 16 | $A \neq (HL)$ If $BC = 0$ or $A = (HL)$ | NOTE: (i) if the result of B-1 is zero the Z liag is set, otherwise it is roset. (2) Z liag is set upon instruction completion only. ### 8-Bit Arithmetic and Logical Group | Mnemonic | Symbolic<br>Operation | 8 | z | | Fla<br>H | | P/V | H | с | Opcode<br>76 543 210 He | | | No.of M<br>Cycles | | | Comments | |-----------------|--------------------------|-----|---|---|----------|---|-----|---|---|-------------------------|----|---|-------------------|----|------------------------------|-----------------------------------------------------------------------------------------------------------| | | | | | | | | | | | | | | | | | | | ADD A, r | A - A + r | | 1 | X | 1 | X | v | 0 | 3 | 10 000 r | | 1 | í | 4 | t | Reg. | | ADD A. n | A - A + n | 1 | 1 | X | • | Х | V | 0 | 1 | 11 000 110<br>- n - | | 2 | 2 | 7 | | С | | ADD A. (HL) | A - A + (HL) | , | 1 | х | | ¥ | ٧ | 0 | | 10 000 110 | | 1 | 2 | 7 | 010 | | | | A - A + (IX + d) | i | | x | | | | ŏ | i | | DD | 3 | 5 | 19 | | н | | | | | | | | | | | | 10 000 110 | | | | | | L | | 100 1 (IV - 1) | A - A + (IY+d) | | | | | v | ٧ | 0 | | - d - | FD | 3 | 5 | 19 | 111 | A | | KDD A, (11 + a) | X - X + (11 + 4) | • | ٠ | ^ | • | ^ | ٠ | Ĭ | • | 10 000 110 | | J | • | | | | | ADC A, s | A - A+++CY | 1 | ı | x | 1 | X | v | a | 1 | - <u>d</u> - | | | | | | ny of r, n, | | SUB s | A - A-s | 1 | 1 | х | 1 | х | ٧ | 1 | 1 | 010 | | | | | | .), (IX + d),<br>+ d) as shown a | | SBC A. a | A - A -s-CY | 1 | 1 | X | 1 | Х | ٧ | 1 | 1 | 01! | | | | | for | ADD instruction. | | AND s | A - A - a | 1 | 1 | Х | 1 | X | P | 0 | 0 | 100 | | | | | | indicated bits | | OR s | A - A V s | 1 | 1 | Х | 0 | Х | P | 0 | 0 | 110 | | | | | | ADD set above. | | XOR s | A - A • s | 1 | 1 | Х | 0 | X | P | 0 | 0 | 101 | | | | | uie | NOD SKI GLOVE. | | CP s | A - s | - 1 | ı | х | 1 | х | v | 1 | t | 1111 | | | | | | | | INC r | r - r + 1 | 1 | ı | х | t | Х | v | 0 | ٠ | 00 r [100] | | 1 | 1 | 4 | | | | INC (HL) | (HL) + (HL) + 1 | 1 | t | х | 1 | Х | v | 0 | ٠ | 00 110 [100] | | 1 | 3 | 11 | | | | INC (IX + d) | (IX + d)<br>(IX + d) + I | 1 | ı | X | 1 | Х | V | 0 | • | 00 110 100 | DD | 3 | 6 | 23 | | | | INC (IY+d) | (IY + d) - | 1 | 1 | х | ı | X | v | 0 | | 11 111 101 | FD | 3 | 6 | 23 | | | | | (IY+d)+1 | | | | | | | | | - d -<br>∞ 110 [00] | | | | | | | | DEC m | m - m-1 | 1 | 1 | х | ı | X | V | 1 | • | [0] | | | | | (IX<br>as<br>DE<br>and<br>Re | any of r, (HL), (+d), (IY+d) shown for INC. C same format d states as INC. place [SS] with [1] in opcode. | General-Purpose Arithmetic and CPU Control Groups ing be ### 16-Bit Arithmetic Group | | | | | | | | _ | | | | | | | | | | | |----------|-------------------|---|---|---|---|---|---|---|---|----|-------------|------------|----|---|---|---------|---------------------------------------------| | HL, sa | HL - HL+ss | • | • | x | x | x | | 0 | ı | 00 | ss] | 001 | | 1 | 3 | 11 | ss Reg.<br>00 BC | | C HL, sa | HL - HL+ss+CY | 1 | 1 | x | X | X | V | 0 | 1 | | | 101<br>010 | ED | 2 | 4 | 15 | 01 DE<br>10 HL<br>11 SP | | HL. ss | HL - HL - ss - CY | 1 | 1 | X | X | X | v | ı | 1 | | | 101 | ED | 2 | 4 | 15 | | | IX. pp | IX - IX + pp | • | • | x | X | x | • | 0 | 1 | | | 001 | | 2 | 4 | 15 | pp Req.<br>00 BC<br>01 DE<br>10 IX<br>11 SP | | IY. rr | IY - IY + rr | ٠ | • | x | x | x | • | 0 | 1 | | | 001<br>101 | FD | 2 | 4 | 15 | 77 Reg.<br>00 BC<br>01 DE<br>10 IY<br>11 SP | | | as - as + 1 | | | ٧ | | v | | | | 00 | <b>ss</b> 0 | 011 | | 1 | 1 | 6 | | | | IX - IX + 1 | • | : | x | • | X | ٠ | ٠ | ٠ | 11 | 011 | 101 | | 2 | 2 | 6<br>10 | | | IY | IY - IY + 1 | • | • | X | • | X | • | ٠ | ٠ | 11 | 111 | 101 | FD | 2 | 2 | 10 | | | : ss | 85 - 85 - l | | | x | | х | • | | • | | | 011 | | ı | 1 | 6<br>10 | | | ιx | IX - IX - 1 | • | • | x | : | X | ٠ | • | • | | | 101<br>011 | | 2 | 2 | | | | C IY | IY - IY - 1 | • | • | X | • | X | • | • | ٠ | 11 | 111 | 101<br>011 | FD | 2 | 2 | . 10 | | | | | | | | | | | | | | | | | | | | | ### Rotate and Shift Group | Mnemonic | Symbolic<br>Operation | 5 | z | | Fla<br>H | 78 | P/V | N | с | Opcode<br>78 543 210 | Hex | | No.of M<br>Cycles | | Comments | |--------------|---------------------------------------------|---------|-----|---|----------|----|-----|---|---|---------------------------------|------|-----|-------------------|-----|----------------------------------------------------------------------------------------------| | RLCA | CY 7-0 | | | x | О | x | | 0 | ı | 00 000 11 | 1 07 | 1 | 1 | 4 | Rotate left circular accumulator. | | RLA | CY 7-0 | • | • | X | 0 | x | • | 0 | 1 | 00 010 11 | 1 17 | 1 | 1 | 4 | Rotate left<br>accumulator. | | RRCA | T O CY | • | • | x | 0 | x | • | 0 | 1 | 00 001 11 | 1 OF | 1 | 1 | . 4 | Rotate right circular accumulator. | | RRA | 7-0-CY | | • | x | 0 | x | • | 0 | 1 | 00 011 11 | 1 1F | 1 | 1 | 4 | Rotate right accumulator. | | RLC r | | 1 | 1 | X | 0 | X | P | 0 | 1 | 11 001 01<br>00 000 r | | 3 2 | 2 | 8 | Rotate left circular<br>register r. | | RLC (HL) | | 1 | 1 | X | 0 | X | P | 0 | 1 | 11 001 01<br>00 000 11 | | 3 2 | 4 | 15 | r Reg.<br>000 B<br>001 C | | RLC (IX + d) | r,(HL),(IX+d),(IY+d) | 1 | ١ | x | 0 | x | P | 0 | t | 11 011 10<br>11 001 01<br>- d - | ı Cı | | 6 | 23 | 010 D<br>011 E<br>100 H<br>101 L<br>111 A | | RLC (IY+d) | | 1 | ı | x | 0 | X | ₽ | 0 | ı | 11 111 10<br>11 001 01 | 1 C | | 6 | 23 | | | RL m | m=r,(HL),(IX+d),(IY+c | ı<br>d) | ı | x | 0 | x | P | 0 | 1 | - d -<br>00 (200) 11 | | | | | Instruction format<br>and states are as<br>shown for RLC's.<br>To form new<br>opcode replace | | RRC m | m=r,(HL),(IX+d),(IY+ | d) | 1 | X | 0 | х | P | 0 | | <u>[007]</u> | | | | | oco or RLC's with shown code. | | RR m | 7 — 0 — CY<br>m=r.(HL).(IX + d).(IY + | ]<br>d) | : : | х | 0 | x | P | 0 | | OIII | | | | | | | SLA m | m = r, (HL), (IX + d), (IY + d) | | 1 | х | 0 | X | P | 0 | 1 | 100 | | | | | | | SRA m | m=r.(HL),(IX+d),(IY+ | d) | | х | 0 | X | P | 0 | 1 | [[0]] | | | | | | | SRL m | 0 - [7 - 0] CY<br>m = r.(HL),(IX + d),(IY + | d) 1 | 1 | х | 0 | X | P | 0 | ı | (111) | | | | | | | RLD | 7-43-0 7-43-<br>A (HL) | 0 1 | . 1 | X | 0 | х | P | 0 | • | 11 101 10<br>01 101 11 | | | 5 | 18 | Rotate digit left and<br>right between<br>the accumulator<br>and location (HL). | | RRD | 7-43-0 7-43- | 0 1 | . 1 | х | 6 | х | P | 0 | • | 11 101 10<br>01 100 11 | | 2 | 5 | 18 | The content of the<br>upper half of<br>the accumulator is<br>unaffected. | ### Bit Set, Reset and Test Group | BIT b. r $Z = r_b$ BIT b. (HL) $Z = (\overline{l}$ BIT b. (IX+d) <sub>b</sub> $Z = (\overline{l}$ BIT b. (IY+d) <sub>b</sub> $Z = (\overline{l}$ | (L) <sub>b</sub> | x<br>x | 1 1 | x<br>x<br>x | | x<br>x | x | 0 | : | 11 001 01: CB<br>01 b r<br>11 001 01: CB<br>01 b 110<br>11 011 101 DD | 2 2 | 2 | 8 | | |--------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------|--------|-----|-------------|---|--------|---|---|---|-----------------------------------------------------------------------|-----|---|----|---------------------------------------------------------------------------------------------| | В(Т ь, (IX + d)ь Z — (Ē | X + d) <sub>b</sub> | x | 1 | x | 1 | | | | : | 11 001 011 CB<br>01 b 110<br>11 011 101 DD | | 3 | | r Reg. | | | | | | | | x | x | С | • | 11 011 101 DD | | | 12 | 001 C | | | | x | | x | 1 | | | | | | 4 | 5 | 20 | 010 D<br>011 E | | BIT b, $(IY + d)_b Z - (\overline{I}')$ | Y + d)b | x | • | X | , | | | | | 11 001 011 CB<br>- d -<br>01 b 110 | | | | 100 H<br>101 L<br>111 A<br>b Bit Tested | | | | | | | • | х | x | 0 | • | 11 111 101 FD<br>11 001 011 CB<br>- d -<br>01 b 110 | 4 | 5 | 20 | 000 0<br>001 1<br>010 2<br>011 3<br>100 4<br>101 5<br>110 6 | | SET b, r _ rb = 1 | | | | x | | х | | | | 11 001 011 CB | 2 | 2 | 8 | 111 7 | | SET b. (HL) (HL)b | - 1 | | • | x | • | x | • | | | 11 001 011 CB | 2 | 4 | 15 | | | SET b, (IX+d) (IX+d) | ) <sub>b</sub> - i | ٠ | • | X | • | x | • | • | • | 11 011 101 DD<br>11 001 011 CB | 4 | 6 | 23 | | | SET b, ( <b>IY</b> + <b>d</b> ) ( <b>IY</b> + <b>d</b> ) | ) <sub>b</sub> = 1 | • | • | X | • | x | • | • | • | 11 111 101 FD<br>11 001 011 CB<br>- d - | 4 | 6 | 23 | | | 53 b, m m <sub>b</sub> - 1<br>m = r,<br>(IX<br>(IY | 0<br>, (HL),<br>+d),<br>+d) | • | • | x | • | x | • | • | • | Ш ь 110<br>[2] | | | | To form new opcode replace of SET b, s with D. Flags and time states for SET instruction. | ### Jump Grup (Continued) | Mnemonic | Symbolic<br>Operation | s | z | | Flag<br>H | | P/V | N | с | Opcode<br>76 543 210 Hex | No.of<br>Bytes | No.al M<br>Cycles | No.of T<br>States | Comments | |----------|------------------------------------|---|---|---|-----------|---|-----|---|---|--------------------------------|----------------|-------------------|-------------------|----------------------| | | continue<br>If Z = 0,<br>PC - PC+e | | | | | | | | | | 2 | 3 | 12 | If condition is met. | | JP (HL) | PC - HL | • | ٠ | X | ٠ | X | ٠ | • | ٠ | 11 101 001 E9 | 1 | 1 | 4 | | | JP (IX) | PC - IX | • | • | X | • | x | • | • | • | 11 011 101 DD<br>11 101 001 E9 | 2 | 2 | 8 | | | JP (IY) | PC - IY | • | • | X | • | X | • | • | • | 11 111 101 FD<br>11 101 001 E9 | 2 | 2 | 8 | | | DINZ, • | B - B - 1<br>If B = 0,<br>continue | • | • | X | • | X | • | • | • | 00 010 000 10 | 2 | 2 | 8 | HB = 0. | | | If B ≠ 0,<br>PC - PC+e | | | | | | | | | | 2 | 3 | 13 | If B ≠ 0. | NOTES: e represents the extension in the relative addressing mode. -2 in the opcode provides an effective address of pc+e as PC is incremented ## Call and Return Group | CALL nn | (SP-1) - PCH<br>(SP-2) - PCL<br>PC - nn | • | • | x | • | x | • | • | • | 11 001 101 CD<br>- n -<br>- n - | 3 | 5 | 17 | | |-------------------|----------------------------------------------------|---|---|---|---|---|---|---|---|---------------------------------|---|---|----|---------------------------------------------------------------------------------------| | CALL oc, nn | If condition | • | • | X | • | X | • | • | ٠ | 11 cc 100 | 3 | 3 | 10 | If cc is false. | | | continue,<br>otherwise same as<br>CALL nn | | | | | | | | | - n - | 3 | 5 | 17 | If cc is true. | | RET | $PC_L - (SP)$<br>$PC_H - (SP + 1)$ | • | ٠ | X | • | x | • | • | ٠ | 11 001 001 C9 | 1 | 3 | 10 | | | RET cc | If condition | • | ٠ | X | ٠ | X | • | • | ٠ | 11 ec 000 | 1 | 1 | 5 | If or is false. | | | continue,<br>otherwise | | | | | | | | | | 1 | 3 | 11 | If cc is true. | | | same as<br>RET | | | | | | | | | | | | | 000 NZ non-zero<br>001 Z zero | | RETI | Return from<br>interrupt | • | ٠ | X | • | X | • | • | • | 11 101 101 ED<br>01 001 101 4D | 2 | 4 | 14 | 010 NC non-carry<br>011 C carry | | RETN <sup>1</sup> | Return from<br>non-maskable<br>interrupt | • | • | X | • | X | • | • | • | 11 101 101 ED<br>01 000 101 45 | 2 | 4 | 14 | 100 PO parity odd<br>101 PE parity even<br>110 P sign positive<br>111 M sign negative | | RST p | (SP-1) - PCH<br>(SP-2) - PCL<br>PCH - 0<br>PCL - p | ٠ | • | х | • | x | • | • | • | 11 t 111 | 1 | 3 | 41 | t p<br>000 00H<br>010 10H<br>010 10H<br>011 18H<br>100 20H<br>101 29H<br>110 30H | NOTE: 'RETN loads IFF2 - IFF1 26 ### Input and Output Grup | Masmonic | Symbolic<br>Operation | 8 | z | | Flag<br>H | | P/V | N | с | Opcode<br>76 543 210 Hex | | No.of M No.<br>Cycles S | | Comments | |------------|--------------------------------------------------------------------------------|---|---------------|----|-----------|---|-----|---|----|-------------------------------|-----|-------------------------|----------|----------------------------------------------------------------------------------| | [N A. (n) | A - (n) | | | x | | X | • | • | • | 11 011 011 D | 3 2 | 3 | 11 | n to A <sub>0</sub> - A <sub>7</sub><br>Acc. to A <sub>8</sub> - A <sub>15</sub> | | N r. (C) | r = (C)<br>if $r = 110$ only the<br>flags will be affected | 1 | 1<br>① | X | 1. | X | P | 0 | • | 11 101 101 E1<br>01 r 000 | 2 | 3 | 12 | C to A <sub>0</sub> ~ A <sub>7</sub><br>B to A <sub>8</sub> ~ A <sub>15</sub> | | NI | (HL) - (C)<br>B - B - 1<br>HL - HL + 1 | X | ī | X | X | X | X | 1 | X | 11 101 101 E<br>10 100 010 A | | 4 | 16 | C to A <sub>0</sub> ~ A <sub>7</sub><br>B to A <sub>8</sub> ~ A <sub>15</sub> | | INIR | (HL) - (C)<br>B - B - 1<br>HL - HL + 1<br>Repeat until | x | 1 | х. | x | X | х | 1 | x | 11 101 101 EI<br>10 110 010 B | | (If B≠0) | 21<br>16 | C to A <sub>0</sub> ~ A <sub>7</sub><br>B to A <sub>8</sub> ~ A <sub>15</sub> | | CNI | B = 0<br>(HL) - (C)<br>B - B - 1 | x | 0 | х | x | x | x | 1 | x | 11 101 101 E1<br>10 101 010 A | | 4 | 16 | C to A <sub>0</sub> ~ A <sub>7</sub><br>B to A <sub>8</sub> ~ A <sub>15</sub> | | INDR | HL - HL - 1<br>(HL) - (C)<br>B - B - 1<br>HL - HL - 1<br>Repeat until | x | 1 | х | x | x | X | 1 | x. | 11 101 101 E<br>10 111 010 B | | (If B≠0) | 21<br>16 | C to A <sub>0</sub> ~ A <sub>7</sub><br>B to A <sub>8</sub> ~ A <sub>15</sub> | | OUT (n), A | B = 0<br>(n) - A | | | X | | x | | • | • | 11 010 011 D | 3 2 | 3 | 11 | n to A <sub>O</sub> - A <sub>7</sub><br>Acc. to A <sub>B</sub> - A <sub>15</sub> | | OUT (C), r | (C) - r | • | • | X | • | X | • | ٠ | • | 11 101 101 E<br>01 r 001 | 2 | 3 | 12 | C to A <sub>0</sub> ~ A <sub>15</sub><br>B to A <sub>8</sub> ~ A <sub>15</sub> | | OUTE | (C) - (HL)<br>B - B - 1 | X | Ŷ | X | Х, | X | X | 1 | x | 11 101 101 E<br>10 100 011 A | | 4 | 16 | C to A <sub>0</sub> ~ A <sub>7</sub><br>B to A <sub>8</sub> ~ A <sub>15</sub> | | OTER | HL - HL + 1<br>(C) - (HL)<br>B - B - 1<br>HL - HL + 1<br>Repeat until<br>B = 0 | x | 1<br><b>①</b> | x | x | x | x | 1 | x | 11 101 101 E<br>10 110 011 B | | (If B ≠ 0) | 21<br>16 | C to A <sub>0</sub> - A <sub>7</sub><br>B to A <sub>8</sub> - A <sub>15</sub> | | OUTD | (C) - (HL)<br>B - B-1<br>HL - HL-1 | х | | х | x | x | x | 1 | x | 11 101 101 E<br>10 101 011 A | | 4 | 16 | C to A <sub>0</sub> ~ A <sub>7</sub><br>B to A <sub>8</sub> ~ A <sub>15</sub> | | OIDR | (C) - (HL)<br>B - B - 1<br>HL - HL - 1<br>Repeat until B = 0 | x | 1 | x | x | x | x | 1 | x | 11 101 101 E<br>10 111 011 | 2 | (If B≠0) | 21<br>16 | C to A <sub>0</sub> ~ A <sub>7</sub><br>B to A <sub>8</sub> - A <sub>15</sub> | NOTE. (1) If the result of B-1 is zero the Z flag is set, otherwise it is reset #### Summary of Flag Operation | Instruction | D <sub>7</sub> | z | | H | | P/V | N | D <sub>0</sub> | Comments | |-----------------------------------------------------|----------------|---|---|---|---|-----|---|----------------|-------------------------------------------------------------------------------------------------------------------------| | ADD A. s: ADC A. s | | - | х | | х | v | 0 | 1 | 8-bit add or add with carry. | | SUB s: SBC A s: CP s; NEG | i | i | х | 1 | х | v | 1 | 1 | 8-bit subtract, subtract with carry, compare and negate accumulator. | | AND a | | 1 | Х | 1 | Х | P | 0 | ા | 1. and a constant | | OR s. XOR a | ŧ | | х | 0 | х | P | 0 | 0 [ | Logical operations. | | INC s | : | 1 | Х | ı | Х | v | 0 | • | 8-bit increment. | | DEC . | | 1 | х | | х | v | 1 | • | 8-bit decrement. | | ADD DD, sa | • | ٠ | Х | х | Х | • | 0 | 1 | 16-bit add. | | ADC HL, ss | | 1 | х | Х | Х | ٧ | 0 | 1 | 16-bit add with carry. | | SBC HL. se | | 1 | X | Х | Х | ٧ | 1 | 1 | 16-bit subtract with carry. | | RLA, RLCA, RRA; RRCA | | • | х | 0 | х | • | 0 | 1 | Rotate accumulator. | | RL m; RLC m; RR m;<br>RRC m; SLA m;<br>SRA m; SRL m | 1 | ı | X | 0 | Х | P | 0 | 1 | Rotate and shift locations. | | RLD: RRD | 1 | 1 | х | 0 | х | P | 0 | | Rotate digit left and right. | | DAA | i | i | X | | X | P | ٠ | 1 | Decimal adjust accumulator. | | CPL | | ٠ | Х | 1 | х | • | 1 | • | Complement accumulator. | | SCF | | • | х | 0 | Х | • | 0 | 1 | Set carry. | | CCF | | | Х | X | х | • | 0 | t | Complement carry. | | IN r (C) | 1 | | х | 0 | X | P | 0 | • | Input register indirect. | | INI IND OUTL OUTD | x | 1 | X | х | х | x | 1 | • 1 | Block input and output, $Z = 0$ if $B \neq 0$ otherwise $Z = 0$ . | | INIR: INDR: OTIR: OTDR | X | 1 | Х | х | Х | х | 1 | ٠, | Block input and durpat. 2 - o it 5 - o dute - as 2 - o. | | LDI: LDD | X | Х | Х | 0 | Х | 1 | 0 | • 1 | Block transfer instructions, $P/V = 1$ if $BC \neq 0$ , otherwise $P/V = 0$ . | | LDIR: LDDR | х | х | X | 0 | Х | 0 | 0 | • f | | | CPI; CPIR; CPD; CPDR | X | 1 | X | X | X | 1 | 1 | • | Block search instructions. $Z = 1$ if $A = (HL)$ , otherwise $Z = 0$ . $P/V = 1$ if $BC \neq 0$ , otherwise $P/V = 0$ . | | LD A. I. LD A. R | 1 | 1 | х | 0 | х | IFF | 0 | • | The content of the interrupt enable flip-flop (IFF) is copied into the P/V flag. | | BIT b, s | X | ı | X | 1 | X | X | Ō | ٠ | The state of bit b of location s is copied into the Z flag. | | Symbol | Operation | |--------|----------------------------------------------------------------------| | s | Sign flag. $S = 1$ if the MSB of the result is 1. | | Z | Zero flag. $Z = 1$ if the result of the operation is 0. | | P/V | Parity or overflow flag. Parity (P) and overflow | | | <ul><li>(V) share the same flag. Logical operations affect</li></ul> | | | this flag with the parity of the result while | | | arithmetic operations affect this flag with the | | | overflow of the result. If P/V holds parity, P/V = | | | l if the result of the operation is even, P/V = 0 if | | | result is odd. If $P/V$ holds overflow, $P/V = 1$ if | | | the result of the operation produced an overflow. | | Н | Half-carry flag. H = 1 if the add or subtract | | | operation produced a carry into or borrow from | | | bit 4 of the accumulator. | | N | Add/Subtract flag. $N = 1$ if the previous opera- | | | tion was a subtract. | | H & N | H and N flags are used in conjunction with the | | | decimal adjust instruction (DAA) to properly cor- | | | rect the result into packed BCD format following | | | addition or subtraction using operands with | | | packed BCD format. | | С | Carry/Link flag. C = 1 if the operation produced | | | a carry from the MSB of the operand or result. | | Symbol | Operation | |--------|-----------------------------------------------------------------------------------------| | 1 | The flag is affected according to the result of the<br>operation. | | • | The flag is unchanged by the operation. | | 0 | The flag is reset by the operation. | | 1 | The flag is set by the operation. | | Х | The flag is a "don't care." | | V | P/V flag affected according to the overflow resu of the operation. | | P | P/V flag affected according to the parity result of<br>the operation. | | r | Any one of the CPU registers A, B, C, D, E, H, I | | s | Any 8-bit location for all the addressing modes allowed for the particular instruction. | | SS | Any 16-bit location for all the addressing modes allowed for that instruction. | | ii | Any one of the two index registers IX or IY. | | R | Refresh counter. | | n | 8-bit value in range < 0, 255 >. | | nn | 16-bit value in range < 0, 65535 >. | ### Pin Descriptions A<sub>0</sub>·A<sub>15</sub>. Address Bus (output, active High, 3-state). A<sub>0</sub>·A<sub>15</sub> form a 16-bit address bus. The Address Bus provides the address for memory data bus exchanges (up to 64K bytes) and for I/O device exchanges. BUSACK. Bus Acknowledge (output, active BUSACK. Bus Acknowledge (output, active Low). Bus Acknowledge indicates to the requesting device that the CPU address bus, data bus, and control signals MREQ, TORQ, RD, and WR have entered their high-impedance states. The external circuitry can now control these lines. BUSREQ. Bus Request (input, active Low). Bus Request has a higher priority than NMI and is always recognized at the end of the current machine cycle. BUSREQ forces the CPU address bus, data bus, and control signals MREQ, IORQ, RD, and WR to go to a high-impedance state so that other devices can control these lines. BUSREQ is normally wire-ORed and requires an external pullup for these applications. Extended BUSREQ periods due to extensive DMA operations can prevent the CPU from properly refreshing dynamic RAMs. D<sub>0</sub>-D<sub>7</sub>. Data Bus (input/output, active High, 3-state). D<sub>0</sub>-D<sub>7</sub> constitute an 8-bit bidirectional data bus, used for data such assectively with permany and I/O. bidirectional data bus, used for data exchanges with memory and I/O. HALT. Halt State (output, active Low). HALT indicates that the CPU has executed a Halt instruction and is awaiting either a non-maskable or a maskable interrupt (with the mask enabled) before operation can resume. While halted, the CPU executes NOPs to maintain memory refresh. while haited, the CPU executes NOPs to maintain memory refresh. INT. Interrupt Request (input, active Low). Interrupt Request is generated by I/O devices. The CPU honors a request at the end of the current instruction if the internal software-controlled interrupt enable flip-flop (IFF) is enabled. INT is normally wire-ORed and requires an external pullup for these applications. applications. IORQ. Input/Output Request (output, active Low, 3-state). IORQ indicates that the lower half of the address bus holds a valid I/O address for an I/O read or write operation. IORQ is also generated concurrently with Muring an interrupt acknowledge cycle to indicate that an interrupt response vector can be placed on the data bus. MI. Machine Cycle One (output, active Low). MI, together with MREQ, indicates that the current machine cycle is the opcode fetch cycle of an instruction execution. MI, together with IORQ, indicates an interrupt acknowledge cycle. MREQ. Memory Request (output, active Low, 3-state). MREQ indicates that the address bus holds a valid address for a memory read or memory write operation. NMI. Non-Maskable Interrupt (input, negative edge-triggered). NMI has a higher priority than INT. NMI is always recognized at the end of the current instruction, independent of the status of the interrupt enable flip-flop, and automatically forces the CPU to restart at location 0066H. RD. Read (output, active Low, 3-state). RD indicates that the CPU wants to read data from memory or an I/O device. The addressed I/O device or memory should use this signal to gate data onto the CPU data bus. data bus. RESET. Reset (input, active Low). RESET initializes the CPU as follows: it resets the interrupt enable flip-flop, clears the PC and Registers I and R, and sets the interrupt status to Mode 0. During reset time, the address and data bus go to a high-impedance state, and all control output signals go to the inactive state. Note that RESET must be active for a minimum of three full clock cycles before the reset operation is complete. reset operation is complete. RFSH. Refresh (output, active Low). RFSH, together with MREQ, indicates that the lower seven bits of the system's address bus can be used as a refresh address to the system's dynamic memories. wait. Wait (input, active Low). WAIT indicates to the CPU that the addressed memory or I/O devices are not ready for a data transfer. The CPU continues to enter a Wait state as long as this signal is active. Extended WAIT periods can prevent the CPU from refreshing dynamic memory properly. WR. Write (output, active Low, 3-state). WR indicates that the CPU data bus holds valid data to be stored at the addressed memory or I/O location. #### **CPU Timing** The Z80 CPU executes instructions by proceeding through a specific sequence of operations: - Memory read or write - I/O device read or write - Interrupt acknowledge The basic clock period is referred to as a T time or cycle, and three or more T cycles make up a machine cycle (M1, M2 or M3 for instance). Machine cycles can be extended either by the CPU automatically inserting one or more Wait states or by the insertion of one or more Wait states by the user. Instruction Opcode Fetch. The CPU places the contents of the Program Counter (PC) on the address bus at the start of the cycle (Figure 5). Approximately one-half clock cycle later, MREQ goes active. When active, RD indicates that the memory data can be enabled onto the CPU data bus. The CPU samples the WAIT input with the The CPU samples the WAIT input with the falling edge of clock state T<sub>2</sub>. During clock states T<sub>3</sub> and T<sub>4</sub> of an MI cycle dynamic RAM refresh can occur while the CPU starts decoding and executing the instruction. When the Refresh Control signal becomes active, refreshing of dynamic memory can take place. NOTE: $T_{\text{w}}\text{-Wait}$ cycle added when necessary for slow ancilliary devices Figure 5. Instruction Opcode Fetch **Z8400** ### CPU Timing (Continued) Memory Read or Write Cycles. Figure 6 shows the timing of memory read or write cycles other than an opcode fetch $(\overline{M1})$ cycle. The $\overline{MREQ}$ and $\overline{RD}$ signals function exactly as in the fetch cycle. In a memory write cycle, $\overline{\text{MREO}}$ also becomes active when the address bus is stable. The $\overline{\text{WR}}$ line is active when the data bus is stable, so that it can be used directly as an $R/\overline{W}$ pulse to most semiconductor memories. Figure 6. Memory Read or Write Cycles #### CPU Timing (Continued) Input or Output Cycles. Figure 7 shows the timing for an I/O read or I/O write operation. During I/O operations, the CPU automatically inserts a single Wait state (T<sub>w</sub>). This extra Wait state allows sufficient time for an I/O port to decode the address from the port address lines. NOTE: $T_{\mathbf{w}^*} = O_{ne}$ Wait cycle automatically inserted by CPU. Figure 7. Input or Output Cycles #### CPU Timing (Continued) Interrupt Request/Acknowledge Cycle. The CPU samples the interrupt signal with the rising edge of the last clock cycle at the end of any instruction (Figure 8). When an interrupt is accepted, a special MI cycle is generated. During this $\overline{Mi}$ cycle, $\overline{IORQ}$ becomes active (instead of $\overline{MREQ}$ ) to indicate that the interrupting device can place an 8-bit vector on the data bus. The CPU automatically adds two Wait states to this cycle. NOTE: 1) $T_L$ = Last state of previous instruction 2) Two Wait cycles automatically inserted by $CPU(^*)$ . Figure 8. Interrupt Request/Acknowledge Cycle #### CPU Timing (Continued) Non-Maskable Interrupt Request Cycle. $\overline{NMI}$ is sampled at the same time as the maskable interrupt input $\overline{INT}$ but has higher priority and cannot be disabled under software control. The subsequent timing is similar to that of a normal instruction fetch except that data put on the bus by the memory is ignored. The CPU instead executes a restart (RST) operation and jumps to the NMI service routine located at address occur. (The control of the o 0066H (Figure 9). Figure 9. Non-Maskable Interrupt Request Operation ### CPU Timing (Continued) Bus Request/Acknowledge Cycle. The CPU samples BUSREQ with the rising edge of the last clock period of any machine cycle (Figure 10). If BUSREQ is active, the CPU sets its address, data, and MREQ, TORQ, RD, and $\overline{\text{WR}}$ lines to a high-impedance state with the rising edge of the next clock pulse. At that time, any external device can take control of these lines, usually to transfer data between memory and I/O devices. NOTE: $T_L = Last$ state of any M cycle. Tx = An arbitrary clock cycle used by requesting device. Figure 10. Z-Bus Request/Acknowledge Cycle #### CPU Timing (Continued) 36 Halt Acknowledge Cycle. When the CPU receives an Halt instruction, it executes NOP states until either an INT or NMI input is received. When in the Halt state, the HALT output is active and remains so until an interrupt is received (Figure 11). Reset Cycle. $\overline{\text{RESET}}$ must be active for at least three clock cycles for the CPU to properly accept it. As long as RESET remains active, the address and data buses float, and the control outputs are inactive. Once RESET goes inactive, three internal T cycles are consumed before the CPU resumes normal processing operation. RESET clears the PC register, so the first opcode fetch will be to location 0000 (Figure 12). Figure 11. Halt Acknowledge Cycle | | cteristics | | Z84 | | Z84 | | Z8400B | | | 00H | |----------------|----------------|---------------------------------------------------------------------------|-------------|-------------|-------------|-------------|---------------|-------------|-------------|-------------| | | Symbol | Parameter | Min<br>(ns) | Max<br>(ns) | Min<br>(ns) | Max<br>(ns) | Min<br>(ns) | Max<br>(ns) | Min<br>(ns) | Max<br>(ns) | | Number | | Clock Cycle Time | 400* | (115) | 250* | (22) | 165* | | 125* | | | 1 | TcC | | 180* | | 110* | _ | 65* | _ | 55* | | | 2 | TwCh | Clock Pulse Width (High) | 180 | 2000 | 110 | 2000 | 65 | 2000 | 55 | 2000 | | 3 | TwCl | Clock Pulse Width (Low) | 180 | 30 | _ | 30 | - 03 | 2000 | _ | 10 | | 4 | TfC | Clock Fall Time | | 30 | _ | 30 | _ | 20 | _ | 10 | | <u> </u> | —TrC — | - Clock Rise Time | | | | 110 | | 90 | | 80 | | 6 | TdCr(A) | Clock 1 to Address Valid Delay | - | 145 | _ | 110 | 35* | 90 | 20* | 80 | | 7 | TdA(MREQf) | Address Valid to MREQ ↓ Delay | 125* | _ | 65* | <br>85 | 35 | | 20 | - 60 | | 8 | TdCf(MREQf) | Clock ↓ to MREQ ↓ Delay | - | 100 | _ | | _ | 70 | _ | | | 9 | TdCr(MREQr) | Clock ↑ to MREQ ↑ Delay | - | 100 | _ | 85 | | 70 | - | 60 | | <del></del> 10 | —TwmreQh — | MREQ Pulse Width (High) | - 170* | | -110*- | | — 65° | | 45°- | | | 11 | TwMREQ1 | MREQ Pulse Width (Low) | 360* | _ | 220* | | 135* | _ | 100* | _ | | 12 | TdCf(MREQr) | Clock ↓ to MREQ ↑ Delay | | 100 | _ | 85 | _ | 70 | _ | 60 | | 13 | TdCf(RDf) | Clock ↓ to $\overline{RD}$ ↓ Delay | _ | 130 | _ | 95 | | 80 | | 70 | | 14 | TdCr(RDr) | Clock ↑ to RD ↑ Delay | - | 100 | _ | 85 | _ | 70 | | 60 | | 15 | — TsD(Cr) ——— | -Data Setup Time to Clock 1 | - 50 - | | - 35 - | | 30 - | | - 30 - | | | 16 | ThD(RDr) | Data Hold Time to RD † | _ | 0 | _ | 0 | _ | 0 | _ | C | | 17 | TsWAIT(Cf) | WAIT Setup Time to Clock↓ | 70 | - | 70 | _ | 60 | _ | 50 | - | | 18 | ThWAIT(Cf) | WAIT Hold Time after Clock↓ | _ | 0 | _ | 0 | | 0 | | C | | 19 | TdCr(M.:) | Clock ↑ to Ml ↓ Delay | | 130 | _ | 100 | _ | 80 | _ | 70 | | 20 | — TdCr(Mlr) —— | –Clock † to Ml † Delay – | | 130 | | 100 | | 80 | | 70 | | 21 | TdCr(RFSHf) | Clock ↑ to RFSH ↓ Dealy | _ | 180 | _ | 130 | | 110 | | 95 | | 22 | TdCr(RFSHr) | Clock ↑ to RFSH ↑ Delay | _ | 150 | - | 120 | | 100 | | 85 | | 23 | TdCf(RDr) | Clock ↓ to RD ↑ Delay | | 110 | | 85 | _ | 70 | _ | 60 | | 24 | TdCr(BCt) | Clock ↑ to RD ↓ Dealy | _ | 110 | _ | 85 | _ | 70 | _ | 60 | | 25 | — TsD(Ct) — | - Data Setup to Clock during | 60- | | 50 - | | <b>—</b> 40 - | | <u> </u> | | | 20 | 152(4) | M <sub>2</sub> , M <sub>3</sub> , M <sub>4</sub> or M <sub>5</sub> Cycles | | | | | | | | | | 26 | TdA(ICEQf) | Address Stable prior to <del>IORQ</del> ↓ | 320* | _ | 180* | _ | 110* | _ | 75* | _ | | 27 | TdCr(ICRQf) | Clock ↑ to IORQ ↓ Delay | _ | 90 | | 75 | | 65 | _ | 55 | | 28 | TdCf(ICRQr) | Clock ↓ to <del>IORQ</del> ↑ Delay | _ | 110 | _ | 85 | | 70 | - | 60 | | 29 | TdCh(WBf) | Data Stable prior to WR ↓ | 190* | - | 80* | _ | 25* | _ | 5* | | | 30 | TdDf(WRf)— | —Clock ↓ to WR ↓ Delay ——— | | —90 | | 80 | | 70 | | 60 | | 31 | TwWE | WR Pulse Width | 360* | _ | 220* | | 135* | | 100* | | | 32 | TdCt(WEr) | Clock ↓ to WR ↑ Delay | _ | 100 | _ | 80 | _ | 70 | _ | 60 | | 33 | TdD(WR:) | Data Stable prior to WR↓ | 20* | _ | -10* | _ | -55 <b>*</b> | _ | 55* | | | 34 | TdCr(WRf) | Clock ↑ to WR ↓ Delay | _ | 80 | _ | 65 | _ | 60 | | 55 | | 35 | TdWE:,2) | Data Stable from WR↑ | 120* | _ | 60* | _ | 30* | _ | 15* | _ | For clock periods other man the minimums shown in the table, calculate parameters using the expressions in the table on the following page. All timings are preliminary and subject to change. #### AC Characteristics (Continued) | | | | Z8- | 400 | Z84 | 00A | Z84 | 100B | Z84 | H00H | |----------------|----------------|--------------------------------------------------------------------|-------------|-------------|------------------|-------------|-------------|------------------|-----------------|-------------| | Number | Symbol | Parameter | Min<br>(ns) | Max<br>(ns) | Min<br>(ns) | Max<br>(ns) | Min<br>(ns) | Max<br>(ns) | Min<br>(ns) | Max<br>(ns) | | 36 | TdCf(HALT) | Clock ↓ to HALT ↑ or ↓ | | 300 | | 300 | | 260 | _ | 225 | | 37 | TwNMI | NMI Pulse Width | 80 | _ | 80 | _ | 70 | | 60° | | | 38 | TsBUSREO(Cr) | BUSREQ Setup Time to Clock ↑ | 80 | _ | 50 | _ | 50 | | 40 | | | 39 | TcBUSUREQ(Cr | BUSREQ Hold Time after Clock 1 | 0 | _ | 0 | where | 0 | _ | 0 | _ | | 40 | - TdCr(BUSACKi | Clock 1 to BUSACK Delay | | - 120 - | | -100 - | | <del></del> 90 - | | <b>—</b> 80 | | 41 | | Clock 1 to BUSACK † Delay | | 110 | _ | 100 | _ | 90 | _ | 80 | | 42 | TdCr(Tz) | Clock ↑ to Data Float Delay | - | 90 | | 90 | | 80 | _ | 70 | | 43 | TdCr(CTz) | Clock † to Control Outputs Float<br>Delay (MREQ, IORQ, RD, and WR) | | 110 | - | 80 | _ | 70 | | 60 | | 44 | TdCr(Az) | Clock ↑ to Address Float Delay | | 110 | _ | 90 | _ | 80 | - | 70 | | <del>4</del> 5 | —TdCTr(A) —— | - MREQ ↑, IORQ ↑, RD ↑, and———<br>WR ↑ to Address Hold Time | -160*- | | - 80*- | | 35* | .• | - 20 <b>*</b> - | | | 46 | TsRESET(Cr) | RESET to Clock 1 Setup Time | 90 | | 60 | _ | 60 | - | 45 | _ | | 47 | ThRESET(Cr) | RESET to Clock † Hold Time | _ | 0 | _ | 0 | _ | 0 | _ | 0 | | 48 | TsINTf(Cr) | INT to Clock † Setup Time | 80 | _ | 80 | - | 70 | _ | 55 | _ | | 49 | ThINTr(Cr) | INT to Clock ↑ Hold Time | _ | 0 | | 0 | _ | 0 | _ | 0 | | 50 | -TdMlf(IORQf)- | —MI↓ to IORQ↓ Delay——— | - 920°- | | - 565 <b>*</b> - | | -365*- | | -270*- | | | 51 | TdCf(IORQf) | Clock ↓ to <del>IORQ</del> ↓ Delay | _ | 110 | _ | 85 | _ | 70 | _ | 60 | | 52 | TdCf(IORQr) | Clock ↑ to IORQ ↑ Delay | - | 100 | _ | 85 | | 70 | _ | 60 | | 53 | TdCf(D) | Clock ↓ to Data Valid Delay | _ | 230 | | 150 | - | 130 | _ | 115 | \* For clock periods other than the minimums shown in the table, calculate parameters using the expressions in the table on the following page. All timings are preliminary and subject to change. ### Footnotes to AC Characteristics | Number | Symbol | Z8400 | Z8400A | Z8400B | |-----------------------------------------------------|----------------|----------------------------------------------------|----------------------------|---------------------------| | 1 | TcC | TwCh + TwCl + TrC + TfC | TwCh + TwCl + TrC + TfC | TwCh + TwCl + TrC + TfC | | 2 | TwCh | Although static by design, | Although static by design, | Although static by design | | | | TwCh of greater than | TwCh of greater than | TwCh of greater than | | | | 200 µs is not guaranteed | 200 μs is not guaranteed | 200 μs is not guaranteed | | 7 | - TdA(MREQf) - | - TwCh + TfC - 75 | - TwCh + TfC - 65 | - TwCh + TfC - 50 | | 10 | TwMREQh | TwCh + TfC - 30 | TwCh + TfC - 20 | TwCh + TfC - 20 | | 11 | TwMREQ1 | TcC - 40 | TeC - 30 | TcC - 30 | | 26 | TdA(IORQf) | TcC-80 | TcC-70 | TcC - 55 | | 29 | TdD(WRf) | TcC-210 | TcC-170 | TcC-140 | | 31 | - TwWR | - TcC - 40 | - TcC - 30 | - TcC - 30 | | 33 | TdD(WRf) | TwCl + TrC - 180 | TwCl + TrC - 140 | TwCl + TrC - 140 | | 35 | TdWRr(D) | TwCl + TrC - 80 | TwCl+TrC-70 | TwCl + TrC - 55 | | 45 | TdCTr(A) | TwCl + TrC 40 | TwCl+TrC-50 | TwCl + TrC - 50 | | 50 | TdMlf(IORQf) | 2TcC + TwCh + TfC - 80 | 2TcC + TwCh + TfC - 65 | 2TcC + TwCh + TfC - 50 | | C Test Cond | itions: | V <sub>ILC</sub> = 0.45 V | | | | $V_{1H} = 2.0 \text{ V}$<br>$V_{T} = 0.8 \text{ V}$ | | V <sub>OH</sub> = 2.0 V<br>V <sub>OL</sub> = 0.8 V | | | | VIHC = VCC | -0.6 V | FLOAT = ±0.5 V | | | ### Absolute Maximum Ratings Storage Temperature ... $-65^{\circ}\text{C}$ to $+150^{\circ}\text{C}$ Temperature under Bias ... ... Specified operating range Voltages on all inputs and outputs with respect to GND ... - 0.3 V to +7.0 V Power Dissipation ... 1.5 W Stresses greater than those listed under Absolute Maximum Ratings may cause permanent damage to the device. This is a stress rating only; operation of the device at any condition above those indicated in the operational sections of these specifications is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability. ### Standard Test Conditions The characteristics below apply for the The characteristics below apply for the following standard test conditions, unless otherwise noted. All voltages are referenced to GND (0 V). Positive current flows into the referenced pin. Available operating temperature ranges are: - 0°C to +70°C, +4.75 V $\leq$ V<sub>CC</sub> $\leq$ +5.25 V ■ $-40^{\circ}$ C to $+85^{\circ}$ C, +4.75 V $\leq$ V<sub>CC</sub> $\leq$ +5.25 V - $-55^{\circ}$ C to $+125^{\circ}$ C, +4.75 V $\leq$ V<sub>CC</sub> $\leq$ +5.25 V All ac parameters assume a load capacitance of 50 pF. Add 10 ns delay for each 50 pF increase in load up to a maximum of 200 pF for the data bus and 100 pF for address and control lines. | Symbol | racteristics Parameter | Min. | Max | Unit | Test Condition | |------------------|-----------------------------------------|----------------------|----------------------|---------|-----------------------------| | V <sub>ILC</sub> | Clock Input Low Voltage | -0.3 | 0.45 | v | | | V <sub>IHC</sub> | Clock Input High Voltage | V <sub>CC</sub> -0.6 | V <sub>CC</sub> +0.3 | V | | | V <sub>II.</sub> | Input Low Voltage | -0.3 | 0.8 | V | | | v <sub>IH</sub> | Input High Voltage | 2.0 | $v_{cc}$ | V | | | V <sub>OL</sub> | Output Low Voltage | | 0.4 | V | $I_{OL} = 1.8 \text{ mA}$ | | V <sub>OH</sub> | Output High Voltage | 2.4 | | V | $I_{OH} = -250 \mu A$ | | Icc | Power Supply Current | | | | | | | 280 | | 1501 | mA | | | | Z80Å | | 2002 | mA | | | | Z80B | | 200 | mÅ | | | | Z80H | | 200 | mA | | | $I_{L,I}$ | Input Leakage Current | _ | 10 | $\mu$ A | $V_{IN} = 0$ to $V_{CC}$ | | ILO | 3-State Output Leakage Current in Ficat | - 10 | 102 | $\mu$ A | $V_{OUT} = 0.4$ to $V_{CC}$ | 1. For military grade parts, I<sub>CC</sub> is 200 mA. 2. Typical rate for 28400A is 90 mA. 3. A<sub>15</sub>-A<sub>0</sub>,D<sub>7</sub>-D<sub>0</sub>, MREQ, IORQ, RD, and WR. #### Capacitance | Symbol | Parameter | Min. | Max | Unit | Note | |--------|--------------------|------|-----|------|---------------------------------------| | CCLOCK | Clock Capacitance | | 35 | рF | | | CIN | Input Capacitance | | 5 | pf | Unmeasured pins<br>returned to ground | | COUT | Output Capacitance | | 10 | рF | - | T<sub>A</sub> = 25°C, f = 1 MHz | Туре | Package | Temp. | Clock | Description | |-----------|----------------------------------------------|---------------|-----------|-----------------------------| | Z6400 B1 | Plastic | 0/ + 70°C | 1 | Z80 Central Processing Unit | | ZS400 B6 | Plastic | - 40/ + 85°C | 1 | | | 78400 F1 | Frit Seal | 0/+70°C | 1 | | | 25400 F6 | Frit Seal | -40/+85°C | 1 | | | Z8400 D1 | Ceramic | 0/+70°C | 1 | | | ZS400 D6 | Ceramic | - 40/ + 85°C | 2.5 MHz | | | 78400 D2 | Ceramic | -55/+125°C | / 2.5 MHZ | | | Z8400 C1 | Plastic Chip-Carrier | 0/+70°C | l . | | | ZS400 C6 | Plastic Chip-Carrier | -40/+85°C | 1 | | | ZS400 K1 | Ceramic Chip-Carrier | 0/ + 70°C | 1 | | | ZS400 K6 | Ceramic Chip-Carrier | - 40/ + 85°C | 1 | | | Z8400 K2 | Ceramic Chip-Carrier | -55/+125°C | 1 | | | ZS400A B1 | Plastic | 0/ + 70°C | 1 | | | Z8400A B6 | Plastic | -40/+85°C | 1 | | | Z8400A F1 | Frit Seal | 0/+70°C | | | | Z8400A F6 | Frit Seal | -40/+85°C | 1 | | | Z8400A D1 | Ceramic | 0/ + 70°C | į | | | Z8400A D6 | Ceramic | - 40/ + 85°C | 1 | | | Z8400A D2 | Ceramic | -55/+125°C | 4.0 MHz | | | Z8400A C1 | Plastic Chip-Carrier | 0/+70°C | i . | | | Z8400A C6 | Plastic Chip-Carrier | -40/+85°C | 1 | | | 78400A K1 | Ceramic Chip-Carrier | 0/+70°C | 1 | | | Z8400A K6 | Ceramic Chip-Carrier | -40/+85°C | J | | | Z8400A K2 | Ceramic Chip-Carrier | -55/+125°C | 1 | | | Z8400B B1 | Plastic | 0/+70°C | ĺ | | | Z8400B B6 | Plastic | -40/+85°C | 1 | | | Z8400B F1 | Frit Seal | 0/ + 70°C | i | | | Z8400B F6 | Frit Seal | - 40/ + 85°C | 1 | | | Z8400B D1 | Ceramic | 0/ + 70°C | 1 | | | Z8400B D6 | Ceramic | 40/ + 85°C | | | | Z8400B D2 | Ceramic | -55/+125°C | 6.0 MHz | | | Z8400B C1 | Plastic Chip-Carrier | 0/ + 70°C | 1 | | | Z8400B C6 | Plastic Chip-Carrier | - 40/ + 85°C | 1 | | | Z8400B K1 | Ceramic Chip-Carrier | 0/+70°C | 1 | | | Z8400B K6 | Ceramic Chip-Carrier | - 40/ + 85°C | 1 | | | Z8400B K2 | Ceramic Chip-Carrier | -55/+125°C | 1 | | | Z8400H B1 | Plastic | 0/+70°C | <u>`</u> | | | Z8400H B6 | Plastic | - 40/ + 85°C; | 1 | | | Z8400H F1 | Frit Seal | 0/+70°C | 1 | | | Z8400H F6 | Frit Seal | - 40/ + 85°C | 1 | | | Z8400H D1 | Ceramic | 0/ + 70°C | | | | Z8400H D6 | Ceramic | -40/+85°C | 8.0 MHz | | | Z8400H C1 | Plastic Chip-Carrier | 0/ + 70°C | 1 | | | Z8400H C6 | Plastic Chip-Carrier Plastic Chip-Carrier | - 40/ + 85°C | 1 | | | 28400H K1 | | 0/+70°C | 1 | | | Z8400H K6 | Ceramic Chip-Carrier<br>Ceramic Chip-Carrier | -40/+,85°C | / | |