## Z8001® / Z8002® Z8000® CPU Central Processing Unit #### October 1988 #### **FEATURES** - Regular, easy-to-use architecture - Instruction set more powerful than many minicomputers - Directly addresses 8 Mbytes - Eight user-selectable addressing modes - Seven data types that range from bits to 32-bit long words and byte and word strings - System and Normal operating modes - Separate code, data, and stack spaces - Sophisticated interrupt structure - Resource-shaping capabilities for multiprocessing systems - Multi-programming support - Compiler support - Memory management and protection provided by Z8010 Memory Management Unit - 32-bit operations, including signed multiply and divide - Z-BUS compatible - 4, 6, and 10 MHz clock rate #### **GENERAL DESCRIPTION** The Z8000 is an advanced high-end 16-bit microprocessor that spans a wide variety of applications ranging from simple stand-alone computers to complex parallel-processing systems. Essentially a monolithic minicomputer central processing unit, the Z8000 CPU is characterized by an instruction set more powerful than many minicomputers; abundant resources in registers, data types, addressing modes and addressing range, and a regular architecture that enhances throughput by avoiding critical bottlenecks such as implied or dedicated registers. CPU resources include sixteen 16-bit general-purpose registers, seven data types that range from bits to 32-bit long words and byte and word strings, and eight user-selectable addressing modes. The 110 distinct instruction types can be combined with the various data types and addressing modes to form a powerful set of 414 instructions. Moreover, the instruction set is regular; most instructions can use any of the five main addressing modes and can operate on byte, word, and long-word data types. The CPU can operate in either the system or normal mode. The distinction between these two modes permits privileged operations, thereby improving operating system organization and implementation. Multiprogramming is supported by the "atomic" Test and Set instruction; multiprocessing by a combination of instruction and hardware features; and compilers by multiple stacks, special instructions, and addressing modes. The Z8000 CPU is offered in three versions: the Z8001/Z160 segmented CPUs and the Z8002 nonsegmented CPU (Figure 1). The main difference is in addressing range. The Z8001 can directly address 8 megabytes of memory; the Z160 directly addresses 2 megabytes; the Z8002 directly addresses 64 kilobytes. The two operating modes - system and normal - and the distinction between code, data, and stack spaces within each mode allows memory extension up to 48 megabytes for the Z8001, 12 megabytes for the Z160 and 384 kilobytes for the Z8002. To meet the requirements of complex, memory-intensive applications, a companion memory-management device is offered for the Z8001. The Z8010 Memory Management Unit manages the large address space by providing features such as segment relocation and memory protection. The Z8001 can be used with or without the Z8010. If used by itself, the Z8001 still provides an 8 megabyte direct addressing range, extendable to 48 megabytes. The Z8001, Z8002 and Z8010 are fabricated with high-density, high-performance scaled n-channel silicon-gate depletion-load technology, and are housed in dual-in-line packages (DIPs) and leadless chip carriers (LCC). #### REGISTER ORGANIZATION The Z8000 CPU is a register-oriented machine that offers sixteen 16-bit general-purpose registers and a set of special system registers. All general-purpose registers can be used as accumulators and all but one as index registers or memory pointers. Register flexibility is created by grouping and overlapping multiple registers (Figures 2 and 3). For byte operations, the first eight 16-bit registers (R0... R7) are treated as sixteen 8-bit registers (RL0, RH0..., RL7, RH7). The sixteen 16-bit registers are grouped in pairs (RR0... RR14) to form 32-bit long-word registers. Similarly, the register set is grouped in quadruples (RQ0... RQ12) to form 64-bit registers. Figure 2. Z8001 General-Purpose Registers Figure 3. Z8002 General-Purpose Registers #### **STACKS** The Z8001, Z8002 and Z160 can use stacks located anywhere in memory. Call and Return instructions as well as interrupts and traps use implied stacks. The distinction between normal and system stacks separates system information from the application program information. Two stack pointers are available: the system stack pointer and the normal stack pointer. Because they are part of the general-purpose register group, the user can manipulate the stack pointers with any instruction available for register operations. In the Z8001, register pair RR14 is the implied stack pointer. Register R14 contains the 7-bit segment number and R15 contains the 16-bit offset. In the Z8002, register R15 is the implied 16-bit stack pointer. #### REFRESH The Z8000 CPU contains a counter that can be used to automatically refresh dynamic memory. The refresh counter register consists of a 9-bit row counter, a 6-bit rate counter, and an enable bit (Figure 4). The 9-bit row counter can address up to 256 rows and is incremented by two each time the rate counter reaches end-of-count. The rate counter determines the time between successive refreshes. It consists of a programmable 6-bit modulo-n prescaler (n = 1 to 64), driven at one-fourth the CPU clock rate. The refresh period can be programmed by 1 to 64 $\mu$ s with a 4 MHz clock. Refresh can be disabled by programming the refresh enable/disable bit. Figure 4. Refresh Counter ## **PROGRAM STATUS INFORMATION** This group of status registers contains the program counter, flags, and control bits. When an interrupt or trap occurs, the entire group is saved and a new program status group is loaded. Figure 5 illustrates how the program status groups of the Z8001 and Z8002 differ. In the nonsegmented Z8002, the program status group consists of two words: the program counter (PC), and the flag and control word (FCW). In the segmented Z8001, the program status group consists of four words: a two-word program counter, the flag and control word, and an unused word reserved for future use. Seven bits of the first PC word designate one of the 128 memory segments. The second word supplies the 16-bit offset that designates a memory location within the segment. With the exception of the segment enable bit in the Z8001 program status group, the flags and control bits are the same for both CPUs. Z8001 Program Status Registers Z8001 Program Status Ārea Pointer 15 UPPER POINTER 0 0 0 0 0 0 0 0 0 Z8002 Program Status Area Pointer Figure 5. Z8000 CPU Special Registers #### INTERRUPT AND TRAP STRUCTURE The Z8000 provides a very flexible and powerful interrupt and trap structure. Interrupts are external asynchronous events requiring CPU attention, and are generally triggered by peripherals needing service. Traps are synchronous events resulting from the execution of certain instructions. Both are processed in a similar manner by the CPU. The CPU supports three types of interrupts (non-maskable, vectored, and non-vectored) and four traps [system call, Extended Process Architecture (EPA) instruction, privileged instructions, and segmentation trap]. The vectored and non-vectored interrupts are maskable. Of the four traps, the only external one is the segmentation trap, which is generated by the Z8010. The remaining traps occur when instructions limited to the system mode are used in the normal mode, or as a result of the System Call instruction, or for an EPA instruction. The descending order of priority for traps and interrupts is: internal traps, nonmaskable interrupt, segmentation trap, vectored interrupt, and non-vectored interrupt. When an interrupt or trap occurs, the current program status is automatically pushed on the system stack. The program status consists of the processor status (PC and FCW) plus a 16-bit identifier. The identifier contains the reason or source of the trap or interrupt. For internal traps, the identifier is the first word of the trapped instruction. For external traps or interrupts, the identifier is the vector on the data bus read by the CPU during the interrupt-acknowledge or trapacknowledge cycle. After saving the current program status, the new program status is automatically loaded from the program status area in system memory. This area is designated by the program status area pointer (PSAP). ## **DATA TYPES** Z8000 instructions can operate on bits, BCD digits (4 bits), bytes (8 bits), words (16 bits), long words (32 bits), and byte strings and word strings (up to 64 kilobytes long). Bits can be set, reset, and tested; digits are used in BCD arithmetic operations; bytes are used for characters or small integer values; words are used for integer values, instructions and nonsegmented addresses; long words are used for long integer values and segmented addresses. All data elements except strings can reside either in registers or memory. Strings are stored in memory only. The basic data element is the byte. The number of bytes used when manipulating a data element is either implied by the operation or—for strings and multiple register operations—explicitly specified in the instruction. # SEGMENTATION AND MEMORY MANAGEMENT High-level languages, sophisticated operating systems, large programs and data bases, and decreasing memory prices are all accelerating the trend toward larger memory requirements in microcomputer systems. The Z8001 meets this requirement with an eight megabyte addressing space. This large address space is directly accessed by the CPU using a segmented addressing scheme and can be managed by the Z8010 Memory Management Unit. #### Segmented Addressing A segmented addressing space—compared with linear addressing—is closer to the way a programmer uses memory because each procedure and data space resides in its own segment. The 8 megabytes of Z8001 addressing space is divided into 128 relocatable segments up to 64 kilobytes each. A 23-bit segmented address uses a 7-bit segment address to point to the segment, and a 16-bit offset to address any location relative to the beginning of the segment. The two parts of the segmented address may be manipulated separately. The segmented Z8001 can run any code written for the nonsegmented Z8002 in any one of its 128 segments, provided it is set to the nonsegmented mode. Figure 6. Logical-to-Physical Address Translation In hardware, segmented addresses are contained in a register pair or long-word memory location. The segment number and offset can be manipulated separately or together by all the available word and long-word operations. When contained in an instruction, a segmented address has two different representations: long offset and short offset. The long offset occupies two words, whereas the short offset requires only one and combines in one word the 7-bit segment number with an 8-bit offset (range 0-256). The short offset mode allows very dense encoding of addresses and minimizes the need for long addresses required by direct accessing of this large address space. ## **Memory Management** The addresses manipulated by the programmer, used by instructions and output by the Z8001, are called *logical* addresses. The Memory Management Unit takes the logical addresses and transforms them into the *physical* addresses required for accessing the memory (Figure 6). This addresse transformation process is called relocation. Segment relocation makes user software addresses independent of the physical memory so the user is freed from specifying where information is actually located in the physical memory. The relocation process is transparent to user software. A translation table in the Memory Management Unit associates the 7-bit segment number with the base address of the physical memory segment. The 16-bit offset is added to the physical base address to obtain the actual physical address. The system may dynamically reload translation tables as tasks are created, suspended, or changed. In addition to supporting dynamic segment relocation, the Memory Management Unit also provides segment protection and other segment management features. The protection features prevent illegal uses of segments, such as writing into a write-protected zone. Each Memory Management Unit stores 64 segment entries that consist of the segment base address, its attributes, size, and status. Segments are variable in size from 256 bytes to 64 kilobytes in increments of 256 bytes. Pairs of Management Units support the 128 segment numbers available for each of the six CPU address spaces. Within an address space, several Management Units can be used to create multiple translation tables. ## **EXTENDED PROCESSING ARCHITECTURE** The Zilog Extended Processing Architecture (EPA) provides an extremely flexible and modular approach to expanding both the hardware and software capabilities of the Z8000 CPU. Features of the EPA include: - Specialized instructions for external processors or software traps may be added to CPU instruction set. - Increases throughput of the system by using up to four specialized external processors in parallel with the CPU. - Permits modular design of Z8000-based systems. - Provides easy management of multiple microprocessor configurations via "single instruction stream" communication. - Simple interconnection between extended processing units and Z8000 CPU requires no additional external supporting logic. - Supports debugging of suspect hardware against proven software. - Standard features on all Zilog Z8000 CPUs. Specific benefits include: - EPUs can be added as the system grows and as EPUs with specialized functions are developed. - Control of EPUs is accomplished via a "single instruction stream" in the Z8000 CPU, eliminating many significant system software and bus contention management obstacles that occur in other multiprocessor (e.g., master-slave) organization schemes. The processing power of the Zilog Z8000 16-bit microprocessor can be boosted beyond its intrinsic capability by Extended Processing Architecture. Simply stated, EPA allows the Z8000 CPU to accommodate up to four Extended Processing Units (EPUs), which perform specialized functions in parallel with the CPU's main instruction execution stream (Figure 7). The use of extended processors to boost the main CPU's performance capability has been proven with large mainframe computers and minicomputers. In these systems, specialized functions such as array processing, special input/output processing, and data communications processing are typically assigned to extended processor hardware. These extended processors are complex computers in their own right. The Zilog Extended Processing Architecture combines the best concepts of these proven performance boosters with the latest in high-density MOS integrated-circuit design. The result is an elegant expansion of design capability—a powerful microprocessor architecture capable of connecting single-chip EPUs that permits very effective parallel processing and makes for a smoothly integrated instruction stream from the Z8000 programmer's point of view. A typical addition to the current Z8000 instruction set is a set of Floating Point Instructions. The Extended Processing Units connect directly to the Z8000 Bus (Z-BUS) and continuously monitor the CPU instruction stream. When an extended instruction is detected, the appropriate EPU responds, obtaining or placing data or status information on the Z-BUS using the Z8000-generated control signals and performing its function as directed. The Z8000 CPU is responsible for instructing the EPU and delivering operands and data to it. The EPU recognizes instructions intended for it and executes them, using data supplied with the instruction and/or data within its internal registers. There are four classes of EPU instructions: - Data transfers between main memory and EPU registers - Data transfers between CPU registers and EPU registers - EPU internal operations - Status transfers between the EPUs and the Z8000 CPU Flag and Control Word register (FCW) Four Z8000 addressing modes may be utilized with transfers between EPU registers and the CPU and main memory: - Register - Indirect Register - Direct Address - Index In addition to the hardware-implemented capabilities of the Extended Processing Architecture, there is an extended instruction trap mechanism to permit software simulation of EPU functions. A control bit in the Z8000 FCW register indicates whether actual EPUs are present or not. If not, when an extended instruction is detected, the Z8000 traps on the instruction, so that a software "trap handler" can emulate the desired EPU function—a very useful development tool. The EPA software trap routine supports the debugging of suspect hardware against proven software. This feature will increase in significance as designers become familiar with the EPA capability of the Z8000 CPU. This software trap mechanism facilitates the design of systems for later addition of EPUs: initially, the extended function is executed as a trap subroutine; when the EPU is finally attached, the trap subroutine is eliminated and the EPA control bit is set. Application software is unaware of the change. Extended Processing Architecture also offers protection against extended instruction overlapping. Each EPU connects to the Z8000 CPU via the STOP line so that if an EPU is requested to perform a second extended instruction function before it has completed the previous one, it can put the CPU into the Stop/Refresh state until execution of the previous extended instruction is complete. EPA and CPU instruction execution are shown in Figure 8. The CPU begins operation by fetching an instruction and determining whether it is a CPU or an EPU command. The EPU meanwhile monitors the Z-BUS for its own instructions. If the CPU encounters an EPU command, it checks to see whether an EPU is present; if not, the EPU may be simulated by an EPU instruction trap software routine; if an EPU is present, the necessary data and/or address is placed on the Z-BUS. If the EPU is free when the instruction and data for it appear, the extended instruction is executed. If the EPU is still processing a previous instruction, it activates the CPU's STOP line to lock the CPU off at the Z-BUS until execution is complete. After the instruction is finished, the EPU deactivates the STOP line and CPU transactions continue. Figure 7. Typical Extended Processor Configuration igtriangle data or addresses are placed on the Bus and used by the EPU in the execution of an instruction. Figure 8. EPA and Z8000 CPU Instruction Execution ## INPUT/OUTPUT A set of I/O instructions performs 8-bit or 16-bit transfers between the CPU and I/O devices. I/O devices are addressed with a 16-bit I/O port address. The I/O port address is similar to a memory address; however, I/O address space need not be part of the memory address space. I/O port and memory addresses coexist on the same bus lines and they are distinguished by the status outputs. Two types of I/O instructions are available: standard and special. Each has its own address space. The I/O instructions include a comprehensive set of In, Out, and Block I/O instructions for both bytes and words. Special I/O instructions are used for loading and unloading the Memory Management Unit. The status information distinguishes between standard and special I/O references. ## MULTI-MICROPROCESSOR SUPPORT Multi-microprocessor systems are supported in hardware and software. A pair of CPU pins is used in conjunction with certain instructions to coordinate multiple microprocessors. The Multi-Micro Out pin issues a request for the resource, while the Multi-Micro In pin is used to recognize the state of the resource. Thus, any CPU in a multiple microprocessor system can exclude all other asynchronous CPUs from a critical shared resource. Multi-microprocessor systems are supported in software by the instructions Multi-Micro Request, Test Multi-Micro In, Set Multi-Micro Out, and Reset Multi-Micro Out. In addition, the eight megabyte CPU address space is beneficial in multiple microprocessor systems that have large memory requirements. #### **ADDRESSING MODES** The information included in Z8000 instructions consists of the function to be performed, the type and size of data elements to be manipulated, and the location of the data elements. Locations are designated by register addresses, memory addresses, or I/O addresses. The addressing mode of a given instruction defines the address space it references and the method used to compute the address itself. Addressing modes are explicitly specified or implied by the instruction. Figure 9 illustrates the eight addressing modes: Register (R), Immediate (IM), Indirect Register (IR), Direct Address (DA), Index (X), Relative Address (RA), Base Address (BA), and Base Index (BX). In general, an addressing mode explicitly specifies either register address space or memory address space. Program memory address space and I/O address space are usually implied by the instruction. <sup>\*</sup>Do not use R0 or RR0 as indirect, index, or base registers. Figure 9. Addressing Modes ## INSTRUCTION SET SUMMARY The Z8000 provides the following types of instructions: - Load and Exchange - Arithmetic - Logical - Program Control - Bit Manipulation - Rotate and Shift - Block Transfer and String Manipulation - Input/Output - CPU Control ## **LOAD AND EXCHANGE** | | | | | | Clock C | | | | | |-----------|---------------|----------|----------|----------------|---------|-----------|--------------|---------|-------------------------------| | | | Addr. | Wo<br>NS | ord, Byt<br>SS | e<br>SL | NS<br>NS | ng Wor<br>SS | a<br>SL | Operation | | Inemonics | Operands | Modes | | | | | | | | | LR | dst | R | 7 | 7 | 7 | | | | Clear<br>dst ← 0 | | LRB | | IR | 8 | 8 | 8 | | | | dst + 0 | | | | DA | 11 | 12 | 14 | | | | | | | | Х | 12 | 12 | 15 | | | | | | X | R, src | <br>R | 6 | 6 | 6 | | | | Exchange | | =XB | , | IR | 12 | 12 | 12 | | | | R ↔ src | | | | DA | 15 | 16 | 18 | | | | | | | | Х | 16 | 16 | 19 | | | | | | | R, src | R | 3 | 3 | 3 | 5 | 5 | 5 | Load into Register | | LD | n, sic | IM | . 7 | 7 | 7 | 11 | 11 | 11 | R ← src | | LDB | | iM | | yte only | | | | | | | LDL | | IR | 7 | 7 | ,<br>7 | 11 | 11 | 11 | | | | | DA | 9 | 10 | 12 | 12 | 13 | 15 | | | | | X | 10 | 10 | 13 | 13 | 13 | 16 | | | | | BA | 14 | 14 | 14 | 17 | 17 | 17 | | | | | BX | 14 | 14 | 14 | 17 | 17 | 17 | | | | dst. R | IR | . 8 | 8 | 8 | 11 | 11 | 11 | Load into Memory (Store) | | LD | usi, n | DA | 11 | 12 | 14 | 14 | 15 | 17 | dst ← R | | LDB | | X | 12 | 12 | 15 | 15 | 15 | 18 | | | LDL | | BA | 14 | 14 | 14 | 17 | 17 | 17 | | | | | BX | 14 | 14 | 14 | 17 | 17 | 11 | | | | | | 11 | 11 | 11 | | | | Load Immediate into Memory | | LD | dst, IM | IR<br>DA | 14 | 15 | 17 | | | | dst ← IM | | LDB | | DA | | 15 | 18 | | | | | | | | X | 15 | - 10 | | | | | | | LDA | R, src | DA | 12 | 13 | 15 | | | | Load Address | | | | X | 13 | 13 | 16 | | | | R ← source address | | | | BA | 15 | 15 | 15 | | | | • | | | | BX | 15 | 15 | 15 | | | | | | LDAR | R, src | RA | 15 | 15 | 15 | | | | Load Address Relative | | LUAN | 11, 3.0 | | _ | | | | | | R ← source address | | 1.5% | R, src | IM | 5 | 5 | 5 | | | | Load Constant | | LDK | n, sic | 1141 | J | • | | | | | R ← n (n = 0 15) | | | R, src, n | IR | 11 | 11 | 11 | + 3n | | | Load Multiple | | LDM | n, sic, II | DA | 14 | 15 | | + 3n | | | R ← src (n consecutive words) | | | | X | 15 | 15 | | + 3n | | | (n = 1 16) | | | mented SS = S | | | | | nted Long | | | | 136 ## LOAD AND EXCHANGE (Continued) | • | | | | | | Cycles* | | | | |------------------------------------------------|-----------------------|-------------------------------------------|-------------------------------------------------------------------------|----------------------------------------------------------------------|---------------------------------------------------------------------------|---------------------------------------|---------------------------------------|---------------------------------------|------------------------------------------------------------------------------------------------------------------------------| | Mnemonics | Operands | Addr.<br>Modes | NS<br>NS | ord, By<br>SS | rte<br>SL | NS<br>NS | ong Wa<br>SS | rd<br>SL | Operation | | LDM | dst, R, n | . IR | 11 | 11 | 11 + | - 3n | | | Load Multiple (Store Multiple) | | | 301, 11, 11 | DA | 14 | 15 | 17 + | | | | dst ← R (n consecutive words) | | | | X | 15 | 15 | 18 + | | | | (n = 1 16) | | LDR | R, src | RA | 14 | 14 | 14 | 17 | 17 | 17 | Load Relative | | LDRB | 7., 0.0 | | | | | • • • | | ., | R ← src | | LDRL | | | | | | | | | (range - 32768 + 32767) | | LDR | dst, R | RA | 14 | 14 | 14 | 17 | 17 | 17 | Load Relative (Store Relative | | LDRB | | | | | | | | | dst ← R | | LDRL | | | | | | | | | (range - 32768 + 32767) | | POP | dst, IR | R | 8 | 8 | 8 | 12 | 12 | 12 | Pop | | POPL | - | IR | 12 | 12 | 12 | 19 | 19 | 19 | dst ← IR | | | | DA | 16 | 16 | 18 | 23 | 23 | 25 | Autoincrement contents of R | | | | X | 16 | 16 | 19 | 23 | 23 | 26 | | | PUSH | IR, src | R | 9 | 9 | 9 | 12 | 12 | 12 | Push | | PUSHL | | IM | 12 | 12 | 12 | 19 | 19 | 19 | Autodecrement contents of R | | | | IR | 13 | 13 | 13 | 20 | 20 | 20 | IR ← src | | | | DA | 14 | 14 | 16 | 21 | 21 | 23 | | | | | Х | 14 | 14 | 17 | 21 | 21 | 24 | | | | | | | | | | | | | | ARITHMETI<br>ADC<br>ADCB | R, src | R | 5 | 5 | 5 | | | | Add with Carry R ← R + src + carry | | ADC<br>ADCB | R, src | | | | | ο | • | | R ← R + src + carry | | ADC<br>ADCB<br>ADD | - | R | 4 | 4 | 4 | 8 | 8 | 8 | R ← R + src + carry Add | | ADC<br>ADCB<br>ADD<br>ADDB | R, src | R<br>IM | 4 7 | 4 7 | 4 7 | 14 | 14 | 14 | R ← R + src + carry | | ADC<br>ADCB<br>ADD<br>ADDB | R, src | R<br>IM<br>IR | 4<br>7<br>7 | 4<br>7<br>7 | 4<br>7<br>7 | 14<br>14 | 14<br>14 | 14<br>14 | R ← R + src + carry Add | | ADC<br>ADCB<br>ADD<br>ADDB | R, src | R<br>IM | 4 7 | 4 7 | 4 7 | 14 | 14 | 14 | R ← R + src + carry Add | | ADC<br>ADCB<br>ADD<br>ADDB<br>ADDL | R, src | R<br>IM<br>IR<br>DA<br>X | 4<br>7<br>7<br>9 | 4<br>7<br>7<br>10 | 4<br>7<br>7<br>12<br>13 | 14<br>14<br>15<br>16 | 14<br>14<br>16<br>16 | 14<br>14<br>18<br>19 | R ← R + src + carry Add R ← R + src | | ADC<br>ADCB<br>ADD<br>ADDB<br>ADDL | R, src | R<br>IM<br>IR<br>DA<br>X | 4<br>7<br>7<br>9<br>10 | 4<br>7<br>7<br>10<br>10 | 4<br>7<br>7<br>12<br>13 | 14<br>14<br>15<br>16 | 14<br>14<br>16<br>16 | 14<br>14<br>18<br>19 | Add<br>R ← R + src + carry Add Compare with Register | | ADC ADCB ADD ADDB ADDL CP CPB | R, src | R<br>IM<br>IR<br>DA<br>X | 4<br>7<br>7<br>9 | 4<br>7<br>7<br>10<br>10<br>4<br>7 | 4<br>7<br>7<br>12<br>13<br>4<br>7 | 14<br>14<br>15<br>16 | 14<br>14<br>16<br>16<br>8<br>14 | 14<br>14<br>18<br>19<br>8<br>14 | R ← R + src + carry Add R ← R + src | | ADC ADCB ADD ADDB ADDL CP CPB | R, src | R<br>IM<br>IR<br>DA<br>X | 4<br>7<br>7<br>9<br>10<br>4<br>7 | 4<br>7<br>7<br>10<br>10 | 4<br>7<br>7<br>12<br>13 | 14<br>14<br>15<br>16<br>8<br>14 | 14<br>14<br>16<br>16<br>8<br>14 | 14<br>14<br>18<br>19<br>8<br>14 | Add<br>R ← R + src + carry Add Compare with Register | | ADC<br>ADCB<br>ADD<br>ADDB<br>ADDL<br>CP<br>CP | R, src | R<br>IM<br>IR<br>DA<br>X<br>R<br>IM<br>IR | 4<br>7<br>7<br>9<br>10<br>4<br>7 | 4<br>7<br>7<br>10<br>10<br>4<br>7 | 4<br>7<br>7<br>12<br>13<br>4<br>7 | 14<br>14<br>15<br>16<br>8<br>14 | 14<br>14<br>16<br>16<br>8<br>14 | 14<br>14<br>18<br>19<br>8<br>14 | Add<br>R ← R + src + carry Add Compare with Register | | ADC ADCB ADD ADDB ADDL CP CPB CPL | R, src | R<br>IM<br>IR<br>DA<br>X<br>R<br>IM<br>IR | 4<br>7<br>7<br>9<br>10<br>4<br>7<br>7 | 4<br>7<br>7<br>10<br>10<br>4<br>7<br>7 | 4<br>7<br>7<br>12<br>13<br>4<br>7<br>7 | 14<br>14<br>15<br>16<br>8<br>14<br>14 | 14<br>14<br>16<br>16<br>8<br>14<br>14 | 14<br>14<br>18<br>19<br>8<br>14<br>14 | Add<br>R ← R + src + carry<br>Add<br>R ← R + src Compare with Register<br>R - src | | ADC ADCB ADD ADDB ADDL CP CPB CPL | R, src | R IM IR DA X R IM IR DA X | 4<br>7<br>7<br>9<br>10<br>4<br>7<br>7<br>9 | 4<br>7<br>7<br>10<br>10<br>4<br>7<br>7<br>10 | 4<br>7<br>7<br>12<br>13<br>4<br>7<br>7<br>12<br>13 | 14<br>14<br>15<br>16<br>8<br>14<br>14 | 14<br>14<br>16<br>16<br>8<br>14<br>14 | 14<br>14<br>18<br>19<br>8<br>14<br>14 | Add<br>R ← R + src + carry Add Compare with Register | | ADC ADCB ADD ADDB ADDL CP CPB CPL | R, src | R IM IR DA X R IM IR DA X IR | 4<br>7<br>7<br>9<br>10<br>4<br>7<br>7<br>9<br>10 | 4<br>7<br>7<br>10<br>10<br>4<br>7<br>7<br>10<br>10 | 4<br>7<br>7<br>12<br>13<br>4<br>7<br>7<br>12<br>13 | 14<br>14<br>15<br>16<br>8<br>14<br>14 | 14<br>14<br>16<br>16<br>8<br>14<br>14 | 14<br>14<br>18<br>19<br>8<br>14<br>14 | Add R + R + src + carry Add R + R + src Compare with Register R - src Compare with immediate | | ADC ADCB ADD ADDB ADDL CP CPB CPL | R, src | R IM IR DA X R IM IR DA X IR | 4<br>7<br>7<br>9<br>10<br>4<br>7<br>7<br>9<br>10 | 4<br>7<br>7<br>10<br>10<br>4<br>7<br>7<br>10<br>10 | 4<br>7<br>7<br>12<br>13<br>4<br>7<br>7<br>12<br>13 | 14<br>14<br>15<br>16<br>8<br>14<br>14 | 14<br>14<br>16<br>16<br>8<br>14<br>14 | 14<br>14<br>18<br>19<br>8<br>14<br>14 | Add R + R + src + carry Add R + R + src Compare with Register R - src Compare with immediate | | ADC | R, src R, src dst, IM | R IM IR DA X R IM IR DA X IR DA X | 4<br>7<br>7<br>9<br>10<br>4<br>7<br>7<br>9<br>10<br>11<br>14<br>15 | 4<br>7<br>7<br>10<br>10<br>4<br>7<br>7<br>10<br>10 | 4<br>7<br>7<br>12<br>13<br>4<br>7<br>7<br>12<br>13<br>11<br>17<br>18 | 14<br>14<br>15<br>16<br>8<br>14<br>14 | 14<br>14<br>16<br>16<br>8<br>14<br>14 | 14<br>14<br>18<br>19<br>8<br>14<br>14 | Add R + R + src + carry Add R + R + src Compare with Register R - src Compare with Immediate dst - IM | | ADC ADCB ADD ADDB ADDL CP CPB CPB CPB CPB DAB | R, src R, src dst, IM | R IM IR DA X R IM IR DA X IR DA X R | 4<br>7<br>7<br>9<br>10<br>4<br>7<br>7<br>9<br>10<br>11<br>14<br>15 | 4<br>7<br>7<br>10<br>10<br>4<br>7<br>7<br>10<br>10<br>11<br>15<br>15 | 4<br>7<br>7<br>12<br>13<br>4<br>7<br>7<br>12<br>13<br>11<br>17<br>18 | 14<br>14<br>15<br>16<br>8<br>14<br>14 | 14<br>14<br>16<br>16<br>8<br>14<br>14 | 14<br>14<br>18<br>19<br>8<br>14<br>14 | Add R+R+src+carry Add R+R+src Compare with Register R-src Compare with Immediate dst-IM Decimal Adjust | | ADC ADCB ADD ADDB ADDL CP CPB CPL CP CPB | R, src R, src dst, IM | R IM IR DA X R IM IR DA X IR DA X R R R | 4<br>7<br>7<br>9<br>10<br>4<br>7<br>7<br>9<br>10<br>11<br>14<br>15<br>5 | 4<br>7<br>7<br>10<br>10<br>4<br>7<br>7<br>10<br>10<br>11<br>15<br>15 | 4<br>7<br>7<br>12<br>13<br>4<br>7<br>7<br>12<br>13<br>11<br>17<br>18<br>5 | 14<br>14<br>15<br>16<br>8<br>14<br>14 | 14<br>14<br>16<br>16<br>8<br>14<br>14 | 14<br>14<br>18<br>19<br>8<br>14<br>14 | Add R+R+src+carry Add R+R+src Compare with Register R-src Compare with Immediate dst-IM Decimal Adjust Decremented by n | <sup>\*</sup>NS = Non-segmented SS = Segmented Short Offset SL = Segmented Long Offset ## ARITHMETIC (Continued) | | | | 307- | | Clock C | | ng Wor | d | | |-----------|----------|----------------|----------|----------------|----------|------|------------------|------|---------------------------------------------------------| | | 0 | Addr.<br>Modes | NS W | ord, Byl<br>SS | e<br>SL | NS | SS | SL | Operation | | Inemonics | Operands | | | | | | 744 | 744 | Divide (signed) | | IV | R, src | R | 107 | 107 | 107 | 744 | 744 | 744 | Word: $R_{n+1} \leftarrow R_{n,n+1} + \text{src}$ | | IVL | | IM | 107 | 107 | 107 | 744 | 744 | 744 | R <sub>n</sub> ← remainder | | | | IR | 107 | 107 | 107 | 744 | 744 | 744 | Long Word: R <sub>n+2,n+3</sub> R <sub>nn+3</sub> +sro | | | | DA | 108 | 109 | 111 | 745 | 746 | 748 | R <sub>n,n+2</sub> ← remainder | | | | X | 109 | 109 | 112 | 746 | 746 | 749 | N <sub>n,n+2</sub> Ternames | | XTS | dst | R | 11 | 11 | 11 | 11 | 11 | 11 | Extend Sign | | XTSB | | | | | | | | | Extend sign of low order half of dst | | XTSL | | | | | | | | | through high order half of dst | | | dst, n | | 4 | 4 | 4 | | | | Increment by n | | NC | ust, 11 | IR | 11 | 11 | 11 | | | | dst ← dst + n | | NCB | | DA | 13 | 14 | 16 | | | | (n = 1 16) | | | | X | 14 | 14 | 17 | | | | | | <u>-</u> | | | 70 | 70 | 70 | 282† | 282 <sup>†</sup> | 282† | Multiply (signed) | | MULT | R, src | R | 70<br>70 | 70 | 70 | 282† | 282† | 282† | Word: $R_{n,n+1} \leftarrow R_{n+1} \bullet \text{src}$ | | MULTL | | IM | | 70 | 70 | 282† | 282† | 282† | Long Word: R <sub>nn+3</sub> ← R <sub>n+2,n+3</sub> | | | | IR<br>DA | 70<br>71 | 72 | 74 | 283† | 284† | 286† | †Plus seven cycles for each 1 in the | | | | DA<br>X | 71<br>72 | 72<br>72 | 75 | 284† | 284 | 287† | multiplicand | | | | · | | | | | | | Negate | | NEG | dst | R | 7 | 7 | 7 | | | | dst ← 0 – dst | | NEGB | | IR | 12 | 12 | 12 | | | | ust o ust | | | | DA | 15 | 16 | 18 | | | | | | | | X | 16 | 16 | 19 | | | | | | SBC | R, src | R | 5 | 5 | 5 | | | | Subtract with Carry | | SBCB | | | | | | | | | R ← R - src - carry | | SUB | R, src | R | 4 | 4 | 4 | 8 | 8 | 8 | Subtract | | SUBB | | IM | 7 | 7 | 7 | 14 | 14 | 14 | R ← R - src | | SUBL | | IR | 7 | 7 | 7 | 14 | 14 | 14 | | | JUDE | | DA | 9 | 10 | 12 | 15 | 16 | 18 | • | | | | X | 10 | 10 | 13 | 16 | 16 | 19 | | | | | | | | | | | | | | LOGICAL | | | | | | | | | AND | | AND | R, src | R | 4 | 4 | 4 | | | | R ← R AND src | | ANDB | | IM | , 7 | 7 | 7 | | | | (1 11) 112 0.0 | | | | IR | 7 | 7 | 7 | | | | | | | | DA | 9 | 10 | 12<br>13 | | | | | | | | X | 10 | 10 | | | | | 0 | | COM | dst | R | 7 | 7 | 7 | | | | Complement dst ← NOT dst | | COMB | | tR | 12 | 12 | . 12 | | | | ust - NOT ust | | | | DA | 15 | 16 | 18 | | | | | | | | X | 16 | 16 | 19 | | | | | | OR | R, src | R | 4 | 4 | 4 | | | | OR | | ORB | | IM | 7 | 7 | 7 | | | | R ← R OR src | | | | IR | 7 | 7 | 7 | | | | | | | | DA | , 9 | 10 | | | | | | | | | X | 10 | 10 | 13 | | | | | | | | | | | = Segme | | | | | 138 | | , | Addr. | W | ord, By | Clock (<br>rte | • | ong Wo | rd | | |-------------|---------------------------------------|---------|----------|----------|----------------|----------|-----------|----------|--------------------------------------------------------| | Mnemonics | Operands | Modes | NS | SS | SL | NS | SS | SL | Operation | | TCC<br>TCCB | cc, dst | R | 5 | 5 | 5 | | | ···· | Test Condition Code Set LSB if cc is true | | | | | | | | | | | | | TEST | dst | R | 7 | 7 | 7 | 13 | 13 | 13 | Test | | TESTB | | IR<br>D | 8 | 8 | 8 | 13 | 13 | 13 | dst OR 0 | | TESTL | | DA<br>X | 11<br>12 | 12<br>12 | 14<br>15 | 16<br>17 | 17<br>17 | 19<br>20 | | | | | | | | | | | | | | XOR | R, src | R | 4 | 4 | 4 | | | | Exclusive OR | | XORB | | IM | 7 | 7 | 7 | | | | R ← R XOR src | | | | IR | 7 | 7 | 7 | | | | | | | | DA<br>X | 9<br>10 | 10<br>10 | 12<br>13 | | | | | | | | | | | | | | **** | | | PROGRAM | CONTROL | | | | | | | | | | CALL | dst | IR | 10 | 15 | . 15 | | | | Call Subroutine | | | | DA | 12 | 18 | 20 | | | | Autodecrement SP | | | | X | 13 | 18 | 21 | | | | @ SP ← PC | | | | | | | | | | | PC ← dst | | CALR | dst | RA | 10 | 10 | 15 | | | | Call Relative | | | | | | | | | | | Autodecrement SP | | | | | | | | | | | @ SP ← PC | | | | | | | | | | | PC←PC + dst (range - 4094 to + 40 | | DJNZ | R, dst | RA | 11 | 11 | 11 | | | | Decrement and Jump if Non-Zer | | DBJNZ | , | | | | | | | | R←R – 1 | | | | | | | | | | | If R ≠ 0: PC←PC + dst(range – 254 to | | IRET† | | | 13 | 13 | 16 | | | | Interrupt Return | | | | * | 10 | | .0 | | | | PS ← @ SP | | | | | | | | | | | Autoincrement SP | | JP | cc, dst | IR | 10 | 10 | 15 | | (taken) | | Jump Conditional | | | 00,000 | IR. | 7 | 7 | 7 | (r | not taken | ı) | If cc is true: PC ← dst | | | | DA | 7 | 8 | 10 | (, | or tancin | ' | 11 00 13 11 40. 1 0 431 | | | | X | 8 | 8 | 11 | | | | | | <br>JR | cc, dst | | 6 | 6 | 6 | | | | Jump Conditional Relative | | Jn | CC, USI | nA. | O | o | U | | | | • | | | | | | | | | | | If cc is true: PC ← PC + dst<br>(range - 256 to + 254) | | | · · · · · · · · · · · · · · · · · · · | | 40 | 40 | 40 | | (1-1) | | | | RET | cc | _ | 10 | 10 | 13 | , | (taken) | | Return Conditional | | | | | 7 | 7 | 7 | (r | ot taken | ) | If cc is true: PC ← @ SP<br>Autoincrement SP | | | | | 20 | - 00 | | | | | <del></del> | | SC | src | IM | 33 | 33 | 39 | | | | System Call | | | | | | | | | | | Autodecrement SP | | | | | | | | | | | @ SP ← old PS | | | | | | | | | | | Push instruction | | | | | | | | | | | PS ← System Call PS | <sup>139</sup> ## **BIT MANIPULATION** | | | A! | w. | ord, Byt | Clock C | Long Word | | |-----------|----------|----------------|----------|-----------|---------|------------|-----------------------------------------------------| | Inemonics | Operands | Addr.<br>Modes | NS | SS | SL | NS SS SL | Operation | | | <u> </u> | | 4 | 4 | 4 | | Test Bit Static | | IT | dst, b | R | 8 | 8 | 8 | | Z flag ← NOT dst bit specified by b | | ITB | | IR | | 11 | 13 | | | | | | DA<br>X | 10<br>11 | 11 | 14 | | | | | | | | 10 | 10 | | Test Bit Dynamic | | IIT | dst, R | R | 10 | 10 | 10 | | Z flag - NOT dst bit specified by | | ITB | | | | | | | contents of R | | | | | | | | | | | RES | dst, b | R | 4 | 4 | 4 | | Reset Bit Static Reset dst bit specified by b | | RESB | | IR | 11 | 11 | 11 | | Reset ast bit specified by b | | | | DA | 13 | 14 | 16 | | | | | | X | 14 | 14 | 17 | | | | RES | dst, R | R | 10 | 10 | 10 | | Reset Bit Dynamic | | RESB | , | | | | | | Reset dst bit specified by contents R | | | dst, b | R | 4 | 4 | 4 | | Set Bit Static | | SET | asi, D | IR | 11 | 11 | 11 | | Set dst bit specified by b | | SETB | | DA | 13 | 14 | 16 | | | | | | X | 14 | 14 | 17 | | | | | | | | | | | Set Bit Dynamic | | SET | dst, R | R | 10 | 10 | 10 | | Set dst bit specified by contents of F | | SETB , | | | | | | | | | TSET | dst | R | 7 | 7 | 7 | | Test and Set | | TSETB | | IR | 11 | 11 | 11 | | S flag ← MSB of dst | | | | DA | 14 | 15 | 17 | | dst ← all 1s | | | | × | 15 | 15 | 18 | | | | ROTATE A | ND SHIFT | | | | | • | | | | | | | 6 for n = | | | Rotate Left | | RL | dst, n | R | | 7 for n = | | | by n bits $(n = 1, 2)$ | | RLB | | | | | | | Rotate Left through Carry | | RLC | dst, n | R | | 6 for n = | | | by n bits $(n = 1, 2)$ | | RLCB | | R | | 7 for n = | =2<br> | | by (1 bits (1 = 1, 2) | | RLDB | R, src | R | 9 | 9 | 9 | | Rotate Digit Left | | RR | dst, n | R | | 6 for n = | = 1 | | Rotate Right | | RRB | 436,11 | R | | 7 for n= | =2 | | by n bits (n = 1, 2) | | | | | | 6 for n : | | | Rotate Right through Carry | | RRC | dst, n | R<br>R | | 7 for n | | | by n bits $(n = 1, 2)$ | | RRCB | | | | | | | Rotate Digit Right | | RRDB | R, src | R<br> | 9 | 9 | 9 | | | | SDA | dst, R | R | | (15 + 3) | 3 n) | (15 + 3 n) | Shift Dynamic Arithmetic Shift dst left or right by | | SDAB | | | | | | | | | SDAL | | | | | | | contents of R | | SDL | dst, R | R | | (15 + 3 | 3 n) | (15 + 3 n) | Shift Dynamic Logical | | SDLB | GOI, | | | | | | Shift dst left or right by | | JULU | | | | | | | contents of R | ## **ROTATE AND SHIFT** (Continued) | | | | | | Cycles* | | | | |---------------------|----------------------------------------|----------------|-------------------|----------|----------|----------|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------| | Mnemonics | Operands | Addr.<br>Modes | Word, By<br>NS SS | te<br>SL | Lo<br>NS | ng Word | I<br>SL | Operation | | SLA<br>SLAB<br>SLAL | dst, n | R | (13 + 3 r | | | 3 + 3 n) | | Shift Left Arithmetic by n bits | | SLL<br>SLLB<br>SLLL | dst, n | R | (13 + 3 r | 1) | (1 | 3 + 3 n) | | Shift Left Logical<br>by n bits | | SRA<br>SRAB<br>SRAL | dst, n | R | (13 + 3 r | 1) | (1 | 3 + 3 n) | | Shift Right Arithmetic<br>by n bits | | SRL<br>SRLB<br>SRLL | dst, n | R | (13 + 3 r | 1) | (1 | 3 + 3 n) | | Shift Right Logical<br>by n bits | | BLOCK TR | ANSFER AND | STRING | G MANIPUL | .ATIC | N | | | | | CPD<br>CPDB | R <sub>x</sub> ,src,R <sub>Y</sub> ,cc | IR | 20 20 | 20 | | | | Compare and Decrement R <sub>X</sub> − src Autodecrement src address R <sub>Y</sub> ← R <sub>Y</sub> − 1 | | CPDR<br>CPDRB | R <sub>X</sub> ,src,R <sub>Y</sub> ,cc | IR | (11 + 9 r | ) | | | | Compare, Decrement, and Repeat R <sub>X</sub> - src Autodecrement src address R <sub>Y</sub> ← R <sub>Y</sub> - 1 Repeat until cc is true or R <sub>Y</sub> = 0 | | CPI<br>CPIB | R <sub>X</sub> ,src,R <sub>Y</sub> ,cc | IR | 20 20 | 20 | | | | Compare and Increment $R_X - \text{src}$ Autoincrement src address $R_Y \leftarrow R_Y - 1$ | | CPIR<br>CPIRB | R <sub>X</sub> ,src,R <sub>Y</sub> ,cc | fR | (11 + 9 n | ) | | | | Compare, Increment, and Repeat $R_X$ – src Autoincrement src address $R_Y \leftarrow R_Y - 1$ Repeat until cc is true or $R_Y = 0$ | | CPSD<br>CPSDB | dst,src,R,cc | IR | 25 25 | 25 | | | | Compare String and Decrement dst – src Autodecrement dst and src addresses R ← R – 1 | | CPSDR<br>CPSDRB | dst,src,R,cc | IR | (11 + 14 r | n) | | | | Compare String, Decrement, and Repeat dst — src Autodecrement dst and src addresses R ← R — 1 Repeat until cc is true or R = 0 | <sup>\*</sup>NS = Non-segmented SS = Segmented Short Offset SL = Segmented Long Offse ## **BLOCK TRANSFER AND STRING MANIPULATION (Continued)** | | | | 107 | ord, Byt | clock ( | rd | | | | |---------------|--------------|----------------|-----|----------|---------|----|----|----|-------------------------------------------------------------------------------------------------------------------------------| | Anemonics | Operands | Addr.<br>Modes | NS | SS SIG | SL | NS | SS | SL | Operation | | CPSI<br>CPSIB | dst,src,R,cc | IR | 25 | 25 | 25 | | | | Compare String and Increment dst − src Autoincrement dst and src addresses R ← R − 1 | | CPSIRB | dst,src,R,cc | IR | (1 | 1 + 141 | <br>n) | | | | Compare String, Increment and Repeat dst - src Autoincrement dst and src addresses R ← R - 1 Repeat until cc is true or R = 0 | | LDD<br>LDDB | dst,src,R | İR | 20 | 20 | 20 | | | | Load and Decrement dst ← src Autodecrement dst and src addresses R ← R − 1 | | LDDR<br>LDDRB | dst,src,R | IR | ( | 11 + 9 | <br>n) | | | | Load, Decrement and Repeat dst ← src Autodecrement dst and src addresses R ← R − 1 Repeat until R = 0 | | LDI<br>LDIB | dst,src,R | IR | 20 | 20 | 20 | | | | Load and Increment dst ← src Autoincrement dst and src addresses R ← R − 1 | | LDIR<br>LDIRB | dst,src,R | IR | | (11 + 9 | n) | | | | Load, Increment and Repeat dst ← src Autoincrement dst and src addresses R ← R − 1 Repeat until R = 0 | | TRDB | dst,src,R | IR | 25 | 25 | 25 | | | | Translate and Decrement dst ← src (dst) Autodecrement dst address R ← R − 1 | | TRDRB | dst,src,R | iR | | (11 + 1 | ‡ n) | | | | Translate, Decrement and Repeat dst ← src (dst) Autodecrement dst address R ← R - 1 Repeat until R = 0 | | TRIB | dst,src,R | iR | 25 | 25 | 25 | | | | Translate and Increment dst ← src (dst) Autoincrement dst address R ← R − 1 | ## **BLOCK TRANSFER AND STRING MANIPULATION (Continued)** THE PROPERTY OF O | | | | 18/- | | | Cycles* | | 4 | | |-----------------|-------------|----------------|----------|---------------|----------|---------|--------------|----------|--------------------------------------------------------------------------------------------------------------------------------| | Mnemonics | Operands | Addr.<br>Modes | NS<br>NS | rd, Byl<br>SS | e<br>SL | NS | ong Wo<br>SS | ra<br>SL | Operation | | TRIRB | dst,src,R | IR | (11 | + 141 | 1) | | | | Translate, Increment and Repeat dst ← src (dst) Autoincrement dst address R ← R − 1 Repeat until R = 0 | | TRTDB | src1,src2,R | IR | 25 | 25 | 25 | | | | Translate and Test, Decrement RH1 ← src2 (src1) Autodecrement src 1 address R ← R − 1 | | TRTDRB | src1,src2,R | IR | (11 | + 141 | n) | | | | Translate and Test, Decrement, and Repeat RH1 ← src2 (src1) Autodecrement src1 address R ← R − 1 Repeat until R = 0 or RH1 = 0 | | TRTIB | src1,src2,R | IR | 25 | 25 | 25 | | | | Translate and Test, Increment RH1 ← src2 (src1) Autoincrement src1 address R ← R - 1 | | TRTIRB | src1,src2,R | IR | (11 | + 14 r | n) | | | | Translate and Test, Increment and Repeat RH1 ← src2 (src1) Autoincrement src 1 address R ← R − 1 Repeat until R = 0 or RH1 = 0 | | INPUT/OU | <b>TPUT</b> | | | | | | | | | | IN <sup>†</sup> | R,src | IR<br>DA | 10<br>12 | 10<br>12 | 10<br>12 | | | | Input<br>R ← src | | IND†<br>INDB† | dst,src,R | IR | 21 | 21 | 21 | | | | Input and Decrement dst ← src Autodecrement dst address R ← R - 1 | | INDR†<br>INDRB† | dst,src,R | IR | (11 | + 10 r | n) | | | | Input, Decrement and Repeat dst ← src Autodecrement dst address R ← R − 1 Repeat until R = 0 | | INI†<br>INIB† | dst,src,R | IR | 21 | 21 | 21 | | | | Input and Increment dst ← src Autoincrement dst address R ← R − 1 | <sup>†</sup>Privileged instruction. Executed in system mode only. ## **INPUT/OUTPUT** (Continued) | | | | | | Clock C | | | | | |-----------------------------------------|-----------|----------------|----------|---------------|----------|----|--------------|----------|------------------------------------------------------------------------------------------------------------| | Inemonics | Operands | Addr.<br>Modes | NS<br>NS | ord, By<br>SS | te<br>SL | NS | ong Wo<br>SS | ra<br>SL | Operation | | NIR†<br>NIRB† | dst,src,R | IR | | 1 + 10 | n) | | | | input, increment and Repeat dst ← src Autoincrement dst address R ← R − 1 Repeat until R = 0 | | OUT <sup>†</sup> | dst,R | IR<br>DA | 10<br>12 | 10<br>12 | 10<br>12 | | | | Output<br>dst ← R | | OUTD†<br>OUTDB† | dst,src,R | IR | 21 | 21 | 21 | | | | Output and Decrement dst ← src Autodecrement src address R ← R − 1 | | OTDR†<br>OTDRB† | dst,src,R | IR | (* | 11 + 10 | n) | | | | Output, Decrement and Repeat dst ← src Autodecrement src address R ← R − 1 Repeat until R = 0 | | OUTI†<br>OUTIB† | dst,src,R | IR | 21 | 21 | 21 | | | | Output and Increment dst ← src Autoincrement src address R ← R − 1 | | OTIR†<br>OTIRB† | dst,src,R | IR | ( | 11 + 10 | ) n) | | | | Output, Increment, and Repeat<br>dst ← src<br>Autoincrement src address<br>R ← R − 1<br>Repeat until R = 0 | | SIN <sup>†</sup> | R,src | . DA | 12 | 12 | 12 | - | | | Special Input<br>R ← src | | SIND†<br>SINDB† | dst,src,R | IR | 21 | 21 | 21 | | | | Special Input and Decrement<br>dst ← src<br>Autodecrement dst address<br>R ← R − 1 | | SINDR†<br>SINDRB† | dst,src,R | IR | | 11 + 10 | ) n) | | | | Special Input, Decrement, and Repeat dst ← src Autodecrement dst address R ← R - 1 Repeat until R = 0 | | SINI <sup>†</sup><br>SINIB <sup>†</sup> | dst,src,R | IR | 21 | 21 | 21 | | | | Special Input and Increment dst ← src Autoincrement dst address R ← R − 1 | <sup>\*</sup>NS = Non-segmented SS = Segmented Short Offset †Privileged instruction. Executed in system mode only. SL = Segmented Long Offse ## **INPUT/OUTPUT** (Continued) | • | | Addr. | 18/ | ord, By | | Cycles*<br>Long Word | | |-------------------------------------------|-----------|-------|-----|---------|----|----------------------|--------------------------------------------------------------------------------------------------------| | Mnemonics | Operands | Modes | NS | SS | SL | NS SS SL | Operation | | SINIR†<br>SINIRB† | dst,src,R | IR . | (1 | 1 + 10 | n) | | Special Input, Increment, and Repeat dst ← src Autoincrement dst address R ← R − 1 Repeat until R = 0 | | SOUT <sup>†</sup><br>SOUTB <sup>†</sup> | dst,src | DA | 12 | 12 | 12 | | Special Output<br>dst ← src | | SOUTD†<br>SOUTDB† | dst,src,R | IR | 21 | 21 | 21 | | Special Output and Decrement dst ← src Autodecrement src address R ← R − 1 | | SOTDR†<br>SOTDRB† | dst,src,R | IR | (1 | 1 + 10 | n) | | Special Output, Decrement, and Repeat dst ← src Autodecrement src address R ← R − 1 Repeat until R = 0 | | SOUTI <sup>†</sup><br>SOUTIB <sup>†</sup> | dst,src,R | IR | 21 | -21 | 21 | | Special Output and Increment dst ← src Autoincrement src address R ← R − 1 | | SOTIR† SOTIRB† | dst,src,R | ` R | (1 | 1 + 10 | n) | | Special Output, Increment, and Repeat dst ← src Autoincrement src address R ← R - 1 Repeat until R = 0 | | COMFLG | flags | _ | 7 | 7 | 7 | | Complement Flag<br>(Any combination of C, Z, S, P/V) | | DI <sup>†</sup> | int | | 7 | 7 | 7 | | Disable Interrupt (Any combination of NVI, VI) | | EI† | int | _ | 7 | 7 | 7 | | Enable Interrupt<br>(Any combination of NVI, VI) | | HALT <sup>†</sup> | _ | _ | ( | 8 + 3 n | ) | | HALT | | LDCTL† | CTLR,src | R | 7 | 7 | 7 | | Load into Control Register CTLR + src | | LDCTL† | dst,CTLR | R | 7 | 7 | 7 | | Load from Control Register<br>dst ← CTLR | <sup>†</sup>Privileged instruction. Executed in system mode only. ## **CPU CONTROL** (Continued) | | | | | | Clock ( | Cycles* | • | | | |-----------|----------|---------------|----------------|----------------|----------------|---------|--------|----|----------------------------------------------------------------| | | | Addr. | W | ord, By | te | L | ong Wo | rd | | | Mnemonics | Operands | Modes | NS | SS | SL | NS | SS | SL | Operation | | LDCŤLB | FLGR,src | R | 7 | 7 | 7 | | | | Load into Flag Byte Register<br>FLGR ← src | | LDCTLB | dst,FLGR | R | 7 | 7 | 7 | | | | Load from Flag Byte Register<br>dst ← FLGR | | LDPS† | src | IR<br>DA<br>X | 12<br>16<br>17 | 16<br>20<br>20 | 16<br>22<br>23 | | | | Load Program Status PS ← src | | MBIT† | <u> </u> | | 7 | 7 | 7 | | | | Test Multi-Micro Bit Set S if MI is Low; reset S if MI is High | | MREQ† | dst | R | | (12 + 1 | ר) | | | | Multi-Micro Request | | MRES† | _ | _ | 5 | 5 | 5 | | | | Multi-Micro Reset | | MSET† | | · | 5 | 7 | 7 | | • | | Multi-Micro Set | | NOP | _ | <del>-</del> | 7 | 7 | 7 | | | | No Operation | | RESFLG | flag | | . , 7 | 7 | 7 | | | | Reset Flag (Any combination of C, Z, S, P/V) | | SETFLG | flag | | 7 | 7 | . 7 | | | | Set Flag (Any combination of C, Z, S, P/V) | <sup>&</sup>quot;NS = Non-segmented SS = Segmented Short Offset SL = Segmented Long Offset Thrivileged instruction. Executed in system mode only. ## **CONDITION CODES** | Code | Meaning | Flag Settings | CC Field | |------|--------------------------------|----------------------------------------|----------| | F | Always false | _ | 0000 | | Т | Always true | _ | 1000 | | Z | Zero | Z = 1 | 0110 | | NZ | Not zero | Z = 0 | 1110 | | С | Carry | C = 1 | 0111 | | NC | No Carry | C = 0 | 1111 | | PL | Plus | S = 0 | 1101 | | MI | Minus | S = 1 | 0101 | | NE | Not equal | Z = 0 | 1110 | | EQ | Equal | Z = 1 | 0110 | | OV | Overflow | P/V = 1 | 0100 | | NOV | No overflow | P/V = 0 | 1100 | | PE | Parity is even | P/V = 1 | 0100 | | PO | Parity is odd | P/V = 0 | 1100 | | GE | Greater than or equal (signed) | (S XOR P/V) = 0 | 1001 | | LT | Less than (signed) | (S XOR P/V) = 1 | 0001 | | GT | Greater than (signed) | [Z QR (S XOR P/V)] = 0 | 1010 | | LE | Less than or equal (signed) | [Z OR (S XOR P/V)] = 1 | 0010 | | UGE | Unsigned greater than or equal | C = 0 | 1111 | | ULT | Unsigned less than | C = 1 | 0111 | | UGT | Unsigned greater than | $\{(C = 0) \text{ AND } (Z = 0)\} = 1$ | 1011 | | ULE | Unsigned less than or equal | (C OR Z) = 1 | 0011 | Note that some condition codes have identical flag settings and binary fields in the instruction: $Z=EQ,\,NZ=NE,\,C=ULT,\,NC=UGE,\,OV=PE,\,NOV=PO$ ## **STATUS CODE LINES** | ST <sub>0</sub> -ST <sub>3</sub> | Definition | |----------------------------------|-----------------------------------------| | 0000 | Internal operation | | 0001 | Memory refresh | | 0010 | I/O reference | | 0011 | Special I/O reference (e.g., to an MMU) | | 0100 | Segment trap acknowledge | | 0101 | Non-maskable interrupt acknowledge | | 0110 | Non-vectored interrupt acknowledge | | 0111 | Vectored interrupt acknowledge | | 1000 | Data memory request | | 1001 | Stack memory request | | 1010 | Data memory request (EPU) | | 1011 | Stack memory request (EPU) | | 1100 | Program reference, nth word | | 1101 | Instruction fetch, first word | | 1110 | Extension processor transfer | | 1111 | Reserved | #### PIN DESCRIPTION **AD<sub>0</sub>-AD<sub>15</sub>.** Address/Data (inputs/outputs, active High, 3-state). These multiplexed address and data lines are used for I/O and to address memory. AS. Address Strobe (output, active Low, 3-state). The rising edge of AS indicates addresses are valid. **BUSACK.** Bus Acknowledge (output active Low). A Low on this line indicates the CPU has relinquished control of the bus **BUSREQ.** Bus Request (input, active Low). This line must be driven Low to request the bus from the CPU. **B/W**. Byte/Word (output, Low = Word, 3-state). This signal defines the type of memory reference on the 16-bit address/data bus. **CLK.** System Clock (input). CLK is a 5V single-phase time-base input. **DS.** Data Strobe (output, active Low, 3-state). This line times the data in and out of the CPU. **MREQ.** Memory Request (output, active Low, 3-state). A Low on this line indicates that the address/data bus holds a memory address. **MI, MO.** Multi-Micro In, Multi-Micro Out (input and output, active Low). These two lines form a resource-request daisy chain that allows one CPU in a multi-microprocessor system to access a shared resource. NMI. Non-Maskable Interrupt (edge triggered, input, active Low). A high-to-low transition on NMI requests a non-maskable interrupt. The $\overline{\text{NMI}}$ interrupt has the highest priority of the three types of interrupts. **N/\overline{S}.** Normal/System Mode (output, Low = System Mode, 3-state). N/ $\overline{S}$ indicates the CPU is in the normal or system mode **NVI.** Non-Vectored Interrupt (input, active Low). A Low on this line requests a non-vectored interrupt. **RESET.** Reset (input, active Low). A Low on this line resets the CPU. $R/\overline{W}$ . Read/Write (output, Low = Write, 3-state). $R/\overline{W}$ indicates that the CPU is reading from or writing to memory or I/O. **SEGT.** Segment Trap (input, active Low). The Memory Management Unit interrupts the CPU with a Low on this line when the MMU detects a segmentation trap. Input on Z8001 only. **SN<sub>0</sub>-SN<sub>6</sub>.** Segment Number (outputs, active High, 3-state). These lines provide the 7-bit segment number used to address one of 128 segments by the Z8010 memory Management Unit. Output by the Z8001 only. ST<sub>0</sub>-ST<sub>3</sub>. Status (outputs, active High, 3-state). These lines specify the CPU status (see Status Code Lines). **STOP.** Stop (input, active Low). This input can be used to single-step instruction execution. VI. Vectored Interrupt (input, active Low). A Low on this line requests a vectored interrupt. **WAIT.** Wait (input, active Low). This line indicates to the CPU that the memory or I/O device is not ready for data transfer. Figure 10a. 48-pin Dual-In-Line Package (DIP), Pin Assignments Figure 11a. 40-pin Dual-In-Line Package (DIP), Pin Assignments 52-pin Chip Carrier, Pin Assignments Figure 11b. 44-pin Chip Carrier, Pin Assignments #### **Z8000 CPU TIMING** The Z8000 CPU executes instructions by stepping through sequences of basic machine cycles, such as memory read or write, I/O device read or write, interrupt acknowledge, and internal execution. Each of these basic cycles requires three to ten clock cycles to execute. Instructions that require more clock cycles to execute are broken up into several machine cycles. Thus no machine cycle is longer than ten clock cycles and fast response to a Bus Request is guaranteed. The instruction opcode is fetched by a normal memory read operation. A memory refresh cycle can be inserted just after the completion of any first instruction fetch (IF<sub>1</sub>) cycle and can also be inserted while the following instructions are being executed: MULT, MULTL, DIV, DIVL, HALT, all Shift instructions, all Block Move instructions, and the Multi-Micro Request instruction (MREQ). The following timing diagrams show the relative timing relationships of all CPU signals during each of the basic operations. When a machine cycle requires additional clock cycles for CPU internal operation, one to five clock cycles are added. Memory and I/O read and write, as well as interrupt acknowledge cycles, can be extended by activating the WAIT input. For exact timing information, refer to the composite timing diagram. Note that the WAIT input is not synchronized in the Z8000 and that the setup and hold times for WAIT, relative to the clock, must be met. If asynchronous WAIT signals are generated, they must be synchronized with the CPU clock before entering the Z8000. #### **MEMORY READ AND WRITE** Memory read and instruction fetch cycles are identical, except for the status information on the $ST_0$ - $ST_3$ outputs. During a memory read cycle, a 16-bit address is placed on the $AD_0$ - $AD_{15}$ outputs early in the first clock period, as shown in Figure 12. In the Z8001, the 7-bit segment number is output on $SN_0$ - $SN_0$ one clock period earlier than the 16-bit address offset. A valid address is indicated by the rising edge of Address Strobe. Status and mode information become valid early in the memory access cycle and remain stable throughout. The state of the WAIT input is sampled in the middle of the second clock cycle by the falling edge of Clock. If WAIT is Low, an additional clock period is added between $T_2$ and $T_3$ . $\overline{WAIT}$ is sampled again in the middle of this wait cycle, and additional wait states can be inserted: this allows interfacing slow memories. No control outputs change during wait states. Although Z8000 memory is word organized, memory is addressed as bytes. All instructions are word-aligned, using even addresses. Within a 16-bit word, the most significant byte ( $D_8$ - $D_{15}$ ) is addressed by the low-order address ( $A_0$ = Low), and the least significant byte ( $D_0$ - $D_7$ ) is addressed by the high-order address ( $A_0$ = High). Figure 12. Memory Read and Write Timing ## INPUT/OUTPUT 1/O timing is similar to memory read/write timing, except that one wait state is automatically ( $T_{WA}$ ) inserted between $\rm T_2$ and $\rm T_3$ (Figure 13). Both the segmented Z8001/Z8005 and the nonsegmented Z8002 use 16-bit I/O addresses. Figure 13. Input/Output Timing ## INTERRUPT AND SEGMENT TRAP REQUEST AND ACKNOWLEDGE The Z8000 CPU recognizes three interrupt inputs (non-maskable, vectored, and nonvectored) and a segmentation trap input. Any High-to-Low transition on the $\overline{\text{NMI}}$ input is asynchronously edge detected and sets the internal $\overline{\text{NMI}}$ latch. The $\overline{\text{VI}}$ , $\overline{\text{NVI}}$ , and $\overline{\text{SEGT}}$ inputs, as well as the state of the internal NMI latch, are sampled at the end of $T_2$ in the last machine cycle of any instruction. In response to an interrupt or trap, the subsequent IF $_1$ cycle is exercised, but ignored. The internal state of the CPU is not altered and the instruction will be refetched and executed after the return from the interrupt routine. The program counter is not updated, but the system stack pointer is decremented in preparation for pushing starting information onto the system stack. The next machine cycle is the interrupt acknowledge cycle. This cycle has five automatic wait states, with additional wait states possible, as shown in Figure 14. After the last wait state, the CPU reads the information on AD<sub>0</sub>-AD<sub>15</sub> and temporarily stores it, to be saved on the stack later in the acknowledge sequence. This word identifies the source of the interrupt or trap. For the nonvectored and nonmaskable interrupts, all 16 bits can represent peripheral device status information. For the vectored interrupt, the low byte is the jump vector, and the high byte can be extra user status. For the segmentation trap, the *high* byte is the Memory Management Unit identifier and the *low* byte is undefined. After the acknowledge cycle, the N/S output indicates the automatic change to system mode. Figure 14. Interrupt and Segment Trap Request/Acknowledge Timing #### STATUS SAVING SEQUENCE The machine cycles, following the interrupt acknowledge or segmentation trap acknowledge cycle, push the old status information on the system stack in the following order: the 16-bit program counter; the 7-bit segment number (Z8001/Z8005 only); the flag control word; and finally the interrupt/trap identifier. Subsequent machine cycles fetch the new program status from the program status area, and then branch to the interrupt/trap service routine. 152 ## **BUS REQUEST ACKNOWLEDGE TIMING** A Low on the BUSREQ input indicates to the CPU that another device is requesting the Address/Data and control buses. The asynchronous BUSREQ input is synchronized at the beginning of any machine cycle (Figure 15). BUSREQ takes priority over WAIT. If BUSREQ is Low, an internal synchronous BUSREQ signal is generated, which—after completion of the current machine cycle—causes the BUSACK output to go Low and all bus outputs to go into the high-impedance state. The requesting device—typically a DMA—can then control the bus. When BUSREQ is released, it is synchronized with the rising clock edge; the BUSACK output goes High one clock period later, indicating that the CPU will again take control of the bus. Figure 15. Bus Request/Acknowledge Timing #### **STOP** The STOP input is sampled by the last falling clock edge immediately preceding any IF<sub>1</sub> cycle (Figure 16) and before the second word of an EPA instruction is fetched. If STOP is found Low during the IF<sub>1</sub> cycle, a stream of memory refresh cycles is inserted after T<sub>3</sub>, again sampling the STOP input on each falling clock edge in the middle of the T<sub>3</sub> states. During the EPA instruction, both EPA instruction words are fetched but any data transfer or subsequent instruction fetch is postponed until STOP is sampled High. This refresh operation does not use the refresh prescaler or its divide-by-four clock prescaler; rather, it double-increments the refresh counter every three clock cycles. When STOP is found High again, the next refresh cycle is completed, any remaining T states of the IF<sub>1</sub> cycle are then executed, and the CPU continues its operation. Figure 16. Stop Timing ## INTERNAL OPERATION Certain extended instructions, such as Multiply and Divide, and some special instructions need additional time for the execution of internal operations. In these cases, the CPU goes through a sequence of internal operation machine cycles, each of which is three to eight clock cycles long (Figure 17). This allows fast response to Bus Request and Refresh Request, because bus request or refresh cycles can be inserted at the end of any internal machine cycle. Figure 17. Internal Operation Timing #### HALT A HALT instruction executes an unlimited number of 3-cycle internal operations, interspersed with memory refresh cycles whenever requested. An interrupt, segmentation trap, or reset are the only exits from a HALT instruction. The CPU samples the $\overline{VI}$ , $\overline{NVI}$ , $\overline{NMI}$ , and $\overline{SEGT}$ inputs at the beginning of every $T_3$ cycle. If an input is found active during two consecutive samples, the subsequent IF $_1$ cycle is exercised, but ignored, and the normal interrupt acknowledge cycle is started. #### MEMORY REFRESH When the 6-bit prescaler in the refresh counter has been decremented to zero, a refresh cycle consisting of three T-states is started as soon as possible (that is, after the next IF<sub>1</sub> cycle or Internal Operation cycle). The 9-bit refresh counter value is put on the low-order side of the address bus (AD<sub>0</sub>-AD<sub>8</sub>); AD<sub>9</sub>-AD<sub>15</sub> are undefined (Figure 18). Since the memory is word-organized, A<sub>0</sub> is always Low during refresh and the refresh counter is always incremented by two, thus stepping through 256 consecutive refresh addresses on $AD_1$ - $AD_8$ . Unless disabled, the presettable prescaler runs continuously and the delay in starting a refresh cycle is therefore not cumulative. While the STOP input is Low, a continuous stream of memory refresh cycles, each three T-states long, is executed without using the refresh prescaler. Figure 18. Memory Refresh Timing ## RESET A Low on the $\overline{RESET}$ input causes the following results within five clock cycles (Figure 19): - AD<sub>0</sub>-AD<sub>15</sub> are 3-stated - AS, DS, MREQ, ST<sub>0</sub>-ST<sub>3</sub>, BUSACK, and MO are forced High - SN<sub>0</sub>-SN<sub>6</sub> are forced Low - Refresh is disabled - R/W. B/W. and N/S are not affected When RESET has been High for three clock periods, three consecutive memory read cycles are executed in the system mode for the Z8001. The Z8002 has two consecutive read cycles. In the Z8001, the first cycle reads the flag and control word from location 0002, the next reads the 7-bit program counter segment number from location 0004, the next reads the 16-bit PC offset from location 0006, and the following IF1 cycle starts the program. In the Z8002, the first cycle reads the flag and control word from location 0002, the next reads the PC from location 0004, and the following IF1 cycle starts the program. 156 ## **COMPOSITE AC TIMING DIAGRAM** The state of s ## **AC CHARACTERISTICS†** | | | | Z8001/2<br>4 MHz | | Z8001/2<br>6 MHz | | Z8001/2<br>10 MHz | | |--------|-----------|----------------------------------------------|------------------|------|------------------|------|-------------------|------| | Number | Symbol | Parameter | Min | Max | Min | Max | Min | Max | | 1 | TcC | Clock Cycle Time | 250 | 2000 | 165 | 2000 | 100 | 2000 | | 2 | TwCh | Clock Width (High) | 105 | 1895 | 70 | 1930 | 40 | 1960 | | 3 | TwCl | Clock Width (Low) | 105 | 1895 | 70 | 1930 | 40 | 1960 | | 4 | TfC | Clock Fall Time | | 20 | | 10 | | 10 | | 5 | TrC | Clock Rise Time | | 20 | | 15 | | 10 | | 6 | TdC(SNv) | Clock † to Segment Number Valid (50 pf load) | | 130 | | 110 | | 90 | | 7 | TdC(SNn) | Clock † to Segment Number Not Valid | 20 | | 10 | | 0 | | | 8 | TdC(Bz) | Clock † to Bus Float | | 65 | | 55 | | 50 | | 9 | TdC(A) | Clock † to Address Valid | | 100 | | 75 | | 55 | | 10 | TdC(Az) | Clock † to Address Float | | 65 | | 55 | | 50 | | 11 | TdA(DR) | Address Valid to Read Data Required Valid | | 475* | | 305* | | 180 | | 12 | TsDR(C) | Read Data to Clock ↓ Setup time | 30 | | 20 | | 10 | | | 13 | TdDS(A) | DS ↑ to Address Active | 80* | | 45* | | 20* | | | 14 | TdC(DW) | Clock † to Write Data Valid | | 100 | | 75 | | 60 | | 15 | ThDR(DS) | Read Data to DS↑ Hold Time | 0 | | 0 | | 0 | | | 16 | TdDW(DS) | Write Data Valid to DS ↑ Delay | 295* | | 195* | | 110* | | | 17 | TdA(MR) | Address Valid to MREQ ↓ Delay | 55* | | 35* | | 20* | | | 18 | TdC(MR) | Clock ↓ to MREQ ↓ Delay | | 80 | | 70 | | 50 | | 19 | TwMRh | MREQ Width (High) | 210* | | 135* | | 80* | | | 20 | TdMR(A) | MREQ ↓ to Address Not Active | 70* | | 35* | | 20* | | | 21 | TdDW(DSW) | Write Data Valid to DS ↓ (Write) Delay | 55* | | 35* | | 15* | | | 22 | TdMR(DR) | MREQ ↓ to Read Data Required Valid | | 370* | | 230* | | 140 | | 23 | TdC(MR) | Clock ↓ MREQ ↑ Delay | | 80 | | 60 | | 50 | | 24 | TdC(ASf) | Clock † to ĀS ↓ Delay | | 80 | | 60 | | 45 | | 25 | TdA(AS) | Address Valid to AS † Delay | 55* | | 35* | | 20* | | | 26 | TdC(ASr) | Clock ↓ to AS ↑ Delay | | 90 | | 80 | | 45 | | 27 | TdAS(DR) | AS ↑ to Read Data Required Valid | | 360* | | 220* | | 1401 | | 28 | TdDS(AS) | DS ↑ to AS ↓ Delay | 70* | | 35* | | 15* | | | 29 | TwAS | AS Width (Low) | 85* | | 55* | | 30* | | | 30 | TdAS(A) | ĀS † to Address Not Active Delay | 70 <b>*</b> | | 45* | | 20* | | | 31 | TdAz(DSR) | Address Float to DS (Read) ↓ Delay | 0 | | 0 | | | | | 32 | TdAS(DSR) | AS ↑ to DS (Read) ↓ Delay | 80* | | 55* | | 30* | | | 33 | TdDSR(DR) | DS (Read) ↓ to Read Data Required Valid | | 205* | | 130* | - | 70* | | 34 | TdC(DSr) | Clock ↓ to DS † Delay | | 70 | | 65 | | 50 | | 35 | TdDS(DW) | DS ↑ to Write Data Not Valid | 75* | | 45* | | 25* | 00 | | 36 | TdA(DSR) | Address Valid to DS (Read) ↓ Delay | 180* | | 110* | | 65* | | | 37 | TdC(DSR) | Clock ↑ to DS (Read) ↓ Delay | | 120 | | 85 | | 65 | | 38 | Twdsr | DS (Read) Width (Low) | 275* | | 185* | | 110* | 55 | | 39 | TdC(DSW) | Clock ↓ to DS (Write) ↓ Delay | • | 95 | . 50 | 80 | | 65 | | 40 | TwDSW | DS (Write) Width (Low) | 185* | | 110* | | 75* | 03 | $<sup>^{\</sup>circ}\text{Clock-cycle}$ time-dependent characteristics. See Footnotes to AC Characteristics. †Units in nanoseconds (ns). ## AC CHARACTERISTICS† (Continued) | | | | Z8001/2<br>4 MHz | | Z8001/2<br>6 MHz | | Z8001/2<br>10 MHz | | |--------|-----------|------------------------------------------|------------------|------|------------------|------|-------------------|------| | Number | Symbol | Parameter | Min | Max | Min | Max | Min | Max | | 41 | TdDSI(DR) | DS (I/O) ↓ to Read Data Required Valid | | 330* | | 210* | | 120* | | 42 | TdC(DSf) | Clock ↓ to DS (I/O) ↓ Delay | | 120 | | 90 | | 65 | | 43 | TwDS | DS (I/O) Width (Low) | 410* | | 255* | | 160* | | | 44 | TdAS(DSA) | AS ↑ to DS (Acknowledge) ↓ Delay | 1065* | | 690* | | 410* | | | 45 | TdC(DSA) | Clock † to DS (Acknowledge) ↓ Delay | | 120 | | 85 | | 70 | | 46 | TdDSA(DR) | DS (Acknowledge) ↓ to Read Data Required | | | | | | 4051 | | | | Delay | • | 455* | | 295* | | 165* | | 47 | TdC(S) | Clock ↑ to Status Valid Delay | | 110 | | 85 | , | 65 | | 48 | TdS(AS) | Status Valid to AS † Delay | 50* | | 30* | | 20* | | | 49 | TsR(C) | RESET to Clock † Setup Time | 180 | | - 70 | | 50 | | | 50 | ThR(C) | RESET to Clock † Hold Time | 0 | | 0 | | 0 | | | 51 | TwNMI | NMI Width (Low) | 100 | | 70 | | 50 | | | 52 | TsNMI(C) | NMI to Clock † Setup Time | 140 | | 70 | | 50 | | | 53 | TsVi(C) | VI, NVI to Clock ↑ Setup Time | 110 | | 50 | | 40 | | | 54 | ThVI(C) | VI, NVI to Clock † Hold Time | 20 | | 20 | | 10 | | | 55 | TsSGT(C) | SEGT to Clock † Setup Time | 70 | | 55 | | 40 | | | 56 | ThSGT(C) | SEGT to Clock † Hold Time | 0 | | 0 | | 0 | | | 57 | TsMI(C) | MI to Clock † Setup Time | 180 | | 140 | | 80 | | | 58 | ThMI(C) | MI to Clock † Hold Time | 0 | | 0 | | 0 | | | 59 | TdC(MO) | Clock ↑ to MO Delay | | 120 | | 85 | | 80 | | 60 | TsSTP(C) | STOP to Clock ↓ Setup Time | 140 | | 100 | | <b>,</b> 50 | | | 61 | ThSTP(C) | STOP to Clock ↓ Hold Time | 0 | | 0 | | 0 | | | 62 | TsW(C) | WAIT to Clock ↓ Setup Time | 50 | | 30 | | 20 | | | 63 | ThW(C) | WAIT to Clock ↓ Hold Time | 10 | | . 10 | | 5 | | | 64 | TsBRQ(C) | BUSREQ to Clock † Setup Time | 90 | | 80 | | 60 | | | 65 | ThBRQ(C) | BUSREQ to Clock † Hold Time | 10 | | 10 | , , | 5 | | | 66 | TdC(BAKr) | Clock ↑ to BUSACK ↑ Delay | , | 100 | | 75 | | 65 | | 67 | TdC(BAKf) | Clock † to BUSACK ↓ Delay | | 100 | | 75 | | 65 | | 68 | TwA | Address Valid Width | 150* | | 95* | | 50* | | | 69 | TdDS(S) | DS † to STATUS Not Valid | 80* | | 55* | | 30* | | <sup>\*</sup>Clock-cycle time-dependent characteristics. See Footnotes to AC Characteristics. <sup>†</sup>Units in nanoseconds (ns). # IMAGE UNAVAILABLE ## **ABSOLUTE MAXIMUM RATINGS** | Voltages on all pins with respect | | |-----------------------------------|---------------------------| | to GND | $-0.3V$ to $+7.0V$ | | Operating Ambient | | | Temperature | .See Ordering Information | | Storage Temperature | 65°C to +150°C | Stresses greater than those listed under Absolute Maximum Ratings may cause permanent damage to the device. This is a stress rating only; operation of the device at any condition above those indicated in the operational sections of these specifications is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability. #### STANDARD TEST CONDITIONS The DC characteristics below apply for the following test conditions, unless otherwise noted. All voltages are referenced to GND (0V). Positive current flows into the referenced pin. Available operating temperature ranges are: - S = 0°C to +70°C, +4.75V $\leq$ V<sub>CC</sub> $\leq$ +5.25V - $E = -40^{\circ}C$ to $+100^{\circ}C$ , $+4.75V \le Vcc \le +5.25V$ The Ordering Information section lists package temperature ranges and product numbers. ## **DC CHARACTERISTICS** | Symbol | Parameter | Min | Max | Unit | Condition | |-----------------------|--------------------------------------|-----------------------|-----------------------|------|------------------------------------| | V <sub>CH</sub> | Clock Input High Voltage | V <sub>CC</sub> - 0.4 | V <sub>CC</sub> + 0.3 | V | Driven by External Clock Generator | | V <sub>CL</sub> | Clock Input Low Voltage | -0.3 | 0.45 | ٧ | Driven by External Clock Generator | | VIH | Input High Voltage | 2.0 | V <sub>CC</sub> + 0.3 | ٧ | | | V <sub>IH</sub> RESET | Input High Voltage on RESET pin | 2.4 | V <sub>CC</sub> + 0.3 | ٧ | | | VIH NMI | Input High Voltage on NMI pin | 2.4 | V <sub>CC</sub> + 0.3 | ٧ | | | VIL | Input Low Voltage | -0.3 | 0.8 | V | | | VOH | Output High Voltage | 2.4 | | V | $I_{OH} = -250 \mu\text{A}$ | | VOL | Output Low Voltage | | 0.4 | · V | $I_{OL} = +2.0 \text{mA}$ | | I <sub>IL</sub> | Input Leakage | | ± 10 | μΑ | 0.4≤V <sub>IN</sub> ≤ + 2.4V | | IL SEGT | Input Leakage on SEGT pin | ~ 100 | 100 | μΑ | | | IOL | Output Leakage | | ± 10 | μΑ | 0.4≤V <sub>IN</sub> ≤ +2.4V | | Icc | V <sub>CC</sub> Power Supply Current | | 300 | mΑ | 4 MHz and 6 MHz commercial | | 100 | CC Conditional Condition | | 400 | mA | Extended temperature range | | | | | 400 | mA | 10 MHz speed range |