1982/83 **Data Book** Zilog Pioneering the Microworld # 1 9 8 2 / 8 3 Data Book Zilog Pioneering the Microworld Copyright 1981, 1982 by Zılog, Inc. All rights reserved. No part of this publication may be reproduced, stored in a retrieval system, or transmitted, in any form or by any means, electronic, mechanical, photocopying, recording, or otherwise, without the prior written permission of Zilog. The information contained herein is subject to change The information contained herein is subject to change without notice. Zilog assumes no responsibility for the use of any circuitry other than circuitry embodied in a Zilog product. No other circuit patent licenses are implied # **Microcomputers in Every Form** Zilog offers microcomputers in every form: from components and development systems to board-level products and complete general-purpose microcomputer systems. This edition of the Zilog Data Book describes Zilog components, development systems, and microcomputer boards. You'll also find a section on the in-depth training courses now offered about most Zilog products. Zilog components, the basic building blocks for our other microcomputer products, include the 8-bit Z80® Microprocessor and its family of intelligent peripherals, the Z8™ Family of Single-Chip Microcomputers, and the 16-bit Z8000™ Microprocessor and its family of intelligent peripherals. Zilog offers a wide variety of development environments, ranging from the inexpensive Z8 and Z8000 Development Modules to the more elaborate PDS 8000 and ZDS-1 Development Systems to the ultra-sophisticated multi-user Z-LAB 8000 Development System. In addition, EMS 8000 and Z-SCAN 8000 both provide in-circuit emulation for the Z8001 and Z8002 Microprocessors. Our Z80 MCB Board Family offers a complete solution for prototype and production designs in which you don't want to design a microcomputer from scratch. This well-established family includes a Z80 CPU board, several types of memory boards, and boards for all types of digital and analog I/O. A complete set of card cages, enclosures, and other accessories makes this family easy to use. # **Table of Contents** | <b>Z80 Family</b> | | |----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------| | Z8300 CPU Central Processing Unit Z8410 DMA Direct Memory Access Z8420 PIO Parallel Input/Output | 27<br>49 | | Z8430 CTC Counter/Timer Circuit | 81<br>93 | | Z8470 DART Dual Asynchronous Receiver/Transmitter | | | <b>Z8000 Family</b> Z8001/2 CPU Central Processing Unit Z8003/4 VMPU Virtual Memory Processing Unit | 125 | | Z8010 Z-MMU Memory Management Unit | 155<br>171 | | Z8016 DTC Direct Memory Access Transfer Controller Z8030 Z-SCC Serial Communications Controller Z8031 Z-ASCC Asynchronous Serial Communications Controller | 175 | | Z8036 Z-CIO Counter/Timer and Parallel I/O Unit Z8038 Z-FIO FIFO Input/Output Interface Unit Z8060 FIFO Buffer Unit and Z-FIO Expander | 241 | | Z8065 Z-BEP Burst Error Processor Z8068 Z-DCP Data Ciphering Processor Z8070 Floating Point Package | 281<br>295 | | Z8090 Z-UPC Universal Peripheral Controller | | | Universal Peripherals Z8530 SCC Serial Communications Controller Z8531 ASCC Asynchronous Serial Communications Controller Z8536 CIO Counter/Timer and Parallel I/O Unit Z8538 FIO—See Z8038 Z-FIO Z8531 Clock Generator and Controller Z8590 UPC Universal Peripheral Controller | 337<br>359<br>379<br>241<br>403 | | <b>Z8 Family</b> Z8601/2/3 MCU Microcomputer Z8611/2/3 MCU Microcomputer Z8671 MCU Microcomputer with BASIC/Debug Interpreter | 431<br>449 | | Z8681 MCU Microcomputer | | | Additional Information Zilog Z-BUS Component Interconnect Z-BUS Backplane Interconnect Advanced Architectural Features of the Z8000 CPU An Introduction to the Z8010 MMU High Reliability Microcircuits | 493<br>497<br>511 | | Package Dimensions | | | Package Summary 18-Pin Packages 28-Pin Packages 40-Pin Packages 48-Pin Packages 28- and 44-Pin Leadless Packages | 536<br>537<br>538<br>540 | # Table of Contents (Continued) | Z80 Microcomputer Board Products Z80 MCB Single Board Computer Z80 RMB RAM Memory Board Z80 AIO/AIB Analog Input/Output and Analog Input Boards Z80 IOB Input/Output Board Z80 SIB Serial Interface Board Z80 PPB PROM Programming Board Z80 PMB PROM Memory Board Z80 MDC Memory and Disk Controller Board Z8000 Dual Processor Upgrade Package | 547<br>551<br>553<br>557<br>559<br>563<br>565<br>567 | |-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------| | Zilog Development Products System 8000 Z-LAB EMS 8000 Emulator Subsystem Z-SCAN 8000 Z8000 Development Module Z8000 Cross-Software Package Z8000 Software Development Package Z8000 PLZ/SYS Compiler ZRTS Zilog Real-Time Software PDS 8000 Development System ZDS 1/40 Z80 Development System Z80 PLZ Compiler RIO Electric Blackboard Z8 Development Module Z8 Software Development Package | 577<br>591<br>593<br>597<br>601<br>603<br>605<br>607<br>611<br>615<br>621<br>623 | | Zilog Technical Training | 631 | # **Functional Index** | Single-C | Chip Microcomputers | | |--------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------| | Z8601<br>Z8602<br>Z8603<br>Z8611<br>Z8612<br>Z8613<br>Z8671<br>Z8681 | Z8 8-Bit with 2K ROM Z8 8-Bit with Memory Interface, 64-Pin, 2K External ROM Z8 Prototyping Device with EPROM Interface, Protopack, 2K External ROM Z8 8-Bit, with 4K ROM Z8 with Memory Interface, 64-Pin 4K External ROM Z8 Prototyping Device with EPROM Interface, Protopack, 4K External ROM 8-Bit BASIC/Debug Interpreter 8-Bit with No On-Chip ROM | 431<br>431<br>449<br>449<br>449<br>467 | | 8-Bit Mi | croprocessors | | | Z8300<br>Z8400<br>Z8410<br>Z8420<br>Z8430<br>Z8440<br>Z8441<br>Z8442<br>Z8470<br>Z8581 | Z80L Low-Power Central Processing Unit Z80 CPU Central Processing Unit Z80 DMA Direct Memory Access Controller Z80 PIO Parallel Input/Output Controller Z80 CTC Counter/Timer Circuit Z80 SIO Dual Channel Serial Input/Output Controller Z80 SIO Dual Channel Serial Input/Output Controller Z80 SIO Dual Channel Serial Input/Output Controller Z80 SIO Dual Channel Serial Input/Output Controller Z80 DART Dual Asynchronous Receiver/Transmitter Clock Generator and Controller | 5<br>49<br>67<br>81<br>93<br>93<br>109 | | 16-Bit M | icroprocessors | | | Z8001/2<br>Z8003/4<br>Z8010<br>Z8015<br>Z8016<br>Z8030<br>Z8031<br>Z8036<br>Z8038<br>Z8060<br>Z8065<br>Z8068<br>Z8068<br>Z8070<br>Z8090<br>Z8581 | Advanced Architectural Features of the Z8000 CPU Introduction to the Z8010 MMU Zilog Z-BUS Component Interconnect Z-BUS Backplane Interconnect Z8000 CPU Central Processing Unit Z8000 VMPU Virtual Memory Processing Unit Z8000 Z-MMU Memory Management Unit Z8000 PMMU Paged Memory Management Unit Z8000 DTC Direct Memory Access Transfer Controller Z8000 Z-SCC Serial Communications Controller Z8000 Z-ASCC Asynchronous Serial Communications Controller Z8000 Z-FIO Counter/Timer and Parallel I/O Unit Z8000 Z-FIO FIFO Input/Output Interface Unit Z8000 FIFO Buffer Unit and Z-FIO Expander Z8000 Z-BEP Burst Error Processor Z8000 Z-DCP Data Ciphering Processor Z8000 Floating Point Package Z8000 Z-UPC Universal Peripheral Controller Clock Generator and Controller | 511<br>475<br>493<br>125<br>153<br>175<br>177<br>177<br>217<br>241<br>273<br>281<br>295<br>311<br>313 | | | ocessor Peripherals ommunications Controllers | | | Z8030<br>Z8031<br>Z8440<br>Z8441<br>Z8442<br>Z8470<br>Z8530<br>Z8531 | Z8000 Z-SCC Serial Communications Controller Z8000 Z-ASCC Asynchronous Serial Communications Controller Z80 SIO Dual Channel Serial Input/Output Controller Z80 SIO Dual Channel Serial Input/Output Controller Z80 SIO Dual Channel Serial Input/Output Controller Z80 SIO Dual Channel Serial Input/Output Controller Z80 DART Dual Asynchronous Receiver/Transmitter SCC Serial Communications Controller ASCC Asynchronous Serial Communications Controller | 197<br>93<br>93<br>93<br>109<br>337 | # Functional Index (Continued) | | ocessor Peripherals (Continued) I/O and Counter/Timers | | |---------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------| | Z8038<br>Z8060 | Z8000 Z-CIO Counter/Timer and Parallel I/O Unit Z8000 Z-FIO FIFO Input/Output Interface Unit Z8000 FIFO Buffer Unit and Z-FIO Expander CIO Counter/Timer and Parallel I/O Unit | 241<br>273 | | Universal | l Peripheral Controllers | | | Z8091/3<br>Z8092/4<br>Z8590<br>Z8591/3 | Z8000 Z-UPC Universal Peripheral Controller Z8000 Z-UPC External ROM-Based Universal Peripheral Controller Z8000 Z-UPC External RAM-Based Universal Peripheral Controller UPC Universal Peripheral Controller UPC External ROM-Based Universal Peripheral Controller UPC External RAM-Based Universal Peripheral Controller | 313<br>313<br>407<br>407 | | Clock Pro | oducts | | | Z8581 | Clock Generator and Controller | 403 | | Board Pro | roducts | | | Z80 AIO/.<br>Z80 IOB I<br>Z80 MCB<br>Z80 MDC<br>Z80 PLZ/S<br>Z80 PMB<br>Z80 PPB I<br>Z80 RMB | cessor Upgrade Package for Z80 Systems (AIB Analog Input/Output and Analog Input Boards Input/Output Board Single Board Computer Memory and Disk Controller Board SYS Compiler for the Z80 PROM Memory Board PROM Programmer Board RAM Memory Board Serial Interface Board | 553<br>557<br>547<br>567<br>619<br>565<br>563<br>551 | | - | ment Products | | | PDS 8000<br>RIO Electory System 80<br>ZDS 1/40<br>ZRTS Zild Z-SCAN<br>Z8 Develor Z80 Softw<br>Z80 PLZ/5<br>Z8000 Cr<br>Z8000 De<br>Z8000 PL | 0 In-Circuit Emulator Subsystem 0 Single-User Development System 20 Single-User Development System 20 Stric Blackboard, CRT Editor for PDS and ZDS Systems 20 ZLAB Multi-User Development System 20 Z80 In-Circuit Emulator and Development System 20 Real-Time, Multitasking Software Tools 20 In-Circuit Emulator 20 Software Development Module, Prototyping and Evaluation Board 20 Ware Development Package, Cross-Assembler for Z80-Based Development Systems 20 SYS Compiler for the Z80 21 Systems Software Package, C Cross-Compiler and Assembler for the Z8001 and Z8002 22 System Systems Systems 23 System Systems Systems Systems System Systems System Systems System Systems System Syste | 611<br>577<br>615<br>607<br>593<br>623<br>623<br>619<br>601<br>597 | # **Part Number Index** | Part Number | Description | |-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 05-0067-00 | System 8000 Z-LAB Multi-User Development System, Model 20, 50 Hz | | 05-0069-00 | System 8000 Z-LAB Multi-User Development System, Model 30, 50 Hz | | 05-0103-00 | Z-SCAN 8000 In-Circuit Emulator | | 05-0122-00 | EMS 8000 In-Circuit Emulator Subsystem | | 05-6003-XX | Z80 RMB RAM Memory Board | | 05-6006-03 | Z80 IOB Input/Output Board | | 05-6007-01 | Z80 SIB Serial Interface Board | | 05-6009-XX | Z80 MCB Single Board Computer | | 05-6011-XX | Z80 MDC Memory and Disk Controller Board | | 05-6013-05 | ZDS 1/40 Z80 In-Circuit Emulator and Development System | | 05-6015-01 | Z80 PPB PROM Programmer Board | | 05-6023-01 | Z80 PMB PROM Memory Board | | 05-6075-01 | Z80 AIO/AIB Analog Input/Output and Analog Input Boards | | 05-6101-01 | Z8002 Development Module | | 05-6102-01 | PDS 8000 Single-User Development System | | 05-6158-01 | Z8 Development Module | | 05-6168-01 | Z8001 Development Module | | 05-6219-00 | Dual Processor Upgrade Package for Z80 Systems | | 06-0086-01 | Z8000 Cross-Software Package, C Cross-Compiler and Assembler for Z8001 and Z8002, | | | DEC 11/70 with UNIX* | | 07-3028-00 | RIO Electric Blackboard, CRT Editor for ZDS Systems | | 07-3029-00 | RIO Electric Blackboard, CRT Editor for PDS Systems | | 07-3301-01 | Z80 PLZ/SYS Compiler for use with PDS 8000/05 and PDS 8000/15 $\dots \dots \dots$ | | 07-3302-01 | Z80 PLZ/SYS Compiler for use with ZDS-1 Series | | 07-3306-02 | Z8000 Software Development Package, Cross-Assembler for Z80-Based Hard Disk Systems with | | | Optional Floppy Drives | | 07-3309-01 | Z8000 Software Development Package, Cross-Assembler for PDS 800/5 | | 07-3310-01 | Z8000 Software Development Package, Cross-Assembler for ZDS-1 Series | | 07-3361-01 | Z8 Software Development Package, Cross-Assembler for use with PDS 8000/5 and | | | PDS 8000/15 | | 07-3362-01 | Z8 Software Development Package for use with ZDS-1 Series | | Z8000 | ZRTS Z8000 Real-Time, Multitasking Software Tools | | Z8001 | 16-Bit, Segmented Central Processing Unit | | Z8002 | 16-Bit, Non-Segmented Central Processing Unit | | Z8010 | Z8001/3 Z-MMU Memory Management Unit | | Z8015 | Z8000 PMMU Paged Memory Management Unit | | Z8016 | Z8000 DTC Direct Memory Access Transfer Controller | | Z8030 | Z8000 Z-SCC Serial Communications Controller | | Z8031 | Z8000 Z-ASCC Asynchronous Serial Communications Controller | <sup>\*</sup>Trademark of Bell Laboratories. # Part Number Index (Continued) | Part Number | Description | | |-------------|------------------------------------------------------------------------|-----------------| | Z8036 | Z8000 Z-CIO Counter/Timer and Parallel I/O Unit | 217 | | Z8038 | Z8000 Z-FIO FIFO Input/Output Interface Unit | 241 | | Z8060 | Z8000 FIFO Buffer Unit and Z-FIO Expander | | | Z8065 | Z8000 Z-BEP Burst Error Processor | | | Z8068 | Z8000 Z-DCP Data Ciphering Processor | | | Z8070 | Z8000 Floating Point Unit | | | Z8090 | Z8000 Z-UPC Universal Peripheral Controller | | | Z8091/3 | Z8000 Z-UPC Universal Peripheral Controller, External ROM-Based | 313 | | Z8092/4 | Z8000 Z-UPC Universal Peripheral Controller, External RAM-Based | | | Z8300 | Z80L CPU Low-Power Z80 Central Processing Unit | 27 | | Z8400 | Z80 CPU Z80 Central Processing Unit | | | Z8410 | Z80 DMA Dual Port, Direct Memory Access Controller | 49 | | Z8420 | Z80 PIO Dual Port, Parallel Input/Output Controller | 67 | | Z8430 | Z80 CTC Four Channel Counter/Timer Circuit | | | Z8440 | Z80 SIO/0 Dual Channel Synchronous/Asynchronous Serial I/O Controller | 93 | | Z8441 | Z80 SIO/1 Dual Channel Synchronous/Asynchronous Serial I/O Controller | 93 | | Z8442 | Z80 SIO/2 Dual Channel Synchronous/Asynchronous Serial I/O Controller | | | Z8470 | Z80 DART Dual Channel Asynchronous Serial I/O Controller | | | Z8530* | SCC Serial Communications Controller | 337 | | Z8531 | ASCC Asynchronous Serial Communications Controller | 359 | | Z8536 | CIO Counter/Timer and Parallel I/O Unit | 379 | | Z8581 | Clock Generator and Controller | 403 | | Z8590 | UPC Universal Peripheral Controller | 407 | | Z8591 | UPC Universal Peripheral Controller with External ROM | 107 | | Z8592 | UPC Universal Peripheral Controller with External RAM | 107 | | Z8593 | UPC Universal Peripheral Controller with External ROM, Protopack | 407 | | Z8594 | UPC Universal Peripheral Controller with External RAM, Protopack | <del>1</del> 07 | | Z8601 | Z8 8-Bit, Single-Chip Microcomputer with 2K ROM | 431 | | Z8602 | Z8 8-Bit Microcomputer with Memory Interface, 64-Pin, 2K External ROM | 431 | | Z8603 | Z8 Prototyping Device with EPROM Interface, Protopack, 2K External ROM | 431 | | Z8611 | Z8 8-Bit, Single-Chip Microcomputer with 4K ROM | 149 | | Z8612 | Z8 8-Bit Microcomputer with Memory Interface, 64-Pin, 4K External ROM | 449 | | Z8613 | Z8 Prototyping Device with EPROM Interface, Protopack, 4K External ROM | 449 | | Z8671 | Z8 8-Bit, Single-Chip BASIC/Debug Interpreter | | | Z8681 | Z8 8-Bit, Single-Chip Microcomputer with No On-Chip ROM | 169 | $<sup>^{\</sup>star}$ All 85XX components are compatible with processors other than Zilog's Z8001, Z8002, Z8003, and Z8004. For further information refer to the individual product specifications # Zalog # Zilog Z80° Family ### Sets the Industry Standard for 8 Bits June 1982 Zilog remains an industry leader, thanks to continuing innovation in microcomputer concepts and integrated design as exemplified in the Z80 Family microcomputer products. At Zilog, innovation means using proven, sophisticated mainframe and minicomputer concepts and translating them into the latest LSI technologies. Integration means more than designing an evergreater number of functions onto a single chip. Zilog integrates technologies—LSI design enhanced by advances in computer-based system architecture and system design technologies. Zilog offers microprocessor solutions to computing problems: from components and development systems to OEM board-level products and general-purpose microcomputer systems. This guide to the Z80 Family of state-of-the-art microprocessors and intelligent peripheral controllers demonstrates Zilog's continued support for the Z80 microprocessor and the other members of the Z80 product family—a family first introduced in 1976 that continues to enjoy growing customer support while family chips are upgraded to newer and ever-higher standards. The **Z8400 Z80 CPU Central Processing Unit** rapidly established itself as the most sophisticated, most powerful, and most versatile 8-bit microprocessor in the world. It offers many more features and functions than its competitor. In addition to being source-code compatible with the 8080A microprocessor, the Z80 offers more instructions than the 8080A (158 vs. 78) and numerous other features that simplify hardware requirements and reduce programming effort while increasing throughput. The dual-register set of the Z80 CPU allows high-speed context switching and more efficient interrupt processing. Two index registers give additional memory-addressing flexibility and simplify the task of programming. Interfacing to dynamic memory is simplified by on-chip, programmable refresh logic. Block moves plus string- and bit-manipulation instructions reduce programming effort, program size, and execution Now the **Z8300 Z80L CPU** extends the range of Z80 applications. This low-power version retains all Z80 CPU functions while providing dramatic power savings and increased reliability. The four traditional functions of a microcomputer system (parallel I/O, serial I/O, counting/timing, and direct memory access) are easily implemented by the Z80 CPU and the following well-proven family of Z80 peripheral devices: Z80 PIO, Z80 SIO, Z80 DART, Z80 CTC, and Z80 DMA. The easily programmed, dualchannel **Z8420 Z80 PIO Parallel Input/Output Controller** offers two 8-bit I/O ports with individual handshake and pattern recognition logic. Both I/O ports operate in either a byte or a bit mode. In addition, this device can be programmed to generate interrupts for various status conditions. All common data communications protocols, asynchronous as well as synchronous, are remarkably well handled by the **Z8440 Z80 SIO Serial Input/Output Controller**. This dual-channel receiver/transmitter device offers on-chip parity and CRC generation/checking. FIFO buffering and flag- and frame-detection generation logic are also offered. If asynchronous-only applications are required, the cost-effective **Z8470 Z80 DART Dual Asynchronous Receiver/Transmitter** can be used in place of the Z80 SIO. The Z80 DART offers all Z80 SIO asynchronous features in two channels. Timing and event-counting functions are the forte of the **Z8430 Z80 CTC Counter/Timer Controller.**The CTC provides four counters, each with individually programmable prescalers. The CTC is a convenient source of programmable clock rates for the SIO. With the **Z8410 Z80 DMA Direct Memory Access Controller**, data can be transferred directly between any two ports (typically, I/O and memory). The DMA transfers, searches, or search/transfers date in Byte-by-Byte, Burst, or Continuous modes. This device can achieve an impressive 2M bits per second data rate in the Search mode. # Z8400 Z80°CPU Central Processing Unit # Product Specification June 1982 #### **Features** - The instruction set contains 158 instructions. The 78 instructions of the 8080A are included as a subset; 8080A software compatibility is maintained. - Six MHz, 4 MHz and 2.5 MHz clocks for the 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 compatible, non-Z80 peripheral device, and Z80 Family peripheral with or without daisy chain. - On-chip dynamic memory refresh counter. Figure 1. Pin Functions Figure 2. Pin Assignments 2001-0210, 0211 5 #### General Description 6 The Z80, Z80A, and Z80B CPUs are thirdgeneration single-chip microprocessors with exceptional computational power. They offer higher system throughput and more efficient memory utilization than comparable secondand 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 generalpurpose 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 allows 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 3. Z80 CPU Block Diagram #### Z80 Microprocessor Family The Zilog Z80 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 microcomputer-based systems. Zilog has designed five components to provide extensive support for the Z80 microprocessor. These are: - 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 peripheral devices such as printers, tape punches, and keyboards. - The CTC (Counter/Timer Circuit) features four programmable 8-bit counter/timers, - each of which has an 8-bit prescaler. Each of the four channels may be configured to operate in either counter or timer mode. - The DMA (Direct Memory Access) controller provides dual port data transfer operations and the ability to terminate 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 modes for both synchronous and asynchronous communication, including Bi-Sync 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. #### 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 '[prime], 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- 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 an additional pair of flip-flops which assists in identifying the interrupt mode at any particular time. Table 1 provides further information on these registers. #### ALTERNATE REGISTER SFT MAIN REGISTER SET F' FLAG REGISTER A ACCUMULATOR F FLAG REGISTER A' ACCUMULATOR GENERAL PURPOSE **GENERAL PURPOSE** C GENERAL PURPOSE GENERAL PURPOSE D GENERAL PURPOSE F GENERAL PURPOSE D' GENERAL PURPOSE E' GENERAL PURPOSE I' GENERAL PURPOSE H GENERAL PURPOSE L GENERAL PURPOSE H' GENERAL PURPOSE - 8 BITS -INTERRUPT FLIP-FLOPS STATUS - 16 BITS IFF2 IFF1 IX INDEX REGISTER IY INDEX REGISTER STORES IFF1 0 = INTERRUPTS DISABLED DURING NMI 1 = INTERRIPTS ENABLED SERVICE SP STACK POINTER INTERRUPT MODE FLIP-FLOPS PC PROGRAM COUNTER IMF<sub>b</sub> INTERRUPT MODE 0 R MEMORY REFRESH I INTERRUPT VECTOR NOT USED INTERRUPT MODE 1 INTERRUPT MODE 2 - 8 BITS - Figure 4. CPU Registers | Z80 CPU | Re | gister | Size (Bits) | Remarks | |-------------|------------------------------------|--------------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------| | Registers | A, A' | Accumulator | 8 | Stores an operand or the results of an operation. | | (Continued) | F, F' | Flags | 8 | See Instruction Set. | | | B, B' | 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 D — 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-transparent dynamic memory refresh. Automatically incremented and placed on the address bus during each instruction fetch cycle. | | | IX | Index Register | 16 | Used for indexed addressing. | | | ΙΥ | 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). | #### 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. $\overline{\text{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, $\overline{\text{INT}}$ , has three programmable response modes available. These are: ■ Mode 0 — compatible with the 8080 microprocessor. ■ Mode 1 — Peripheral Interrupt service, for use with non-8080/Z80 systems. Table 1. Z80 CPU Registers 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 $\overline{\text{NMI}}$ and $\overline{\text{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. #### Interrupts: General Operation (Continued) 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 shutdown after power failure has been 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 routing. **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 $\overline{\text{BUSREQ}}$ is not active) a special interrupt processing cycle begins. This is a special fetch ( $\overline{\text{M1}}$ ) cycle in which $\overline{\text{IORQ}}$ becomes active rather than $\overline{\text{IORQ}}$ , as in normal $\overline{\text{M1}}$ cycle. In addition, this special $\overline{\text{M1}}$ 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 compatible with 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. **Mode 1 Interrupt Operation.** Mode <u>l</u> operation is very similar to that for the $\overline{\text{NMI}}$ . The principal difference is that the Mode <u>l</u> interrupt has a restart location of 0038H only. 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_0$ ) 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 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 succeeding 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, IFF<sub>1</sub> and IFF<sub>2</sub>, 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 and Z80 Assembly Language Manual. | Action | IFF <sub>1</sub> | IFF <sub>2</sub> | Comments | |------------------------------|------------------|------------------|-------------------------------------------------------------------------------| | CPU Reset | 0 | 0 | Maskable interrupt<br>INT disabled | | DI instruction 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_1$ | IFF <sub>1</sub> → IFF <sub>2</sub><br>(Maskable inter-<br>rupt INT disabled) | | RETN instruction execution | IFF <sub>2</sub> | • | IFF <sub>2</sub> → IFF <sub>1</sub> at completion of an NMI service routine. | Table 2. State of Flip-Flops #### 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. 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 (03-0029-01) and Assembly Language Programming Manual (03-0002-01) 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 - □ 8-bit arithmetic and logic operations - ☐ General-purpose arithmetic and CPU control | | 16-bit | arithmetic | operations | |--|--------|------------|------------| |--|--------|------------|------------| - □ Rotates and shifts - ☐ Bit set, reset, and test operations - □ Jumps - $\hfill\Box$ 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 | Mnemonic | Symbolic<br>Operation | s | z | | Fle<br>H | zgs | P/V | N | С | Opcode<br>76 543 210 | Hex | | No.of M<br>Cycles | | Comments | |----------------------------------------|------------------------------------------------|---|----|-------------|----------|-------------|-----|---|---|-------------------------------------------------|--------------------------|-------------|-------------------|---------------|----------------------------------| | LD r, r'<br>LD r, n | $r \leftarrow r'$<br>$r \leftarrow n$ | : | : | X | : | X | | : | : | 01 r r'<br>00 r 110 | | 1 2 | 1 2 | <b>4</b><br>7 | r, r' Reg. | | LD r, (HL)<br>LD r, (IX+d) | $r \leftarrow (HL)$<br>$r \leftarrow (IX + d)$ | : | : | X<br>X | : | X | : | : | : | 01 r 110<br>11 011 101<br>01 r 101 | DD | 1<br>3 | 2<br>5 | 7<br>19 | 001 C<br>010 D<br>011 E<br>100 H | | LD r, (I <b>Y</b> + d) | $r \leftarrow (IY + d)$ | • | • | х | • | X | • | • | • | + d → 11 111 101 01 r 110 + d → | FD | 3 | 5 | 19 | 101 L<br>111 <b>A</b> | | LD (HL), r<br>LD (IX+d), r | (HL) ← r<br>(IX+d) ← r | : | : | X | : | X | : | : | : | 01 110 r<br>11 011 101<br>01 110 r | DD | 1<br>3 | 2<br>5 | 7<br>19 | | | LD (IY+d), $r$ | (IY + d) - r | • | • | X | • | Х | • | • | • | - d -<br>11 111 101<br>01 110 r<br>- d - | FD | 3 | 5 | 19 | | | LD (HL), n | (HL) - n | • | • | X | • | X | • | • | • | 00 110 110 | 36 | 2 | 3 | 10 | | | LD (IX+d), n | $(IX + d) \leftarrow n$ | • | • | Х | • | х | • | • | • | - n -<br>11 011 101<br>00 110 110<br>- d - | DD<br>36 | 4 | 5 | 19 | | | LD (IY+d), n | (IY + d) - n | • | • | X | • | Х | • | • | • | + n → 11 111 101 00 110 110 + d → | | 4 | 5 | 19 | | | LD A, (BC) | A - (BC) | • | • | Х | • | х | • | • | • | 00 001 010 | | 1 | 2 | 7 | | | LD A, (DE)<br>LD A, (nn) | A ← (DE)<br>A ← (nn) | : | : | X | : | X | : | : | : | 00 011 010<br>00 111 010<br>- n - | 1 <b>A</b><br>3 <b>A</b> | 3 | 2<br>4 | 7<br>13 | | | LD (BC), A<br>LD (DE), A<br>LD (nn), 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<br>- n - | 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 | ŧ | х | 0 | x | IFF | 0 | • | 11 101 101 | | 2 | 2 | 9 | | | LD A, R | A - R | 1 | ı | х | 0 | X | IFF | 0 | • | 01 010 111 | 57<br>ED | 2 | 2 | 9 | | | LD I, A | I - A | • | • | Х | • | x | • | • | • | 01 011 111 | 5F<br>ED | 2 | 2 | 9 | | | LD R, A | R - A | • | ٠. | х | • | х | • | • | • | 01 000 111<br>11 101 101<br>01 001 111 | 47<br>ED<br>4F | 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 PV flag For an explanation of flag notation and symbols for mnemonic tables, see Symbolic Notation section following tables 10 2001-001 | 6-Bit Load<br>Froup | Mnemonic | Symbolic<br>Operation | 8 | z | | F! | lags | P/V | N | С | Opcode<br>78 543 210 Hex | No.of<br>Bytes | No.of M<br>Cycles | | | Comments | |---------------------------------|--------------------------------|-------------------------------------------------------------------------------------------------------------------|---------|------|-------------|-------|-------------|---------|-------|--------|--------------------------------------------------|----------------|-------------------|-------------|----------------------|------------------------| | ··oup | LD dd, nn | dd nn | • | • | Х | • | Х | • | • | • | 00 dd0 001<br>← n → | 3 | 3 | 10 | <u>dd</u><br>00 | Pair<br>BC | | | LD IX, nn | IX - nn | • | • | X | • | X | • | • | • | - n -<br>11 011 101 DD<br>00 100 001 21<br>- n - | 4 | 4 | 14 | 01<br>10<br>11 | DE<br>HL<br>SP | | | LD IY, nn | IY - nn | • | • | x | • | X | • | • | • | 11 111 101 FD<br>00 100 001 21 | 4 | 4 | 14 | | | | | LD HL, (nn) | H - (nn+1)<br>L - (nn) | • | • | x | • | x | • | • | • | 00 101 010 2A<br>- n - | 3 | 5 | 16 | | | | | LD dd, (nn) | $dd_{L} \leftarrow (nn+1)$ $dd_{L} \leftarrow (nn)$ | • | • | X | • | X | • | • | • | - n - 11 101 101 ED 01 dd1 011 - n - | 4 | 6 | 20 | | | | | LD IX, (nn) | $\begin{array}{l} IX_{H} \leftarrow (nn+1) \\ IX_{L} \leftarrow (nn) \end{array}$ | • | • | X | • | X | • | • | • | - n -<br>11 011 101 DD<br>00 101 010 2A<br>- n - | 4 | 6 | 20 | | | | | LD IY, (nn) | IY <sub>H</sub> - (nn+1)<br>IY <sub>L</sub> - (nn) | • | • | X | • | x | • | • | • | - n -<br>11 111 101 FD<br>00 101 010 2A<br>- n - | 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) \leftarrow ddH$<br>$(nn) \leftarrow ddL$ | • | • | X | • | X | • | • | • | - n - 11 101 101 ED 01 dd0 011 - n - | 4 | 6 | 20 | | | | | LD (nn), IX | $(nn+1) \leftarrow IX_L$ | • | • | X | • | X | • | • | • | - n -<br>11 011 101 DD<br>00 100 010 22<br>- n - | 4 | 6 | 20 | | | | | LD (nn), IY | $(nn+1) \leftarrow IY_{\mathbf{H}}$<br>$(nn) \leftarrow IY_{\mathbf{L}}$ | • | • | x | • | x | • | • | • | - n -<br>11 111 101 FD<br>00 100 010 22<br>- n - | 4 | 6 | 20 | | | | | LD SP, HL<br>LD SP, IX | SP - HL<br>SP - IX | : | : | X<br>X | : | X<br>X | : | : | : | n - n - 11 111 001 F9 11 011 101 DD | 1<br>2 | 1<br>2 | 6<br>10 | | | | | LD SP, IY | SP - IY | • | • | X | • | X | • | • | • | 11 111 001 F9<br>11 111 101 FD | 2 | 2 | 10 | | _ | | | PUSH qq | $(SP-2) \leftarrow qqL$<br>$(SP-1) \leftarrow qqH$<br>$SP \rightarrow SP-2$ | • | • | X | • | X | • | • | • | 11 111 001 F9<br>11 gg0 101 | 1 | 3 | 11 | 99<br>00<br>01<br>10 | Pair<br>BC<br>DE<br>HL | | | PUSH IX | $(SP-2) \leftarrow IX_L$<br>$(SP-1) \leftarrow IX_H$<br>$SP \rightarrow SP - 2$ | • | • | X | • | X | • | • | • | 11 011 101 DD<br>11 100 101 E5 | 2 | 4 | 15 | 11 | AF | | | PUSH IY | $(SP-2) \leftarrow IY_L$<br>$(SP-1) \leftarrow IY_H$<br>$SP \rightarrow SP-2$ | • | • | X | | X | • | • | • | 11 111 101 FD<br>11 100 101 E5 | 2 | 4 | 15 | | | | | POP qq | $qqH \leftarrow (SP+1)$<br>$qqL \leftarrow (SP)$<br>$SP \rightarrow SP + 2$ | • | • | X | • | X | • | • | • | 11 gg0 001 | 1 | 3 | 10 | | | | | POP IX | $ \begin{aligned} IX_{H} &\leftarrow (SP+1) \\ IX_{L} &\leftarrow (SP) \\ SP &\rightarrow SP + 2 \end{aligned} $ | • | • | X | • | X | • | • | • | 11 011 101 DD<br>11 100 001 E1 | 2 | 4 | 14 | | | | | POP IY | $\begin{array}{l} SP + SP + 1 \\ IY_{L} - (SP + 1) \\ IY_{L} - (SP) \\ SP - SP + 2 \end{array}$ | • | • | х | • | х | • | • | • | 11 111 101 FD<br>11 100 001 E1 | 2 | 4 | 14 | | | | | qq is a<br>(PAIR) | any of the register pairs BC<br>any of the register pairs AF<br>bH, (PAIR) L refer to high or<br>BCL = C, AFH = A | , BC, D | E, H | _ | r eig | ht bit | s of th | he re | gister | pair respectively, | | | | | | | Exchange,<br>Block<br>Transfer, | EX DE, HL<br>EX AF, AF'<br>EXX | DE HL<br>AF AF'<br>BC BC'<br>DE DE' | : | : | X<br>X<br>X | : | X<br>X<br>X | : | : | : | 11 101 011 EB<br>00 001 000 08<br>11 011 001 D9 | 1<br>1<br>1 | 1<br>1<br>1 | 4<br>4<br>4 | | ister bank and | | 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<br>X | : | X<br>X<br>X | : | : | : | 00 | 00 | 01 | 011<br>000<br>001 | | 1<br>1<br>1 | 1<br>1<br>1 | 4<br>4<br>4 | Register bank and auxiliary register | |--------------------------------|------------------------------------------------------------------------|---|---|-------------|---|-------------|--------|---|---|----|------|----|-------------------|----------|-------------|-------------|-------------|---------------------------------------------------------------------------------------------| | EX (SP), HL | $HL \rightarrow HL'$<br>$H \rightarrow (SP+1)$<br>$L \rightarrow (SP)$ | • | • | x | • | x | • | • | • | 1 | 1 10 | 00 | 011 | ЕЗ | 1 | 5 | 19 | bank exchange | | EX (SP), IX | $IX_{H} \rightarrow (SP+1)$<br>$IX_{L} \rightarrow (SP)$ | • | • | X | • | X | • | • | • | | | | | DD<br>E3 | 2 | 6 | 23 | | | EX (SP), IY | $\begin{array}{l} IY_{H} - (SP+1) \\ IY_{L} - (SP) \end{array}$ | • | • | X | • | X | •<br>① | • | • | 1 | 1 11 | 11 | | FD | 2 | 6 | 23 | | | LDI | (DE) (HL)<br>DE DE + 1<br>HL HL + 1<br>BC BC - 1 | • | • | x | 0 | x | ï | 0 | • | | | | | ED<br>A0 | 2 | 4 | 16 | Load (HL) into<br>(DE), increment<br>the pointers and<br>decrement the byte<br>counter (BC) | | LDIR | (DE) (HL) DE DE+1 HL HL+1 BC BC-1 Repeat until BC = 0 | • | • | x | 0 | x | 0 | 0 | • | | | | | ED<br>B0 | 2 2 | 5<br>4 | 21<br>16 | counter (BC) If BC ≠ 0 If BC = 0 | NOTE $\bigcirc$ P/V flag is 0 if the result of BC - 1 = 0, otherwise P/V = 1 | Exchange,<br>Block | Mnemonic | Symbolic<br>Operation | s | z | | Flo | igs | P/V | N | С | Opcode<br>76 543 210 Hex | | No.of M<br>Cycles | | Comments | |------------------------------------------|---------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------|------------------|------------------|----------------------------|----------------------------|----------------------------|----------------------------|----------------------------|------------------|-------------------------------------------------------|-------------|-------------------|---------------|----------------------------------------------------------------------------------------------------------------------------------| | Fransfer, Block Search Groups Continued) | LDD | (DE) (HL) DE DE 1 HL HL 1 BC BC 1 | • | • | х | 0 | х | 9 : | 0 | • | 11 101 101 ED<br>10 101 000 A8 | 2 | 4 | 16 | | | , | LDDR | (DE) (HL) DE DE -1 HL HL -1 BC BC -1 Repeat until | • | • | х | 0 | Х | 0 | 0 | • | 11 101 101 ED<br>10 111 000 B8 | 2 2 | 5<br>4 | 21<br>16 | If BC ≠ 0<br>If BC = 0 | | | CPI | BC = 0 A - (HL) HL - HL+1 | ţ | ()<br>1 | Х | 1 | х | : | 1 | • | 11 101 101 ED<br>10 100 001 A1 | 2 | 4 | 16 | | | | CPIR | BC ← BC − 1<br>A − (HL) | | <b>⊘</b> : | х | 1 | х | 1 | 1 | | 11 101 101 ED | 2 | 5 | 21 | If BC ≠ 0 and | | | o | HL - HL + 1 BC - BC - 1 Repeat until A = (HL) or BC = 0 | · | • | | • | - | · | • | | 10 110 001 B1 | 2 | 4 | 16 | $A \neq (HL)$ If BC = 0 or $A = (HL)$ | | | CPD | A - (HL)<br>HL - HL - 1<br>BC - BC - 1 | t | 2 | Х | 1 | Х | _ | 1 | • | 11 101 101 ED<br>10 101 001 A9 | 2 | 4 | 16 | | | | CPDR | A - (HL) | 1 | ②<br>1 | х | 1 | Х | 1 | 1 | • | 11 101 101 ED | 2 | 5 | 21 | If BC ≠ 0 and | | | | HL - HL-1 BC - BC-1 Repeat until A = (HL) or BC = 0 | | | | | | | | | 10 111 001 B9 | 2 | 4 | 16 | $A \neq (HL)$ If $BC = 0$ or $A = (HL)$ | | | ag is 0 if the result of B0 is 1 if $A = (HL)$ , otherw | | | erwı | se P/\ | / = | 1 | | | | | | | | | | 8-Bit<br>Arithmetic<br>and Logical | ADD A, r<br>ADD A, n | A - A + r<br>A - A + n | : | : | X<br>X | : | | v<br>v | | : | 10 000 r<br>11 000 110<br>← n → | 1<br>2 | 1<br>2 | 4<br>7 | r Reg.<br>000 B<br>001 C | | Group | | $A \leftarrow A + (HL)$ $A \leftarrow A + (IX + d)$ | 1 | t<br>t | X<br>X | i<br>i | X<br>X | v<br>v | 0 | 1 | 10 000 110<br>11 011 101 DD<br>10 000 110 | 1 3 | 2<br>5 | 7<br>19 | 010 D<br>011 E<br>100 H<br>101 L | | | ADD A, (IY+d) | $A \leftarrow A + (IY + d)$ | 1 | t | Х | ŧ | х | V | 0 | 1 | ← d →<br>11 111 101 FD<br>10 000 110 | 3 | 5 | 19 | 111 A | | | ADC A, s SUB s SBC A, s AND s OR s XOR s CP s | A - A + s + CY<br>A - A - s<br>A - A - s - CY<br>A - A \wedge s<br>A - A \wedge s<br>A - A \end{array} s<br>A - A \end{array} s | :<br>:<br>:<br>: | :<br>:<br>:<br>: | x<br>x<br>x<br>x<br>x<br>x | ;<br>;<br>;<br>1<br>0<br>0 | x<br>x<br>x<br>x<br>x<br>x | V<br>V<br>V<br>P<br>P<br>P | 0<br>1<br>1<br>0<br>0<br>0 | ;<br>;<br>0<br>0 | - d - 001 010 011 100 110 111 | | | | s is any of r, n, (HL), (IX + d), (IY + d) as shown for ADD instruction. The indicated bits replace the 000 in the ADD set above | | | INC r<br>INC (HL)<br>INC (IX+d) | $r \leftarrow r + 1$<br>$(HL) \leftarrow (HL) + 1$<br>$(IX + d) \leftarrow$<br>(IX + d) + 1 | 1 1 | :<br>: | X<br>X<br>X | : | X<br>X<br>X | v<br>v<br>v | 0 0 | : | 00 r 100<br>00 110 100<br>11 011 101 DE<br>00 110 100 | 1<br>1<br>3 | 1<br>3<br>6 | 4<br>11<br>23 | | | | INC (IY+d) | (IY + d) ←<br>(IY + d) + l | ŧ | 1 | X | 1 | X | v | 0 | • | - d -<br>11 111 101 FD<br>00 110 100 | 3 | 6 | 23 | | | | DEC m | m — m-1 | 1 | 1 | X | 1 | х | v | 1 | • | - d - | | | | m is any of r, (HL), (IX+d), (IY+d) as shown for INC DEC same format and states as INC Replace [100] with [101] in opcode | | General-<br>Purpose | Mnemonic | Symbolic<br>Operation | s | z | | Flo<br>H | | P/V | N | С | Opcode<br>76 543 210 Hex | | No.of M<br>Cycles | | Comments | |----------------------------|---------------------|------------------------------------------------------------------------------------------------------------|-------|------|-------------|---------------|-------------|-----|---|----------|-------------------------------------------------------|-------------|-------------------|-------------|-----------------------------------------------------| | Arithmetic and CPU Control | DAA | Converts acc content<br>into packed BCD<br>following add or<br>subtract with packed | 1 | ; | Х | t | Х | P | • | 1 | 00 100 111 27 | 1 | 1 | 4 | Decimal adjust accumulator. | | Groups | CPL | BCD operands<br>A - Ā | • | • | х | 1 | X | • | 1 | • | 00 101 111 2F | 1 | 1 | 4 | Complement accumulator (one's | | | NEG | A - 0 - A | t | 1 | х | 1 | X | | 1 | | 11 101 101 ED<br>01 000 100 44 | 2 | 2 | 8 | complement). Negate acc. (two's complement). | | | CCF<br>SCF | $CY \leftarrow \overline{CY}$ $CY \leftarrow 1$ | • | • | X | <b>X</b><br>0 | X | • | 0 | 1 | 00 111 111 3F<br>00 110 111 37 | 1 | 1 | 4 | Complement carry<br>flag.<br>Set carry flag | | | NOP<br>HALT<br>DI ★ | No operation<br>CPU halted<br>IFF 0 | : | : | X<br>X<br>X | : | X<br>X<br>X | : | : | : | 00 000 000 00<br>01 110 110 76<br>11 110 011 F3 | 1<br>1<br>1 | 1<br>1<br>1 | 4<br>4<br>4 | | | | EI *<br>IM 0 | IFF - 1<br>Set interrupt<br>mode 0 | : | : | X | : | X | • | : | : | 11 111 011 FB<br>11 101 101 ED<br>01 000 110 46 | 1 2 | 1 2 | 8 | | | | IM 1<br>IM 2 | Set interrupt<br>mode 1<br>Set interrupt | • | | X<br>X | • | x | • | | • | 11 101 101 ED<br>01 010 110 56<br>11 101 101 ED | 2 | 2 | 8 | | | | CY 1 | mode 2 Indicates the interrupt enable flindicates the carry flip-flop, dicates interrupts are not sample. | | | end o | of EI o | or DI | | | | 01 011 110 5E | | | | | | l6-Bit | ADD HL, ss | HL - HL+ss | • | • | х | Х | Х | • | 0 | 1 | 00 ssl 001 | 1 | 3 | 11 | ss Reg.<br>00 BC | | Arithmetic<br>Group | ADC HL, ss | HL HL+ss+CY | 1 | 1 | Х | х | Х | V | 0 | : | 11 101 101 ED<br>01 ssl 010 | 2 | 4 | 15 | 01 DE<br>10 HL<br>11 SP | | | SBC HĹ, ss | HL - HL-ss-CY | ŧ | t | | Х | | | | | 11 101 101 ED<br>01 ss0 010 | 2 | 4 | 15 | | | | ADD IX, pp | IX - IX + pp | • | • | Х | Х | х | • | 0 | 1 | 11 011 101 DD<br>01 pp1 001 | 2 | 4 | 15 | pp Reg.<br>00 BC<br>01 DE<br>10 IX<br>11 SP | | | ADD IY, rr | IY - IY + rr | • | • | Х | X | Х | • | 0 | t | 11 111 101 FD<br>00 rrl 001 | 2 | 4 | 15 | rr Reg.<br>00 BC<br>01 DE<br>10 IY | | | INC ss<br>INC IX | $ss \leftarrow ss + 1$<br>$IX \leftarrow IX + 1$ | : | : | X<br>X | : | X<br>X | : | : | : | 00 ss0 011<br>11 011 101 DD<br>00 100 011 23 | 1 2 | 1<br>2 | 6<br>10 | 11 SP | | | INC IY | IY - IY + 1 | • | • | Х | • | X | • | • | • | 11 111 101 FD<br>00 100 011 23 | 2 | 2 | 10 | | | | DEC ss<br>DEC IX | ss - ss - 1<br>IX - IX - 1 | : | : | X | • | X | : | : | : | 00 ssl 011<br>11 011 101 DD<br>00 101 011 2B | 1 2 | 1 2 | 6<br>10 | | | | DEC IY NOTES ss is | IY - IY - 1 any of the register pairs BC, Di | - | SD | х | • | х | | | <u>.</u> | 11 111 101 FD<br>00 101 011 2B | 2 | 2 | 10 | | | | pp is | any of the register pairs BC, D<br>any of the register pairs BC, DI | E, IX | , SP | | | | | | | | | | | | | Rotate and<br>Shift Group | RLCA | CY 7 - 0 - A | • | • | x | 0 | х | • | 0 | t | 00 000 111 07 | 1 | 1 | 4 | Rotate left circular accumulator | | | RLA | CY 7 0 A | • | • | Х | 0 | X | • | 0 | ŧ | 00 010 111 17 | 1 | 1 | 4 | Rotate left<br>accumulator | | | RRCA | 7 — 0 CY | • | • | X | 0 | X | • | 0 | ı | 00 001 111 OF | 1 | 1 | 4 | Rotate right circular accumulator | | | RRA | 7 — 0 — CY | • | • | х | 0 | X | • | 0 | ŧ | 00 011 111 1F | 1 | 1 | 4 | Rotate right accumulator | | | RLC r | | 1 | t | Х | 0 | X | P | 0 | t | 11 001 011 CE<br>00 000 r | 3 2 | 2 | 8 | Rotate left circular<br>register r | | | RLC (HL) | | 1 | t | Х | 0 | X | P | 0 | ı | 11 001 011 CE<br>00 000 110 | 3 2 | 4 | 15 | r Reg<br>000 B<br>001 C | | | RLC (IX+d) | r,(HL),(IX + d),(IY + d) | 1 | 1 | Х | 0 | Х | P | 0 | t | 11 011 101 DE<br>11 001 011 CE<br>← d →<br>00 000 110 | | 6 | 23 | 010 D<br>011 E<br>100 H<br>101 L<br>111 A | | | RLC (IY+d) | | t | 1 | X | 0 | Х | P | 0 | 1 | 11 111 101 FD<br>11 001 011 CE<br>- d - | | 6 | 23 | Instruction format | | | RL m | $ \begin{array}{ccc} \hline CY & & 7 & & 0 \\ m = r, (HL), (IX + d), (IY + d) \end{array} $ | 1 | 1 | Х | 0 | х | P | 0 | t | 00 000 110<br>010 | | | | and states are as<br>shown for RLC's<br>To form new | | | RRC m | m = r, (HL), (IX + d), (IY + d) | 1 | 1 | X | 0 | X | P | 0 | 1 | 001 | | | | opcode replace OOO or RLC's with shown code | | Rotate and<br>Shift Group | Mnemonic | Symbolic<br>Operation | s | z | | Flo | igs | P/V | N | С | Opcode<br>76 543 210 | Hex | No.of<br>Bytes | No.of M<br>Cycles | No.of T<br>States | Comments | |---------------------------|---------------|----------------------------------------------------------------------------------------------|------|--------|-------|-----|-----|-----|---|---|-----------------------------------------------|----------|----------------|-------------------|-------------------|--------------------------------------------------------------------------------------------------------------| | (Continued) | RR m | m = r, (HL), (IX + d), (IY + d) | ı | ı | х | 0 | Х | P | 0 | ı | 011 | | | | | | | | SLA m | $CY \longrightarrow 7 \longrightarrow 0 \longrightarrow 0$ $m = r, (HL), (IX + d), (IY + d)$ | ı | 1 | х | 0 | x | P | 0 | 1 | 100 | | | | | | | | SRA m | m = r, (HL), (IX + d), (IY + d) | 1 | 1 | Х | 0 | X | P | 0 | ı | 101 | | | | | | | | | $0 \longrightarrow 7 \longrightarrow 0 \longrightarrow CY$ $m = r, (HL), (IX + d), (IY + d)$ | t | 1 | Х | 0 | X | P | 0 | 1 | 111 | | | | | | | | RLD | 7 - 4 3 - 0 | 1 | ŧ | Х | 0 | Х | P | 0 | • | 11 101 101<br>01 101 111 | ED<br>6F | 2 | 5 | 18 | Rotate digit left and<br>right between<br>the accumulator | | | RRD | 7 - 4 3 - 0 7 - 4 3 - 0 (HL) | ı | ı | х | 0 | x | P | 0 | • | 11 101 101<br>01 100 111 | ED<br>67 | 2 | 5 | 18 | and location (HL) The content of the upper half of the accumulator is unaffected | | Bit Set, Reset | BIT b, r | Z - T <sub>b</sub> | х | 1 | х | l | х | х | 0 | | 11 001 011<br>01 b r | СВ | 2 | 2 | 8 | r Reg. | | and Test | BIT b, (HL) | $Z \leftarrow (\overline{HL})_b$ | X | 1 | X | 1 | X | X | 0 | • | 11 001 011 | СВ | 2 | 3 | 12 | 001 C | | Group | BIT b, (IX+d) | $D_b Z \leftarrow (\overline{IX + d})_b$ | X | 1 | X | 1 | X | X | 0 | • | 01 b 110<br>11 011 101<br>11 001 011<br>- d - | | 4 | 5 | 20 | 010 D<br>011 E<br>100 H<br>101 L | | | RIT L /IV1 | $b_b Z \leftarrow (\overline{IY + d})_b$ | ¥ | | у | 1 | ¥ | y | 0 | | 01 b 110 | FD | 4 | 5 | 20 | 111 A b Bit Tested 000 0 | | | μι υ, (II +α) | p 2 ← (11 + α/b | ^ | • | Λ | 1 | Λ | Λ | U | • | 11 101 101<br>11 001 011<br>- d -<br>01 b 110 | | 7 | J | 20 | 001 1<br>010 2<br>011 3<br>100 4<br>101 5<br>110 6 | | | SET b, r | r <sub>b</sub> - 1 | • | • | x | • | x | • | • | • | 11 001 011 | СВ | 2 | 2 | 8 | 111 7 | | | SET b, (HL) | $(HL)_b \leftarrow 1$ | • | • | х | • | x | • | • | • | 11 001 011<br>11 001 110 | СВ | 2 | 4 | 15 | | | | SET b, (IX+d) | d) $(IX+d)_b \leftarrow 1$ | | • | х | • | Х | • | • | • | 11 011 101<br>11 001 011<br>- d - | | 4 | 6 | 23 | | | | SET b, (IY+d) | (IY + d) <sub>b</sub> ← 1 | • | • | x | • | X | • | • | • | П b 110<br>11 111 101<br>11 001 011<br>- d - | FD<br>CB | 4 | 6 | 23 | | | | RES b, m | $m_b \leftarrow 0$ $m = r, (HL),$ $(IX + d),$ $(IY + d)$ | • | • | x | • | x | • | • | • | П ь 110<br>Ю | | | | | To form new opcode replace opcode seplace opcode for b, s with of Flags and time states for SET instruction. | | | NOTES The r | notation mb indicates bit b (0 to | 7) c | or loc | ation | m | | | | | | | | | | | | Jump<br>Group | JP nn | PC - nn | | • | х | | х | • | • | • | 11 000 011<br>- n -<br>- n - | СЗ | 3 | 3 | 10 | | | | JP cc, nn | If condition cc is<br>true PC - nn,<br>otherwise<br>continue | • | • | x | • | x | • | • | • | 11 cc 010<br>- n -<br>- n - | | 3 | 3 | | Condition | | | JR e | PC - PC+e | • | ٠ | Х | | X | | | • | 00 011 000<br>- e-2 - | | 2 | 3 | | 111 M sign negative | | | JR C, e | If C = 0,<br>continue<br>If C = 1, | • | • | Х | • | х | • | • | • | 00 111 000<br>← e-2 → | 38 | 2 | 3 | | If condition not met. If condition is met. | | | JR NC, e | $PC \leftarrow PC + e$<br>If $C = 1$ , | | | х | | х | | | | 00 110 000 | 30 | 2 | 2 | 7 | If condition not met. | | | | continue<br>If $C = 0$ , | | | * | | •• | | | | ÷ e-2 → | | 2 | 3 | | If condition is met. | | | JP Z, e | $PC \leftarrow PC + e$ If $Z = 0$ continue | • | • | X | • | x | • | • | • | 00 101 000<br>← e-2 → | 28 | 2 | 2 | 7 | If condition not met. | | | | If $Z = 1$ , | | | | | | | | | . 6-2 → | | 2 | 3 | 12 | If condition is met. | | | JR NZ, e | $PC \leftarrow PC + e$ If $Z = 1$ , continue | • | • | Х | • | x | • | • | • | 00 100 000<br>← e-2 → | 20 | 2 | 2 | | If condition not met. | | | TD //// | If $Z = 0$ ,<br>PC $\leftarrow$ PC + e | | | •- | | | | | | 11 12 20 | | 2 | 3 | | If condition is met. | | | JP (HL) | PC - HL | • | • | | • | | | | • | 11 101 001 | | 1 | 1 | 4<br>8 | | | | JP (IX) | PC - IX | _ | | | | | | • | | 11 011 101 | | 2 | 2 | | | | ump Group<br>Continued) | Mnemonic | Symbolic<br>Operation | s | z | | Fle<br>H | igs | P/V | N <sup>2</sup> | c | Opcode<br>76 543 210 Hex | | No.of M<br>Cycles | | Comments | |-------------------------|----------|-----------------------------------------------------------------------------------------------|---|---|---|----------|-----|-----|----------------|---|--------------------------------|---|-------------------|---|-------------------------------| | oominaoa, | JP (IY) | PC - IY | • | • | Х | • | X | • | • | • | 11 111 101 FD<br>11 101 001 E9 | 2 | 2 | 8 | | | | DJNZ, e | $B \leftarrow B - 1$<br>If $B = 0$ ,<br>continue<br>If $B \neq 0$ ,<br>$PC \leftarrow PC + e$ | • | • | Х | • | Х | • | • | • | 00 010 000 10<br>- e-2 - | 2 | 3 | 8 | If $B = 0$ . If $B \neq 0$ . | | | e 18 e<br>e - 2 | oresents the extension in the real signed two's complement nur in the opcode provides an effect 2 prior to the addition of e | nber ir | n the | rang | e < | - 126 | 6, 129<br>PC 1 | ><br>incr | emen | ited | | | | | | | | | | |--------------------------|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------|---------|-------|------|-----|-------|----------------|-----------|------|------|------|---------------|------------|----------------|---|---|--------------------------------|----------|---------------------------------------------------------------------------------------------| | Call and<br>Return Group | CALL nn | (SP-1) - PC <sub>H</sub><br>(SP-2) - PC <sub>L</sub><br>PC - nn | • | • | х | • | х | • | • | • | | - | Ol<br>n<br>n | - | CD | 3 | | 5 | 17 | | | | CALL cc, nn | | • | • | Х | • | X | • | • | • | | | cc : | | | 3 | | 3 | 10 | If cc is false | | | | cc is false<br>continue,<br>otherwise same as<br>CALL nn | | | | | | | | | | - | n | - | | 3 | | 5 | 17 | If cc is true | | | RET | $PC_L \leftarrow (SP)$<br>$PC_H \leftarrow (SP+1)$ | • | • | X | • | X | • | • | • | 1 | 1 0 | 01 | 001 | C9 | 1 | | 3 | 10 | | | | RET cc | If condition<br>cc is false | • | • | X | • | X | • | • | • | 1 | 11 | cc ( | 000 | | 1 | | 1 | 5 | If cc is false. | | | | continue,<br>otherwise<br>same as<br>RET | | | | | | | | | | | | | | 1 | | 3 | 11 | If cc is true. cc Condition 000 NZ non-zero 001 Z zero | | | RETI | Return from | • | • | х | • | x | • | • | • | 1 | 1 1 | .01 | 101 | ED | 2 | : | 4 | 14 | 010 NC non-carry<br>011 C carry | | | RETN1 | interrupt<br>Return from<br>non-maskable<br>interrupt | • | • | X | • | X | • | • | • | 1 | 1 1 | 01 | 101 | 4D<br>ED<br>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 | • | Х | • | • | • | 1 | 11 | t | 111 | | 1 | | 3 | 11 | t p<br>000 00H<br>001 08H<br>010 10H<br>011 18H<br>100 20H<br>101 28H<br>110 30H<br>111 38H | | | NOTE 'RETN | N loads IFF2 → IFF1 | | | | | | | | | | | | | | | | | | | | nput and | IN A, (n) | A - (n) | • | ٠ | Х | • | Х | • | • | • | | | | | DB | 2 | 2 | 3 | 11 | n to An ~ An | | Output Group | IN r, (C) | $r \leftarrow (C)$<br>if $r = 110$ only the<br>flags will be affected | t | _ | X | t | х | P | 0 | • | 1 | 11 1 | n<br>101<br>r | 101<br>000 | ED | 2 | 2 | 3 | 12 | Acc to $A_8 \sim A_{15}$<br>C to $A_0 \sim A_7$<br>B to $A_8 \sim A_{15}$ | | | INI | (HL) - (C)<br>B - B-1 | х | 1 | X | х | Х | Х | t | Х | | | | | ED<br>A2 | 2 | 2 | 4 | 16 | C to $A_0 \sim A_7$<br>B to $A_8 \sim A_{15}$ | | | INIR | $\begin{aligned} HL &\leftarrow HL + 1\\ (HL) &\leftarrow (C)\\ B &\leftarrow B - 1\\ HL &\leftarrow HL + 1\\ Repeat until\\ B &= 0 \end{aligned}$ | Х | 1 | Х | х | Х | Х | t | Х | | | | | ED<br>B2 | | 2 | 5<br>(If B≠0)<br>4<br>(If B=0) | 21<br>16 | C to $A_0 \sim A_7$ B to $A_8 \sim A_{15}$ | | | IND | (HL) + (C)<br>B + B - 1 | Х | 1 | х | Х | Х | х | ı | х | | | | | ED<br>AA | 2 | 2 | 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 | х | х | Х | х | t | х | | | | | ED<br>BA | | 2 | 5<br>(If B≠0)<br>4<br>(If B=0) | 21<br>16 | C to $A_0 \sim A_7$<br>B to $A_8 \sim A_{15}$ | | | OUT (n), A | $B = 0$ $(n) \leftarrow A$ | • | • | Х | • | Х | • | ı | X | | | | | D3 | 2 | 2 | 3 | 11 | n to A <sub>0</sub> ~ A <sub>7</sub><br>Acc to A <sub>8</sub> ~ A <sub>15</sub> | | | OUT (C), r | (C) - r | • | • | Х | • | Х | • | t | Х | ] | 11 | | 101<br>001 | ED | 2 | 2 | 3 | 12 | Acc to A8 $\sim$ A15<br>C to A0 $\sim$ A7<br>B to A8 $\sim$ A15 | | | OUTI | (C) + (HL)<br>B + B-1<br>HI - HI + 1 | Х | 1 | Х | Х | Х | Х | t | Х | | | | | ED<br>A3 | 2 | 2 | 4 | 16 | C to $A_0 \sim A_7$ B to $A_8 \sim A_{15}$ | | | OTIR | HL - HL + 1 $(C) - (HL)$ $B - B - 1$ $HL - HL + 1$ Repeat until $B = 0$ | Х | 1 | х | х | х | х | t | х | | | | | ED<br>B3 | | 2 | 5<br>(If B≠0)<br>4<br>(If B=0) | 21<br>16 | C to $A_0 \sim A_7$<br>B to $A_8 \sim A_{15}$ | | | | - | | 1 | | | | | | | | | | | | | | | | | NOTE $\bigcirc$ If the result of B-1 is zero the Z flag is set, otherwise it is reset $\bigcirc$ N Flag is 1 if data bit is 1, othewise N Flag is 0 (C) - (HL) B - B - 1 HL - HL - 1 OUTD 4 2 11 101 101 ED 10 101 011 AB 16 C to $A_0 \sim A_7$ B to $A_8 \sim A_{15}$ | and<br>t Group | Mnemonic | Symbolic<br>Operation | s | z | | Flo<br>H | ıgs | P/V | N | С | Opcode<br>76 543 210 Hex | | No.of M<br>Cycles | | Comments | |----------------|----------|-----------------------------------------------------------------|---|---|---|----------|-----|-----|---|---|-----------------------------|---|--------------------------------|----------|-------------------------------------------------------------------------------| | ntinued) | OTDR | (C) - (HL)<br>B - B - 1<br>HL - HL - 1<br>Repeat until<br>B = 0 | х | 1 | х | Х | Х | Х | 1 | Х | 11 101 101 ED<br>10 111 011 | 2 | 5<br>(If B≠0)<br>4<br>(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> | #### Summary of Flag Operation | Instruction | D <sub>7</sub><br>S | z | | н | | P/V | N | D <sub>0</sub> | Comments | |-----------------------------------------------------|---------------------|---|---|---|---|-----|---|----------------|----------------------------------------------------------------------------------------------------------------| | ADD A, s, ADC A, s | 1 | 1 | Х | 1 | Х | ٧ | 0 | 1 | 8-bit add or add with carry | | SUB s, SBC A, s, CP s, NEG | 1 | 1 | Х | 1 | Х | v | 1 | 1 | 8-bit subtract, subtract with carry, compare and negate accumulator | | AND s | 1 | 1 | Х | 1 | Х | P | 0 | 0) | | | OR s, XOR s | 1 | 1 | Х | 0 | Х | P | 0 | 0 🛭 | Logical operations | | INC s | 1 | 1 | Х | 1 | Х | V | 0 | • | 8-bit increment | | DEC s | 1 | 1 | Х | 1 | Х | V | 1 | • | 8-bit decrement, | | ADD DD, ss | • | • | Х | Х | Х | • | 0 | 1 | 16-bit add | | ADC HL, ss | 1 | 1 | Х | Х | Х | V | 0 | 1 | 16-bit add with carry | | SBC HL, ss | 1 | 1 | Х | Х | Х | V | 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 | Х | 0 | Х | P | 0 | 1 | Rotate and shift locations | | RLD, RRD | 1 | : | Х | 0 | Х | P | 0 | • | Rotate digit left and right | | DAA | 1 | 1 | Х | 1 | Х | P | • | 1 | Decimal adjust accumulator | | CPL | • | • | Х | 1 | Х | • | 1 | | Complement accumulator | | SCF | • | • | Х | 0 | Х | • | 0 | 1 | Set carry | | CCF | • | • | Х | Х | Х | • | 0 | 1 | Complement carry | | IN r (C) | t | t | Х | 0 | Х | P | 0 | • | Input register indirect | | INI, IND, OUTI, OUTD | X | 1 | Х | Х | Х | Х | 1 | • 1 | Block input and output $Z = 0$ if $B \neq 0$ otherwise $Z = 0$ | | INIR, INDR, OTIR, OTDR | Х | 1 | Х | Х | Х | Х | 1 | ٠ĵ | block input and output $L = 0$ if $B \neq 0$ otherwise $L = 0$ | | LDI, LDD | Х | Х | Х | 0 | Х | 1 | 0 | • 1 | Plant to refer to the part of PC + 0 at the part of C | | LDIR, LDDR | X | Х | Х | Ó | Х | ò | Ō | ٠Ì٠ | Block transfer instructions $P/V = 1$ if $BC \neq 0$ , otherwise $P/V = 0$ | | CPI, CPIR, CPD, CPDR | Х | 1 | Х | Х | Х | 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 | t | Х | 0 | Х | IFF | 0 | • | The content of the interrupt enable flip-flop (IFF) is copied into the P/V flag | | BIT b, s | X | 1 | Х | 1 | X | Х | 0 | • | The state of bit b of location s is copied into the Z flag | #### Symbolic Notation | <b>Symbol</b><br>S<br>Z<br>P/V | | |--------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Н | The result of the operation is $e^{-H}$ , $H^{-V} = 0$ in 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 operation was a subtract. | | H & N | H and N flags are used in conjunction with the decimal adjust instruction (DAA) to properly correct 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 | Symbol | Operation | |----------|-----------------------------------------------------| | <b>t</b> | The flag is affected according to the result of the | | | operation. | | • | The flag is unchanged by the operation. | | 0 | The flag is reset by the operation. | | 1 | The flag is set by the operation. | | X | The flag is a "don't care " | | V | P/V flag affected according to the overflow result | | | of the operation. | | P | P/V flag affected according to the parity result of | | | the operation. | | r | Any one of the CPU registers A, B, C, D, E, H, L. | | 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. | | 11 | 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 >. | | | | 2001-001 #### 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 Low). Bus Acknowledge indicates to the requesting device that the CPU address bus, data bus, and control signals MREQ, IORQ, 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 \$\overline{NMI}\$ and is always recognized at the end of the current machine cycle. \$\overline{BUSREQ}\$ forces the CPU address bus, data bus, and control signals \$\overline{MREQ}\$, \$\overline{IORQ}\$, \$RD\$, and \$WR\$ to go to a high-impedance state so that other devices can control these lines. \$\overline{BUSREQ}\$ is normally wire-ORed and requires an external pullup for these applications. Extended \$\overline{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_0$ - $D_7$ constitute an 8-bit 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. 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. $\overline{\text{Ml.}}$ Machine Cycle One (output, active Low). $\overline{\text{Ml}}$ , together with $\overline{\text{MREQ}}$ , indicates that the current machine cycle is the opcode fetch cycle of an instruction execution. $\overline{\text{Ml}}$ , 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). $\overline{\text{NMI}}$ has a higher priority than $\overline{\text{INT}}$ . $\overline{\text{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. **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. **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 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 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. The CPU samples the $\overline{WAIT}$ input with the falling edge of clock state $T_2$ . During clock states $T_3$ and $T_4$ of an $\overline{M1}$ 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: Tw-Wait cycle added when necessary for slow ancilliary devices. Figure 5. Instruction Opcode Fetch Memory Read or Write Cycles. Figure 6 shows the timing of memory read or write cycles other than an opcode fetch $(\overline{Ml})$ cycle. The $\overline{MREQ}$ and $\overline{RD}$ signals function exactly as in the fetch cycle. In a memory write cycle, $\overline{\text{MREQ}}$ 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{\text{W}}$ pulse to most semiconductor memories. Figure 6. Memory Read or Write Cycles 2005-883 **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_w)$ . 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}^*} = \text{One Wait cycle automatically inserted by CPU}$ . Figure 7. Input or Output Cycles 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 $\overline{\rm Ml}$ cycle is generated. During this $\overline{\text{M1}}$ cycle, $\overline{\text{IORQ}}$ becomes active (instead of $\overline{\text{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 2005-884, 885 #### Non-Maskable Interrupt Request Cycle. NMI is sampled at the same time as the maskable interrupt input 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 0066H (Figure 9). <sup>\*</sup>Although $\overline{NMI}$ is an asynchronous input, to quarantee its being recognized on the following machine cycle, $\overline{NMI}$ 's falling edge must occur no later than the rising edge of the clock cycle preceding $T_{L,AST}$ . Figure 9. Non-Maskable Interrupt Request Operation 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, IORQ, RD, and 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<sub>L</sub> = Last state of any M cycle. Tx = An arbitrary clock cycle used by requesting device. Figure 10. Z-BUS Request/Acknowledge Cycle 2005-0218, 886 **Halt Acknowledge Cycle.** When the CPU receives a Halt instruction, it executes NOP states until either an $\overline{\text{INT}}$ or $\overline{\text{NMI}}$ input is received. When in the Halt state, the $\overline{\text{HALT}}$ output is active and remains so until an interrupt is received (Figure 11). NOTE. INT will also force a Halt exit. \*See note, Figure 9. Figure 11. Halt Acknowledge Cycle **Reset Cycle.** $\overline{\text{RESET}}$ must be active for at least three clock cycles for the CPU to properly accept it. As long as $\overline{\text{RESET}}$ remains active, the address and data buses float, and the control outputs are inactive. Once $\overline{\text{RESET}}$ goes inactive, three internal T cycles are consumed before the <u>CPU</u> resumes normal processing operation. <u>RESET</u> clears the PC register, so the first opcode fetch will be to location 0000 (Figure 12). Figure 12. Reset Cycle #### AC Characteristics | | | | | CPU | | CPU | | CPU† | |--------|--------------|---------------------------------------------------------------------------------------------------------------|-------------------|---------------------------------------|---------------|------------------|----------------|----------------| | Number | Symbol | Parameter | Min | Мах | Min | Max | Min | Max | | 1 | TcC | Clock Cycle Time | 400* | · · · · · · · · · · · · · · · · · · · | 250* | - | 165* | | | 2 | TwCh | Clock Pulse Width (High) | 180* | | 110* | | 65* | | | 3 | TwCl | Clock Pulse Width (Low) | 180 | 2000 | 110 | 2000 | 65 | 2000 | | 4 | TfC | Clock Fall Time | | 30 | _ | 30 | | 20 | | 5 — | -TrC | - Clock Rise Time | | <del> 30</del> | | —30 <del>—</del> | | 20 - | | 6 | TdCr(A) | Clock † to Address Valid Delay | _ | 145 | | 110 | Appendication. | 90 | | 7 | TdA(MREQf) | Address Valid to MREQ 1 Delay | 125* | _ | 65* | universe. | 35* | _ | | 8 | TdCf(MREQf) | Clock ↓ to MREQ ↓ Delay | | 100 | | 85 | | 70 | | 9 | TdCr(MREQr) | Clock † to MREQ † Delay | | 100 | | 85 | | 70 | | 10 — | -TwMREQh | -MREQ Pulse Width (High) | <del></del> 170* | | 110*· | | 65*- | | | 11 | TwMREQ1 | MREQ Pulse Width (Low) | 360* | | 220* | | 135* | | | 12 | TdCf(MREQr) | Clock ↓ to MREQ ↑ Delay | | 100 | | 85 | | 70 | | 13 | TdCf(RDf) | Clock ↓ to RD ↓ Delay | _ | 130 | | 95 | | 80 | | 14 | TdCr(RDr) | Clock $\dagger$ to $\overline{\text{RD}}$ $\dagger$ Delay | _ | 100 | | 85 | | 70 | | 15 | -TsD(Cr) | -Data Setup Time to Clock † | 50 | | 35 <b>-</b> | | 30 - | | | 16 | ThD(RDr) | Data Hold Time to $\overline{RD}$ † | - | 0 | _ | 0 | - | 0 | | 17 | TsWAIT(Cf) | WAIT Setup Time to Clock ↓ | 70 | | 70 | _ | 60 | | | 18 | ThWAIT(Cf) | WAIT Hold Time after Clock ↓ | | 0 | _ | 0 | | 0 | | 19 | TdCr(Mlf) | Clock ↑ to Ml ↓ Delay | | 130 | _ | 100 | | 80 | | 20 — | -TdCr(Mlr) | –Clock † to Ml † Delay ––––– | | <u>130</u> | | <u> </u> | | 80 | | 21 | TdCr(RFSHf) | Clock ↑ to RFSH ↓ Delay | _ | 180 | | 130 | | 110 | | 22 | TdCr(RFSHr) | Clock $\dagger$ to $\overline{RFSH}$ $\dagger$ Delay | | 150 | _ | 120 | | 100 | | 23 | TdCf(RDr) | Clock ↓ to $\overline{RD}$ ↑ Delay | | 110 | | 85 | _ | 70 | | 24 | TdCr(RDf) | Clock ↑ to $\overline{RD}$ ↓ Delay | | 100 | | 85 | | 70 | | 25 | -TsD(Cf) | -Data Setup to Clock ↓ during ——<br>M <sub>2</sub> , M <sub>3</sub> , M <sub>4</sub> or M <sub>5</sub> Cycles | <del></del> 60 | | 50 <i>-</i> - | | 40 | | | 26 | TdA(IORQf) | Address Stable prior to <del>IORQ</del> + | 320* | | 180* | | 110* | | | 27 | TdCr(IORQf) | Clock ↑ to <del>IORQ</del> ↓ Delay | | 90 | | 75 | | 65 | | 28 | TdCf(IORQr) | Clock↓to <del>IORQ</del> ↑ Delay | | 110 | | 85 | | 70 | | 29 | TdD(WRf) | Data Stable prior to $\overline{ m WR}~ floor$ | 190* | | 80* | | 25* | | | 30 — | -TdCf(WRf) | -Clock↓to WR↓Delay ——— | | 90 <del>-</del> | | 80 | | <del> 70</del> | | 31 | TwWR | WR Pulse Width | 360* | | 220* | | 135* | | | 32 | TdCf(WRr) | Clock ↓ to WR ↑ Delay | _ | 100 | | 80 | | 70 | | 33 | TdD(WRf) | Data Stable prior to $\overline{ m WR}~\downarrow$ | 20* | | -10* | | -55* | | | 34 | TdCr(WRf) | Clock ↑ to WR ↓ Delay | | 80 | | 65 | | 60 | | 35— | -TdWRr(D) | – Data Stable from WR 1 | <del></del> 120*- | | 60*- | | 30*- | | | 36 | TdCf(HALT) | Clock ↓ to HALT ↑ or ↓ | - | 300 | | 300 | | 260 | | 37 | TwNMI | NMI Pulse Width | 80 | | 80 | | 70 | | | 38 | TsBUSREQ(Cr) | BUSREQ Setup Time to Clock † | 80 | | 50 | | 50 | | <sup>\*</sup> For clock periods other than the minimums shown in the table, calculate parameters using the expressions in the table on the following page. † Units in nanoseconds (ns) All timings are preliminary and subject to change. | AC | |-------------| | Charac- | | teristics | | (Continued) | | Number | Symbol | Parameter | Z80<br>Min | CPU<br>Max | Z80A<br>Min | CPU<br>Max | Z80B<br><b>M</b> in | CPU†<br>Max | |--------|----------------|-----------------------------------------------------------------------|----------------|------------|-------------|------------|---------------------|-----------------| | 39 | ThBUSREQ(Cr) | BUSREQ Hold Time after Clock † | 0 | | 0 | | 0 | | | 40 | -TdCr(BUSACKf) | -Clock † to BUSACK Delay | | —120 — | | -100 - | | <del> 90-</del> | | 41 | TdCf(BUSACKr) | Clock ↓ to BUSACK ↑ Delay | | 110 | | 100 | | 90 | | 42 | TdCr(Dz) | Clock † to Data Float Delay | _ | 90 | | 90 | | 80 | | 43 | TdCr(CTz) | Clock † to Control Outputs Float<br>Delay (MREQ, IORQ, RD,<br>and WR) | - | 110 | | 80 | | 70 | | 44 | TdCr(Az) | Clock † to Address Float Delay | | 110 | | 90 | | 80 | | 45 — | - TdCTr(A) | -MREQ t, IORQ t, RD t, and WR t to Address Hold Time | —160* | | 80* | | 35*- | | | 46 | TsRESET(Cr) | RESET to Clock † Setup Time | 90 | | 60 | | 60 | _ | | 47 | ThRESET(Cr) | RESET to Clock † Hold Time | | 0 | | 0 | | 0 | | 48 | TsINTf(Cr) | INT to Clock † Setup Time | 80 | _ | 80 | _ | 70 | | | 49 | ThINTr(Cr) | $\overline{\text{INT}}$ to Clock ↑ Hold Time | _ | 0 | | 0 | | 0 | | 50 | -TdM1f(IORQf) | -M1 ↓ to IORQ ↓ Delay ———— | <b>-</b> 920*- | | 565* - | | 365*- | | | 51 | TdCf(IORQf) | Clock ↓ to <del>IORQ</del> ↓ Delay | _ | 110 | _ | 85 | | 70 | | 52 | TdCf(IORQr) | Clock † to $\overline{\text{IORQ}}$ † Delay | | 100 | | 85 | _ | 70 | | 53 | TdCf(D) | Clock ↓ to Data Valid Delay | | 230 | _ | 150 | | 130 | <sup>\*</sup> For clock periods other than the minimums shown in the table, calculate parameters using the following expressions. Calculated values above assumed TrC = TfC = 20 ns. † Units in nanoseconds (ns). All timings are preliminary and #### Footnotes to AC Characteristics | Number | Symbol | Z80 | Z80A | Z80B | |--------|---------------|-------------------------------------------------------------------------------|-------------------------------------------------------------------------------|--------------------------------------------------------------------------------| | 1 | TcC | TwCh + TwCl + TrC + TfC | TwCh + TwCl + TrC + TfC | TwCh + TwCl + TrC + TfC | | 2 | TwCh | Although static by design, TwCh of greater than 200 $\mu s$ is not guaranteed | Although static by design, TwCh of greater than 200 $\mu$ s is not guaranteed | Although static by design,<br>TwCh of greater than 200 μs<br>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 | TcC - 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 | TdM1f(IORQf) | 2TcC + TwCh + TfC - 80 | 2TcC + TwCh + TfC - 65 | 2TcC + TwCh + TfC - 50 | AC Test Conditions: V<sub>IH</sub> = 2 0 V V<sub>IH</sub> = 0.8 V V<sub>IHC</sub> = V<sub>CC</sub> -0.6 V V<sub>ILC</sub> = 0.45 V $V_{OH} = 2.0 \text{ V}$ $V_{OL} = 0.8 \text{ V}$ FLOAT = ±0.5 V subject to change. All timings assume equal loading on pins with $50~\mathrm{pF}$ Absolute Storage Temperature.....-65°C to +150°C Maximum Temperature Ratings under Bias ...... Specified operating range Voltages on all inputs and 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 following standard test conditions, unless otherwise noted. All voltages are referenced to GND (0 V). Positive current flows into the referenced pin. Available operating outputs with respect to ground .-0.3 V to +7 V All ac parameters assume a load capacitance of 100 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 $\blacksquare$ S\* = 0°C to +70°C, $+4.75~\mathrm{V} \leq \mathrm{V}_{\mathrm{CC}} \leq +5.25~\mathrm{V}$ ■ $E^* = -40$ °C to +85°C, +4.75 V $\leq$ V<sub>CC</sub> $\leq$ +5.25 V temperature ranges are: ■ $M^* = -55$ °C to +125°C, $+4.5 \text{ V} \le \text{V}_{CC} \le +5.5 \text{ V}$ \*See Ordering Information section for package temperature range and product number 10 10<sup>3</sup> μΑ -10 | DC | Symbol | Parameter | Min | Max | Unit | Test Condition | |----------------------|-----------------------------|---------------------------------------------|-------------------|---------------------------------------------|----------------|-----------------------------| | Character-<br>istics | $v_{\rm ILC}$ | Clock Input Low Voltage | -0.3 | 0.45 | V | | | | $v_{\mathrm{IHC}}$ | Clock Input High Voltage | V <sub>CC</sub> 6 | $V_{\rm CC}$ + .3 | V | | | | $V_{\mathrm{IL}}$ | Input Low Voltage | -0.3 | 0.8 | V | | | | $V_{\mathrm{IH}}$ | Input High Voltage | 2.0 | $v_{cc}$ | V | | | | $v_{\scriptscriptstyle OL}$ | Output Low Voltage | | 0.4 | V | $I_{OL} = 1.8 \text{ mA}$ | | | $v_{OH}$ | Output High Voltage | 2.4 | | V | $I_{OH} = -250 \mu\text{A}$ | | | $I_{CC}$ | Power Supply Current<br>Z80<br>Z80A<br>Z80B | | 150 <sup>1</sup><br>200 <sup>2</sup><br>200 | mA<br>mA<br>mA | | Input Leakage Current 3-State Output Leakage Current in Float 3 $~A_{15}\text{--}A_0,~D_7\text{--}D_0,~MREQ,~\overline{IORQ},~\overline{RD},~and~\overline{WR}$ 1. For military grade parts, $I_{\mbox{CC}}$ is 200 mÅ 2. Typical rate for Z80A is 90 mA. | Capacitance | Symbol | Parameter | Min | Max | Unit | Note | |-------------|--------------------|--------------------|-----|-----|------|------------------------------------| | | C <sub>CLOCK</sub> | Clock Capacitance | | 35 | рF | | | | $C_{IN}$ | Input Capacitance | | 5 | рF | Unmeasured pins returned to ground | | | COUT | Output Capacitance | | 10 | рF | returned to ground | $T_A = 25$ °C, f = 1 MHz $I_{LI}$ ILEAK $V_{\rm IN} = 0$ to $V_{\rm CC}$ $V_{\rm OUT} = 0.4$ to $V_{\rm CC}$ | Ordering<br>Information | Product<br>Number | Package<br>Temp | /<br>Speed | Description | Product<br>Number | Package/<br>Temp | Speed | Description | |-------------------------|-------------------|-----------------|------------|-------------------|-------------------|------------------|---------|-------------------| | | Z8400 | CE | 2.5 MHz | Z80 CPU (40-pin) | Z8400A | CMB | 4.0 MHz | Z80A CPU (40-pin) | | | Z8400 | CM | 2.5 MHz | Same as above | Z8400 <b>A</b> | CS | 4.0 MHz | Same as above | | | Z8400 | CMB | 2.5 MHz | Same as above | Z8400 <b>A</b> | DE | 4.0 MHz | Same as above | | | Z8400 | CS | 2.5 MHz | Same as above | Z8400A | DS | 4.0 MHz | Same as above | | | Z8400 | DE | 2.5 MHz | Same as above | Z8400 <b>A</b> | PE | 4.0 MHz | Same as above | | | Z8400 | DS | 2.5 MHz | Same as above | Z8400 <b>A</b> | PS | 4.0 MHz | Same as above | | | Z8400 | PE | 2.5 MHz | Same as above | Z8400B | CS | 6.0 MHz | Z80B CPU (40-pin) | | | Z8400 | PS | 2.5 MHz | Same as above | Z8400B | DS | 6.0 MHz | Same as above | | | Z8400 <b>A</b> | CE | 4.0 MHz | Z80A CPU (40-pin) | Z8400B | PS | 6.0 MHz | Same as above | | | Z8400 <b>A</b> | CM | 4.0 MHz | Same as above | | | | | <sup>\*</sup>NOTES C = Ceramic, D = Cerdip, P = Plastic, E = -40°C to +85°C, M = -55°C to +125°C, MB = -55°C to +125°C with MIL-STD-883 Class B processing, S = 0°C to +70°C ### Z8300 Low Power Z80L® CPU Central Processing Unit ### Product Specification June 1982 #### **Features** - The Z80L combines the high performance of the Z80 CPU with extremely low power consumption. It has the identical pinout and instruction set of the Z80. The result is increased reliability and lower system power requirements. This dramatic power savings makes the Z80L a natural choice for both hand-held and battery backup applications. - The Z80L CPU is offered in three versions: Z8300-1—1.0 MHz clock, 15 mA typical current consumption Z8300-2—1.5 MHz clock, 20 mA typical current consumption Z8300-3—2.5 MHz clock, 25 mA typical current consumption - The extensive instruction set contains 158 instructions, resulting in sophisticated data handling capabilities. The 78 instructions of the 8080A are included as a subset; 8080A and Z80 Family software compatibility is maintained. - The Z80L 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. Two 16-bit index registers facilitate program processing of tables and arrays. - There are three modes of high-speed interrupt processing: 8080 compatible, non-Z80 peripheral device, and Z80 Family peripheral with or without daisy chain. - On-chip dynamic memory refresh counter. Figure 1. Pin Functions Figure 2. Pin Assignments #### General Description The Z80L CPUs are fourth-generation microprocessors with exceptional computational power. They offer high system throughput and efficient memory utilization combined with extremely low power consumption. 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 allows operation in foreground-background mode or it may be reserved for very fast interrupt response. The Z80L 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 Z80L processors. Subsequent text provides more detail on the Z80L I/O controller family, registers, instruction set, interrupts and daisy chaining, CPU timing, and low power requirements. **280L Low Power Feature.** The Z80L Family offers state-of-the-art microprocessor performance with extremely low power consumption. Its low power requirement rivals comparable CMOS microprocessors. The Z80L Family's lower power consumption provides the ability to reduce system power requirements and enables its use in applications not previously possible. The Z80L is very well suited to battery backup applications or to systems operating primarily on batteries in hand-held or portable systems. Figure 3. Z80L CPU Block Diagram #### Z80L Microprocessor Family The Zilog Z80L 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 microcomputer-based systems. The Z80 Family components provide extensive support for the Z80L microprocessor. These are: - 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 peripheral devices such as printers, tape punches, and keyboards. - The CTC (Counter/Timer Circuit) features four programmable 8-bit counter/timers, each of which has an 8-bit prescaler. Each - of the four channels may be configured to operate in either counter or timer mode. - The DMA (Direct Memory Access) controller provides dual port data transfer operations and the ability to terminate 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 modes 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. - These peripherals will also be available in a low power version with the exception of the DMA. #### Z80L CPU Registers Figure 4 shows three groups of registers within the Z80L CPU. The first group consists of duplicate sets of 8-bit registers: a principal set and an alternate set (designated by '[prime], 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- 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 an additional pair of flip-flops which assists in identifying the interrupt mode at any particular time. Table 1 provides further information on these registers. #### MAIN DEGISTED SET ALTERNATE REGISTER SET F FLAG REGISTER A' ACCUMULATOR F' FLAG REGISTER A ACCUMULATOR B GENERAL PURPOSE C' GENERAL PURPOSE C GENERAL PURPOSE GENERAL PURPOSE E' GENERAL PURPOSE D GENERAL PURPOSE E GENERAL PURPOSE D' GENERAL PURPOSE L GENERAL PURPOSE H' GENERAL PURPOSE L' GENERAL PURPOSE H GENERAL PURPOSE 8 BITS 16 BITS INTERRUPT FUR-FLORS STATUS IX INDEX REGISTER IFF1 IFF2 IV INDEX REGISTER STORES IFF1 0 = INTERRUPTS DISABLED DURING NMI 1 = INTERRUPTS ENABLED SERVICE -SP STACK POINTER INTERRIPT MODE FUR FLORS PC PROGRAM COUNTER IMF. INTERRUPT MODE 0 R MEMORY REFRESH I INTERRUPT VECTOR NOT USED INTERRUPT MODE 1 INTERRUPT MODE 2 8 BITS Figure 4. CPU Registers 2001-0213 | Z80L CPU | |-------------| | Registers | | (Continued) | | Re | gister | Size (Bits) | Remarks | |----------------------|--------------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------| | A, A' | Accumulator | 8 | Stores an operand or the results of an operation. | | F, F' | Flags | 8 | See Instruction Set. | | B, B' | 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. | | Н, Н' | 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 D — 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-transparent dynamic memory refresh. Automatically incremented and placed on the address bus during each instruction fetch cycle. | | 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_1\text{-}IFF_2$ | 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. Z80L CPU Registers #### Interrupts: General Operation The CPU accepts two interrupt input signals: $\overline{\text{NMI}}$ and $\overline{\text{INT}}$ . The NMI is a non-maskable interrupt and has the highest priority. $\overline{\text{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 Z80L has a single response mode for interrupt service for the non-maskable interrupt. The maskable interrupt, $\overline{\text{INT}}$ , has three programmable response modes available. These are: ■ Mode 0 — compatible 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 $\overline{NMI}$ and $\overline{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. Interrupts: General Operation (Continued) Non-Maskable Interrupt ( $\overline{\text{NMI}}$ ). The non-maskable interrupt cannot be disabled by program control and therefore will be accepted all times by the CPU. $\overline{\text{NMI}}$ is usually reserved for servicing only the highest priority type interrupts, such as that for orderly shutdown after power failure has been detected. After recognition of the $\overline{\text{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 Z80L 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 $\overline{\text{BUSREQ}}$ is not active) a special interrupt processing cycle begins. This is a special fetch $(\overline{\text{M1}})$ cycle in which $\overline{\text{IORQ}}$ becomes active rather than $\overline{\text{MREQ}}$ , as in a normal $\overline{\text{M1}}$ cycle. In addition, this special $\overline{\text{M1}}$ cycle is automatically extended by two $\overline{\text{WAIT}}$ states, to allow for the time required to acknowledge the interrupt request and to place the interrupt vector on the bus. Mode 0 Interrupt Operation. This mode is compatible with the 8080 microprocessor interrupt service procedures. The interrupting device places an instruction on the data bus. This is normally a Restart Instruction, which a call will initiate a call to the selected one of eight restart locations in page zero of memory. **Mode 1 Interrupt Operation.** Mode 1 operation is very similar to that for the NMI. The principal difference is that the Mode 1 interrupt has a vector address of 0038H only. Mode 2 Interrupt Operation. This interrupt mode has been designed to utilize most effectively the capabilities of the Z80L 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 calls 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_0$ ) 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 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 succeeding 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 Z80L CPU will nest (queue) any pending interrupts or interrupts received while a selected peripheral is being serviced. **Interrupt Enable/Disable Operation.** Two flip-flops, IFF<sub>1</sub> and IFF<sub>2</sub>, 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 and Z80 Assembly Language Manual. | Action | IFF <sub>1</sub> | IFF <sub>2</sub> | Comments | |------------------------------|------------------|------------------|-------------------------------------------------------------------------------| | CPU Reset | 0 | 0 | Maskable interrupt<br>INT disabled | | DI instruction execution | 0 | 0 | Maskable interrupt 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 inter-<br>rupt INT disabled) | | RETN instruction execution | IFF <sub>2</sub> | • | IFF <sub>2</sub> — IFF <sub>1</sub> at completion of an NMI service routine. | Table 2. State of Flip-Flops #### Instruction Set The Z80L microprocessor has one of the most powerful and versatile instruction sets available in any 8-bit microprocessor and identical to that of the Z80. 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. The following is a summary of the Z80L instruction set and shows the assembly language mnemonic, the operation, the flag status, and gives comments on each instruction. The Z80 CPU Technical Manual (03-0029-XX) and Assembly Language Programming Manual (03-0002-XX) contain significantly more details for programming use. The instructions in Table 2 are divided into the following categories: - □ 8-bit loads - □ 16-bit loads - □ Exchanges, block transfers, and searches - □ 8-bit arithmetic and logic operations - ☐ General-purpose arithmetic and CPU control - □ 16-bit arithmetic operations - □ Rotates and shifts - ☐ 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 | Mnemonic | Symbolic<br>Operation | s | z | | Flo<br>H | ıgs | P/V | N | С | Opcode<br>76 543 210 | Hex | | No.of M<br>Cycles | | Comments | |-------------------------------------|------------------------------------------------|---|---|---|----------|-----|-----|---|---|--------------------------|------------|--------|-------------------|---------|---------------------------| | LD r, r'<br>LD r, n | r - r' | • | : | X | : | X | | • | • | 01 r r'<br>00 r 110 | | 1 2 | 1 2 | 4 7 | <u>r, r' Reg</u><br>000 B | | | r ← n | • | ٠ | А | ٠ | Λ | • | • | • | ← n → | | 2 | | | 001 C | | LD r, (HL)<br>LD r, (I <b>X</b> +d) | $r \leftarrow (HL)$<br>$r \leftarrow (IX + d)$ | : | : | X | : | X | : | : | : | 01 r 110<br>11 011 101 | | 1<br>3 | 2<br>5 | 7<br>19 | 010 D<br>011 E | | LD I, (IX+u) | r – (IX+u) | | Ť | ^ | • | Λ | ٠ | • | • | 01 r 101 | טט | 3 | 3 | 15 | 100 H | | LD r, (IY + d) | $r \leftarrow (IY + d)$ | | | х | | х | | | | + d →<br>11 111 101 | ED | 3 | 5 | 19 | 101 L<br>111 A | | LD I, (II I G) | 1 - (11 + u) | | | Λ | | Λ | | | | 01 r 110 | 1.2 | | J | 10 | 111 11 | | LD (HL), r | (HL) - r | | | х | | х | | | | ← d →<br>01 110 r | | 1 | 2 | 7 | | | LD(IX+d), r | (IX + d) ← r | • | • | X | • | X | • | • | • | 11 011 101 | DD | 3 | 5 | 19 | | | | | | | | | | | | | 01 110 r<br>← d → | | | | | | | LD(IY+d), r | (IY + d) - r | • | • | Х | • | Х | • | • | • | 11 111 101 | FD | 3 | 5 | 19 | | | | | | | | | | | | | 01 110 r<br>← d → | | | | | | | LD (HL), n | (HL) ← n | • | • | Х | • | Х | • | • | • | 00 110 110 | 36 | 2 | 3 | 10 | | | LD (IX + d), n | (IX + d) ← n | • | • | Х | | Х | | | | - n -<br>11 011 101 | DD | 4 | 5 | 19 | | | | | | | | | | | | | 00 110 110 | 36 | | | | | | | | | | | | | | | | - d -<br>- n - | | | | | | | LD $(IY + d)$ , n | $(IY + d) \leftarrow n$ | • | • | Х | • | Х | ٠ | • | • | 11 111 101<br>00 110 110 | FD<br>36 | 4 | 5 | 19 | | | | | | | | | | | | | - d - | 30 | | | | | | LD A, (BC) | A - (BC) | | | Х | | х | | | | ← n →<br>00 001 010 | 0 <b>A</b> | 1 | 2 | 7 | | | LD A, (DE) | A - (DE) | • | • | Х | • | Х | • | | • | 00 011 010 | 1A | 1 | 2 | 7 | | | LD A, (nn) | A ← (nn) | • | • | Х | • | X | • | • | • | 00 111 010<br>← n → | 3 <b>A</b> | 3 | 4 | 13 | | | | | | | | | | | | | ← n → | | | | | | | LD (BC), A<br>LD (DE), A | (BC) - A<br>(DE) - A | : | : | X | : | X | : | : | : | 00 000 010<br>00 010 010 | 02<br>12 | 1 | 2 2 | 7<br>7 | | | LD (nn), A | (nn) - A | • | • | X | • | X | • | • | • | 00 110 010 | 32 | 3 | 4 | 13 | | | | | | | | | | | | | ← n →<br>← n → | | | | | | | LD A, I | A - I | 1 | 1 | Х | 0 | Х | IFF | 0 | • | 11 101 101 | | 2 | 2 | 9 | | | LD A, R | A - R | t | 1 | x | 0 | х | IFF | 0 | | 01 010 111<br>11 101 101 | 57<br>ED | 2 | 2 | 9 | | | | | • | • | | | | | | | 01 011 111 | 5F | | | | | | LD I, A | I A | • | • | Х | • | Х | • | • | • | 11 101 101<br>01 000 111 | ED<br>47 | 2 | 2 | 9 | | | LD R, A | R - A | • | • | Х | • | Х | • | ٠ | • | 11 101 101 | ED | 2 | 2 | 9 | | | | | | | | | | | | | 01 001 111 | 4F | | | | | 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 P/V flag For an explanation of flag notation and symbols for mnemonic tables, see Symbolic Notation section following tables | 6-Bit Load<br>Froup | Mnemonic | Symbolic<br>Operation | s | z | | F1<br>H | ags | P/V | N | С | Opcode<br>76 543 210 Hex | | No.of M<br>Cycles | | Comment | <b>s</b> | |-----------------------|------------------------|-----------------------------------------------------------------------------------------------------------------|----------|------|--------|---------|--------|---------|-------|--------|----------------------------------------------------------|-----|-------------------|----------|----------------------------------------------------------------|-----------------------| | · | LD dd, nn | dd - nn | • | • | Х | • | х | • | • | • | 00 dd0 001<br>- n - | 3 | 3 | 10 | dd Pair<br>00 BC | | | | LD IX, nn | IX - nn | • | • | х | • | Х | • | • | • | - n - 11 011 101 DD 00 100 001 21 - n n - | 4 | 4 | 14 | 01 DE<br>10 HL<br>11 SP | | | | LD IY, nn | IY - nn | • | • | Х | • | х | • | • | • | 11 111 101 FD<br>00 100 001 21<br>- n - | 4 | 4 | 14 | | | | | LD HL, (nn) | H - (nn+1)<br>L - (nn) | • | • | х | • | Х | • | • | • | → n → 00 101 010 2Å → n → → n → | 3 | 5 | 16 | | | | | LD dd, (nn) | $\begin{array}{l} dd_{H} \leftarrow (nn+1) \\ dd_{L} \leftarrow (nn) \end{array}$ | • | • | Х | • | Х | • | • | • | 11 101 101 ED<br>01 dd1 011<br>← n → | 4 | 6 | 20 | | | | | LD IX, (nn) | $\begin{array}{l} IX_{H} \leftarrow (nn+1) \\ IX_{L} \leftarrow (nn) \end{array}$ | • | • | Х | • | х | • | • | • | ← n → 11 011 101 DD 00 101 010 2A ← n → | 4 | 6 | 20 | | | | | LD IY, (nn) | $\begin{array}{l} IY_{H} \leftarrow (nn+1) \\ IY_{L} \leftarrow (nn) \end{array}$ | • | • | Х | • | х | • | • | • | - n -<br>11 111 101 FD<br>00 101 010 2A<br>- n - | 4 | 6 | 20 | | | | | LD (nn), HL | (nn+1) - H<br>(nn) - L | • | • | х | • | х | • | • | • | → n →<br>00 100 010 22<br>→ n → | 3 | 5 | 16 | | | | | LD (nn), dd | $(nn+1) \leftarrow ddH$<br>$(nn) \leftarrow ddL$ | • | • | Х | • | х | • | • | • | - n -<br>11 101 101 ED<br>01 dd0 011<br>- n - | 4 | 6 | 20 | | • | | | LD (nn), IX | $(nn+1) \leftarrow IX_H$<br>$(nn) \leftarrow IX_L$ | • | • | Х | • | х | • | • | • | ← n → 11 011 101 DD 00 100 010 22 ← n → | 4 | 6 | 20 | | | | | LD (nn), IY | $(nn+1) \leftarrow IY_H$<br>$(nn) \leftarrow IY_L$ | • | • | х | • | х | • | • | • | - n -<br>11 111 101 FD<br>00 100 010 22<br>- n - | 4 | 6 | 20 | | | | | LD SP, HL<br>LD SP, IX | SP HL<br>SP IX | : | : | X<br>X | : | X<br>X | : | : | : | - n -<br>11 111 001 F9<br>11 011 101 DD<br>11 111 001 F9 | 1 2 | 1<br>2 | 6<br>10 | | | | | LD SP, IY | SP - IY | • | • | X | • | X | • | • | • | 11 111 101 FD | 2 | 2 | 10 | D | | | | PUSH qq | $(SP-2) \leftarrow qqL$<br>$(SP-1) \leftarrow qqH$<br>$SP \rightarrow SP-2$ | • | • | X | • | X | • | • | • | 11 111 001 F9<br>11 gg0 101 | 1 | 3 | 11 | 99 Pair<br>00 BC<br>01 DE<br>10 HL | | | | PUSH IX | $(SP-2) - IX_L$<br>$(SP-1) - IX_H$<br>SP - SP - 2 | • | • | Х | • | Х | • | • | • | 11 011 101 DD<br>11 100 101 ES | 2 | 4 | 15 | 11 AF | | | | PUSH IY | $(SP-2) \leftarrow IY_L$<br>$(SP-1) \leftarrow IY_H$<br>$SP \rightarrow SP-2$ | • | | Х | | | • | • | • | 11 111 101 FD<br>11 100 101 E5 | 2 | 4 | 15 | | | | | POP qq | $qqH \leftarrow (SP+1)$<br>$qqL \leftarrow (SP)$<br>$SP \rightarrow SP + 2$ | • | • | Х | • | Х | • | • | • | 11 gg0 001 | 1 | 3 | 10 | | | | | POP IX | $SP \rightarrow SP + 2$<br>$IX_H \leftarrow (SP + 1)$<br>$IX_L \leftarrow (SP)$<br>$SP \rightarrow SP + 2$ | • | • | х | • | Х | • | • | • | 11 011 101 DD<br>11 100 001 E1 | 2 | 4 | 14 | | | | | POP IY | SP - SP + 2<br>$IY_H - (SP + 1)$<br>$IY_L - (SP)$<br>SP - SP + 2 | • | • | Х | • | х | • | • | • | 11 111 101 FD<br>11 100 001 E1 | 2 | 4 | 14 | | | | | gg is a<br>(PAIR) | iny of the register pairs BC<br>iny of the register pairs AF<br>H, (PAIR)L refer to high or<br>BCL = C, AFH = A | , BC, DE | , HL | order | r eıg | ht bit | s of ti | ne re | gister | pair respectively, | | | | | | | xchange, | EX DE, HL | DE HL | • | • | Х | • | Х | | | • | 11 101 011 EB | 1 | 1 | 4 | | | | lock<br>ransfer, | EX AF, AF'<br>EXX | AF AF'<br>BC BC'<br>DE DE' | : | : | X | : | X | : | : | : | 00 001 000 08<br>11 011 001 D9 | 1 | 1 | 4 | Register bank a<br>auxiliary reg | ster | | lock Search<br>Froups | EX (SP), HL | HL HL'<br>H (SP + 1)<br>L (SP) | • | • | х | • | х | • | • | • | 11 100 011 E3 | 1 | 5 | 19 | bank exchan | ye | | Loups | EX (SP), IX | $IX_{H} \leftrightarrow (SP + 1)$ | • | • | х | • | X | • | • | • | 11 011 101 DD | 2 | 6 | 23 | | | | | EX (SP), IY | $IX_L \rightarrow (SP)$<br>$IY_H \rightarrow (SP+1)$<br>$IY_L \rightarrow (SP)$ | • | • | х | • | Х | •<br>① | • | • | 11 100 011 E3<br>11 111 101 FD<br>11 100 011 E3 | 2 | 6 | 23 | | | | | LDI | (DE) - (HL)<br>DE - DE + 1<br>HL - HL + 1<br>BC - BC - 1 | • | • | Х | 0 | Х | ī | 0 | • | 11 101 101 ED<br>10 100 000 A0 | 2 | 4 | 16 | Load (HL) into<br>(DE), increm<br>the pointers<br>decrement th | ent<br>and<br>ie byte | | | LDIR | (DE) (HL) DE DE + 1 HL HL + 1 BC BC - 1 Repeat until | • | • | х | 0 | Х | 0 | 0 | • | 11 101 101 ED<br>10 110 000 B0 | 2 2 | 5<br>4 | 21<br>16 | counter (BC) If BC ≠ 0 If BC = 0 | | NOTE $\bigcirc$ P/V flag is 0 if the result of BC - 1 = 0, otherwise P/V = 1 2001-001 | | Mnemonic | Symbolic<br>Operation | s | z | | Flag<br>H | P | /V N | C | : | Opcode<br>76 543 210 H | No<br>ex By | of<br>tes | No.of M<br>Cycles | | Comments | |----------|----------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|---------------------------------------|---------------------------------------|---------------------------------------|-------------|-----------------------------------------|-----------------------------------------|---|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|-------------|-------------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------| | rch | LDD | (DE) (HL) DE DE 1 HL HL 1 BC BC 1 | • | • | х | 0 | | D<br>I ( | ) • | • | 11 101 101 1<br>10 101 000 . | | 2 | 4 | 16 | | | ω, | LDDR | (DE) ← (HL) DE ← DE − 1 HL ← HL − 1 BC ← BC − 1 Repeat until BC = 0 | • | • | х | 0 | х | 0 ( | ) • | • | 11 101 101 1<br>10 111 000 1 | | 2 2 | 5<br>4 | 21<br>16 | If BC ≠ 0 If BC = 0 | | | CPI | A - (HL)<br>HL - HL + 1<br>BC - BC - 1 | 1 | | х | ı | Х | _ | ١ • | • | 11 101 101 1<br>10 100 001 . | | 2 | 4 | 16 | | | | CPIR | A - (HL) | 1 | 2 | Х | 1 | | ①<br>1 : | 1 • | | 11 101 101 1 | ED | 2 | 5 | 21 | If BC ≠ 0 and | | | | HL - HL+1 BC - BC-1 Repeat until A = (HL) or BC = 0 | | | | | | | | | 10 110 001 | 31 | 2 | 4 | 16 | $A \neq (HL)$ If $BC = 0$ or $A = (HL)$ | | | CPD | A - (HL)<br>HL - HL-1<br>BC - BC-1 | t | | Х | ı | Х | | 1 • | • | 11 101 101 1<br>10 101 001 | | 2 | 4 | 16 | | | | CPDR | A - (HL) | t | 2 | Х | ı | | ①<br>: | 1 • | | 11 101 101 | ED | 2 | 5 | 21 | If BC ≠ 0 and | | | | HL - HL-1 BC - BC-1 Repeat until A = (HL) or BC = 0 | | | | | | | | | 10 111 001 | | 2 | 4 | 16 | $A \neq (HL)$ If $BC = 0$ or $A = (HL)$ | | | (2) 2 Hag | i is 1 if $A = (HL)$ , otherw | | U | | | | | | | | | | | | | | | ADD A, r<br>ADD A, n | A - A + r A - A + n | 1 | : | x<br>x | | x<br>x | V 0 | | | 10 000 r<br>11 000 110 | | 1 2 | 1 2 | 4 7 | r Reg<br>000 B | | c<br>:al | ADD A, r<br>ADD A, n | A - A + r | 1 | 1 | | 1 | x<br>x | | 1 | | 11 000 110<br>- n - 10 000 110 11 011 101 10 000 110 | DD | | | | 000 B<br>001 C<br>010 D<br>011 E<br>100 H<br>101 L | | | ADD A, r<br>ADD A, n<br>ADD A, (HL)<br>ADD A, (IX+d) | A - A + r<br>A - A + n<br>A - A + (HL) | t<br>: | 1 1 | x<br>x<br>x | 1 | X<br>X<br>X | V 0<br>V 0 | : : | | 11 000 110 - n - 10 000 110 11 011 101 10 000 110 - d - 11 111 101 10 000 110 | DD<br>FD | 2 | 2 | 7 | 000 B<br>001 C<br>010 D<br>011 E<br>100 H | | | ADD A, r<br>ADD A, n<br>ADD A, (HL)<br>ADD A, (IX+d) | A - A + r $A - A + n$ $A - A + (HL)$ $A - A + (IX + d)$ | 1 1 1 1 | : : : : | x x x x x x x x x x x x x x x x x x x | : : : : : : : : : : : : : : : : : : : | x | V 0<br>V 0 | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | | 11 000 110 - n - 10 000 110 11 011 101 10 000 110 - d - 11 111 101 - d - 001 - 01 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 - 100 | | 1 3 | 2<br>2<br>5 | 7<br>7<br>19 | 000 B<br>001 C<br>010 D<br>011 E<br>100 H<br>101 L | | | ADD A, r ADD A, (HL) ADD A, (IY+d) ADD A, (IY+d) ADC A, s SUB s SBC A, s AND s OR s XOR s | A - A + r $A - A + n$ $A - A + (HL)$ $A - A + (IX + d)$ $A - A + (IY + d)$ $A - A + s + CY$ $A - A - s$ $A - A - s - CY$ CY$ $A - A - CY$ $A - A - CY$ $A $A$ | | 1 | x x x x x x x x x x x x x x x x x x x | : : : : : : : : : : : : : : : : : : : | x | V 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | | 11 000 110 - n - 10 000 110 11 011 101 10 000 110 - d - 11 111 101 10 000 110 - d - 10 101 10 100 110 100 110 100 00 110 100 100 110 11 | | 1 3 | 2<br>2<br>5 | 7<br>7<br>19 | 000 B 001 C 010 D 011 E 100 H 101 L 111 A s is any of r, n, (HL), (IX + d), (IY + d) as shown for ADD instruction The indicated bits replace the 0000 in | | | ADD A, r ADD A, (HL) ADD A, (IX+d) ADD A, (IY+d) ADC A, s SUB a SBC A, s AND s OR s CP s INC r INC (HL) | A - A + r $A - A + n$ $A - A + (HL)$ $A - A + (IX + d)$ $A - A + (IY + d)$ $A - A + S + CY$ $A - A - C$ | | ; ; ; ; ; ; ; ; ; ; ; ; ; ; ; ; ; ; ; | x x x x x x x x x x x x x x x x x x x | : : : : : : : : : : : : : : : : : : : | x | V 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | | | 11 000 110 - n - 10 000 110 11 011 101 10 000 110 - d - 11 111 101 10 000 110 - d - 10 101 10 000 110 - d - 10 101 10 000 110 1000 110 1000 110 110 | FD | 1<br>3<br>3 | 2<br>2<br>5<br>5 | 7<br>7<br>19<br>19 | 000 B 001 C 010 D 011 E 100 H 101 L 111 A s is any of r, n, (HL), (IX + d), (IY + d) as shown for ADD instruction The indicated bits replace the 0000 in | 34 2001-001 | General-<br>Purpose | Mnemonic | Symbolic<br>Operation | s | z | | Flo<br>H | gs | P/V | N | С | Opcode<br>76 543 210 Hex | | No.of M<br>Cycles | No.of T<br>States | Comments | |-------------------------------|------------------|---------------------------------------------------------------------------------------------------------|-------|------|-------|----------|--------|-----|---|--------|-------------------------------------------------------|--------|-------------------|-------------------|------------------------------------------------------------| | rithmetic<br>nd<br>PU Control | DAA | Converts acc content<br>into packed BCD<br>following add or<br>subtract with packed | 1 | 1 | Х | 1 | Х | P | • | 1 | 00 100 111 27 | 1 | 1 | 4 | Decimal adjust accumulator | | roups | CPL | BCD operands.<br>A - Ā | • | • | x | 1 | х | • | 1 | • | 00 101 111 2F | 1 | 1 | 4 | Complement accumulator (one's | | | NEG | A - 0 - A | 1 | t | X | ı | X | V | 1 | 1 | 11 101 101 ED<br>01 000 100 44 | 2 | 2 | 8 | complement). Negate acc. (two's complement) | | | CCF | $CY \leftarrow \overline{CY}$ | • | • | X | Х | X | • | 0 | 1 | 00 111 111 3F | 1 | 1 | 4 | Complement carry | | | SCF<br>NOP | CY ← 1<br>No operation | : | : | X | 0 | X<br>X | : | 0 | l<br>• | 00 110 111 37<br>00 000 000 00 | 1<br>1 | 1<br>1 | 4<br>4 | Set carry flag | | | HALT | CPU halted | • | • | X | : | Х | : | : | • | 01 110 110 76<br>11 110 011 F3 | 1 | 1 | 4 | | | | DI ★<br>EI ★ | IFF - 0<br>IFF - 1 | : | : | Х | • | X | • | : | : | 11 111 011 FB | l<br>l | 1<br>1 | 4 | | | | IM 0 | Set interrupt<br>mode 0 | • | • | Х | • | Х | • | • | • | 11 101 101 ED<br>01 000 110 46 | 2 | 2 | 8 | | | | IM 1 | Set interrupt<br>mode 1 | • | • | Х | • | Х | • | • | • | 11 101 101 ED<br>01 010 110 56 | 2 | 2 | 8 | | | | IM 2 | Set interrupt<br>mode 2 | • | • | Х | • | Х | • | • | • | 11 101 101 ED<br>01 011 110 5E | 2 | 2 | 8 | | | | CY 1 | ndicates the interrupt enable fli<br>ndicates the carry flip-flop<br>dicates interrupts are not samp | | | end o | of El c | or DI | | | | | | | | | | 6-Bit | ADD HL, ss | HL - HL+ss | • | • | х | х | х | • | 0 | 1 | 00 ssl 001 | 1 | 3 | 11 | ss Reg.<br>00 BC | | krithmetic<br>Froup | ADC HL, ss | HL - HL+ss+CY | 1 | ı | X | X | X | V | 0 | ı | 11 101 101 ED<br>01 ssl 010 | 2 | 4 | 15 | 01 DE<br>10 HL | | - | SBC HĹ, ss | HL - HL-ss-CY | 1 | ı | х | х | x | v | l | t | 11 101 101 ED | 2 | 4 | 15 | 11 SP | | | ADD IX, pp | IX - IX + pp | • | • | х | X | X | • | 0 | ı | 01 ss0 010<br>11 011 101 DD | 2 | 4 | 15 | pp Reg.<br>00 BC | | | ADD IX, pp | IY - IY + rr | • | | х | х | х | • | 0 | 1 | 01 ppl 001<br>11 111 101 FD<br>00 rrl 001 | 2 | 4 | 15 | 01 DE<br>10 IX<br>11 SP<br>rr Reg.<br>00 BC | | | INC ss | ss — ss + 1 | • | • | X | • | X | • | • | • | 00 ss0 011 | 1 | 1 | 6 | 01 DE<br>10 IY<br>11 SP | | | INC IX | IX - IX + 1 | • | • | X | • | X | • | | • | 11 011 101 DD<br>00 100 011 23 | 2 | 2 | 10 | | | | INC IY | IY IY + 1 | • | • | X | • | х | • | • | • | 11 111 101 FD<br>00 100 011 23 | 2 | 2 | 10 | | | | DEC ss<br>DEC IX | ss ss - 1<br>IX IX - 1 | : | : | X | : | X | : | : | : | 00 ssl 011<br>11 011 101 DD<br>00 101 011 2B | 1<br>2 | 1 2 | 6<br>10 | | | | DEC IY | IY - IY-1 | • | • | Х | • | X | • | • | • | 11 111 101 FD<br>00 101 011 2B | 2 | 2 | 10 | | | | pp is | any of the register pairs BC, DE<br>any of the register pairs BC, D<br>any of the register pairs BC, DE | E, IX | , SP | | | | | | | | | | | | | lotate and<br>hift Group | RLCA | CY 7 0 A | | • | х | 0 | х | • | 0 | ı | 00 000 111 07 | 1 | 1 | 4 | Rotate left circular accumulator | | | RLA | CY - 7 - 0 | • | • | x | 0 | x | • | 0 | 1 | 00 010 111 17 | 1 | 1 | 4 | Rotate left<br>accumulator | | | RRCA | 7 — 0 CY | • | • | X | 0 | X | • | 0 | ı | 00 001 111 OF | 1 | 1 | 4 | Rotate right circular accumulator | | | RRA | 7 — 0 — CY | • | • | X | 0 | х | • | 0 | t | 00 011 111 1F | 1 | 1 | 4 | Rotate right<br>accumulator | | | RLC r | | 1 | ı | х | 0 | х | P | 0 | 1 | 11 001 011 CB | 2 | 2 | 8 | Rotate left circular register r | | | RLC (HL) | | 1 | ı | X | 0 | X | P | 0 | 1 | 00 000 r<br>11 001 011 CB<br>00 000 110 | 2 | 4 | 15 | r Reg | | | RLC (IX+d) | r,(HL),(IX + d),(IY + d) | 1 | 1 | х | 0 | х | P | 0 | ī | 11 011 101 DD<br>11 001 011 CB<br>- d -<br>00 000 110 | | 6 | 23 | 001 C<br>010 D<br>011 E<br>100 H<br>101 L<br>111 A | | | RLC (IY+d) | | ı | t | x | 0 | х | P | 0 | 1 | 11 111 101 FD<br>11 001 011 CB | | 6 | 23 | ^ | | | nL m | $m = r_{i}(HL)_{i}(IX + d)_{i}(IY + d)$ | ı | 1 | х | 0 | х | P | 0 | ı | ← d → 00 000 110 | | | | Instruction format<br>and states are as<br>shown for RLC's | | | RRC m | m=r,(HL),(IX+d),(II+d) | 1 | 1 | х | 0 | x | P | 0 | | 001 | | | | To form new opcode replace | | Rotate and<br>Shift Group | Mnemonic | Symbolic<br>Operation | s | z | | Fl- | ags | P/V | N | С | Opcode<br>76 543 210 | Hex | No.of<br>Bytes | No.of M<br>Cycles | | Comments | |---------------------------|-----------------|---------------------------------------------------------------------------------------------|------|-------|-------|-----|-----|-----|---|---|-----------------------------------------------|---------------------|----------------|-------------------|----|------------------------------------------------------------------------------------------------| | Continued) | RR m | m = r, (HL), (IX + d), (IY + d) | ı | 1 | х | 0 | х | P | 0 | ı | 011 | | | | | | | | SLA m | $CY \longrightarrow 7 \longrightarrow 0 \longrightarrow 0$ $m = r,(HL),(IX + d),(IY + d)$ | 1 | 1 | Х | 0 | Х | P | 0 | 1 | 100 | | | | | | | | SRA m | m = r, (HL), (IX + d), (IY + d) | 1 | 1 | Х | 0 | Х | P | 0 | ı | 101 | | | | | | | | | $0 \rightarrow \boxed{7 \rightarrow 0} \qquad \boxed{CY}$ $m = r, (HL), (IX + d), (IY + d)$ | 1 | 1 | Х | 0 | Х | P | 0 | 1 | 111 | | | | | | | | RLD ( | 7 - 4 3 - 0 | | ı | х | 0 | Х | P | 0 | • | 11 101 101<br>01 101 111 | ED<br>6F | 2 | 5 | 18 | Rotate digit left and<br>right between<br>the accumulator | | | RRD [ | 7 - 4 3 - 0 7 - 4 3 - 0 (HL) | 1 | 1 | Х | 0 | Х | P | 0 | • | 11 101 101<br>01 100 111 | ED<br>67 | 2 | 5 | 18 | and location (HL) The content of the upper half of the accumulator is unaffected | | Bit Set, Reset | BIT b, r | $Z \leftarrow \bar{r}_b$ | х | t | х | 1 | х | х | 0 | | 11 001 011<br>01 b r | СВ | 2 | 2 | 8 | r Reg | | nd Test | BIT b, (HL) | $Z \leftarrow (\overline{HL})_b$ | X | 1 | X | 1 | X | Х | 0 | • | 11 001 011 | СВ | 2 | 3 | 12 | 001 C | | Group | BIT b, (IX+d) | $_{b} Z - (\overline{IX + d})_{b}$ | Х | 1 | X | 1 | X | х | 0 | • | 01 b 110<br>11 011 101<br>11 001 011<br>- d - | | 4 | 5 | 20 | 010 D<br>011 E<br>100 H<br>101 L | | | RIT L (IV) | $_{\mathbf{b}} \mathbf{Z} \leftarrow (\overline{\mathbf{IY}} + \mathbf{d})_{\mathbf{b}}$ | Y | | y | 1 | ¥ | х | 0 | | 01 b 110 | FD. | 4 | 5 | 20 | 111 A b Bit Tested 000 0 | | | ыг ы, (II + d) | <u>р 2 — (11 т u/b</u> | ^ | • | ^ | 1 | Λ | ^ | J | • | 11 111 101<br>11 001 011<br>- d -<br>01 b 110 | CB | * | J | 20 | 000 1<br>001 1<br>010 2<br>011 3<br>100 4<br>101 5<br>110 6 | | | SET b, r | r <sub>b</sub> - 1 | • | • | х | • | х | • | • | • | 11 001 011 | СВ | 2 | 2 | 8 | 111 7 | | | SET b, (HL) | $(HL)_b - 1$ | • | • | X | • | X | • | • | • | 11 b r<br>11 001 011<br>[1] b 110 | СВ | 2 | 4 | 15 | | | | SET b, (IX + d) | $(IX + d)_b - 1$ | • | • | Х | • | х | • | • | • | 11 011 101<br>11 001 011<br>- d - | | 4 | 6 | 23 | | | | SET b, (IY+d) | (IY + d) <sub>b</sub> - 1 | • | • | х | • | х | • | • | • | П b 110<br>11 111 101<br>11 001 011<br>- d - | | 4 | 6 | 23 | | | | RES b, m | $m_b \leftarrow 0$ $m = r, (HL),$ $(IX + d),$ $(IY + d)$ | • | • | X | • | х | • | • | • | <u>П</u> ь 110 | | | | | To form new opcode replace ii of SET b, s with iii Flags and time states for SET instruction. | | | NOTES The no | otation mb indicates bit b (0 to | 7) c | r loc | ation | m | | | | | | Salasana emerchan A | | | | | | lump | JP nn | PC - nn | • | • | х | • | х | | | | 11 000 011<br>- n - | СЗ | 3 | 3 | 10 | | | Group | JP cc, nn | If condition cc is true PC — nn, otherwise continue | • | • | X | • | х | • | • | • | - n - 11 cc 010 - n n - | | 3 | 3 | | Condition | | | JR e | PC - PC+e | • | • | X | • | х | ٠ | • | • | 00 011 000 | 18 | 2 | 3 | | 110 P sign positive 111 M sign negative | | | JR C, e | If C = 0, continue | • | • | Х | • | х | • | • | • | - e-2 -<br>00 111 000<br>- e-2 - | 38 | 2 | 2 | | If condition not met | | | ID 110 | If C = 1,<br>PC - PC+e | | | | | | | | | 00 1 | | 2 | 3 | | If condition is met | | | JR NC, e | If C = 1,<br>continue<br>If C = 0, | • | • | Х | • | Х | • | • | • | 00 110 000<br>- e-2 - | 30 | 2 | 3 | | If condition not met. If condition is met. | | | JP Z, e | $PC \leftarrow PC + e$ If $Z = 0$ continue | • | • | x | • | X | • | • | • | 00 101 000<br>- e-2 → | 28 | 2 | 2 | | If condition not met. | | | | If Z = 1,<br>PC - PC+e | | | | | | | | | | | 2 | 3 | 12 | If condition is met | | | JR NZ, e | If Z = 1,<br>continue<br>If Z = 0, | • | • | X | • | Х | • | • | • | 00 100 000<br>- e-2 - | 20 | 2 | 2 | | If condition not met | | | | PC - PC+e | | | | | | | | | | | 1 | 1 | 4 | i condition is thet | | | JP (HL) | PC - HL | • | | Х | • | Х | • | • | | 11 101 001 | | | | | | | Jump Group<br>(Continued) | Mnemonic | Symbolic<br>Operation | s | z | | Fle<br>H | ags | P/V | N ( | c | | Opco<br>543 | | Hex | No.of<br>Bytes | No.of M<br>Cycles | | Comments | |---------------------------|-------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|-------|-----------------------|---------------|-----------------------|-----------------|---------------------------------------|------------------|--------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------|-------------------------------|--------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Continued) | JP (IY) | PC - IY | • | • | Х | • | Х | • | • | • | | | | FD | 2 | 2 | 8 | | | | DJNZ, e | B - B-1 | • | • | Х | • | Х | • | • | • | 00 | 010 | 000 | E9 | 2 | 2 | 8 | If $B = 0$ | | | | If $B = 0$ , continue | | | | | | | | | - | e - | 2 - | | | | | | | | | If B ≠ 0,<br>PC ← PC+e | | | | | | | | | | | | | 2 | 3 | 13 | If B ≠ 0 | | | e is a s | esents the extension in the re<br>signed two's complement nur<br>in the opcode provides an effi- | nber 1 | n the | rang | e < | -126 | ), 129<br>PC is | ><br>incr | ement | ed | | | | | | | da an ann an a | | | by î | 2 prior to the addition of e | | | | | | | | | | | | | | | | | | Call and<br>Return Group | CALL nn | (SP-1) PC <sub>H</sub><br>(SP-2) PC <sub>L</sub><br>PC nn | • | • | Х | • | Х | • | • | • | 11<br>- | n | 101 | CD | 3 | 5 | 17 | | | | CALL cc, nn | If condition<br>cc is false | • | • | Х | • | Х | • | • | • | 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 | $\begin{array}{l} PC_{L} \leftarrow (SP) \\ PC_{H} \leftarrow (SP+1) \end{array}$ | • | • | Х | • | Х | • | • | • | 11 | 001 | 001 | C9 | 1 | 3 | 10 | | | | RET cc | If condition | • | • | Х | • | Х | • | • | • | 11 | cc | 000 | | 1 | 1 | 5 | If cc is false | | | | cc is false<br>continue, | | | | | | | | | | | | | 1 | 3 | 11 | If cc is true | | | | otherwise<br>same as<br>RET | | | | | | | | | | | | | | | | cc Condition 000 NZ non-zero 001 Z zero | | | RETI | Return from<br>interrupt | • | • | Х | • | Х | • | • | • | | 101<br>001 | | ED<br>4D | 2 | 4 | 14 | 010 NC non-carry<br>011 C carry | | | RETNl | Return from<br>non-maskable<br>interrupt | • | • | Х | • | Х | • | • | • | 11 | 101 | 101 | ED<br>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) - PC <sub>H</sub><br>(SP-2) - PC <sub>L</sub> | • | • | х | • | х | • | • | • | 11 | t | 111 | | 1 | 3 | 11 | t p<br>000 00H | | | | PC <sub>L</sub> - p | | | | | | | | | | | | | | | | 001 08H<br>010 10H<br>011 18H<br>100 20H | | | | | | | | | | | | | | | | | | | | 101 28H<br>110 30H<br>111 38H | | | NOTE 'RETN I | oeds IFF2 → IFF1 | | | | | - | | | <del></del> | | | | | | | | 110 30H | | | IN A, (n) | oads IFF <sub>2</sub> — IFF <sub>1</sub> $A = (n)$ | • | • | x | • | х | • | • | • | | | | DB | 2 | 3 | 11 | 110 30H<br>111 38H<br>n to A <sub>0</sub> ~ A <sub>7</sub> | | | IN A, (n) | | • | • : | x<br>x | | x<br>x | •<br>P | • 0 | • | 11 | n | 101 | ED | 2 2 | 3 | 11 12 | 110 30H<br>111 38H | | Input and<br>Output Group | IN A, (n) | A - (n)<br>r - (C)<br>if $r = 110$ only the flags will be affected<br>(HL) - (C)<br>B - B - 1 | • t | 0 | х | 1 | х | •<br>P | | | 11<br>01 | n<br>101<br>r | 101 | ED | | | | 110 30H<br>111 38H<br>n to A <sub>0</sub> ~ A <sub>7</sub><br>Acc to A <sub>8</sub> ~ A <sub>15</sub><br>C to A <sub>0</sub> ~ A <sub>7</sub> | | | IN A, (n) IN r, (C) | A-(n)<br>r-(C)<br>if $r=110$ only the<br>flags will be affected<br>(HL) $-(C)$<br>B-B-1<br>HL $-HL+1$<br>(HL) $-(C)$ | | 1 | x<br>x | ı<br>X | x<br>x | | ı | х | 11<br>01<br>11<br>10 | n<br>101<br>r<br>101<br>100 | 101<br>000<br>101<br>010 | ED ED A2 ED | 2 | 3<br>4<br>5 | 12 | n to A <sub>0</sub> ~ A <sub>7</sub> Acc to A <sub>8</sub> ~ A <sub>15</sub> C to A <sub>0</sub> ~ A <sub>7</sub> B to A <sub>8</sub> ~ A <sub>15</sub> C to A <sub>0</sub> ~ A <sub>7</sub> B to A <sub>8</sub> ~ A <sub>15</sub> C to A <sub>0</sub> ~ A <sub>7</sub> C to A <sub>0</sub> ~ A <sub>7</sub> C to A <sub>0</sub> ~ A <sub>7</sub> C to A <sub>0</sub> ~ A <sub>7</sub> C to A <sub>0</sub> ~ A <sub>7</sub> C to A <sub>0</sub> ~ A <sub>7</sub> | | | IN A, (n) IN r, (C) INI | A-(n) $r-(C)$ if $r=110$ only the flags will be affected $(HL)-(C)$ $B-B-1$ $HL-HL+1$ | | 1 | x<br>x | ı<br>X | x<br>x | х | ı | х | 11<br>01<br>11<br>10 | n<br>101<br>r<br>101<br>100 | 101<br>000<br>101<br>010 | ED ED A2 | 2 | 3 | 12 | n to A <sub>0</sub> ~ A <sub>7</sub> Acc to A <sub>8</sub> ~ A <sub>15</sub> C to A <sub>0</sub> ~ A <sub>7</sub> B to A <sub>8</sub> ~ A <sub>15</sub> C to A <sub>0</sub> ~ A <sub>7</sub> B to A <sub>8</sub> ~ A <sub>15</sub> | | | IN A, (n) IN r, (C) INI | A - (n) r - (C) if r = 110 only the flags will be affected (HL) - (C) B - B - 1 HL - HL + 1 (HL) - (C) B - B - 1 HL - HL + 1 Repeat until B = 0 (HL) - (C) B - B - 1 | | 1 | x<br>x | x<br>x | x<br>x | х | 1 | x<br>x | 11<br>01<br>11<br>10<br>11<br>10 | n<br>101<br>r<br>101<br>100<br>101<br>110 | 101<br>000<br>101<br>010 | ED ED A2 ED | 2 2 | 3 4 5 (If B≠0) 4 | 12<br>16<br>21 | n to A <sub>0</sub> ~ A <sub>7</sub> Acc to A <sub>8</sub> ~ A <sub>15</sub> C to A <sub>0</sub> ~ A <sub>7</sub> B to A <sub>8</sub> ~ A <sub>15</sub> C to A <sub>0</sub> ~ A <sub>7</sub> B to A <sub>8</sub> ~ A <sub>15</sub> C to A <sub>0</sub> ~ A <sub>7</sub> C to A <sub>0</sub> ~ A <sub>7</sub> C to A <sub>0</sub> ~ A <sub>7</sub> C to A <sub>0</sub> ~ A <sub>7</sub> C to A <sub>0</sub> ~ A <sub>7</sub> C to A <sub>0</sub> ~ A <sub>7</sub> | | | IN A, (n) IN r, (C) INI INI | A - (n) r - (C) if r = 110 only the flags will be affected (HL) - (C) B - B - 1 HL - HL + 1 (HL) - (C) B - B - 1 HL - HL + 1 Repeat until B = 0 (HL) - (C) B - B - 1 HL - HL - (C) HL - HL - (C) HL - HL - (C) | x<br>x | | x<br>x<br>x | x<br>x<br>x | x<br>x<br>x | x<br>x | 1 | x<br>x | 11 10 11 10 11 10 11 | 101<br>r<br>101<br>100<br>101<br>110<br>101<br>101 | 101<br>000<br>101<br>010<br>101<br>010 | ED ED ED B2 | 2 2 2 | $\begin{matrix} 3 \\ \\ 4 \\ \\ 5 \\ (\text{If } B \neq 0) \\ \\ 4 \\ (\text{If } B = 0) \end{matrix}$ | 12<br>16<br>21<br>16 | 110 30H 111 38H n to A <sub>0</sub> ~ A <sub>7</sub> Acc to A <sub>8</sub> ~ A <sub>15</sub> C to A <sub>0</sub> ~ A <sub>7</sub> B to A <sub>8</sub> ~ A <sub>15</sub> C to A <sub>0</sub> ~ A <sub>7</sub> B to A <sub>8</sub> ~ A <sub>15</sub> C to A <sub>0</sub> ~ A <sub>7</sub> B to A <sub>8</sub> ~ A <sub>15</sub> C to A <sub>0</sub> ~ A <sub>7</sub> B to A <sub>8</sub> ~ A <sub>15</sub> C to A <sub>0</sub> ~ A <sub>7</sub> B to A <sub>8</sub> ~ A <sub>15</sub> | | | IN A, (n) IN r, (C) INI INIR | A - (n) r - (C) if r = 110 only the flags will be affected (HL) - (C) B - B - 1 HL - HL + 1 (HL) - (C) B - B - 1 HL - HL + 1 Repeat until B = 0 (HL) - (C) B - B - 1 HL - HL - 1 (HL) - (C) B - B - 1 HL - HL - 1 (HL) - (C) B - B - 1 HL - HL - 1 Repeat until | x<br>x | | x<br>x<br>x | x<br>x<br>x | x<br>x<br>x | x<br>x | 1 | x<br>x | 11 10 11 10 11 10 11 | 101<br>r<br>101<br>100<br>101<br>110<br>101<br>101 | 101<br>000<br>101<br>010<br>101<br>010 | ED A2 ED B2 ED AA | 2<br>2<br>2<br>2 | 3<br>4<br>5<br>(If B≠0)<br>4<br>(If B=0) | 12<br>16<br>21<br>16 | n to A <sub>0</sub> ~ A <sub>7</sub> Acc to A <sub>8</sub> ~ A <sub>15</sub> C to A <sub>0</sub> ~ A <sub>7</sub> B to A <sub>8</sub> ~ A <sub>15</sub> C to A <sub>0</sub> ~ A <sub>7</sub> B to A <sub>8</sub> ~ A <sub>15</sub> C to A <sub>0</sub> ~ A <sub>7</sub> B to A <sub>8</sub> ~ A <sub>15</sub> C to A <sub>0</sub> ~ A <sub>7</sub> B to A <sub>8</sub> ~ A <sub>15</sub> C to A <sub>0</sub> ~ A <sub>7</sub> B to A <sub>8</sub> ~ A <sub>15</sub> | | | IN A, (n) IN r, (C) INI INIR | $\begin{array}{lll} A-(n) \\ r-(C) \\ \text{if } r=110 \text{ only the flags will be affected} \\ (HL)-(C) \\ B-B-1 \\ HL-HL+1 \\ (HL)-(C) \\ B-B-1 \\ HL-HL+1 \\ \text{Repeat until } \\ B=0 \\ (HL)-(C) \\ B-B-1 \\ HL-HL-1 \\ (HL)-(C) \\ B-B-1 \\ HL-HL-1 \\ (HL)-(C) \\ HL-HL-1 \\ (HL)-(C) \\ HL-HL-1 \\ (HL)-(C) \\ HL-HL-1 \\ (HL)-(C) \\ HL-HL-1 \\ (HL)-(C) \\ HL-HL-1 \\ (HL)-(C) \\ HL-HL-1 \\ (HL-HL-1) \\$ | x<br>x | | x<br>x<br>x | x<br>x<br>x | x<br>x<br>x | x<br>x<br>x | 1 | x<br>x<br>x | 111 01 11 10 11 10 11 10 11 10 11 10 11 10 11 10 11 10 11 10 11 10 11 11 | n 101 r 101 100 101 111 101 111 101 111 101 111 101 111 101 101 111 101 111 101 101 111 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 101 10 | 101<br>000<br>101<br>010<br>101<br>010 | ED ED ED B2 | 2<br>2<br>2<br>2<br>2 | 3 4 5 (If B≠0) 4 (If B=0) 4 5 (If B≠0) 4 | 12<br>16<br>21<br>16<br>16<br>21 | n to A <sub>0</sub> ~ A <sub>7</sub> Acc to A <sub>8</sub> ~ A <sub>15</sub> C to A <sub>0</sub> ~ A <sub>7</sub> B to A <sub>8</sub> ~ A <sub>15</sub> C to A <sub>0</sub> ~ A <sub>7</sub> B to A <sub>8</sub> ~ A <sub>15</sub> C to A <sub>0</sub> ~ A <sub>7</sub> B to A <sub>8</sub> ~ A <sub>15</sub> C to A <sub>0</sub> ~ A <sub>7</sub> B to A <sub>8</sub> ~ A <sub>15</sub> C to A <sub>0</sub> ~ A <sub>7</sub> B to A <sub>8</sub> ~ A <sub>15</sub> C to A <sub>0</sub> ~ A <sub>7</sub> B to A <sub>8</sub> ~ A <sub>15</sub> C to A <sub>0</sub> ~ A <sub>7</sub> B to A <sub>8</sub> ~ A <sub>15</sub> C to A <sub>0</sub> ~ A <sub>7</sub> B to A <sub>8</sub> ~ A <sub>15</sub> | | | IN A, (n) IN r, (C) INI INIR IND | $ A-(n) \\ r-(C) \\ \text{if } r=110 \text{ only the flags will be affected} \\ (HL)-(C) \\ B-B-1 \\ HL-HL+1 \\ (HL)-(C) \\ B-B-1 \\ HL-HL+1 \\ Repeat until \\ B=0 \\ (HL)-(C) \\ B-B-1 \\ HL-HL-1 \\ (HL)-(C) \\ B-B-1 \\ HL-HL-1 \\ (HL)-(C) \\ B-B-1 \\ HL-HL-1 \\ (HL)-(C) \\ B-B-1 \\ HL-HL-1 \\ (HL)-(D) \\ B-B-1 \\ HL-HL-1 \\ (HL-HL-1) (HL-1) (HL-1)$ | x x | | x<br>x<br>x<br>x | x x x | x<br>x<br>x<br>x | x<br>x<br>x | ;<br>; | x<br>x<br>x<br>x | 111 01 11 10 11 10 11 10 11 11 10 11 11 | n 101 r 101 100 101 111 101 101 111 101 10 | 101<br>000<br>101<br>101<br>010<br>101<br>010 | ED ED A2 ED B2 ED AA ED BA | 2<br>2<br>2<br>2<br>2<br>2 | $\begin{array}{c} 3 \\ 4 \\ 5 \\ (\text{If } B \neq 0) \\ 4 \\ (\text{If } B = 0) \\ 4 \\ (\text{If } B \neq 0) \\ 4 \\ (\text{If } B = 0) \end{array}$ | 12<br>16<br>21<br>16<br>16<br>21<br>16 | n to A <sub>0</sub> ~ A <sub>7</sub> Acc to A <sub>8</sub> ~ A <sub>15</sub> C to A <sub>0</sub> ~ A <sub>7</sub> B to A <sub>8</sub> ~ A <sub>15</sub> C to A <sub>0</sub> ~ A <sub>7</sub> B to A <sub>8</sub> ~ A <sub>15</sub> C to A <sub>0</sub> ~ A <sub>7</sub> B to A <sub>8</sub> ~ A <sub>15</sub> C to A <sub>0</sub> ~ A <sub>7</sub> B to A <sub>8</sub> ~ A <sub>15</sub> C to A <sub>0</sub> ~ A <sub>7</sub> B to A <sub>8</sub> ~ A <sub>15</sub> C to A <sub>0</sub> ~ A <sub>7</sub> B to A <sub>8</sub> ~ A <sub>15</sub> | | | IN A, (n) IN r, (C) INI INIR IND INDR | A - (n) r - (C) if r = 110 only the flags will be affected (HL) - (C) B - B - 1 HL - HL + 1 (HL) - (C) B - B - 1 HL - HL + 1 Repeat until B = 0 (HL) - (C) B - B - 1 HL - HL - 1 (HL) - (C) B - B - 1 HL - HL - 1 (HL) - (C) CO B - B - 1 HL - HL - 1 (HL) - (C) CO CO CO CO CO CO CO CO CO | x<br>x | | x<br>x<br>x<br>x | x x x | x<br>x<br>x<br>x | x<br>x<br>x | ;<br>; | x<br>x<br>x<br>x | 111 01 11 10 11 11 10 11 11 11 11 11 11 | 101 r 101 100 101 111 010 n n 101 r 101 101 r | 101<br>000<br>101<br>101<br>010<br>101<br>010 | ED ED A2 ED B2 ED AA ED BA | 2<br>2<br>2<br>2<br>2<br>2<br>2 | $\begin{array}{c} 3 \\ \\ 4 \\ \\ 5 \\ (\text{If } B \neq 0) \\ \\ 4 \\ (\text{If } B = 0) \\ \\ 4 \\ \\ (\text{If } B \neq 0) \\ \\ 4 \\ \\ (\text{If } B = 0) \\ \\ 3 \end{array}$ | 12<br>16<br>21<br>16<br>16<br>21<br>16 | n to A <sub>0</sub> ~ A <sub>7</sub> Acc to A <sub>8</sub> ~ A <sub>15</sub> C to A <sub>0</sub> ~ A <sub>7</sub> B to A <sub>8</sub> ~ A <sub>15</sub> C to A <sub>0</sub> ~ A <sub>7</sub> B to A <sub>8</sub> ~ A <sub>15</sub> C to A <sub>0</sub> ~ A <sub>7</sub> B to A <sub>8</sub> ~ A <sub>15</sub> C to A <sub>0</sub> ~ A <sub>7</sub> B to A <sub>8</sub> ~ A <sub>15</sub> C to A <sub>0</sub> ~ A <sub>7</sub> B to A <sub>8</sub> ~ A <sub>15</sub> C to A <sub>0</sub> ~ A <sub>7</sub> B to A <sub>8</sub> ~ A <sub>15</sub> C to A <sub>0</sub> ~ A <sub>7</sub> B to A <sub>8</sub> ~ A <sub>15</sub> C to A <sub>0</sub> ~ A <sub>7</sub> | | | IN A, (n) IN r, (C) INI INIR IND INDR OUT (n), A OUT (C), r | A - (n) r - (C) if r = 110 only the flags will be affected (HL) - (C) B - B - 1 HL - HL + 1 (HL) - (C) B - B - 1 HL - HL + 1 Repeat until B = 0 (HL) - (C) B - B - 1 HL - HL - 1 (HL) - (C) B - B - 1 HL - HL - 1 (HL) - (C) C - (C) C - (C) - (HL) | x x x x | | x<br>x<br>x<br>x<br>x | x x x x x x x | x<br>x<br>x<br>x<br>x | x<br>x<br>x | I I I I I I I I I I I I I I I I I I I | x x x x x | 111 01 11 10 11 11 10 11 11 10 11 11 10 11 11 | 101 r 101 100 101 111 101 101 101 101 10 | 101<br>000<br>101<br>010<br>101<br>010<br>101<br>010<br>101<br>101 | ED A2 ED B2 ED AA ED BA ED BA | 2<br>2<br>2<br>2<br>2<br>2<br>2<br>2 | 3 4 5 (If $B \neq 0$ ) 4 (If $B = 0$ ) 4 5 (If $B \neq 0$ ) 4 (If $B = 0$ ) 3 3 | 12<br>16<br>21<br>16<br>16<br>21<br>16<br>11 | 110 30H 111 38H n to A <sub>0</sub> ~ A <sub>7</sub> Acc to A <sub>8</sub> ~ A <sub>15</sub> C to A <sub>0</sub> ~ A <sub>7</sub> B to A <sub>8</sub> ~ A <sub>15</sub> C to A <sub>0</sub> ~ A <sub>7</sub> B to A <sub>8</sub> ~ A <sub>15</sub> C to A <sub>0</sub> ~ A <sub>7</sub> B to A <sub>8</sub> ~ A <sub>15</sub> C to A <sub>0</sub> ~ A <sub>7</sub> B to A <sub>8</sub> ~ A <sub>15</sub> C to A <sub>0</sub> ~ A <sub>7</sub> B to A <sub>8</sub> ~ A <sub>15</sub> C to A <sub>0</sub> ~ A <sub>7</sub> B to A <sub>8</sub> ~ A <sub>15</sub> C to A <sub>0</sub> ~ A <sub>7</sub> B to A <sub>8</sub> ~ A <sub>15</sub> C to A <sub>0</sub> ~ A <sub>7</sub> B to A <sub>8</sub> ~ A <sub>15</sub> C to A <sub>0</sub> ~ A <sub>7</sub> Acc to A <sub>8</sub> ~ A <sub>15</sub> C to A <sub>0</sub> ~ A <sub>7</sub> B to A <sub>8</sub> ~ A <sub>15</sub> C to A <sub>0</sub> ~ A <sub>7</sub> B to A <sub>8</sub> ~ A <sub>15</sub> | NOTE ① If the result of B-1 is zero the Z flag is set, otherwise it is reset ② N Flag is 1 if data bit is 1, othewise N Flag is 0 2001-001 | and<br>at Group Mnemonic | Symbolic<br>Operation | s | z | | F | Flags<br>i | | / <b>V</b> | N | С | Opcode<br>76 543 210 Hex | | No.of M<br>Cycles | | Comments | |--------------------------|--------------------------------------------------------|---|---|-----|---|------------|---|------------|---|---|-----------------------------|---|--------------------------------|----------|-------------------------------------------------------------------------------| | nued) OTDR | (C) - (HL)<br>B - B - 1<br>HL - HL - 1<br>Repeat until | Х | 1 | ı X | 2 | х х | < | Х | 1 | Х | 11 101 101 ED<br>10 111 011 | 2 | 5<br>(If B≠0)<br>4<br>(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> | ### Summary of Flag Operation | Instruction | D <sub>7</sub><br>S | z | | н | | P/V | N | D <sub>0</sub> | Comments | |-----------------------------------------------------|---------------------|---|---|---|---|-----|---|----------------|---------------------------------------------------------------------------------------------------------------| | ADD A, s, ADC A, s | 1 | 1 | Х | t | Х | V | 0 | t | 8-bit add or add with carry | | SUB s, SBC A, s, CP s, NEG | 1 | 1 | Х | 1 | Х | V | 1 | 1 | 8-bit subtract, subtract with carry, compare and negate accumulator | | AND s | 1 | t | Х | 1 | Х | P | 0 | 0 ) | | | OR s, XOR s | 1 | 1 | Х | 0 | Х | P | 0 | 0 | Logical operations | | INC s | 1 | 1 | Х | 1 | Х | V | 0 | • | 8-bit increment | | DEC s | 1 | 1 | Х | 1 | Х | V | 1 | • | 8-bit decrement | | ADD DD, ss | • | • | Х | Х | Х | • | 0 | 1 | 16-bit add | | ADC HL, ss | 1 | 1 | Х | Х | Х | V | 0 | 1 | 16-bit add with carry | | SBC HL, ss | 1 | 1 | Х | Х | Х | V | 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 | 1 | Х | 0 | Х | P | Q | 1 | Rotate and shift locations | | RLD, RRD | 1 | 1 | Х | 0 | Х | P | 0 | • | Rotate digit left and right | | DAA | 1 | 1 | Х | 1 | Х | P | • | 1 | Decimal adjust accumulator | | CPL | • | • | Х | 1 | Х | • | 1 | • | Complement accumulator | | SCF | • | • | Х | 0 | Х | • | 0 | 1 | Set carry | | CCF | • | • | Х | Х | Х | • | 0 | 1 | Complement carry | | IN r (C) | ı | 1 | Х | 0 | Х | P | 0 | • | Input register indirect | | INI, IND, OUTI, OUTD | Х | 1 | Х | Х | Х | Х | 1 | • 1 | Block input and output $Z = 0$ if $B \neq 0$ otherwise $Z = 0$ | | INIR, INDR, OTIR, OTDR | Х | 1 | Х | Х | Х | Х | 1 | • j | Block input and output Z = 0 ii B ≠ 0 otherwise Z = 0 | | LDI, LDD | Х | Х | Х | 0 | Х | 1 | 0 | • 1 | Block transfer instructions $P/V = 1$ if $BC \neq 0$ , otherwise $P/V = 0$ | | LDIR, LDDR | Х | Х | Х | 0 | Х | 0 | 0 | • } | block transfer instructions $F/V = 1$ if $BC \neq 0$ , otherwise $F/V = 0$ | | CPI, CPIR, CPD, CPDR | Х | 1 | Х | Х | Х | 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 | Х | ı | Х | 1 | Х | X | 0 | • | The state of bit b of location s is copied into the Z flag | 11 R nn ## Symbolic Notation Symbol | 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/ <b>V</b> | Parity or overflow flag. Parity (P) and overflow | | | (V) share the same flag. Logical operations affect | | | 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 = | | | 1 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. | | H | 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- | | 14 | | | | 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. | | C | • | | С | Carry/Link flag. $C = 1$ if the operation produced | | | a carry from the MSB of the operand or result. | | | | Operation | Symbol | Operation | |--------|-----------------------------------------------------| | 1 | The flag is affected according to the result of the | | | operation. | | • | The flag is unchanged by the operation | | 0 | The flag is reset by the operation | | 1 | The flag is set by the operation | | X | The flag is a "don't care." | | V | P/V flag affected according to the overflow result | | | of the operation. | | P | P/V flag affected according to the parity result of | | | the operation | | r | Any one of the CPU registers A, B, C, D, E, H, L. | | 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. | | 11 | Any one of the two index registers IX or IY. | | D | P ( ) | Refresh counter 8-bit value in range < 0, 255 >. 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 Low). Bus Acknowledge indicates to the requesting device that the CPU address bus, data bus, and control signals MREQ, IORQ, 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_0$ - $D_7$ . Data Bus (input/output, active High, 3-state). $D_0$ - $D_7$ constitute an 8-bit 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. ĪNT. 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. ĪNT is normally wire-ORed and requires an external pullup for these applications. $\overline{\text{IORQ}}$ . Input/Output Request (output, active Low, 3-state). $\overline{\text{IORQ}}$ indicates that the lower half of the address bus holds a valid I/O address for an I/O read or write operation. $\overline{\text{IORQ}}$ is also generated concurrently with $\overline{\text{MI}}$ during an interrupt acknowledge cycle to indicate that an interrupt response vector can be placed on the data bus. $\overline{\text{Ml.}}$ Machine Cycle One (output, active Low). $\overline{\text{Ml}}$ , together with $\overline{\text{MREQ}}$ , indicates that the current machine cycle is the opcode fetch cycle of an instruction execution. $\overline{\text{Ml}}$ , 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, active Low, 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. **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. **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 CPU executes instructions by proceeding through a specific sequence of operations: - Memory read or write - I/O device read or write - Interrupt acknowledge 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 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. The CPU samples the $\overline{WAIT}$ input with the falling edge of clock state $T_2$ . During clock states $T_3$ and $T_4$ of an M1 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_{\mathbf{w}}$ -Wait cycle added when necessary for slow ancilliary devices Figure 5. Instruction Opcode Fetch 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{MREQ}}$ 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/W pulse to most semiconductor memories. Figure 6. Memory Read or Write Cycles 2005-883 **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_w)$ . 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}^*}$ = One Wait cycle automatically inserted by CPU. Figure 7. Input or Output Cycles 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 $\overline{\rm Ml}$ cycle is generated. During this $\overline{\text{Ml}}$ cycle, $\overline{\text{IORQ}}$ becomes active (instead of $\overline{\text{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 42 2005-884, 885 Non-Maskable Interrupt Request Cycle. NMI is sampled at the same time as the maskable interrupt input INT but has higher priority and cannot be disabled under software control. The subsequent timing is similar to that of a normal memory read operation except that data put on the bus by the memory is ignored. The CPU instead executes a restart (RST) operation and jumps to the $\overline{\text{NMI}}$ service routine located at address 0066H (Figure 9). <sup>\*</sup>Although $\overline{NMI}$ is an asynchronous input, to guarantee its being recognized on the following machine cycle, $\overline{NMI}$ 's falling edge must occur no later than the rising edge of the clock cycle preceding $T_{\mbox{\scriptsize LAST}}$ Figure 9. Non-Maskable Interrupt Request Operation **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, IORQ, RD, and 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 TL = Last state of any M cycle $T_X$ = An arbitrary clock cycle used by requesting device Figure 10. Z-BUS Request/Acknowledge Cycle 2005-0218, 886 Halt Acknowledge Cycle. When the CPU receives a $\overline{HALT}$ instruction, it executes NOP states until either an $\overline{INT}$ or $\overline{NMI}$ input is received. When in the Halt state, the $\overline{\text{HALT}}$ output is active and remains so until an interrupt is processed (Figure 11). NOTE INT will also force a Halt exit. \*See note, Figure 9 Figure 11. Halt Acknowledge Cycle **Reset Cycle.** $\overline{\text{RESET}}$ must be active for at least three clock cycles for the CPU to properly accept it. As long as $\overline{\text{RESET}}$ remains active, the address and data buses float, and the control outputs are inactive. Once $\overline{\text{RESET}}$ goes inactive, two 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 12. Reset Cycle #### AC Characteristics† | | | | | MHz) | | MHz) | (2.5 | Z8300-3<br>(2.5 MHz)<br>Min Max | | |--------|--------------|---------------------------------------------------------------------------------------------------------------|--------------------|-----------------|--------------------|----------------------------|-------------------|---------------------------------|--| | Number | Symbol | Parameter | (ns) | (ns) | (ns) | (ns) | (ns) | (ns) | | | 1 | TcC | Clock Cycle Time | 1000* | | 650* | | 400* | | | | 2 | TwCh | Clock Pulse Width (High) | 470* | | 300* | | 180* | | | | 3 | TwCl | Clock Pulse Width (Low) | 470 | 2000 | 300 | 2000 | 180 | 2000 | | | 4 | TfC | Clock Fall Time | | 30 | _ | 30 | | 30 | | | 5— | TrC — | Clock Rise Time | | 30- | | <del></del> 30 <del></del> | | <del></del> 30 | | | 6 | TdCr(A) | Clock † to Address Valid Delay | _ | 380 | _ | 250 | - | 145 | | | 7 | TdA(MREQf) | Address Valid to MREQ<br>↓ Delay | 370* | _ | 200* | | 125* | _ | | | 8 | TdCf(MREQf) | Clock ↓ to MREQ ↓ Delay | _ | 260 | | 170 | | 100 | | | 9 | TdCr(MREQr) | Clock † to MREQ † Delay | | 260 | | 170 | | 100 | | | 10 — | -TwMREQh | - MREQ Pulse Width (High)- | <del> 4</del> 10*- | | <del></del> 270* - | | <del></del> 170*- | | | | 11 | TwMREQ1 | MREQ Pulse Width (Low) | 890* | _ | 580* | _ | 360* | | | | 12 | TdCf(MREQr) | Clock ↓ to MREQ ↑ Delay | | 260 | _ | 170 | _ | 100 | | | 13 | TdCf(RDf) | Clock ↓ to $\overline{RD}$ ↓ Delay | _ | 340 | _ | 230 | _ | 130 | | | 14 | TdCr(RDr) | Clock $\dagger$ to $\overline{\text{RD}}$ $\dagger$ Delay | | 260 | _ | 170 | _ | 100 | | | 15 | TsD(Cr) | -Data Setup Time to Clock 1 | <del></del> 140 | | ——90— | | 50 | | | | 16 | ThD(RDr) | Data Hold Time to $\overline{RD}$ † | | 0 | | 0 | | 0 | | | 17 | TsWAIT(Cf) | WAIT Setup Time to Clock ↓ | 190 | | 120 | _ | 70 | _ | | | 18 | ThWAIT(Cf) | WAIT Hold Time after Clock↓ | | 0 | | 0 | _ | 0 | | | 19 | TdCr(Mlf) | Clock † to Ml ↓ Delay | _ | 340 | _ | 230 | | 130 | | | 20 — | TdCr(Mlr)—— | -Clock † to Ml † Delay | | <del> 340</del> | | <del> 230</del> | | <b>—</b> 130 | | | 21 | TdCr(RFSHf) | Clock ↑ to RFSH ↓ Delay | _ | 460 | | 310 | _ | 180 | | | 22 | TdCr(RFSHr) | Clock † to RFSH † Delay | **** | 390 | _ | 260 | | 150 | | | 23 | TdCf(RDr) | Clock ↓ to RD ↑ Delay | _ | 290 | | 180 | | 110 | | | 24 | TdCr(RDf) | Clock ↑ to $\overline{RD}$ ↓ Delay | _ | 260 | | 170 | | 100 | | | 25 — | TsD(Cf) | -Data Setup to Clock during ——<br>M <sub>2</sub> , M <sub>3</sub> , M <sub>4</sub> or M <sub>5</sub> Cycles | —160 — | | 110 | | <del></del> | | | | 26 | TdA(IORQf) | Address Stable prior to $\overline{\text{IORQ}}$ \$\diamond\$ | 790* | | 510* | _ | 320* | _ | | | 27 | TdCr(IORQf) | Clock † to IORQ ↓ Delay | | 240 | | 160 | | 90 | | | 28 | TdCf(IORQr) | Clock ↓ to IORQ ↑ Delay | | 290 | | 190 | _ | 110 | | | 29 | TdD(WRf) | Data Stable prior to WR ↓ | 470* | _ | 280* | | 190* | | | | 30 — | TdCf(WRf)—— | -Clock ↓ to WR ↓ Delay- | | <del> 240</del> | | —160 <del>–</del> | | <del></del> 90 | | | 31 | TwWR | WR Pulse Width | 890* | | 580* | _ | 360* | _ | | | 32 | TdCf(WRr) | Clock ↓ to WR ↑ Delay | | 260 | | 170 | | 100 | | | 33 | TdD(WRf) | Data Stable prior to WR ↓ | -30* | | +30* | _ | 30* | | | | 34 | TdCr(WRf) | Clock ↑ to WR ↓ Delay | _ | 210 | _ | 140 | _ | 80 | | | 35 — | TdWRr(D) | -Data Stable from WR 1 | — 290*- | | <del></del> 190* - | | <del></del> 130*- | | | | 36 | TdCf(HALT) | Clock to HALT or | - | 760 | _ | 510 | | 300 | | | 37 | TwNMI | NMI Pulse Width | 210 | - | 140 | _ | 80 | | | | 38 | TsBUSREQ(Cr) | BUSREQ Setup Time to Clock 1 | 210 | _ | 140 | | 80 | | | <sup>\*</sup>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 assume equal loading on pins within 50 pF Timings are preliminary and subject to change | AC | |-------------| | Charac- | | teristics† | | (Continued) | | | | | Z8300-1 | | Z830 | 00-2 | Z830 | Z8300-3 | | |--------|-----------------|-----------------------------------------------------------------------|--------------------|-----------------|-------------|-------------|-------------|------------------|--| | Number | Symbol | Parameter | Min<br>(ns) | Max<br>(ns) | Min<br>(ns) | Max<br>(ns) | Min<br>(ns) | Max<br>(ns) | | | 39 | ThBUSREQ(Cr) | BUSREQ Hold Time after Clock † | 0 | | 0 | _ | 0 | | | | 40 | -TdCr(BUSACKf) | -Clock ↑ to BUSACK ↓ Delay —— | | <del></del> 310 | | -210- | | <del>-</del> 120 | | | 41 | TdCf(BUSACKr) | Clock ↓ to BUSACK ↑ Delay | | 290 | | 190 | | 110 | | | 42 | TdCr(Dz) | Clock † to Data Float Delay | | 240 | _ | 160 | | 90 | | | 43 | TdCr(CTz) | Clock † to Control Outputs Float<br>Delay (MREQ, IORQ, RD,<br>and WR) | - | 290 | _ | 190 | _ | 110 | | | 44 | TdCr(Az) | Clock † to Address Float Delay | _ | 290 | | 190 | | 110 | | | 45 | -TdCTr(A) | - MREQ †, IORQ †, RD †, and ——<br>WR † to Address Hold Time | <del> 4</del> 00*- | | 260*- | | 160*- | | | | 46 | TsRESET(Cr) | RESET to Clock † Setup Time | 240 | ******* | 160 | | 90 | | | | 47 | ThRESET(Cr) | RESET to Clock † Hold Time | **** | 0 | | 0 | _ | 0 | | | 48 | TsINTf(Cr) | INT to Clock ↑ Setup Time | 210 | | 140 | | 80 | | | | 49 | ThINTr(Cr) | INT to Clock † Hold Time | | 0 | | 0 | _ | 0 | | | 50 | -TdM1f(IORQf) — | -M1↓to <del>IORQ</del> ↓Delay———— | - 2300*- | | 1500*- | | 920*- | | | | 51 | TdCf(IORQf) | Clock ↓ to <del>IORQ</del> ↓ Delay | | 290 | | 190 | | 110 | | | 52 | TdCf(IORQr) | Clock † to $\overline{\text{IORQ}}$ † Delay | | 260 | | 170 | | 100 | | | 53 | TdCf(D) | Clock to Data Valid Delay | - | 290 | | 400 | _ | 230 | | <sup>\*</sup>For clock periods other than the minimums shown in the table, calculate parameters using the following expressions. Calculated values above assumed TrC = TfC = 20 ns † All timings assume equal loading on pins with 50 pF Timings are preliminary and subject to change. #### Footnotes to AC Characteristics | Number | Symbol | Z8300-1 | Z8300-2 | Z8300-3 | |--------|---------------|-------------------------------------------------------------------------------|-------------------------------------------------------------------------------|-------------------------------------------------------------------------------| | 1 | TcC | TwCh + TwCl + TrC + TfC | TwCh + TwCl + TrC + TfC | TwCh + TwCl + TrC + TfC | | 2 | TwCh | Although static by design, TwCh of greater than 200 $\mu s$ is not guaranteed | Although static by design, TwCh of greater than 200 $\mu$ s is not guaranteed | Although static by design, TwCh of greater than 200 $\mu$ s is not guaranteed | | 7 | - TdA(MREQf)— | -TwCh + TfC - 200 | -TwCh + TfC - 130 | -TwCh + TfC - 75 | | 10 | TwMREQh | TwCh + TfC - 90 | TwCh + TfC - 60 | TwCh + TfC - 30 | | 11 | TwMREQ1 | TcC - 110 | TcC - 70 | TcC - 40 | | 26 | TdA(IORQf) | TcC - 210 | TcC - 140 | TcC - 80 | | 29 | TdD(WRf) | TcC - 540 | TcC - 360 | TcC - 210 | | 31 | TwWR ——— | TcC - 110 | TcC - 70 | TcC - 40 | | 33 | TdD(WRf) | TwCl + TrC - 470 | TwCl + TrC - 300 | TwCl + TrC - 180 | | 35 | TdWRr(D) | TwCl + TrC - 210 | TwCl + TrC - 140 | TwCl + TrC - 80 | | 45 | TdCTr(A) | TwCl + TrC - 110 | TwCl + TrC - 70 | TwCl + TrC - 40 | | 50 | TdM1f(IORQf) | 2TcC + TwCh + TfC - 210 | 2TcC + TwCh + TfC - 140 | 2TcC + TwCh + TfC - 80 | $\begin{array}{lll} AC \; Test \; Conditions \\ V_{IH} = \; 2 \; 0 \; V \\ V_{IL} = \; 0 \; 8 \; V \\ V_{IHC} = \; V_{CC} - 0 \; 6 \; V \\ V_{ILC} = \; 0 \; 45 \; V \\ V_{OH} = \; 2 \; 0 \; V \\ V_{OL} = \; 0 \; 8 \; V \\ FLOAT = \; \pm 0 \; 5 \; V \end{array}$ | Absolute<br>Maximum<br>Ratings | Storage Temperature65°C to +150°C Temperature under Bias See Ordering Information Voltages on all inputs and outputs with respect to ground0.3 V to +7 V Power Dissipation | 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 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: - $S^* = 0$ °C to +70°C, +4.75 V ≤ $V_{CC}$ ≤ +5.25 V - $E^* = -40$ °C to +85°C, +4.75 V $\leq$ V<sub>CC</sub> $\leq$ +5.25 V - $M^* = -55^{\circ}C \text{ to } + 125^{\circ}C,$ + 4.5 $V \le V_{CC} \le +5.5 V$ All ac parameters assume a load capacitance of 100 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 #### DC Characteristics | Symbol | Parameter | Min | Max | Unit | Test Condition | |--------------------|-----------------------------------------|-------------------|-------------------|---------|-----------------------------------| | $V_{\rm ILC}$ | Clock Input Low Voltage | -0.3 | 0.45 | V | | | $v_{\mathrm{IHC}}$ | Clock Input High Voltage | V <sub>CC</sub> 6 | $V_{\rm CC}$ + .3 | V | | | $v_{\rm IL}$ | Input Low Voltage | -0.3 | 0.8 | V | | | $v_{\mathrm{IH}}$ | Input High Voltage | 2.0 | $v_{\rm cc}$ | V | | | $V_{OL}$ | Output Low Voltage | | 0.4 | V | $I_{OL} = 1.8 \text{ mA}$ | | $V_{OH}$ | Output High Voltage | 2.4 | | V | $I_{OH} = -250 \mu\text{A}$ | | $I_{LI}$ | Input Leakage Current | | 10 | $\mu$ A | $V_{\rm IN}$ = 0 to $V_{\rm CC}$ | | $I_{LEAK}$ | 3-State Output Leakage Current in Float | -10 | 101 | $\mu$ A | $V_{OUT} = 0.4 \text{ to } V_{C}$ | | $I_{CC}$ | Power Supply Current | | | | | | | | | | | | | | Temperature | | | | | | |-------------------|-------------|-----|-----------------|-------------|------|--| | Frequency | 0°C<br>Max | Мах | 25°C<br>Typical | 70°C<br>Max | Unit | | | Z8300-1 (1.0 MHz) | 30 | 25 | 15 | 20 | mA | | | Z8300-2 (1.5 MHz) | 35 | 30 | 20 | 25 | mA | | | Z8300-3 (2.5 MHz) | <b>4</b> 5 | 40 | 25 | 35 | mA | | <sup>1</sup> 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 | Мах | Unit | Note | |-------------|-----------------------------------------------------|--------------------------------------------------------|-----|---------------|----------------|------------------------------------| | | C <sub>CLOCK</sub> C <sub>IN</sub> C <sub>OUT</sub> | Clock Capacitance Input Capacitance Output Capacitance | | 35<br>5<br>10 | pF<br>pF<br>pF | Unmeasured pins returned to ground | $T_A = 25$ °C, f = 1 MHz <sup>\*</sup>See Ordering Information section for package temperature range and product number | Ordering<br>Information | Product<br>Number | Package/<br>Temp | Speed | Description | Product<br>Number | Package/<br>Temp | Speed | Description | |-------------------------|-------------------|------------------|---------|-------------------|-------------------|------------------|---------|-------------------| | | Z8300-1 | PS | 1.0 MHz | Z80L CPU (40-pin) | Z8300-2 | CS | 1.5 MHz | Z80L CPU (40-pin) | | | Z8300-1 | CS | 1.0 MHz | Same as above | Z8300-3 | PS | 2.5 MHz | Same as above | | | Z8300-2 | PS | 1.5 MHz | Same as above | Z8300-3 | CS | 2.5 MHz | Same as above | NOTES C = Ceramic, P = Plastic, S = 0°C to +70°C. 48 00-2189-03 ### Z8410 Z80° DMA Direct Memory Access Controller # **Product Specification** June 1982 #### **Features** - Transfers, searches and search/transfers in Byte-at-a-Time, Burst or Continuous modes. Cycle length and edge timing can be programmed to match the speed of any port. - Dual port addresses (source and destination) generated for memory-to-I/O, memory-to-memory, or I/O-to-I/O operations. Addresses may be fixed or automatically incremented/decremented. - Next-operation loading without disturbing current operations via buffered starting- - address registers. An entire previous sequence can be repeated automatically. - Extensive programmability of functions. CPU can read complete channel status. - Standard Z-80 Family bus-request and prioritized interrupt-request daisy chains implemented without external logic. Sophisticated, internally modifiable interrupt vectoring. - Direct interfacing to system buses without external logic. #### General Description The Z-80 DMA (Direct Memory Access) is a powerful and versatile device for controlling and processing transfers of data. Its basic function of managing CPU-independent transfers between two ports is augmented by an array of features that optimize transfer speed and control with little or no external logic in systems using an 8- or 16-bit data bus and a 16-bit address bus. Transfers can be done between any two ports (source and destination), including memory-to-I/O, memory-to-memory, and I/O-to-I/O. Dual port addresses are automatically generated for each transaction and may be either fixed or incrementing/decrementing. In addition, bit-maskable byte searches can be performed either concurrently with transfers or as an operation in itself. Figure 1. Pin Functions Figure 2. Pin Assignments 2032-0125, 0126 General Description (Continued) The Z-80 DMA contains direct interfacing to and independent control of system buses, as well as sophisticated bus and interrupt controls. Many programmable features, including variable cycle timing and auto-restart, minimize CPU software overhead. They are especially useful in adapting this special- purpose transfer processor to a broad variety of memory, I/O and CPU environments. The Z-80 DMA is an n-channel silicon-gate depletion-load device packaged in a 40-pin plastic or ceramic DIP. It uses a single +5 V power supply and the standard Z-80 Family single-phase clock. ## Functional Description Classes of Operation. The Z-80 DMA has three basic classes of operation: - Transfers of data between two ports (memory or I/O peripheral) - Searches for a particular 8-bit maskable byte at a single port in memory or an I/O peripheral - Combined transfers with simultaneous search between two ports Figure 4 illustrates the basic functions served by these classes of operation. During a transfer, the DMA assumes control of the system address and data buses. Data is read from one addressable port and written to the other addressable port, byte by byte. The ports may be programmed to be either system main memory or peripheral I/O devices. Thus, a block of data may be written from one peripheral to another, from one area of main memory to another, or from a peripheral to main memory and vice versa. During a search-only operation, data is read from the source port and compared byte by byte with a DMA-internal register containing a programmable match byte. This match byte may optionally be masked so that only certain bits within the match byte are compared. Search rates up to 1.25M bytes per second can be obtained with the 2.5 MHz Z-80 DMA or 2M bytes per second with the 4 MHz Z-80A DMA. In combined searches and transfers, data is transferred between two ports while simultaneously searching for a bit-maskable byte match. Data transfers or searches can be programmed to stop or interrupt under various conditions. In addition, CPU-readable status bits can be programmed to reflect the condition. **Modes of Operation.** The Z-80 DMA can be programmed to operate in one of three transfer and/or search modes: - Byte-at-a-Time: data operations are performed one byte at a time. Between each byte operation the system buses are released to the CPU. The buses are requested again for each succeeding byte operation. - Burst: data operations continue until a port's Ready line to the DMA goes inactive. The DMA then stops and releases the system buses after completing its current byte operation. - Continuous: data operations continue until the end of the programmed block of data is reached before the system buses are released. If a port's Ready line goes inactive before this occurs, the DMA simply pauses until the Ready line comes active again. Figure 3. Typical Z-80 Environment Figure 4. Basic Functions of the Z-80 DMA Functional Description (Continued) In all modes, once a byte of data is read into the DMA, the operation on the byte will be completed in an orderly fashion, regardless of the state of other signals (including a port's Ready line). Due to the DMA's high-speed buffered method of reading data, operations on one byte are not completed until the next byte is read in. This means that total transfer or search block lengths must be two or more bytes, and that block lengths programmed into the DMA must be one byte less than the desired block length (count is N-1 where N is the block length). Commands and Status. The Z-80 DMA has several writable control registers and readable status registers available to the CPU. Control bytes can be written to the DMA whenever the DMA is not controlling the system buses, but the act of writing a control byte to the DMA disables the DMA until it is again enabled by a specific command. Status bytes can also be read at any such time, but writing the Read Status Byte command or the Initiate Read Sequence command disables the DMA. Control bytes to the DMA include those which effect immediate command actions such as enable, disable, reset, load starting-address buffers, continue, clear counters, clear status bits and the like. In addition, many mode-setting control bytes can be written, including mode and class of operation, port configuration, starting addresses, block length, address counting rule, match and match-mask byte, interrupt conditions, interrupt vector, status-affects-vector condition, pulse counting, auto restart, Ready-line and Wait-line rules, and read mask. Readable status registers include a general status byte reflecting Ready-line, end-of-block, byte-match and interrupt conditions, as well as 2-byte registers for the current byte count, Port A address and Port B address. Variable Cycle. The Z-80 DMA has the unique feature of programmable operation-cycle length. This is valuable in tailoring the DMA to the particular requirements of other system components (fast or slow) and maximizes the data-transfer rate. It also eliminates external logic for signal conditioning. There are two aspects to the variable cycle feature. First, the entire read and write cycles (periods) associated with the source and destination ports can be independently programmed as 2, 3 or 4 T-cycles long (more if Wait cycles are used), thereby increasing or decreasing the speed with which all DMA signals change (Figure 5). Second, the four signals in each port specifically associated with transfers of data (I/O Request, Memory Request, Read, and Write) can each have its active trailing edge terminated one-half T-cycle early. This adds a further dimension of flexibility and speed, allowing such things as shorter-than-normal Read or Write signals that go inactive before data starts to change. Address Generation. Two 16-bit addresses are generated by the Z-80 DMA for every transfer operation, one address for the source port and another for the destination port. Each address can be either variable or fixed. Variable addresses can increment or decrement from the programmed starting address. The fixed-address capability eliminates the need for separate enabling wires to I/O ports. Port addresses are multiplexed onto the system address bus, depending on whether the DMA is reading the source port or writing to the destination port. Two readable address counters (2 bytes each) keep the current address of each port. **Auto Restart.** The starting addresses of either port can be reloaded automatically at the end of a block. This option is selected by the Auto Restart control bit. The byte counter is cleared when the addresses are reloaded. The Auto Restart feature relieves the CPU of software overhead for repetitive operations such as CRT refresh and many others. Moreover, when the CPU has access to the buses during byte-at-a-time or burst transfers, different starting addresses can be written into buffer registers during transfers, causing the Auto Restart to begin at a new location. **Interrupts.** The Z-80 DMA can be programmed to interrupt the CPU on three conditions: - Interrupt on Ready (before requesting bus) - Interrupt on Match - Interrupt on End of Block Figure 5. Variable Cycle Length # Functional Description (Continued) Any of these interrupts cause an interruptpending status bit to be set, and each of them can optionally alter the DMA's interrupt vector. Due to the buffered constraint mentioned under "Modes of Operation," interrupts on Match at End of Block are caused by matches to the byte just prior to the last byte in the block. The DMA shares the Z-80 Family's elaborate interrupt scheme, which provides fast interrupt service in real-time applications. In a Z-80 CPU environment, the DMA passes its internally modifiable 8-bit interrupt vector to the CPU, which adds an additional eight bits to form the memory address of the interrupt-routine table. This table contains the address of the beginning of the interrupt routine itself. In this process, CPU control is transferred directly to the interrupt routine, so that the next instruction executed after an interrupt acknowledge is the first instruction of the interrupt routine itself. **Pulse Generation.** External devices can keep track of how many bytes have been transferred by using the DMA's pulse output, which provides a signal at 256-byte intervals. The interval sequence may be offset at the beginning by 1 to 255 bytes. The Interrupt line outputs the pulse signal in a manner that prevents misinterpretation by the CPU as an interrupt request, since it only appears when the Bus Request and Bus Acknowledge lines are both active. #### Pin Description **A<sub>0</sub>-A<sub>15</sub>.** System Address Bus (output, 3-state). Addresses generated by the DMA are sent to both source and destination ports (main memory or I/O peripherals) on these lines. **BAI.** Bus Acknowledge In (input, active Low). Signals that the system buses have been released for DMA control. In multiple-DMA configurations, the BAI pin of the highest priority DMA is normally connected to the Bus Acknowledge pin of the CPU. Lower-priority DMAs have their BAI connected to the BAO of a higher-priority DMA. **BAO.** Bus Acknowledge Out (output, active Low). In a multiple-DMA configuration, this pin signals that no other higher-priority DMA has requested the system buses. BAI and BAO form a daisy chain for multiple-DMA priority resolution over bus control. BUSREQ. Bus Request (bidirectional, active Low, open drain). As an output, it sends requests for control of the system address bus, data bus and control bus to the CPU. As an input, when multiple DMAs are strung together in a priority daisy chain via BAI and BAO, it senses when another DMA has requested the buses and causes this DMA to refrain from bus requesting until the other DMA is finished. Because it is a bidirectional pin, there cannot be any buffers between this DMA and any other DMA. It can, however, have a buffer between it and the CPU because it is unidirectional into the CPU. A pull-up resistor is connected to this pin. **CE/WAIT.** Chip Enable and Wait (input, active Low). Normally this functions only as a $\overline{\text{CE}}$ line, but it can also be programmed to serve a WAIT function. As a $\overline{\text{CE}}$ line from the CPU, it becomes active when $\overline{\text{WR}}$ and $\overline{\text{IORQ}}$ are active and the I/O port address on the system address bus is the DMA's address, thereby allowing a transfer of control or command bytes from the CPU to the DMA. As a WAIT line from memory or I/O devices, after the DMA has received a bus-request acknowledge from the CPU, it causes wait states to be inserted in the DMA's operation cycles thereby slowing the DMA to a speed that matches the memory or I/O device. **CLK.** System Clock (input). Standard Z-80 single-phase clock at 2.5 MHz (Z-80 DMA) or 4.0 MHz (Z-80A DMA). For slower system clocks, a TTL gate with a pullup resistor may be adequate to meet the timing and voltage level specification. For higher-speed systems, use a clock driver with an active pullup to meet the $V_{\rm IH}$ specification and risetime requirements. In all cases there should be a resistive pullup to the power supply of $10 \, {\rm K}$ ohms (max) to ensure proper power when the DMA is reset. **D<sub>0</sub>-D<sub>7</sub>.** System Data Bus (bidirectional, 3-state). Commands from the CPU, DMA status, and data from memory or I/O peripherals are transferred on these lines. **IEI.** Interrupt Enable In (input, active High). This is used with IEO to form a priority daisy chain when there is more than one interrupt-driven device. A High on this line indicates that no other device of higher priority is being serviced by a CPU interrupt service routine. **IEO.** Interrupt Enable Out (output, active High). IEO is High only if IEI is High and the CPU is not servicing an interrupt from this DMA. Thus, this signal blocks lower-priority devices from interrupting while a higher-priority device is being serviced by its CPU interrupt service routine. ## Pin Description (Continued) INT/PULSE. Interrupt Request (output, active Low, open drain). This requests a CPU interrupt. The CPU acknowledges the interrupt by pulling its IORQ output Low during an MI cycle. It is typically connected to the INT pin of the CPU with a pullup resistor and tied to all other INT pins in the system. This pin can also be used to generate periodic pulses to an external device. It can be used this way only when the DMA is bus master (i.e., the CPU's BUSREQ and BUSACK lines are both Low and the CPU cannot see interrupts). **IORQ.** Input/Output Request (bidirectional, active Low, 3-state). As an input, this indicates that the lower half of the address bus holds a valid I/O port address for transfer of control or status bytes from or to the CPU, respectively; this DMA is the addressed port if its $\overline{CE}$ pin and its $\overline{WR}$ or $\overline{RD}$ pins are simultaneously active. As an output, after the DMA has taken control of the system buses, it indicates that the 8-bit or 16-bit address bus holds a valid port address for another I/O device involved in a DMA transfer of data. When $\overline{IORQ}$ and $\overline{MI}$ are both active simultaneously, an interrupt acknowledge is indicated. $\overline{\mathbf{M1.}}$ Machine Cycle One (input, active Low). Indicates that the current CPU machine cycle is an instruction fetch. It is used by the DMA to decode the return-from-interrupt instruction (RETI) (ED-4D) sent by the CPU. During two-byte instruction fetches, $\overline{\mathrm{M1}}$ is active as each opcode byte is fetched. An interrupt acknowledge is indicated when both $\overline{\text{M1}}$ and $\overline{\text{IORO}}$ are active. **MREQ.** Memory Request (output, active Low, 3-state). This indicates that the address bus holds a valid address for a memory read or write operation. After the DMA has taken control of the system buses, it indicates a DMA transfer request from or to memory. **RD.** Read (bidirectional, active Low, 3-state). As an input, this indicates that the CPU wants to read status bytes from the DMA's read registers. As an output, after the DMA has taken control of the system buses, it indicates a DMA-controlled read from a memory or I/O port address. RDY. Ready (input, programmable active Low or High). This is monitored by the DMA to determine when a peripheral device associated with a DMA port is ready for a read or write operation. Depending on the mode of DMA operation (Byte, Burst or Continuous), the RDY line indirectly controls DMA activity by causing the BUSREQ line to go Low or High. **WR.** Write (bidirectional, active Low, 3-state). As an input, this indicates that the CPU wants to write control or command bytes to the DMA write registers. As an output, after the DMA has taken control of the system buses, it indicates a DMA-controlled write to a memory or I/O port address. #### Internal Structure The internal structure of the Z-80 DMA includes driver and receiver circuitry for interfacing with an 8-bit system data bus, a 16-bit system address bus, and system control lines (Figure 6). In a Z-80 CPU environment, the DMA can be tied directly to the analogous pins on the CPU (Figure 7) with no additional buffering, except for the CEVWAIT line. The DMA's internal data bus interfaces with the system data bus and services all internal logic and registers. Addresses generated from this logic for Ports A and B (source and destination) of the DMA's single transfer channel are multiplexed onto the system address bus. Specialized logic circuits in the DMA are dedicated to the various functions of external bus interfacing, internal bus control, byte matching, byte counting, periodic pulse generation, CPU interrupts, bus requests, and address generation. A set of twenty-one writable control registers and seven readable status registers provides the means by which the CPU governs and monitors the activities of these logic circuits. All registers are eight bits wide, with double-byte information stored in adjacent registers. The two address counters (two bytes each) for Ports A and B are buffered by the two starting addresses. Figure 6. Block Diagram Internal Structure (Continued) The 21 writable control registers are organized into seven base-register groups, most of which have multiple registers. The base registers in each writable group contain both control/command bits and pointer bits that can be set to address other registers within the group. The seven readable status registers have no analogous second-level registers. The registers are designated as follows, according to their base-register groups: WR0-WR6 — Write Register groups 0 through 6 (7 base registers plus 14 associated registers) RRO-RR6 - Read Registers 0 through 6 Writing to a register within a write-register group involves first writing to the base register, with the appropriate pointer bits set, then writing to one or more of the other registers within the group. All seven of the readable status registers are accessed sequentially according to a programmable mask contained in one of the writable registers. The section entitled "Programming" explains this in more detail. A pipelining scheme is used for reading data in. The programmed block length is the number of bytes compared to the byte counter, which increments at the end of each cycle. In searches, data byte comparisons with the match byte are made during the read cycle of the next byte. Matches are, therefore, discovered only after the next byte is read in. In multiple-DMA configurations, interruptrequest daisy chains are prioritized by the order in which their IEI and IEO lines are connected (Zilog Application Note 03-0041-01, *The* Z-80 Family Program Interrupt Structure). The system bus, however, may not be pre-empted. Any DMA that gains access to the system bus keeps the bus until it is finished. #### Write Registers WR0 Base register byte Port A starting address (low byte) Port A starting address (high byte) Block length (low byte) Block length (high byte) WR1 Base register byte Port A variable-timing byte WR2 Base register byte Port B variable-timing byte WR3 Base register byte Mask byte Match byte WR4 Base register byte Port B starting address (low byte) Port B starting address (high byte) Interrupt control byte Pulse control byte Interrupt vector WR5 Base register byte WR6 Base register byte Read mask #### Read Registers RR0 Status byte RR1 Byte counter (low byte) RR2 Byte counter (high byte) RR3 Port A address counter (low byte) RR4 Port A address counter (high byte) RR5 Port B address counter (low byte) Port'B address counter (high byte) RR6 Figure 7. Multiple-DMA Interconnection to the Z-80 CPU #### Programming The Z-80 DMA has two programmable fundamental states: (1) an enabled state, in which it can gain control of the system buses and direct the transfer of data between ports, and (2) a disabled state, in which it can initiate neither bus requests nor data transfers. When the DMA is powered up or reset by any means, it is automatically placed into the disabled state. Program commands can be written to it by the CPU in either state, but this automatically puts the DMA in the disabled state. which is maintained until an enable command is issued by the CPU. The CPU must program the DMA in advance of any data search or transfer by addressing it as an I/O port and sending a sequence of control bytes using an Output instruction (such as OTIR for the Z-80 CPU). Writing. Control or command bytes are written into one or more of the Write Register groups (WR0-WR6) by first writing to the base register byte in that group. All groups have base registers and most groups have additional associated registers. The associated registers in a group are sequentially accessed by first writing a byte to the base register containing register-group identification and pointer bits (1's) to one or more of that base register's associated registers. This is illustrated in Figure 8b. In this figure, the sequence in which associated registers within a group can be written to is shown by the vertical position of the associated registers. For example, if a byte written to the DMA contains the bits that identify WR0 (bits D0, D1 and D7), and also contains 1's in the bit positions that point to the associated "Port A Starting Address (low byte)," and "Port A Starting Address (high byte)," then the next two bytes written to the DMA will be stored in these two registers, in that order. **Reading.** The Read Registers (RR0-RR6) are read by the CPU by addressing the DMA as an I/O port using an Input instruction (such as INIR for the Z-80 CPU). The readable bytes contain DMA status, byte-counter values, and port addresses since the last DMA reset. The registers are always read in a fixed sequence beginning with RR0 and ending with RR6. However, the register read in this sequence is determined by programming the Read Mask in WR6. The sequence of reading is initialized by writing an Initiate Read Sequence or Set Read Status command to WR6. After a Reset DMA, the sequence must be initialized with the Initiate Read Sequence command or a Read Status command. The sequence of reading all registers that are not excluded by the Read Mask register must be completed before a new Initiate Read Sequence or Read Status command. **Fixed-Address Programming.** A special circumstance arises when programming a destination port to have a fixed address. The load command in WR6 only loads a fixed address to a port selected as the source, not to a port selected as the destination. Therefore, a fixed destination address must be loaded by temporarily declaring it a fixed-source address and subsequently declaring the true source as such, thereby implicitly making the other a destination. The following example illustrates the steps in this procedure, assuming that transfers are to occur from a variable-address source (Port A) to a fixed-address destination (Port B): - Temporarily declare Port B as source in WRO. - 2. Load Port B address in WR6. - 3. Declare Port A as source in WRO. - 4. Load Port A address in WR6. - 5. Enable DMA in WR6. Figure 9 illustrates a program to transfer data from memory (Port A) to a peripheral device (Port B). In this example, the Port A memory starting address is $1050_{\rm H}$ and the Port B peripheral fixed address is $05_{\rm H}$ . Note that the data flow is $1001_{\rm H}$ bytes—one more than specified by the block length. The table of DMA commands may be stored in consecutive memory locations and transferred to the DMA with an output instruction such as the Z-80 CPU's OTIR instruction. Figure 8a. Read Registers 2032-0132 Figure 8b. Write Registers | Comments | D <sub>7</sub> | D <sub>6</sub> | D <sub>5</sub> | D <sub>4</sub> | D <sub>3</sub> | D <sub>2</sub> | D <sub>1</sub> | D <sub>0</sub> | HEX | |-----------------------------------------------------------------------------------------------------|----------------|---------------------------------------|---------------------------------------|----------------------------------------------|--------------------------------------------|------------------------------------------|----------------|----------------|-----| | WR0 sets DMA to receive block length, Port A starting address and temporarily sets Port B as source | 0 | 1<br>Block Length<br>Upper<br>Follows | 1<br>Block Length<br>Lower<br>Follows | 1<br>Port A<br>Upper<br>Address<br>Follows | 1<br>Port A<br>Lower<br>Address<br>Follows | 0 B → A Temporary for Loading B Address* | 0<br>Transfer, | 1<br>No Search | 79 | | Port A address (lower) | 0 | 1 | 0 | 1 | 0 | 0 | 0 | 0 | 50 | | Port A address (upper) | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 10 | | Block length (lower) | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 00 | | Block length (upper) | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 10 | | WR1 defines Port A as memory with fixed incrementing address | 0 | 0<br>No Timing<br>Follows | 0<br>Address<br>Changes | 1<br>Address<br>Increments | 0<br>Port is<br>Memory | 1 | 0 | 0 | 14 | | WR2 defines Port B as<br>peripheral with fixed<br>address | 0 | 0<br>No Timing<br>Follows | 1<br>Fixed<br>Address | 0 | 1<br>Port is<br>I/O | 0 | 1 | 0 | 28 | | WR4 sets mode to Burst,<br>sets DMA to expect Port B<br>address | 1 | 1<br>Burst | 0<br>Mode | 0<br>No Interrupt<br>Control Byte<br>Follows | 0<br>No Upper<br>Address | 1<br>Port B Lower<br>Address<br>Follows | 0 | 1 | C5 | | Port B address (lower) | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 1 | 05 | | WR5 sets Ready active High | 1 | 0 | 0<br>No Auto<br>Restart | 0<br>No Wait<br>States | 1<br>RDY<br>Active High | 0 | 1 | 0 | 8A | | WR6 loads Port B address and resets block counter * | 1 | 1 | 0 | 0 | 1 | 1 | 1 | 1 | CF | | WR0 sets Port A as source * | 0 | 0 | | 0<br>ss or Block<br>Bytes<br>I | 0 | A <del></del> B | 0<br>Transfer, | 1<br>No Search | 05 | | WR6 loads Port A address and resets block counter | 1 | 1 | 0 | 0 | 1 | 1 | 1 | 1 | CF | | WR6 enables DMA to start operation | 1 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 87 | NOTE The actual number of bytes transferred is one more than specified by the block length \*These entries are necessary only in the case of a fixed destination address Figure 9. Sample DMA Program Inactive State Timing (DMA as CPU Peripheral) In its disabled or inactive state, the DMA is addressed by the CPU as an I/O peripheral for write and read (control and status) operations. Write timing is illustrated in Figure 10. Reading of the DMA's status byte, byte counter or port address counters is illustrated In Figure 11. These operations require less than three T-cycles. The $\overline{\text{CE}}$ , $\overline{\text{IORQ}}$ and $\overline{\text{RD}}$ lines are made active over two rising edges of CLK, and data appears on the bus approximately one T-cycle after they become active. Figure 10. CPU-to-DMA Write Cycle Figure 11. CPU-to-DMA Read Cycle Active State Timing (DMA as Bus Controller) 58 **Default Read and Write Cycles.** By default, and after reset, the DMA's timing of read and write operations is exactly the same as the Z-80 CPU's timing of read and write cycles for memory and I/O peripherals, with one exception: during a read cycle, data is latched on the falling edge of $T_3$ and held on the data bus across the boundary between read and write cycles, through the end of the following write cycle. Figure 12 illustrates the timing for memory-to-I/O port transfers and Figure 13 illustrates I/O-to-memory transfers. Memory-to-memory and I/O-to-I/O transfer timings are simply permutations of these diagrams. The default timing uses three T-cycles for memory transactions and four T-cycles for I/O transactions, which include one automatically <u>Inserted</u> wait cycle between $T_2$ and $T_3$ . If the <u>CE/WAIT</u> line is programmed to act as a <u>WAIT</u> line during the DMA's active state, it is sampled on the falling edge of $T_2$ for memory transactions and the falling edge of $T_W$ for I/O transactions. If <u>CE/WAIT</u> is Low during this time another T-cycle is added, during which the <u>CE/WAIT</u> line will again be sampled. The duration of transactions can thus be indefinitely extended. Variable Cycle and Edge Timing. The Z-80 DMA's default operation-cycle length for the source (read) port and destination (write) port can be independently programmed. This variable-cycle feature allows read or write cycles consisting of two, three or four T-cycles (more if Wait cycles are inserted), thereby increasing or decreasing the speed of all signals generated by the DMA. In addition, Figure 12. Memory-to-I/O Transfer 2032-0134, 0135, 0136 Figure 13. I/O-to-Memory Transfer the trailing edges of the $\overline{IORQ}$ , $\overline{MREQ}$ , $\overline{RD}$ and $\overline{WR}$ signals can be independently terminated one-half cycle early. Figure 14 illustrates this. In the variable-cycle mode, unlike default timing, $\overline{IORO}$ comes active one-half cycle before $\overline{MREO}$ , $\overline{RD}$ and $\overline{WR}$ . $\overline{CE/WAIT}$ can be used to extend only the 3 or 4 T-cycle variable memory cycles and only the 4-cycle variable I/O cycle. The $\overline{CE/WAIT}$ line is sampled at the falling edge of $T_2$ for 3- or 4-cycle memory cycles, and at the falling edge of $T_3$ for 4-cycle I/O cycles. During transfers, data is latched on the clock edge causing the rising edge of $\overline{\text{RD}}$ and held through the end of the write cycle. Bus Requests. Figure 15 illustrates the bus request and acceptance timing. The RDY line, which may be programmed active High or Low, is sampled on every rising edge of CLK. If it is found to be active, and if the bus is not in use by any other device, the following rising edge of CLK drives BUSREQ low. After receiving BUSREQ the CPU acknowledges on the BAI input either directly or through a multiple-DMA daisy chain. When a Low is detected on BAI for two consecutive rising edges of CLK, the DMA will begin transferring data on the next rising edge of CLK. Figure 14. Variable-Cycle and Edge Timing Figure 15. Bus Request and Acceptance Active State Timing (DMA as Bus Controller) (Continued) Bus Release Byte-at-a-Time. In Byte-at-a-Time mode, BUSREQ is brought High on the rising edge of CLK prior to the end of each read cycle (search-only) or write cycle (transfer and transfer/search) as illustrated in Figure 16. This is done regardless of the state of RDY. There is no possibility of confusion when a Z-80 CPU is used since the CPU cannot begin an operation until the following T-cycle. Most other CPUs are not bothered by this either, although note should be taken of it. The next bus request for the next byte will come after both BUSREQ and BAI have returned High. Bus Release at End of Block. In Burst and Continuous modes, an end of block causes BUSREQ to go High usually on the same rising edge of CLK in which the DMA completes the transfer of the data block (Figure 17). The last byte in the block is transferred even if RDY goes inactive before completion of the last byte transfer. Bus Release on Not Ready. In Burst mode, when RDY goes inactive it causes BUSREQ to go High on the next rising edge of CLK after the completion of its current byte operation (Figure 18). The action on BUSREQ is thus somewhat delayed from action on the RDY line. The DMA always completes its current byte operation in an orderly fashion before releasing the bus. By contrast, BUSREQ is not released in Continuous mode when RDY goes inactive. Figure 16. Bus Release (Byte-at-a-Time Mode) Figure 18. Bus Release When Not Ready (Burst Mode) Instead, the DMA idles after completing the current byte operation, awaiting an active RDY again. **Bus Release on Match.** If the DMA is programmed to stop on match in Burst or Continuous modes, a match causes BUSREQ to go inactive on the next DMA operation, i.e., at the end of the next read in a search or at the end of the following write in a transfer (Figure 19). Due to the pipelining scheme, matches are determined while the next DMA read or write is being performed. The RDY line can go inactive after the matching operation begins without affecting this bus-release timing. **Interrupts.** Timings for interrupt acknowledge and return from interrupt are the same as timings for these in other Z-80 peripherals. Refer to Zilog Application Note 03-0041-01 (The Z-80 Family Program Interrupt Structure). Interrupt on RDY (interrupt before requesting bus) does not directly affect the BUSREQ line. Instead, the interrupt service routine must handle this by issuing the following commands to WR6: - Enable after Return From Interrupt (RETI) Command — Hex B7 - 2. Enable DMA Hex 87 - An RETI instruction that resets the Interrupt Under Service latch in the Z-80 DMA. Figure 17. Bus Release at End of Block (Burst and Continuous Modes) Figure 19. Bus Release on Match (Burst and Continuous Modes) | Absolute | |----------| | Maximum | | Ratings | | | Operating Ambient Temperature Under Bias ... As Specified Under Ordering Information. Storage Temperature..... -65°C to +150°C Voltage On Any Pin with 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. #### Test Conditions The characteristics below apply for the following 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: ■ $S^* = 0$ °C to +70°C, +4.75 V $\leq$ V<sub>CC</sub> $\leq$ +5.25 V ■ $E^* = -40$ °C to +85°C, +4.75 V $\leq$ V<sub>CC</sub> $\leq$ +5.25 V ■ $M^* = -55^{\circ}C$ to $+125^{\circ}C$ , $+4.5 \text{ V} \le V_{CC} \le +5.5 \text{ V}$ \*See Ordering Information section for package temperature range and product number All ac parameters assume a load capacitance of 100 pF max. Timing references between two output signals assume a load difference of 50 pF max. #### DC Characteristics | Symbol | Parameter | Min | Мах | Unit | Test Condition | |--------------------|-----------------------------------------------|----------------|------------|----------|------------------------------------------------------------------------------| | $V_{\rm ILC}$ | Clock Input Low Voltage | -0.3 | 0.45 | V | | | $V_{\mathrm{IHC}}$ | Clock Input High Voltage | $V_{\rm CC}$ 6 | 5.5 | V | | | $V_{\mathrm{IL}}$ | Input Low Voltage | -0.3 | 0.8 | V | | | $V_{\mathrm{IH}}$ | Input High Voltage | 2.0 | 5.5 | V | | | $V_{\rm OL}$ | Output Low Voltage | | 0.4 | V | $I_{OL}$ = 3.2mA for $\overline{BUSREQ}$<br>$I_{OL}$ = 2.0 mA for all others | | $v_{\mathrm{OH}}$ | Output High Voltage | 2.4 | | V | $I_{OH} = 250 \mu\text{A}$ | | $I_{CC}$ | Power Supply Current<br>Z-80 DMA<br>Z-80A DMA | | 150<br>200 | mA<br>mA | | | $I_{LI}$ | Input Leakage Current | | 10 | $\mu$ A | $V_{\rm IN}$ = 0 to $V_{\rm CC}$ | | $I_{LOH}$ | 3-State Output Leakage Current in Float | | 10 | $\mu$ A | $V_{\rm OUT}$ = 2.4 to $V_{\rm CC}$ | | $I_{\text{LOL}}$ | 3-State Output Leakage Current in Float | | -10 | μĀ | $V_{OUT} = 0.4 V$ | | $I_{\mathrm{LD}}$ | Data Bus Leakage Current ın Input Mode | | ±10 | $\mu$ A | $0 \! \leq \! V_{\mathrm{IN}} \! \leq \! V_{\mathrm{CC}}$ | $V_{CC}$ = 5 V ±5% unless otherwise specified, over specified temperature range #### Capacitance | Symbol | Parameter | Min | Мах | Unit | Test Condition | |-----------|--------------------|-----|-----|------|--------------------| | С | Clock Capacitance | | 35 | рF | Unmeasured Pins | | $C_{IN}$ | Input Capacitance | | 5 | рF | Returned to Ground | | $C_{OUT}$ | Output Capacitance | | 10 | рF | | Over specified temperature range, f = 1 MHz Inactive State AC Characteristics | Number | Symbol | Parameter | Z-80<br>Min | DMA<br>Max | Z-80A<br>Min | DMA<br>Max | Unit | |---------------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------|-------------|---------------|--------------|------------|------| | 1 | TcC | Clock Cycle Time | 400 | 4000 | 250 | 4000 | ns | | 2 | TwCh | Clock Width (High) | 170 | 2000 | 110 | 2000 | ns | | 3 | TwCl | Clock Width (Low) | 170 | 2000 | 110 | 2000 | ns | | 4 | TrC | Clock Rise Time | | 30 | | 30 | ns | | <del> 5</del> | TfC — | -Clock Fall Time | | <b>—</b> 30 – | | — 30 — | ns | | 6 | Th | Hold Time for Any Specified Setup Time | 0 | | 0 | | ns | | 7 | TsC(Cr) | IORQ, WR, CE ↓ to Clock ↑ Setup | 280 | | 145 | | ns | | 8 | TdDO(RDf) | RD1 to Data Output Delay | | 500 | | 380 | ns | | 9 | TsWM(Cr) | Data In to Clock † Setup ( $\overline{WR}$ or $\overline{Ml}$ ) | 50 | | 50 | | ns | | 10 | - TdCf(DO) | - <del>IORQ</del> ↓ to Data Out Delay (INTA Cycle) ——— | | —340 — | | —160 — | ns | | 11 | TdRD(Dz) | RD † to Data Float Delay (output buffer disable) | | 160 | | 110 | ns | | 12 | TsIEI(IORQ) | IEI↓ to <del>IORQ</del> ↓ Setup (INTA Cycle) | 140 | | 140 | | ns | | 13 | TdIEOr(IEIr) | IEI † to IEO † Delay | | 210 | | 160 | ns | | 14 | TdIEOf(IEIf) | IEI ↓ to IEO ↓ Delay | | 190 | | 130 | ns | | 15 | TdM1(IEO) | $\overline{\frac{Ml}{Ml}}$ to IEO Delay (interrupt just prior to — | | 300 | | 190 | ns | | 16 | TsMlf(Cr) | $\overline{\mathrm{Ml}}$ ‡ to Clock † Setup | 210 | | 90 | | ns | | 17 | TsMlr(Cf) | M1 ↑ to Clock ↓ Setup | 20 | | -10 | | ns | | 18 | TsRD(Cr) | RD ↓ to Clock † Setup (MI Cycle) | 240 | | 115 | | ns | | 19 | TdI(INT) | Interrupt Cause to $\overline{\text{INT}} \downarrow \text{Delay} (\overline{\text{INT}} \text{ generated} \\ \text{only when DMA is inactive)}$ | | 500 | | 500 | ns | | 20 | TdBAIr(BAOr) | BAI t to BAO t Delay | | _200 _ | | _150 | ns | | 21 | TdBAIf(BAOf) | BAI ↓ to BAO ↓ Delay | | 200 | | 150 | ns | | 22 | TsRDY(Cr) | RDY Active to Clock † Setup | 150 | | 100 | | ns | #### NOTE <sup>1</sup> Negative minimum setup values mean that the first-mentioned event can come after the second-mentioned event Inactive State AC Characteristics (Continued) NOTE Signals in this diagram bear no relation to one another unless specifically noted as a numbered item 2032-0144 Active State AC Characteristics | Number | Symbol | Parameter | Z-80<br>Min(ns) | DMA<br>Max(ns) | Z-80A<br>Min(ns) | DMA<br>Max(ns) | |--------|-------------|-------------------------------------------------------------------------------------------------------------------------------------|-----------------|-----------------------------|------------------|----------------| | 1 | TcC | Clock Cycle Time | 400 | | 250 | | | 2 | TwCh | Clock Width (High) | 180 | 2000 | 110 | 2000 | | 3 | TwCl | Clock Width (Low) | 180 | 2000 | 110 | 2000 | | 4 | TrC | Clock Rise Time | | 30 | | 30 | | 5 | -TfC | -Clock Fall Time- | | 30 | | 30- | | 6 | TdA | Address Output Delay | | 145 | | 110 | | 7 | TdC(Az) | Clock † to Address Float Delay | | 110 | | 90 | | 8 | TsA(MREQ) | Address to $\overline{\text{MREQ}}\ \downarrow \ \text{Setup}\ (\text{Memory Cycle})$ | (2) + (5) - 75 | | (2) + (5) - 75 | | | 9 | TsA(IRW) | Address Stable to $\overline{\text{IORQ}}$ , $\overline{\text{RD}}$ , $\overline{\text{WR}}$ \$\displies \text{Setup}\$ (I/O Cycle) | (1)-80 | | (1)-70 | | | 10 | -TdRW(A) | -RD, WR 1 to Addr. Stable Delay———— | -(3) + (4)-40 | | -(3) + (4)-50 | | | *11 | TdRW(Az) | RD, WR 1 to Addr. Float | (3) + (4) - 60 | | (3) + (4) - 45 | | | 12 | TdCf(DO) | Clock ↓ to Data Out Delay | | 230 | | 150 | | *13 | TdCr(Dz) | Clock † to Data Float Delay (Write Cycle) | | 90 | | 90 | | 14 | TsDI(Cr) | Data In to Clock † Setup (Read cycle when rising edge ends read) | 50 | | 35 | | | 15 | -TsDI(Cf) | <ul> <li>-Data In to Clock Setup (Read cycle when-<br/>falling edge ends read)</li> </ul> | 60 | | 50 | | | *16 | TsDO(WfM) | Data Out to WR ↓ Setup (Memory Cycle) | (1)-210 | | (1)-170 | | | 17 | TsDO(WfI) | Data Out to $\overline{\mathrm{WR}} \downarrow \mathrm{Setup}$ (I/O cycle) | 100 | | 100 | | | *18 | TdWr(DO) | WR † to Data Out Delay | (3) + (4) - 80 | | (3) + (4) - 70 | | | 19 | Th | Hold Time for Any Specified Setup Time | 0 | | 0 | | | 20 | -TdCf(Mf) | -Clock ↓ to MREQ ↓ Delay | | 100 | | 85 | | 21 | TdCr(Mr) | Clock † to MREQ † Delay | | 100 | | 85 | | 22 | TdCf(Mr) | Clock ↓ to MREQ ↑ Delay | | 100 | | 85 | | 23 | TwM1 | MREQ Low Pulse Width | (1)-40 | | (1)-30 | | | *24 | TwMh | MREQ High Pulse Width | (2) + (5) - 30 | | (2) + (5)-20 | | | 25 | -TdCr(If)—— | -Clock ↑ to <del>IORQ</del> ↓ Delay———————————————————————————————————— | | ——90 — | | <del></del> 75 | | 26 | TdCr(Ir) | Clock † to <del>IORQ</del> † Delay | | 100 | | 85 | | *27 | TdCf(Ir) | Clock ↓ to <del>IORQ</del> ↑ Delay | | 110 | | 85 | | 28 | TdCr(Rf) | Clock ↑ to $\overline{RD}$ ↓ Delay | | 100 | | 85 | | 29 | TdCf(Rf) | Clock ↓ to RD ↓ Delay | | 130 | | 95 | | 30 | -TdCr(Rr) | -Clock † to $\overline{\text{RD}}$ † Delay | | <del></del> 100 <del></del> | | <del>8</del> 5 | | 31 | TdCf(Rr) | Clock ↓ to RD ↑ Delay | | 110 | | 85 | | 32 | TdCr(Wf) | Clock ↑ to WR ↓ Delay | | 80 | | 65 | | 33 | TdCf(Wf) | Clock ↓ to WR ↓ Delay | | 90 | | 80 | | 34 | TdCr(Wr) | Clock † to WR † Delay | | 100 | | 80 | | 35 | -TdCf(Wr) | -Clock↓to WR↑Delay | | ——100 — | | 80 | | 36 | TwWl | WR Low Pulse Width | (1)-40 | | (1)-30 | | | 37 | TsWA(Cf) | WAIT to Clock Setup | 70 | | 70 | | | 38 | TdCr(B) | Clock t to BUSREQ Delay | | 150 | | 100 | | 39 | TdCr(Iz) | Clock † to $\overline{\text{IORQ}}$ , $\overline{\text{MREQ}}$ , $\overline{\text{RD}}$ , $\overline{\text{WR}}$ Float Delay | | 100 | | 80 | #### NOTES. NOTES. Numbers in parentheses are other parameter-numbers in this table, their values should be substituted in equations. All equations imply DMA default (standard) timing Data must be enabled onto data bus when RD is active. Asterisk (\*) before parameter number means the parameter is not illustrated in the AC Timing Diagrams NOTE Signals in this diagram bear no relation to one another unless specifically noted as a numbered item. 2032-0145 AC | Ordering<br>Information | Product<br>Number | Package/<br>Temp | Speed | Description | Product<br>Number | Package/<br>Temp | Speed | Description | |-------------------------|-------------------|------------------|---------|------------------|-------------------|------------------|---------|-------------------| | | Z8410 | CE | 2.5 MHz | Z80 DMA (40-pin) | Z8410 <b>A</b> | CE | 4.0 MHz | Z80A DMA (40-pin) | | | Z8410 | CM | 2.5 MHz | Same as above | Z8410A | CM | 4.0 MHz | Same as above | | | Z8410 | CMB | 2.5 MHz | Same as above | Z8410A | CMB | 4.0 MHz | Same as above | | | Z8410 | CS | 2.5 MHz | Same as above | Z8410A | CS | 4.0 MHz | Same as above | | | Z8410 | DE | 2.5 MHz | Same as above | Z8410A | DE | 4.0 MHz | Same as above | | | Z8410 | DS | 2.5 MHz | Same as above | Z8410A | DS | 4.0 MHz | Same as above | | | Z8410 | PE | 2.5 MHz | Same as above | Z8410A | PE | 4.0 MHz | Same as above | | | Z8410 | PS | 2.5 MHz | Same as above | Z8410A | PS | 4.0 MHz | Same as above | <sup>\*</sup>NOTES: C = Ceramic, D = Cerdip, P = Plastic; E = $-40^{\circ}$ C to $+85^{\circ}$ C, M = $-55^{\circ}$ C to $+125^{\circ}$ C, MB = $-55^{\circ}$ C to $+125^{\circ}$ C with MIL-STD-883, Class B processing, S = $0^{\circ}$ C to $+70^{\circ}$ C. 66 ### Z8420 Z80° PIO Parallel Input/Output Controller ## **Product Specification** June 1982 #### Features - Provides a direct interface between Z-80 microcomputer systems and peripheral devices. - Both ports have interrupt-driven handshake for fast response. - Four programmable operating modes: byte input, byte output, byte input/output (Port A only), and bit input/output. - Programmable interrupts on peripheral status conditions. - Standard Z-80 Family bus-request and prioritized interrupt-request daisy chains implemented without external logic. - The eight Port B outputs can drive Darlington transistors (1.5 mA at 1.5 V). #### General Description The Z-80 PIO Parallel I/O Circuit is a programmable, dual-port device that provides a TTL-compatible interface between peripheral devices and the Z-80 CPU. The CPU configures the Z-80 PIO to interface with a wide range of peripheral devices with no other external logic. Typical peripheral devices that are compatible with the Z-80 PIO include most keyboards, paper tape readers and punches, printers, PROM programmers, etc. One characteristic of the Z-80 peripheral controllers that separates them from other interface controllers is that all data transfer between the peripheral device and the CPU is accomplished under interrupt control. Thus, the interrupt logic of the PIO permits full use of the efficient interrupt capabilities of the Z-80 CPU during I/O transfers. All logic necessary to implement a fully nested interrupt structure is included in the PIO. Another feature of the PIO is the ability to interrupt the CPU upon occurrence of specified status conditions in the peripheral device. For example, the PIO can be programmed to interrupt if any specified peripheral alarm conditions should occur. This interrupt capability reduces the time the processor must spend in polling peripheral status. Figure 1. Pin Functions Figure 2. Pin Assignments General Description (Continued) The Z-80 PIO interfaces to peripherals via two independent general-purpose I/O ports, designated Port A and Port B. Each port has eight data bits and two handshake signals, Ready and Strobe, which control data transfer. The Ready output indicates to the peripheral that the port is ready for a data transfer. Strobe is an input from the peripheral that indicates when a data transfer has occurred. **Operating Modes.** The Z-80 PIO ports can be programmed to operate in four modes: byte output (Mode 0), byte input (Mode 1), byte input/output (Mode 2) and bit input/output (Mode 3). In Mode 0, either Port A or Port B can be programmed to output data. Both ports have output registers that are individually addressed by the CPU; data can be written to either port at any time. When data is written to a port, an active Ready output indicates to the external device that data is available at the associated port and is ready for transfer to the external device. After the data transfer, the external device responds with an active Strobe input, which generates an interrupt, if enabled. In Mode 1, either Port A or Port B can be configured in the input mode. Each port has an input register addressed by the CPU. When the CPU reads data from a port, the PIO sets the Ready signal, which is detected by the external device. The external device then places data on the I/O lines and strobes the I/O port, which latches the data into the Port Input Register, resets Ready, and triggers the Interrupt Request, if enabled. The CPU can read the input data at any time, which again sets Ready. Mode 2 is bidirectional and uses Port A, plus the interrupts and handshake signals from both ports. Port B must be set to Mode 3 and masked off. In operation, Port A is used for both data input and output. Output operation is similar to Mode 0 except that data is allowed out onto the Port A bus only when $\overline{\text{ASTB}}$ is Low. For input, operation is similar to Mode 1, except that the data input uses the Port B handshake signals and the Port B interrupt (if enabled). Both ports can be used in Mode 3. In this mode, the individual bits are defined as either input or output bits. This provides up to eight separate, individually defined bits for each port. During operation, Ready and Strobe are not used. Instead, an interrupt is generated if the condition of one input changes, or if all inputs change. The requirements for generating an interrupt are defined during the programming operation; the active level is specified as either High or Low, and the logic condition is specified as either one input active (OR) or all inputs active (AND). For example, if the port is programmed for active Low inputs and the logic function is AND, then all inputs at the specified port must go Low to generate an interrupt. Data outputs are controlled by the CPU and can be written or changed at any time. - Individual bits can be masked off. - The handshake signals are not used in Mode 3; Ready is held Low, and Strobe is disabled. - When using the Z-80 PIO interrupts, the Z-80 CPU interrupt mode must be set to Mode 2. Figure 3. PIO in a Typical Z80 Family Environment #### Internal Structure The internal structure of the Z-80 PIO consists of a Z-80 CPU bus interface, internal control logic, Port A I/O logic, Port B I/O logic, and interrupt control logic (Figure 4). The CPU bus interface logic allows the Z-80 PIO to interface directly to the Z-80 CPU with no other external logic. The internal control logic synchronizes the CPU data bus to the peripheral device interfaces (Port A and Port B). The two I/O ports (A and B) are virtually identical and are used to interface directly to peripheral devices. Port Logic. Each port contains separate input and output registers, handshake control logic, and the control registers shown in Figure 5. All data transfers between the peripheral unit and the CPU use the data input and output registers. The handshake logic associated with each port controls the data transfers through the input and the output registers. The mode control register (two bits) selects one of the four programmable operating modes. The control mode (Mode 3) uses the remaining registers. The input/output control register specifies which of the eight data bits in the port are to be outputs and enables these bits; the remaining bits are inputs. The mask register and the mask control register control Mode 3 interrupt conditions. The mask register specifies which of the bits in the port are active and which are masked or inactive. The mask control register specifies two conditions: first, whether the active state of the input bits is High or Low, and second, whether an interrupt is generated when any one unmasked input bit is active (OR condition) or if the interrupt is generated when all unmasked input bits are active (AND condition). Interrupt Control Logic. The interrupt control logic section handles all CPU interrupt protocol for nested-priority interrupt structures. Any device's physical location in a daisy-chain configuration determines its priority. Two lines (IEI and IEO) are provided in each PIO to form this daisy chain. The device closest to the CPU has the highest priority. Within a PIO, Port A interrupts have higher priority than those of Port B. In the byte input, byte output, or bidirectional modes, an interrupt can be generated whenever the peripheral requests a new byte transfer. In the bit control mode, an interrupt can be generated when the peripheral status matches a programmed value. The PIO provides for complete control of nested interrupts. That is, lower priority devices may not interrupt higher priority devices that have not had their interrupt service routines completed by the CPU. Higher priority devices may interrupt the servicing of lower priority devices. Figure 4. Block Diagram 2006-0316 Internal Structure (Continued) If the CPU (in interrupt Mode 2) accepts an interrupt, the interrupting device must provide an 8-bit interrupt vector for the CPU. This vector forms a pointer to a location in memory where the address of the interrupt service routine is located. The 8-bit vector from the interrupting device forms the least significant eight bits of the indirect pointer while the I Register in the CPU provides the most significant eight bits of the pointer. Each port (A and B) has an independent interrupt vector. The least significant bit of the vector is automatically set to 0 within the PIO because the pointer must point to two adjacent memory locations for a complete 16-bit address. Unlike the other Z-80 peripherals, the PIO does not enable interrupts immediately after programming. It waits until $\overline{\rm M1}$ goes Low (e.g., during an opcode fetch). This condition is unimportant in the Z-80 environment but might not be if another type of CPU is used. The PIO decodes the RETI (Return From Interrupt) instruction directly from the CPU data bus so that each PIO in the system knows at all times whether it is being serviced by the CPU interrupt service routine. No other communication with the CPU is required. **CPU Bus I/O Logic.** The CPU bus interface logic interfaces the Z-80 PIO directly to the Z-80 CPU, so no external logic is necessary. For large systems, however, address decoders and/or buffers may be necessary. Internal Control Logic. This logic receives the control words for each port during programming and, in turn, controls the operating functions of the Z-80 PIO. The control logic synchronizes the port operations, controls the port mode, port addressing, selects the read/write function, and issues appropriate commands to the ports and the interrupt logic. The Z-80 PIO does not receive a write input from the CPU; instead, the $\overline{\text{RD}}$ , $\overline{\text{CE}}$ , $\overline{\text{C/D}}$ and $\overline{\text{IORO}}$ signals generate the write input internally. Figure 5. Typical Port I/O Block Diagram 2006-0317 Programming Mode 0, 1, or 2. (Byte Input, Output, or Bidirectional). Programming a port for Mode 0, 1, or 2 requires two words per port. These words are: > A Mode Control Word. Selects the port operating mode (Figure 6). This word may be written any time. An Interrupt Vector. The Z-80 PIO is designed for use with the Z-80 CPU in interrupt Mode 2 (Figure 7). When interrupts are enabled, the PIO must provide an interrupt vector. Mode 3. (Bit Input/Output). Programming a port for Mode 3 operation requires a control word, a vector (if interrupts are enabled), and three additional words, described as follows: I/O Register Control. When Mode 3 is selected, the mode control word must be followed by another control word that sets the I/O control register, which in turn defines which port lines are inputs and which are outputs (Figure 8). Figure 6. Mode Control Word Figure 7. Interrupt Vector Word Figure 8. I/O Register Control Word Interrupt Control Word. In Mode 3, handshake is not used. Interrupts are generated as a logic function of the input signal levels. The interrupt control word sets the logic conditions and the logic levels required for generating an interrupt. Two logic conditions or functions are available: AND (if all input bits change to the active level, an interrupt is triggered), and OR (if any one of the input bits changes to the active level, an interrupt is triggered). Bit D<sub>6</sub> sets the logic function, as shown in Figure 9. The active level of the input bits can be set either High or Low. The active level is controlled by Bit D5. Mask Control Word. This word sets the mask control register, allowing any unused bits to be masked off. If any bits are to be masked, then D<sub>4</sub> must be set. When D<sub>4</sub> is set, the next word written to the port must be a mask control word (Figure 10). Interrupt Disable. There is one other control word which can be used to enable or disable a port interrupt. It can be used without changing the rest of the interrupt control word (Figure 11). \*NOTE. THE PORT IS NOT ENABLED UNTIL THE INTERRUPT ENABLE IS FOLLOWED BY AN ACTIVE M1 Figure 9. Interrupt Control Word Figure 10. Mask Control Word Figure 11. Interrupt Disable Word #### Pin Description **A<sub>0</sub>-A<sub>7</sub>.** Port A Bus (bidirectional, 3-state). This 8-bit bus transfers data, status, or control information between Port A of the PIO and a peripheral device. A<sub>0</sub> is the least significant bit of the Port A data bus. **ARDY.** Register A Ready (output, active High). The meaning of this signal depends on the mode of operation selected for Port A as follows: Output Mode. This signal goes active to indicate that the Port A output register has been loaded and the peripheral data bus is stable and ready for transfer to the peripheral device. **Input Mode.** This signal is active when the Port A input register is empty and ready to accept data from the peripheral device. Bidirectional Mode. This signal is active when data is available in the Port A output register for transfer to the peripheral device. In this mode, data is not placed on the Port A data bus, unless ASTB is active. Control Mode. This signal is disabled and forced to a Low state. **ASTB.** Port A Strobe Pulse From Peripheral Device (input, active Low). The meaning of this signal depends on the mode of operation selected for Port A as follows: Output Mode. The positive edge of this strobe is issued by the peripheral to acknowledge the receipt of data made available by the PIO Input Mode. The strobe is issued by the peripheral to load data from the peripheral into the Port A input register. Data is loaded into the PIO when this signal is active Bidirectional Mode. When this signal is active, data from the Port A output register is gated onto the Port A bidirectional data bus. The positive edge of the strobe acknowledges the receipt of the data. Control Mode. The strobe is inhibited internally. **B<sub>0</sub>-B<sub>7</sub>.** Port B Bus (bidirectional, 3-state). This 8-bit bus transfers data, status, or control information between Port B and a peripheral device. The Port B data bus can supply 1.5 mA at 1.5 V to drive Darlington transistors. B<sub>0</sub> is the least significant bit of the bus. **B/A.** Port B Or A Select (input, High = B). This pin defines which port is accessed during a data transfer between the CPU and the PIO. A Low on this pin selects Port A; a High selects Port B. Often address bit $A_0$ from the CPU is used for this selection function. **BRDY.** Register B Ready (output, active High). This signal is similar to ARDY, except that in the Port A bidirectional mode this signal is High when the Port A input register is empty and ready to accept data from the peripheral device. **BSTB.** Port B Strobe Pulse From Peripheral Device (input, active Low). This signal is similar to $\overline{ASTB}$ , except that in the Port A bidirectional mode this signal strobes data from the peripheral device into the Port A input register. **C/D.** Control Or Data Select (input, High = C). This pin defines the type of data transfer to be performed between the CPU and the PIO. A High on this pin during a CPU write to the PIO causes the Z-80 data bus to be interpreted as a command for the port selected by the $B/\overline{A}$ Select line. A Low on this pin means that the Z-80 data bus is being used to transfer data between the CPU and the PIO. Often address bit $A_1$ from the CPU is used for this function. **CE.** Chip Enable (input, active Low). A Low on this pin enables the PIO to accept command or data inputs from the CPU during a write cycle or to transmit data to the CPU during a read cycle. This signal is generally decoded from four I/O port numbers for Ports A and B, data, and control. **CLK.** System Clock (input). The Z-80 PIO uses the standard single-phase Z-80 system clock. **D<sub>0</sub>-D<sub>7</sub>.** Z-80 CPU Data Bus (bidirectional, 3-state). This bus is used to transfer all data and commands between the Z-80 CPU and the Z-80 PIO. $D_0$ is the least significant bit. **IEI.** Interrupt Enable In (input, active High). This signal is used to form a priority-interrupt daisy chain when more than one interrupt-driven device is being used. A High level on this pin indicates that no other devices of higher priority are being serviced by a CPU interrupt service routine. **IEO.** Interrupt Enable Out (output, active High). The IEO signal is the other signal required to form a daisy chain priority scheme. It is High only if IEI is High and the CPU is not servicing an interrupt from this PIO. Thus this signal blocks lower priority devices from interrupting while a higher priority device is being serviced by its CPU interrupt service routine. INT. Interrupt Request (output, open drain, active Low). When INT is active the Z-80 PIO is requesting an interrupt from the Z-80 CPU. IORQ. Input/Output Request (input from Z-80 CPU, active Low). IORQ is used in conjunction with $B/\overline{A}$ , $C/\overline{D}$ , $\overline{CE}$ , and $\overline{RD}$ to transfer commands and data between the Z-80 CPU and the Z-80 PIO. When $\overline{CE}$ , $\overline{RD}$ , and $\overline{IORQ}$ are active, the port addressed by B/A transfers data to the CPU (a read operation). Conversely, when $\overline{CE}$ and $\overline{IORQ}$ are active but $\overline{RD}$ is not, the port addressed by $B/\overline{A}$ is written into from the CPU with either data or control information, as specified by $C/\overline{D}$ . Also, if IORQ and MI are active simultaneously, the CPU is acknowledging an interrupt; the interrupting port automatically places its interrupt vector on the CPU data bus if it is the highest priority device requesting an interrupt. ## Pin Description (Continued) $\overline{\text{Ml.}}$ Machine Cycle (input from CPU, active Low). This signal is used as a sync pulse to control several internal PIO operations. When both the $\overline{\text{Ml}}$ and $\overline{\text{RD}}$ signals are active, the Z-80 CPU is fetching an instruction from memory. Conversely, when both $\overline{\text{Ml}}$ and $\overline{\text{IORQ}}$ are active, the CPU is acknowledging an interrupt. In addition, $\overline{\text{Ml}}$ has two other functions within the Z-80 PIO: it synchronizes the PIO interrupt logic, when $\overline{\text{M1}}$ occurs without an active $\overline{\text{RD}}$ or $\overline{\text{IORQ}}$ signal, the PIO is reset RD. Read Cycle Status (input from Z-80 CPU, active Low). If RD is active, or an I/O operation is in progress, RD is used with B/A, C/D, CE, and IORQ to transfer data from the Z-80 PIO to the Z-80 CPU. #### Timing The following timing diagrams show typical timing in a Z-80 CPU environment. For more precise specifications refer to the composite ac timing diagram. Write Cycle. Figure 12 illustrates the timing for programming the Z-80 PIO or for writing data to one of its ports. No Wait states are allowed for writing to the PIO other than the automatically inserted $T_{WA}$ . The PIO does not receive a specific write signal; it internally generates its own from the lack of an active $\overline{RD}$ signal. Figure 12. Write Cycle Timing **Read Cycle.** Figure 13 illustrates the timing for reading the data input from an external device to one of the Z-80 PIO ports. No Wait states are allowed for reading the PIO other than the automatically inserted $T_{WA}$ . Output Mode (Mode 0). An output cycle (Figure 14) is always started by the execution of an output instruction by the CPU. The $\overline{WR}^*$ pulse from the CPU latches the data from the CPU data bus into the selected port's output register. The $\overline{WR}^*$ pulse sets the Ready flag after a Low-going edge of CLK, indicating data is available. Ready stays active until the positive edge of the 'trobe line is received, indicating that data was taken by the peripheral. The positive edge of the strobe pulse generates an $\overline{INT}$ if the interrupt enable flipflop has been set and if this device has the highest priority. Figure 13. Read Cycle Timing $*\overline{WR} = RD \bullet \overline{CE} \bullet \overline{C/D} \bullet \overline{IORO}$ Figure 14. Mode 0 Output Timing 2006-0324, 0325, 0326 ## Timing (Continued) Input Mode (Mode 1). When STROBE goes Low, data is loaded into the selected port input register (Figure 15). The next rising edge of strobe activates INT, if Interrupt Enable is set and this is the highest-priority requesting device. The following falling edge of CLK resets Ready to an inactive state, indicating that the input register is full and cannot accept any more data until the CPU completes a read. When a read is complete, the positive edge of $\overline{\text{RD}}$ sets Ready at the next Low-going transition of CLK. At this time new data can be loaded into the PIO. Figure 15. Mode l Input Timing Bidirectional Mode (Mode 2). This is a combination of Modes 0 and 1 using all four handshake lines and the eight Port A I/O lines (Figure 16). Port B must be set to the bit mode and its inputs must be masked. The Port A handshake lines are used for output control and the Port B lines are used for input control. If interrupts occur, Port A's vector will be used during port output and Port B's will be used during port input. Data is allowed out onto the Port A bus only when $\overline{ASTB}$ is Low. The rising edge of this strobe can be used to latch the data into the peripheral. Figure 16. Mode 2 Bidirectional Timing #### Timing (Continued) Bit Mode (Mode 3). The bit mode does not utilize the handshake signals, and a normal port write or port read can be executed at any time. When writing, the data is latched into the output registers with the same timing as the output mode (Figure 17). When reading the PIO, the data returned to the CPU is composed of output register data from those port data lines assigned as outputs and input register data from those port data lines assigned as inputs. The input register contains data that was present immediately prior to the falling edge of $\overline{RD}$ . An interrupt is generated if interrupts from the port are enabled and the data on the port data lines satisfy the logical equation defined by the 8-bit mask and 2-bit mask control registers. However, if Port A is programmed in bidirectional mode, Port B does not issue an interrupt in bit mode and must therefore be polled. Figure 17. Mode 3 Bit Mode Timing Interrupt Acknowledge Timing. During $\overline{\text{M1}}$ time, peripheral controllers are inhibited from changing their interrupt enable status, permitting the Interrupt Enable signal to ripple through the daisy chain. The peripheral with IEI High and IEO Low during $\overline{\text{INTACK}}$ places a preprogrammed 8-bit interrupt vector on the data bus at this time (Figure 18). IEO is held Low until a Return From Interrupt (RETI) instruction is executed by the CPU while IEI is High. The 2-byte RETI instruction is decoded internally by the PIO for this purpose. Figure 18. Interrupt Acknowledge Timing Return From Interrupt Cycle. If a Z-80 perpheral has no interrupt pending and is not under service, then its IEO = IEI. If it has an interrupt under service (i.e., it has already interrupted and received an interrupt acknowledge) then its IEO is always Low, inhibiting lower priority devices from interrupting. If it has an interrupt pending which has not yet been acknowledged, IEO is Low unless an "ED" is decoded as the first byte of a 2-byte opcode (Figure 19). In this case, IEO goes High until the next opcode byte is decoded, whereupon it goes Low again. If the second byte of the opcode was a "4D," then the opcode was an RETI instruction. After an "ED" opcode is decoded, only the peripheral device which has interrupted and is currently under service has its IEI High and its IEO Low. This device is the highest-priority device in the daisy chain that has received an interrupt acknowledge. All other peripherals have IEI = IEO. If the next opcode byte decoded is "4D," this peripheral device resets its "interrupt under service" condition. Figure 19. Return From Interrupt | Number | · Symbol | Parameter | Z-80<br>Min<br>(ns) | PIO<br>Max<br>(ns) | Z-80A<br>Min<br>(ns) | PIO<br>Max<br>(ns) | Z-80B<br>Min<br>(ns) | PIO <sup>[9]</sup><br>Max<br>(ns) | Comment | |--------|-----------------------|-------------------------------------------------------------------------------------------------------------|-----------------------|--------------------|-----------------------------------------|--------------------|----------------------|-----------------------------------|------------| | 1 | TcC | | 400 | [1] | 250 | [1] | 165 | | | | 2 | TwCh | Clock Cycle Time<br>Clock Width (High) | 170 | 2000 | 105 | 2000 | 65 | [1]<br>2000 | | | 3 | TwCl | Clock Width (Low) | 170 | 2000 | 105 | 2000 | 65 | 2000 | | | 4 | TfC | Clock Fall Time | 110 | 30 | 100 | 30 | | 20 | | | 5 — | -TrC | — Clock Rise Time ———— | | <del></del> 30 | | 30 - | | 20 | | | 6 | TsCS(RI) | $\overline{CE}$ , B/ $\overline{A}$ , C/ $\overline{D}$ to $\overline{RD}$ , $\overline{IORQ}$ Setup Time | 50 | | 50 | | 50 | | [6] | | 7 | Th | Any Hold Times for Specified<br>Setup Time | 0 | | 0 | | 0 | 0 | | | 8 | TsRI(C) | RD, IORQ to Clock † Setup<br>Time | 115 | | 115 | | 70 | | | | 9 — | -TdRI(DO) <del></del> | —RD, IORQ ↓to Data Out Delay — | | <del></del> 430 - | *************************************** | <del></del> 380 | | <del></del> 300 | [2] | | 10 | TdRI(DOs) | RD, TORQ 1 to Data Out Float<br>Delay | | 160 | | 110 | | 70 | | | 11 | TsDI(C) | Data In to Clock † Setup Time | 50 | | 50 | | 40 | | CL = 50 pF | | 12 | TdIO(DOI) | IORQ ↓ to Data Out Delay<br>(INTACK Cycle) | 340 | | 160 | | 120 | | [3] | | 13 — | -TsMl(Cr) | —MI ↓ to Clock † Setup Time—— | <b>-210</b> - | | — 90 — | | 70 - | | | | 14 | TsM1(Cf) | Ml to Clock ↓ Setup Time<br>(Ml Cycle) | 0 | | 0 | | 0 | | [8] | | 15 | TdM1(IEO) | MI ↓ to IEO ↓ Delay (Interrupt<br>Immediately Preceding MI ↓) | | 300 | | 190 | | 100 | [5, 7] | | 16 | TsIEI(IO) | IEI to IORQ Setup Time<br>(INTACK Cycle) | 140 | | 140 | | 100 | | [7] | | 17 — | -TdIEI(IEOf) — | — IEI↓ to IEO↓ Delay———— | | <del></del> 190 - | | —130 — | | —120 —— | CL = 50 pF | | 18 | TdIEI(IEOr) | IEI † to IEO † Delay (after ED<br>Decode) | | 210 | | 160 | | 160 | (5) | | 19 | TcIO(C) | IORQ † to Clock Setup Time<br>(To Activate READY on Next | 220 | | 200 | | 170 | | | | 20 — | -T4C(DDV_) | Clock Cycle) — Clock to READY Delay ——— | 220<br>200 <i>-</i> - | | —190 — | | —170<br>—170 — | | [5] | | 20 | IdC(RDII) | Clock + to READ! Delay | 200 - | | 190 | | 170 | | CL = 50 pF | | 21 | TdC(RDYf) | Clock ↓ to READY ↑ Delay | 150 | | 140 | | 120 | | [5] | | 22 | TwSTB | STROBE Pulse Width | 150 | | 150 | | 120 | | [4] | | 23 | TsSTB(C) | STROBE ↑ to Clock ↓ Setup<br>Time (To Activate READY on<br>Next Clock Cycle) | 220 | | 220 | | 150 | | [5] | | 24 — | TdIO(PD)—— | - IORQ † to PORT DATA Stable -<br>Delay (Mode 0) | | 200 | | 180 | | 160 | [5] | | 25 | TsPD(STB) | PORT DATA to STROBE † Setup Time (Mode 1) | 260 | | 230 | | 190 | | | | 26 | TdSTB(PD) | STROBE to PORT DATA<br>Stable (Mode 2) | | 230 | | 210 | | 180 | [5] | | 27 — | TdSTB(PDr)— | STROBE † to PORT DATA Float<br>Delay (Mode 2) | | 200 | | 180 | | 160 | CL = 50 pF | | 28 | TdPD(INT) | PORT DATA Match to INT <br>Delay (Mode 3) | | 540 | | 490 | | 430 | | | 29 | TdSTB(INT) | STROBE ↑ to INT ↓ Delay | | 490 | | 440 | | 350 | | #### NOTES - [2] Increase TRICIOD) by 10 ns for each 50 pF increase in load - [2] increase Indico/ by 10 is for each 30 pF increase in to up to 200 pF max. [3] Increase TdIO(DOI) by 10 ns for each 50 pF, increase in loading up to 200 pF max. [4] For Mode 2. TwSTB > TsPD(STB) - [5] Increase these values by 2 ns for each 10 pF increase in loading up to 100 pF max. - [6] TsCS(RI) may be reduced. However, the time subtracted from TsCS(RI) will be added to TdRI(DO). [7] 2.5 TcC > (M-2)TdIEI(IEOf) + TdMI(IEO) + TsIEI(IO) + TTL Buffer Delay, if any. [8] MI must be active for a minimum of two clock cycles to reset the PIO. [9] Z80B PIO numbers are preliminary and subject to change. | Absolute | |----------| | Maximum | | Ratings | Voltages on all inputs and outputs with respect to GND.....-0.3 V to +7.0 V Operating Ambient Temperature . . . . . . . . . . . . . As Specified in 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. #### Test Conditions The characteristics below apply for the following 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: ■ $S^* = 0$ °C to +70°C, +4.75 V ≤ $V_{CC}$ ≤ +5.25 V ■ $E^* = -40$ °C to +85°C, +4.75 V $\leq$ V<sub>CC</sub> $\leq$ +5.25 V ■ $M^* = -55$ °C to +125 °C, +4.5 V ≤ $V_{CC}$ ≤ +5.5 V \*See Ordering Information section for package temperature range and product number All ac parameters assume a load capacitance of 100 pF max. Timing references between two output signals assume a load difference of 50 pF max. ### DC Characteristics | Symbol | Parameter | Min | Max | Unit | Test Condition | |--------------------|-----------------------------------------------|-------------------|-------|---------|-------------------------------| | V <sub>ILC</sub> | Clock Input Low Voltage | -0.3 | +0.45 | V | | | $V_{\mathrm{IHC}}$ | Clock Input High Voltage | $V_{\rm CC}$ -0.6 | +5.5 | V | | | $V_{\rm IL}$ | Input Low Voltage | -0.3 | +0.8 | V | | | $V_{IH}$ | Input High Voltage | +2.0 | +5.5 | V | | | $V_{OL}$ | Output Low Voltage | | +0.4 | V | $I_{OL} = 2.0 \text{ mA}$ | | $V_{OH}$ | Output High Voltage | +2.4 | | V | $I_{OH} = -250 \mu\text{A}$ | | $I_{LI}$ | Input Leakage Current | -10.0 | +10.0 | $\mu$ A | $0 < V_{\rm IN} < V_{\rm CC}$ | | $I_Z$ | 3-State Output/Data Bus Input Leakage Current | -10.0 | +10.0 | $\mu$ A | $0 < V_{\rm IN} < V_{\rm CC}$ | | $I_{CC}$ | Power Supply Current | | 100.0 | mA | $V_{OH} = 1.5V$ | | $I_{OHD}$ | Darlington Drive Current | -1.5 | 3.8 | mA | $R_{EXT} = 390 \Omega$ | Over specified temperature and voltage range #### Capacitance | Symbol | Parameter | Min | Мах | Unit | Test Condition | |----------|--------------------|-----|------|------|----------------------------| | C | Clock Capacitance | | 10 | рF | Unmeasured | | $C_{IN}$ | Input Capacitance | | 5 | рF | pins returned<br>to ground | | COLL | Output Capacitance | | . 10 | рF | io ground | Over specified temperature range; f = 1MHz | Ordering<br>Information | Product<br>Number | Package/<br>Temp | Speed | Description | Product<br>Number | Package/<br>Temp | Speed | Description | |-------------------------|-------------------|------------------|---------|-------------------|-------------------|------------------|---------|-------------------| | | Z8420 | CE | 2.5 MHz | Z80 PIO (40-pin) | Z8420A | DE | 4.0 MHz | Z80A PIO (40-pin) | | | Z8420 | CM | 2.5 MHz | Same as above | Z8420A | DS | 4.0 MHz | Same as above | | | Z8420 | CMB | 2.5 MHz | Same as above | Z8420A | PE | 4.0 MHz | Same as above | | | Z8420 | CS | 2.5 MHz | Same as above | Z8420A | PS | 4.0 MHz | Same as above | | | Z8420 | DE | 2.5 MHz | Same as above | Z8420B | CE | 6.0 MHz | Z80B PIO (40-pin) | | | Z8420 | DS | 2.5 MHz | Same as above | Z8420B | CM | 6.0 MHz | Same as above | | | Z8420 | PE | 4.0 MHz | Same as above | Z8420B | CMB | 6.0 MHz | Same as above | | | Z8420 | PS | 4.0 MHz | Same as above | Z8420B | CS | 6.0 MHz | Same as above | | | Z8420A | CE | 4.0 MHz | Z80A PIO (40-pin) | Z8420B | DE | 6.0 MHz | Same as above | | | Z8420A | CM | 4.0 MHz | Same as above | Z8420B | DS | 6.0 MHz | Same as above | | | Z8420A | CMB | 4.0 MHz | Same as above | Z8420B | PE | 6.0 MHz | Same as above | | | Z8420A | CS | 4.0 MHz | Same as above | Z8420B | PS | 6.0 MHz | Same as above | \*NOTES. C = Ceramic, D = Cerdip, P = Plastic, E = -40°C to +85°C, M = -55°C to +125°C, MB = 55°C to +125°C with MIL-STD-883 Class B processing, S = 0°C to +70°C ### Z8430 Z80° CTC Counter/ Timer Circuit ### Product Specification June 1982 #### **Features** - Four independently programmable counter/timer channels, each with a readable downcounter and a selectable 16 or 256 prescaler. Downcounters are reloaded automatically at zero count. - Three channels have Zero Count/Timeout outputs capable of driving Darlington transistors. - Julie 1302 - Selectable positive or negative trigger initiates timer operation. - Standard Z-80 Family daisy-chain interrupt structure provides fully vectored, prioritized interrupts without external logic. The CTC may also be used as an interrupt controller. - Interfaces directly to the Z-80 CPU or—for baud rate generation—to the Z-80 SIO. #### General Description The Z-80 CTC four-channel counter/timer can be programmed by system software for a broad range of counting and timing applications. The four independently programmable channels of the Z-80 CTC satisfy common microcomputer system requirements for event counting, interrupt and interval timing, and general clock rate generation. System design is simplified because the CTC connects directly to both the Z-80 CPU and the Z-80 SIO with no additional logic. In larger systems, address decoders and buffers may be required. Programming the CTC is straightforward: each channel is programmed with two bytes; a third is necessary when interrupts are enabled. Once started, the CTC counts down, reloads its time constant automatically, and resumes counting. Software timing loops are completely eliminated. Interrupt processing is simplified because only one vector need be specified; the CTC internally generates a unique vector for each channel. The Z-80 CTC requires a single +5 V power supply and the standard Z-80 single-phase system clock. It is fabricated with n-channel silicon-gate depletion-load technology, and packaged in a 28-pin plastic or ceramic DIP. D5 🗆 27 D<sub>2</sub> 26 D<sub>1</sub> D<sub>6</sub> 25 D D<sub>0</sub> D7 GND RD 🗆 Z80 CTC ZC/TO₀ □ 780A CTC 22 CLK/TRG1 21 CLK/TRG2 20 CLK/TRG3 19 CS1 18 CS0 ZC/TO1 ZC/TO₂ □ IORQ 🗖 10 IEO 🗖 11 17 RESET 16 CE 15 CLK INT | 12 13 M1 Figure 1. Pin Functions Figure 2. Pin Assignments #### Functional Description The Z-80 CTC has four independent counter/timer channels. Each channel is individually programmed with two words: a control word and a time-constant word. The control word selects the operating mode (counter or timer), enables or disables the channel interrupt, and selects certain other operating parameters. If the timing mode is selected, the control word also sets a prescaler, which divides the system clock by either 16 or 256. The time-constant word is a value from 1 to 256. During operation, the individual counter channel counts down from the preset time constant value. In counter mode operation the counter decrements on each of the CLK/TRG input pulses until zero count is reached. Each decrement is synchronized by the system clock. For counts greater than 256, more than one counter can be cascaded. At zero count, the down-counter is automatically reset with the time constant value. The timer mode determines time intervals as small as 4 $\mu s$ (Z-80A) or 6.4 $\mu s$ (Z-80) without additional logic or software timing loops. Time intervals are generated by dividing the system clock with a prescaler that decrements a preset down-counter. Thus, the time interval is an integral multiple of the clock period, the prescaler value (16 or 256) and the time constant that is preset in the down-counter. A timer is triggered automatically when its time constant value is programmed, or by an external CLK/TRG input. Three channels have two outputs that occur at zero count. The first output is a zero-count/timeout pulse at the ZC/TO output. The fourth channel (Channel 3) does not have a ZC/TO output; interrupt request is the only output available from Channel 3. The second output is Interrupt Request $(\overline{INT})$ , which occurs if the channel has its interrupt enabled during programming. When the Z-80 CPU acknowledges Interrupt Request, the Z-80 CTC places an interrupt vector on the data bus. The four channels of the Z-80 CTC are fully prioritized and fit into four contiguous slots in a standard Z-80 daisy-chain interrupt structure. Channel 0 is the highest priority and Channel 3 the lowest. Interrupts can be individually enabled (or disabled) for each of the four channels. #### Architecture The CTC has four major elements, as shown in Figure 3. - CPU bus I/O - Channel control logic - Interrupt logic - Counter/timer circuits **CPU Bus I/O.** The CPU bus I/O circuit decodes the address inputs, and interfaces the CPU data and control signals to the CTC for distribution on the internal bus. **Internal Control Logic.** The CTC internal control logic controls overall chip operating functions such as the chip enable, reset, and read/write logic. Interrupt Logic. The interrupt control logic ensures that the CTC interrupts interface properly with the Z-80 CPU interrupt system. The logic controls the interrupt priority of the CTC as a function of the IEI signal. If IEI is High, the CTC has priority. During interrupt Figure 3. Functional Block Diagram Architecture (Continued) processing, the interrupt logic holds IEO Low, which inhibits the interrupt operation on lower priority devices. If the IEI input goes Low, priority is relinquished and the interrupt logic drives IEO Low. If a channel is programmed to request an interrupt, the interrupt logic drives IEO Low at the zero count, and generates an $\overline{\text{INT}}$ signal to the Z-80 CPU. When the Z-80 CPU responds with interrupt acknowledge ( $\overline{\text{Ml}}$ and $\overline{\text{IORQ}}$ ), then the interrupt logic arbitrates the CTC internal priorities, and the interrupt control logic places a unique interrupt vector on the data bus. If an interrupt is pending, the interrupt logic holds IEO Low. When the Z-80 CPU issues a Return From Interrupt (RETI) instruction, each peripheral device decodes the first byte (ED $_{16}$ ). If the device has a pending interrupt, it raises IEO (High) for one $\overline{\rm M1}$ cycle. This ensures that all lower priority devices can decode the entire RETI instruction and reset properly. Figure 4. Counter/Timer Block Diagram **Counter/Timer Circuits.** The CTC has four independent counter/timer circuits, each containing the logic shown in Figure 4. **Channel Control Logic.** The channel control logic receives the 8-bit channel control word when the counter/timer channel is programmed. The channel control logic decodes the control word and sets the following operating conditions: - Interrupt enable (or disable) - Operating mode (timer or counter) - Timer mode prescaler factor (16 or 256) - Active slope for CLK/TRG input - Timer mode trigger (automatic or CLK/TRG input) - Time constant data word to follow - Software reset Time Constant Register. When the counter/timer channel is programmed, the time constant register receives and stores an 8-bit time constant value, which can be anywhere from 1 to 256 (0 = 256). This constant is automatically loaded into the down-counter when the counter/timer channel is initialized, and subsequently after each zero count. **Prescaler.** The prescaler, which is used only in timer mode, divides the system clock frequency by a factor of either 16 or 256. The prescaler output clocks the down-counter during timer operation. The effect of the prescaler on the down-counter is a multiplication of the system clock period by 16 or 256. The prescaler factor is programmed by bit 5 of the channel control word. **Down-Counter.** Prior to each count cycle, the down-counter is loaded with the time constant register contents. The counter is then decremented one of two ways, depending on operating mode: - By the prescaler output (timer mode) - By the trigger pulses into the CLK/TRG input (counter mode) Without disturbing the down-count, the Z-80 CPU can read the count remaining at any time by performing an I/O read operation at the port address assigned to the CTC channel. When the down-counter reaches the zero count, the ZC/TO output generates a positive-going pulse. When the interrupt is enabled, zero count also triggers an interrupt request signal $(\overline{\rm INT})$ from the interrupt logic. #### Programming Each Z-80 CTC channel must be programmed prior to operation. Programming consists of writing two words to the I/O port that corresponds to the desired channel. The first word is a control word that selects the operating mode and other parameters; the second word is a time constant, which is a binary data word with a value from 1 to 256. A time constant word must be preceded by a channel control word. After initialization, channels may be reprogrammed at any time. If updated control and time constant words are written to a channel during the count operation, the count continues to zero before the new time constant is loaded into the counter. If the interrupt on any Z-80 CTC channel is enabled, the programming procedure should also include an interrupt vector. Only one vector is required for all four channels, because the interrupt logic automatically modifies the vector for the channel requesting service. A control word is identified by a 1 in bit 0. A 1 in bit 2 indicates a time constant word is to follow. Interrupt vectors are always addressed to Channel 0, and identified by a 0 in bit 0. **Addressing.** During programming, channels are addressed with the channel select pins CS<sub>1</sub> and CS<sub>2</sub>. A 2-bit binary code selects the appropriate channel as shown in the following table. | Channel | $CS_1$ | CS <sub>0</sub> | | |---------|--------|-----------------|--| | 0 | 0 | 0 | | | 1 | 0 | 1 | | | 2 | 1 | 0 | | | 3 | 1 | 1 | | **Reset.** The CTC has both hardware and software resets. The hardware reset terminates all down-counts and disables all CTC interrupts by resetting the interrupt bits in the control registers. In addition, the ZC/TO and Interrupt outputs go inactive, IEO reflects IEI, and D<sub>0</sub>-D<sub>7</sub> go to the high-impedance state. All channels must be completely reprogrammed after a hardware reset. The software reset is controlled by bit 1 in the channel control word. When a channel receives a software reset, it stops counting. When a software reset is used, the other bits in the control word also change the contents of the channel control register. After a software reset a new time constant word must be written to the same channel. If the channel control word has both bits $D_1$ and $D_2$ set to 1, the addressed channel stops operating, pending a new time constant word. The channel is ready to resume after the new constant is programmed. In timer mode, if $D_3 = 0$ , operation is triggered automatically when the time constant word is loaded. **Channel Control Word Programming.** The channel control word is shown in Figure 5. It sets the modes and parameters described below. Interrupt Enable. $D_7$ enables the interrupt, so that an interrupt output ( $\overline{INT}$ ) is generated at zero count. Interrupts may be programmed in either mode and may be enabled or disabled at any time. Operating Mode. $D_6$ selects either timer or counter mode. Prescaler Factor. (Timer Mode Only). D<sub>5</sub> selects factor—either 16 or 256. Trigger Slope. $D_4$ selects the active edge or slope of the CLK/TRG input pulses. Note that reprogramming the CLK/TRG slope during operation is equivalent to issuing an active edge. If the trigger slope is changed by a control word update while a channel is pending operation in timer mode, the result is the same as a CLK/TRG pulse and the timer starts. Similarly, if the channel is in counter mode, the counter decrements. Figure 5. Channel Control Word ## (Continued) Programming Trigger Mode (Timer Mode Only). D<sub>3</sub> selects the trigger mode for timer operation. When D<sub>3</sub> is reset to 0, the timer is triggered automatically. The time constant word is programmed during an I/O write operation, which takes one machine cycle. At the end of the write operation there is a setup delay of one clock period. The timer starts automatically (decrements) on the rising edge of the second clock pulse $(T_2)$ of the machine cycle following the write operation. Once started, the timer runs continuously. At zero count the timer reloads automatically and continues counting without interruption or delay, until stopped by a reset. > When $D_3$ is set to 1, the timer is triggered externally through the CLK/TRG input. The time constant word is programmed during an I/O write operation, which takes one machine cycle. The timer is ready for operation on the rising edge of the second clock pulse (T2) of the following machine cycle. Note that the first timer decrement follows the active edge of the CLK/TRG pulse by a delay time of one clock cycle if a minimum setup time to the rising edge of clock is met. If this minimum is not met, the delay is extended by another clock period. Consequently, for immediate triggering, the CLK/TRG input must precede T2 by one clock cycle plus its minimum setup time. If the minimum time is not met, the timer will start on the third clock cycle $(T_3)$ . Once started the timer operates continuously, without interruption or delay, until stopped by a reset. Time Constant to Follow. A 1 in $D_2$ indicates that the next word addressed to the selected channel is a time constant data word for the time constant register. The time constant word may be written at any time. A 0 in D<sub>2</sub> indicates no time constant word is to follow. This is ordinarily used when the channel is already in operation and the new channel control word is an update. A channel will not operate without a time constant value. The only way to write a time constant value is to write a control word with D2 set. Figure 6. Time Constant Word Software Reset. Setting D<sub>1</sub> to 1 causes a software reset, which is described in the Reset section Control Word. Setting Do to 1 identifies the word as a control word. Time Constant Programming. Before a channel can start counting it must receive a time constant word from the CPU. During programming or reprogramming, a channel control word in which bit 2 is set must precede the time constant word to indicate that the next word is a time constant. The time constant word can be any value from 1 to 256 (Figure 6). Note that $00_{16}$ is interpreted as 256. In timer mode, the time interval is controlled by three factors: - The system clock period $(\phi)$ - The prescaler factor (P), which multiplies the interval by either 16 r 256 - The time constant (T), which is programmed into the time constant register Consequently, the time interval is the product of $\phi \times P \times T$ . The minimum timer resolution is $16 \times \phi$ (4 $\mu$ s with a 4 MHz clock). The maximum timer interval is $256 \times \phi \times 256$ (16.4 ms with a 4 MHz clock). For longer intervals timers may be cascaded. Interrupt Vector Programming. If the Z-80 CTC has one or more interrupts enabled, it can supply interrupt vectors to the Z-80 CPU. To do so, the Z-80 CTC must be pre-programmed with the most-significant five bits of the interrupt vector. Programming consists of writing a vector word to the I/O port corresponding to the Z-80 CTC Channel 0. Note that D<sub>0</sub> of the vector word is always zero, to distinguish the vector from a channel control word. D<sub>1</sub> and D<sub>2</sub> are not used in programming the vector word. These bits are supplied by the interrupt logic to identify the channel requesting interrupt service with a unique interrupt vector (Figure 7). Channel 0 has the highest priority. Figure 7. Interrupt Vector Word #### Pin Description **CE.** Chip Enable (input, active Low). When enabled the CTC accepts control words, interrupt vectors, or time constant data words from the data bus during an I/O write cycle; or transmits the contents of the down-counter to the CPU during an I/O read cycle. In most applications this signal is decoded from the eight least significant bits of the address bus for any of the four I/O port addresses that are mapped to the four counter-timer channels. **CLK.** System Clock (input). Standard single-phase Z-80 system clock. **CLK/TRG<sub>0</sub>-CLK/TRG<sub>3</sub>.** External Clock/Timer Trigger (input, user-selectable active High or Low). Four pins corresponding to the four Z-80 CTC channels. In counter mode, every active edge on this pin decrements the down-counter. In timer mode, an active edge starts the timer. $\begin{array}{ll} \textbf{CS}_0\textbf{-CS}_1. \ \ \textit{Channel Select} \ (\text{inputs active High}). \\ \text{Two-bit binary address code selects one of the four CTC channels for an I/O write or read} \\ \text{(usually connected to $A_0$ and $A_1$)}. \end{array}$ **D<sub>0</sub>-D<sub>7</sub>.** System Data Bus (bidirectional, 3-state). Transfers all data and commands between the Z-80 CPU and the Z-80 CTC. Figure 8. A Typical Z-80 Environment **IEI.** Interrupt Enable In (input, active High). A High indicates that no other interrupting devices of higher priority in the daisy chain are being serviced by the Z-80 CPU. **IEO.** Interrupt Enable Out (output, active High). High only if IEI is High and the Z-80 CPU is not servicing an interrupt from any Z-80 CTC channel. IEO blocks lower priority devices from interrupting while a higher priority interrupting device is being serviced. **INT.** Interrupt Request (output, open drain, active Low). Low when any Z-80 CTC channel that has been programmed to enable interrupts has a zero-count condition in its down-counter. IORQ. Input/Output Request (input from CPU, active Low). Used with CE and RD to transfer data and channel control words between the Z-80 CPU and the Z-80 CTC. During a write cycle, IORQ and CE are active and RD mactive. The Z-80 CTC does not receive a specific write signal; rather, it internally generates its own from the inverse of an active RD signal. In a read cycle, IORQ, CE and RD are active; the contents of the down-counter are read by the Z-80 CPU. If IORQ and MI are both true, the CPU is acknowledging an interrupt request, and the highest priority interrupting channel places its interrupt vector on the Z-80 data bus. $\overline{\text{Ml.}}$ Machine Cycle One (input from CPU, active Low). When $\overline{\text{Ml}}$ and $\overline{\text{IORQ}}$ are active, the Z-80 CPU is acknowledging an interrupt. The Z-80 CTC then places an interrupt vector on the data bus if it has highest priority, and if a channel has requested an interrupt ( $\overline{\text{INT}}$ ). **RD.** Read Cycle Status (input, active Low). Used in conjunction with $\overline{\text{IORO}}$ and $\overline{\text{CE}}$ to transfer data and channel control words between the Z-80 CPU and the Z-80 CTC. **RESET.** Reset (input active Low). Terminates all down-counts and disables all interrupts by resetting the interrupt bits in all control registers; the ZC/TO and the Interrupt outputs go inactive; IEO reflects IEI; $D_0$ – $D_7$ go to the high-impedance state. **ZC/TO<sub>0</sub>-ZC/TO<sub>2</sub>.** Zero Count/Timeout (output, active High). Three ZC/TO pins corresponding to Z-80 CTC channels 2 through 0 (Channel 3 has no ZC/TO pin). In both counter and timer modes the output is an active High pulse when the down-counter decrements to zero. #### Timing **Read Cycle Timing.** Figure 9 shows read cycle timing. This cycle reads the contents of a down-counter without disturbing the count. During clock cycle $T_2$ , the Z-80 CPU initiates a read cycle by driving the following inputs Low: $\overline{\text{RD}}$ , $\overline{\text{IORQ}}$ , and $\overline{\text{CE}}$ . A 2-bit binary code at inputs $\overline{\text{CS}}_1$ and $\overline{\text{CS}}_0$ selects the channel to be read. $\overline{\text{MI}}$ must be High to distinguish this cycle from an interrupt acknowledge. No additional wait states are allowed. Figure 9. Read Cycle Timing **Write Cycle Timing.** Figure 10 shows write cycle timing for loading control, time constant or vector words. The CTC does not have a write signal input, so it generates one internally when the read $(\overline{\text{RD}})$ input is High during $\text{T}_1$ . During $\text{T}_2$ $\overline{\text{IORQ}}$ and $\overline{\text{CE}}$ inputs are Low. $\overline{\text{MI}}$ must be High to distinguish a write cycle from an interrupt acknowledge. A 2-bit binary code at inputs $\text{CS}_1$ and $\text{CS}_0$ selects the channel to be addressed, and the word being written is placed on the Z-80 data bus. The data word is Figure 10. Write Cycle Timing latched into the appropriate register with the rising edge of clock cycle T<sub>3</sub>. Figure 11. Timer Mode Timing Timer Operation. In the timer mode, a CLK/TRG pulse input starts the timer (Figure 11) on the second succeeding rising edge of CLK. The trigger pulse is asynchronous, and it must have a minimum width. A minimum lead time (210 ns) is required between the active edge of the CLK/TRG and the next rising edge of CLK to enable the prescaler on the following clock edge. If the CLK/TRG edge occurs closer than this, the initiation of the timer function is delayed one clock cycle. This corresponds to the startup timing discussed in the programming section. The timer can also be started automatically if so programmed by the channel control word. Figure 12. Counter Mode Timing Counter Operation. In the counter mode, the CLK/TRG pulse input decrements the down-counter. The trigger is asynchronous, but the count is synchronized with CLK. For the decrement to occur on the next rising edge of CLK, the trigger edge must precede CLK by a minimum lead time as shown in Figure 12. If the lead time is less than specified, the count is delayed by one clock cycle. The trigger pulse must have a minimum width, and the trigger period must be at least twice the clock period. The ZC/TO output occurs immediately after zero count, and follows the rising CLK edge. #### Interrupt Operation The Z-80 CTC follows the Z-80 system interrupt protocol for nested priority interrupts and return from interrupt, wherein the interrupt priority of a peripheral is determined by its location in a daisy chain. Two lines—IEI and IEO—in the CTC connect it to the system daisy chain. The device closest to the +5 V supply has the highest priority (Figure 13). For additional information on the Z-80 interrupt structure, refer to the Z-80 CPU Product Specification and the Z-80 CPU Technical Manual. Figure 13. Daisy-Chain Interrupt Priorities Within the Z-80 CTC, interrupt priority is predetermined by channel number: Channel 0 has the highest priority, and Channel 3 the lowest. If a device or channel is being serviced with an interrupt routine, it cannot be interrupted by a device or channel with lower priority until service is complete. Higher priority devices or channels may interrupt the servicing of lower priority devices or channels. A Z-80 CTC channel may be programmed to request an interrupt every time its down-counter reaches zero. Note that the CPU must be programmed for interrupt mode 2. Some time after the interrupt request, the CPU sends an interrupt acknowledge. The CTC interrupt control logic determines the highest priority channel that is requesting an interrupt. Then, if the CTC IEI input is High (indicating that it has priority within the system daisy chain) it places an 8-bit interrupt vector on the system data bus. The high-order five bits of this vector ming process; the next two bits are provided by the CTC interrupt control logic as a binary code that identifies the highest priority channel requesting an interrupt; the low-order bit is always zero. Interrupt Acknowledge Timing. Figure 14 shows interrupt acknowledge timing. After an interrupt request, the Z-80 CPU sends an interrupt acknowledge ( $\overline{\text{M1}}$ and $\overline{\text{IORO}}$ ). All channels are inhibited from changing their interrupt request status when $\overline{\text{M1}}$ is active—about two clock cycles earlier than $\overline{\text{IORO}}$ . $\overline{\text{RD}}$ is High to distinguish this cycle from an instruction fetch. The CTC interrupt logic determines the highest priority channel requesting an interrupt. If the CTC interrupt enable input (IEI) is High, the highest priority interrupting channel within the CTC places its interrupt vector on the data bus when $\overline{\rm IORQ}$ goes Low. Two wait states (TWA) are automatically inserted at this time to allow the daisy chain to stabilize. Additional wait states may be added. Return from Interrupt Timing. At the end of an interrupt service routine the RETI (Return From Interrupt) instruction initializes the daisy chain enable lines for proper control of nested priority interrupt handling. The CTC decodes the 2-byte RETI code internally and determines whether it is intended for a channel being serviced. Figure 15 shows RETI timing. If several Z-80 peripherals are in the daisy chain, IEI settles active (High) on the chip currently being serviced when the opcode $\mathrm{ED}_{16}$ is decoded. If the following opcode is $\mathrm{4D}_{16}$ , the peripheral being serviced is released and its IEO becomes active. Additional wait states are allowed. Figure 14. Interrupt Acknowledge Timing Figure 15. Return From Interrupt Timing | Absolute<br>Maximum<br>Ratings | Voltages on all inputs and outputs with respect to GND0.3 V to +7.0 V Operating Ambient As Specified in TemperatureOrdering Information Storage Temperature65°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. | |--------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| |--------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| #### Test Conditions The characteristics below apply for the following 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: - S\* = 0°C to +70°C, +4.75 V $\leq$ V<sub>CC</sub> $\leq$ +5.25 V - $E^* = -40$ °C to +85°C, +4.75 V $\leq$ V<sub>CC</sub> $\leq$ +5.25 V - $M^* = -55$ °C to +125°C, +4.5 V ≤ $V_{CC}$ ≤ +5.5 V \*See Ordering Information section for package temperature range and product number | DC<br>Character- | Symbol | Parameter | Min | Мах | Unit | Test Condition | |------------------|--------------------|-----------------------------------------|-------------------|-------------------|---------|------------------------------------------------| | istics | $V_{\rm ILC}$ | Clock Input Low Voltage | -0.3 | +0.45 | V | | | | $V_{\mathrm{IHC}}$ | Clock Input High Voltage | V <sub>CC</sub> 6 | $V_{\rm CC} + .3$ | V | | | | $V_{\mathrm{IL}}$ | Input Low Voltage | -0.3 | +0.8 | V | | | | $V_{IH}$ | Input High Voltage | +2.0 | $v_{\rm cc}$ | V | | | | $v_{OL}$ | Output Low Voltage | | +0.4 | V | $I_{OL} = 2 \text{ mA}$ | | | $v_{OH}$ | Output High Voltage | +2.4 | | V | $I_{OH} = 250 \mu A$ | | | $I_{CC}$ | Power Supply Current | | +120 | mĀ | | | | ${ m I_{LI}}$ | Input Leakage Current | | +10 | $\mu$ A | $V_{\rm IN} = 0 \text{ to } V_{\rm CC}$ | | | $I_{LOH}$ | 3-State Output Leakage Current in Float | | +10 | $\mu$ A | $V_{OUT} = 2.4 \text{ to } V_{CC}$ | | | $I_{LOL}$ | 3-State Output Leakage Current in Float | | -10 | $\mu$ A | $V_{OUT} = 0.4 V$ | | | $I_{OHD}$ | Darlington Drive Current | -1.5 | | mA | $V_{OH} = 1.5 \text{ V}$ $R_{EXT} = 390\Omega$ | | Capacitance | Symbol | Parameter | Мах | Unit | Condition | |-------------|-----------|--------------------|-----|------|--------------------| | | CLK | Clock Capacitance | 20 | рF | Unmeasured pins | | | $C_{IN}$ | Input Capacitance | 5 | рF | returned to ground | | | $C_{OUT}$ | Output Capacitance | 10 | рF | | $T_{A} = 25$ °C, f = 1 MHz | | | | Z-80 CTC | | Z-80A CTC<br>Min Max | | Z-80<br>Min | B CTC<br>Max | | |--------|-------------|-------------------------------------------------------------------------------------|----------------|-------------|----------------------|----------------------|------------------|-------------------------|------------| | Number | Symbol | Parameter | Min<br>(ns) | Max<br>(ns) | (ns) | (ns) | (ns) | (ns) | Notes* | | 1 | TcC | Clock Cycle Time | 400 | [1] | 250 | [1] | 165 | [1] | | | 2 | TwCH | Clock Width (High) | 170 | 2000 | 105 | 2000 | 65 | 2000 | | | 3 | TwCl | Clock Width (Low) | 170 | 2000 | 105 | 2000 | 65 | 2000 | | | 4 | TfC | Clock Fall Time | | 30 | | 30 | | 20 | | | 5 | TrC | - Clock Rise Time - | | 30 | | <del></del> 30 - | | 20 | | | 6 | Th | All Hold Times | 0 | | 0 | | 0 | | | | 7 | TsCS(C) | CS to Clock † Setup Time | 250 | | 160 | | 100 | | | | 8 | TsCE(C) | CE to Clock † Setup Time | 200 | | 150 | | 100 | | | | 9 | TsIO(C) | IORQ ↓ to Clock ↑ Setup Time | 250 | | 115 | | 70 | | | | 10 | TsRD(C) — | - RD ↓ to Clock † Setup Time — | — 240 <b>—</b> | | 115 | | <del> 70 -</del> | | | | 11 | TdC(DO) | Clock † to Data Out Delay | | 240 | | 200 | | 130 | [2] | | 12 | TdC(DOz) | Clock ↓ to Data Out Float Delay | , | 230 | | 110 | | 90 | | | 13 | TsDI(C) | Data In to Clock † Setup Time | 60 | | 50 | | 40 | | | | 14 | TsMl(C) | $\overline{\text{Ml}}$ to Clock † Setup Time | 210 | | 90 | | 70 | | | | 15 — | TdM1(IEO)— | - M1 ↓ to IEO ↓ Delay (Interrupt | | | | | | | | | | | immediately preceding M1) | | 300 | | 190 | | 130 | [3] | | 16 | TdIO(DOI) | IORQ ↓ to Data Out Delay<br>(INTA Cycle) | | 340 | | 160 | | 110 | [2] | | 17 | TdIEI(IEOf) | IEI↓to IEO↓Delay | | 190 | | 130 | | 100 | [3] | | 18 | TdIEI(IEOr) | IEI † to IEO † Delay<br>(After ED Decode) | | 220 | | 160 | | 110 | [3] | | 19 | TdC(INT) | Clock ↑ to INT ↓ Delay | (TcC- | - 200) | | (TcC+ | l40) | TcC+120 | [4] | | 20 — | TdCLK(INT)— | - CLK/TRG † to TNT1 | (TcC+ | | | (TcC + 1<br>2TcC + 3 | | TcC + 130<br>2TcC + 280 | [5]<br>[5] | | 21 | TcCTR | CLK/TRG Cycle Time | (2TcC) | , | (2TcC) | | 2TcC | | [5] | | 22 | TrCTR | CLK/TRG Rise Time | ,, | 50 | , | 50 | | 40 | | | 23 | TfCTR | CLK/TRG Fall Time | | 50 | | 50 | | 40 | | | 24 | TwCTRl | CLK/TRG Width (Low) | 200 | | 200 | | 120 | | | | 25 — | TwCTRh | - CLK/TRG Width (High) | 200 | | 200 | | <b>–</b> 120 - | | | | 26 | TsCTR(Cs) | CLK/TRG † to Clock † Setup<br>Time for Immediate Count | 300 | | 210 | | 150 | | [5] | | 27 | TsCTR(Ct) | CLK/TRG † to Clock † Setup<br>Time for enabling of Prescaler<br>on following clock† | 210 | | 210 | | 150 | | [4] | | 28 | TdC(ZC/TOr) | Clock † to ZC/TO † Delay | | 260 | | 190 | | 140 | | | 29 | TdC(ZC/TOf) | Clock ↓ to ZC/TO ↓ Delay | | 190 | | 190 | | 140 | | <sup>[</sup>A] 2.5 TcC > (n-2) TdIEI(IEOf) + TdM1(IEO) + TsIEI(IO) <sup>+</sup> TTL buffer delay, if any [B] RESET must be active for a minimum of 3 clock cycles <sup>[1]</sup> TcC = TwCh + TwCl + TrC + TfC [2] Increase delay by 10 ns for each 50 pF increase in loading, 200 pF maximum for data lines, and 100 pF for control lines <sup>[3]</sup> Increase delay by 2 ns for each 10 pF increase in loading, 100 pF maximum. <sup>[4]</sup> Timer mode. <sup>[5]</sup> Counter mode. [6] RESET must be active for a minimum of 3 clock cycles. \* All timings are preliminary and subject to change. | Ordering<br>Information | Product<br>Number | Package/<br>Temp | Speed | Description | Product<br>Number | Package/<br>Temp | Speed | Description | |-------------------------|-------------------|------------------|---------|-------------------|-------------------|------------------|---------|-------------------| | | Z8430 | CE | 2.5 MHz | Z80 CTC (28-pin) | Z8430A | СМВ | 4.0 MHz | Z80A CTC (28-pin) | | | Z8430 | CM | 2.5 MHz | Same as above | Z8530A | CS | 4.0 MHz | Same as above | | | Z8430 | CMB | 2.5 MHz | Same as above | Z8430A | DE | 4.0 MHz | Same as above | | | Z8430 | CS | 2.5 MHz | Same as above | Z8430A | DS | 4.0 MHz | Same as above | | | Z8430 | DE | 2.5 MHz | Same as above | Z8430A | PE | 4.0 MHz | Same as above | | | Z8430 | DS | 2.5 MHz | Same as above | Z8430A | PS | 4.0 MHz | Same as above | | | Z8430 | PE | 2.5 MHz | Same as above | Z8430B | CS | 6.0 MHz | Same as above | | | Z8430 | PS | 2.5 MHz | Same as above | Z8430B | DS | 6.0 MHz | Same as above | | | Z8430A | CE | 4.0 MHz | Z80A CTC (28-pin) | Z8430B | PS | 6.0 MHz | Same as above | | | Z8430A | CM | 4.0 MHz | Same as above | | | | | \*NOTES: C = Ceramic, D = Cerdip, P = Plastic; E = -40°C to +85°C, M = -55°C to +125°C, MB = -55°C to +125°C with MIL-STD-883 Class B processing, S = 0°C to +70°C. 00-2022-A ### Z8440 Z80° SIO Serial Input/Output Controller # **Product Specification** #### June 1982 #### **Features** - Two independent full-duplex channels, with separate control and status lines for modems or other devices. - Data rates of 0 to 500K bits/second in the x1 clock mode with a 2.5 MHz clock (Z-80 SIO), or 0 to 800K bits/second with a 4.0 MHz clock (Z-80A SIO). - Asynchronous protocols: everything necessary for complete messages in 5, 6, 7 or 8 bits/character. Includes variable stop bits and several clock-rate multipliers; break generation and detection; parity; overrun and framing error detection. - Synchronous protocols: everything necessary for complete bit- or byte-oriented messages in 5, 6, 7 or 8 bits/character, including IBM Bisync, SDLC, HDLC, CCITT-X.25 and others. Automatic CRC generation/checking, sync character and zero insertion/deletion, abort generation/detection and flag insertion. - Receiver data registers quadruply buffered, transmitter registers doubly buffered. - Highly sophisticated and flexible daisychain interrupt vectoring for interrupts without external logic. #### General Description The Z-80 SIO Serial Input/Output Controller is a dual-channel data communication interface with extraordinary versatility and capability. Its basic functions as a serial-toparallel, parallel-to-serial converter/controller can be programmed by a CPU for a broad range of serial communication applications. The device supports all common asynchronous and synchronous protocols, byte- or bit-oriented, and performs all of the functions traditionally done by UARTs, USARTs and synchronous communication controllers combined, plus additional functions traditionally performed by the CPU. Moreover, it does this on two fully-independent channels, with an exceptionally sophisticated interrupt structure that allows very fast transfers. Full interfacing is provided for CPU or DMA Figure 1. Z-80 SIO/2 Pin Functions Figure 2. Z-80 SIO/2 Pin Assignments General Description (Continued) control. In addition to data communication, the circuit can handle virtually all types of serial I/O with fast (or slow) peripheral devices. While designed primarily as a member of the Z-80 family, its versatility makes it well suited to many other CPUs. The Z-80 SIO is an n-channel silicon-gate depletion-load device packaged in a 40-pin plastic or ceramic DIP. It uses a single +5 V power supply and the standard Z-80 family single-phase clock. #### Pin Description Figures 1 through 6 illustrate the three pin configurations (bonding options) available in the SIO. The constraints of a 40-pin package make it impossible to bring out the Receive Clock ( $\overline{\text{RxC}}$ ), Transmit Clock ( $\overline{\text{TxC}}$ ), Data Terminal Ready ( $\overline{\text{DTR}}$ ) and Sync ( $\overline{\text{SYNC}}$ ) signals for both channels. Therefore, either Channel B lacks a signal or two signals are bonded together in the three bonding options offered: - Z-80 SIO/2 lacks SYNCB - Z-80 SIO/1 lacks DTRB - Z-80 SIO/0 has all four signals, but TxCB and RxCB are bonded together The first bonding option above (SIO/2) is the preferred version for most applications. The pin descriptions are as follows: $\mathbf{B}/\overline{\mathbf{A}}$ . Channel A Or B Select (input, High selects Channel B). This input defines which channel is accessed during a data transfer between the CPU and the SIO. Address bit $A_0$ from the CPU is often used for the selection function. $\mathbf{C}/\overline{\mathbf{D}}$ . Control Or Data Select (input, High selects Control). This input defines the type of information transfer performed between the CPU and the SIO. A High at this input during a CPU write to the SIO causes the information on the data bus to be interpreted as a command for the channel selected by $B/\overline{A}$ . A Low at $C/\overline{D}$ means that the information on the data bus is data. Address bit $A_1$ is often used for this function. **CE.** Chip Enable (input, active Low). A Low level at this input enables the SIO to accept command or data input from the CPU during a write cycle or to transmit data to the CPU during a read cycle. **CLK.** System Clock (input). The SIO uses the standard Z-80 System Clock to synchronize internal signals. This is a single-phase clock. CTSA, CTSB. Clear To Send (inputs, active Low). When programmed as Auto Enables, a Low on these inputs enables the respective transmitter. If not programmed as Auto Enables, these inputs may be programmed as general-purpose inputs. Both inputs are Schmitt-trigger buffered to accommodate slow-risetime signals. The SIO detects pulses on these inputs and interrupts the CPU on both logic level transitions. The Schmitt-trigger buffering does not guarantee a specified noise-level margin. **D<sub>0</sub>-D<sub>7</sub>.** System Data Bus (bidirectional, 3-state). The system data bus transfers data and commands between the CPU and the Z-80 SIO. $D_0$ is the least significant bit. DCDA. DCDB. Data Carrier Detect (inputs, active Low). These pins function as receiver enables if the SIO is programmed for Auto Enables; otherwise they may be used as general-purpose input pins. Both pins are Schmitt-trigger buffered to accommodate slow-risetime signals. The SIO detects pulses on these pins and interrupts the CPU on both logic level transitions. Schmitt-trigger buffer- Figure 3. Z-80 SIO/1 Pin Functions Figure 4. Z-80 SIO/1 Pin Assignments ## Pin Description (Continued) ing does not guarantee a specific noise-level margin. **DTRA. DTRB.** Data Terminal Ready (outputs, active Low). These outputs follow the state programmed into Z-80 SIO. They can also be programmed as general-purpose outputs. In the Z-80 SIO/1 bonding option, $\overline{\text{DTRB}}$ is omitted. **IEI.** Interrupt Enable In (input, active High). This signal is used with IEO to form a priority daisy chain when there is more than one interrupt-driven device. A High on this line indicates that no other device of higher priority is being serviced by a CPU interrupt service routine. **IEO.** Interrupt Enable Out (output, active High). IEO is High only if IEI is High and the CPU is not servicing an interrupt from this SIO. Thus, this signal blocks lower priority devices from interrupting while a higher priority device is being serviced by its CPU interrupt service routine. $\overline{\textbf{INT.}}$ Interrupt Request (output, open drain, active Low). When the SIO is requesting an interrupt, it pulls $\overline{\textbf{INT}}$ Low. $\overline{\text{IORQ}}$ . Input/Output Request (input from CPU, active Low). $\overline{\text{IORQ}}$ is used in conjunction with B/ $\overline{\text{A}}$ , C/ $\overline{\text{D}}$ , $\overline{\text{CE}}$ and $\overline{\text{RD}}$ to transfer commands and data between the CPU and the SIO. When $\overline{\text{CE}}$ , $\overline{\text{RD}}$ and $\overline{\text{IORQ}}$ are all active, the channel selected by B/ $\overline{\text{A}}$ transfers data to the CPU (a read operation). When $\overline{\text{CE}}$ and $\overline{\text{IORQ}}$ are active but $\overline{\text{RD}}$ is inactive, the channel selected by B/ $\overline{\text{A}}$ is written to by the CPU with either data or control information as specified by C/ $\overline{\text{D}}$ . If $\overline{\text{IORO}}$ and $\overline{\text{MI}}$ are active simultane- ously, the CPU is acknowledging an interrupt and the SIO automatically places its interrupt vector on the CPU data bus if it is the highest priority device requesting an interrupt. $\overline{\text{M1.}}$ Machine Cycle (input from Z-80 CPU, active Low). When $\overline{\text{M1}}$ is active and $\overline{\text{RD}}$ is also active, the Z-80 CPU is fetching an instruction from memory; when $\overline{\text{M1}}$ is active while $\overline{\text{IORQ}}$ is active, the SIO accepts $\overline{\text{M1}}$ and $\overline{\text{IORQ}}$ as an interrupt acknowledge if the SIO is the highest priority device that has interrupted the Z-80 CPU. RxCA. RxCB. Receiver Clocks (inputs). Receive data is sampled on the rising edge of RxC. The Receive Clocks may be 1, 16, 32 or 64 times the data rate in asynchronous modes. These clocks may be driven by the Z-80 CTC Counter Timer Circuit for programmable baud rate generation. Both inputs are Schmittinger buffered (no noise level margin is specified). In the Z-80 SIO/0 bonding option, $\overline{RxCB}$ is bonded together with $\overline{TxCB}$ . **RD.** Read Cycle Status (input from CPU, active Low). If $\overline{RD}$ is active, a memory or I/O read operation is in progress. $\overline{RD}$ is used with B/ $\overline{A}$ , $\overline{CE}$ and $\overline{IORQ}$ to transfer data from the SIO to the CPU. **RxDA**, **RxDB**. Receive Data (inputs, active High). Serial data at TTL levels. RESET. Reset (input, active Low). A Low RESET disables both receivers and transmitters, forces TxDA and TxDB marking, forces the modem controls High and disables all interrupts. The control registers must be Figure 5. Z-80 SIO/0 Pin Functions Figure 6. Z-80 SIO/0 Pin Assignments 2042-0111, 0120 ## Pin Description (Continued) rewritten after the SIO is reset and before data is transmitted or received. RTSA.RTSB. Request To Send (outputs, active Low). When the RTS bit in Write Register 5 (Figure 14) is set, the RTS output goes Low. When the RTS bit is reset in the Asynchronous mode, the output goes High after the transmitter is empty. In Synchronous modes, the RTS pin strictly follows the state of the RTS bit. Both pins can be used as general-purpose outputs. SYNCA, SYNCB. Synchronization (inputs/outputs, active Low). These pins can act either as inputs or outputs. In the asynchronous receive mode, they are inputs similar to CTS and DCD. In this mode, the transitions on these lines affect the state of the Sync/Hunt status bits in Read Register 0 (Figure 13), but have no other function. In the External Sync mode, these lines also act as inputs. When external synchronization is achieved, SYNC must be driven Low on the second rising edge of RxC after that rising edge of RxC on which the last bit of the sync character was received. In other words, after the sync pattern is detected, the external logic must wait for two full Receive Clock cycles to activate the SYNC input. Once SYNC is forced Low, it should be kept Low until the CPU informs the external synchronization detect logic that synchronization has been lost or a new message is about to start. Character assembly begins on the rising edge of RxC that immediately precedes the falling edge of SYNC in the External Sync mode. In the internal synchronization mode (Monosync and Bisync), these pins act as outputs that are active during the part of the receive clock $(\overline{RxC})$ cycle in which sync characters are recognized. The sync condition is not latched, so these outputs are active each time a sync pattern is recognized, regardless of character boundaries. In the Z-80 SIO/2 bonding option, $\overline{\text{SYNCB}}$ is omitted. TxCA, TxCB. Transmitter Clocks (inputs). In asynchronous modes, the Transmitter Clocks may be 1, 16, 32 or 64 times the data rate; however, the clock multiplier for the transmitter and the receiver must be the same. The Transmit Clock inputs are Schmitt-trigger buffered for relaxed rise- and fall-time requirements (no noise level margin is specified). Transmitter Clocks may be driven by the Z-80 CTC Counter Timer Circuit for programmable baud rate generation. In the Z-80 SIO/0 bonding option, $\overline{\text{TxCB}}$ is bonded together with $\overline{\text{RxCB}}$ . **TxDA. TxDB.** Transmit Data (outputs, active High). Serial data at TTL levels. TxD changes from the falling edge of $\overline{\text{TxC}}$ . W/RDYA, W/RDYB. Wait/Ready A, Wait/Ready B (outputs, open drain when programmed for Wait function, driven High and Low when programmed for Ready function). These dual-purpose outputs may be programmed as Ready lines for a DMA controller or as Wait lines that synchronize the CPU to the SIO data rate. The reset state is open drain. Figure 7. Block Diagram 96 2042-0106 #### Functional Description The functional capabilities of the Z-80 SIO can be described from two different points of view: as a data communications device, it transmits and receives serial data in a wide variety of data-communication protocols; as a Z-80 family peripheral, it interacts with the Z-80 CPU and other peripheral circuits, sharing the data, address and control buses, as well as being a part of the Z-80 interrupt structure. As a peripheral to other microprocessors, the SIO offers valuable features such as nonvectored interrupts, polling and simple handshake capability. Figure 8 illustrates the conventional devices that the SIO replaces. The first part of the following discussion covers SIO data-communication capabilities; the second part describes interactions between the CPU and the SIO. Figure 8. Conventional Devices Replaced by the Z-80 SIO Data Communication Capabilities The SIO provides two independent full-duplex channels that can be programmed for use in any common asynchronous or synchronous data-communication protocol. Figure 9 illustrates some of these protocols. The following is a short description of them. A more detailed explanation of these modes can be found in the *Z-80 SIO Technical Manual*. Asynchronous Modes. Transmission and reception can be done independently on each channel with five to eight bits per character, plus optional even or odd parity. The transmitters can supply one, one-and-a-half or two stop bits per character and can provide a break output at any time. The receiver breakdetection logic interrupts the CPU both at the start and end of a received break. Reception is protected from spikes by a transient spikerejection mechanism that checks the signal one-half a bit time after a Low level is detected on the receive data input (RxDA or RxDB in Figure 5). If the Low does not persist—as in the case of a transient—the character assembly process is not started. Framing errors and overrun errors are detected and buffered together with the partial character on which they occurred. Vectored interrupts allow fast servicing of error conditions using dedicated routines. Furthermore, a built-in checking process avoids interpreting a framing error as a new start bit: a framing error results in the addition of one-half a bit time to the point at which the search for the next start bit is begun. The SIO does not require symmetric transmit and receive clock signals—a feature that allows it to be used with a Z-80 CTC or many other clock sources. The transmitter and receiver can handle data at a rate of 1, 1/16, 1/32 or 1/64 of the clock rate supplied to the receive and transmit clock inputs. In asynchronous modes, the <u>SYNC</u> pin may be programmed as an input that can be used for functions such as monitoring a ring indicator. **Synchronous Modes.** The SIO supports both byte-oriented and bit-oriented synchronous communication. Synchronous byte-oriented protocols can be handled in several modes that allow character synchronization with an 8-bit sync character (Monosync), any 16-bit sync pattern (Bisync), or with an external sync signal. Leading sync Data Communication Capabilities (Continued) characters can be removed without interrupting the CPU. Five-, six- or seven-bit sync characters are detected with 8- or 16-bit patterns in the SIO by overlapping the larger pattern across multiple in-coming sync characters, as shown in Figure 10. CRC checking for synchronous byteoriented modes is delayed by one character time so the CPU may disable CRC checking on specific characters. This permits implementation of protocols such as IBM Bisync. Both CRC-16 ( $X^{16} + X^{15} + X^2 + 1$ ) and CCITT $(X^{16} + X^{12} + X^5 + 1)$ error checking polynomials are supported. In all non-SDLC modes, the CRC generator is initialized to 0's; in SDLC modes, it is initialized to 1's. The SIO can be used for interfacing to peripherals such as hard-sectored floppy disk, but it cannot generate or check CRC for IBM-compatible soft-sectored disks. The SIO also provides a feature that automatically transmits CRC data when no other data is available for transmission. This allows very high-speed transmissions under DMA control with no need for CPU intervention at the end of a message. When there is no data or CRC to send in synchronous modes, the transmitter inserts 8- or 16-bit sync characters regardless of the programmed character length. The SIO supports synchronous bit-oriented protocols such as SDLC and HDLC by performing automatic flag sending, zero insertion and CRC generation. A special command can be used to abort a frame in transmission. At the end of a message the SIO automatically transmits the CRC and trailing flag when the transmit buffer becomes empty. If a transmit underrun occurs in the middle of a message, an external/status interrupt warns the CPU of this status change so that an abort may be issued. One to eight bits per character can be sent, which allows reception of a message with no prior information about the character structure in the information field of a frame. The receiver automatically synchronizes on the leading flag of a frame in SDLC or HDLC, and provides a synchronization signal on the SYNC pin; an interrupt can also be programmed. The receiver can be programmed to search for frames addressed by a single byte to only a specified user-selected address or to a global broadcast address. In this mode, frames that do not match either the user-selected or broadcast address are ignored. The number of address bytes can be extended under software control. For transmitting data, an interrupt on the first received character or on every character can be selected. The receiver automatically deletes all zeroes inserted by the transmitter during character assembly. It also calculates and automatically checks the CRC to validate frame transmission. At the end of transmission, the status of a received frame is available in the status registers. The SIO can be conveniently used under DMA control to provide high-speed reception or transmission. In reception, for example, the SIO can interrupt the CPU when the first character of a message is received. The CPU then enables the DMA to transfer the message to memory. The SIO then issues an end-of-frame interrupt and the CPU can check the status of the received message. Thus, the CPU is freed for other service while the message is being received. Figure 9. Some Z-80 SIO Protocols Figure 10. #### I/O Interface Capabilities The SIO offers the choice of polling, interrupt (vectored or non-vectored) and block-transfer modes to transfer data, status and control information to and from the CPU. The block-transfer mode can also be implemented under DMA control. Polling. Two status registers are updated at appropriate times for each function being performed (for example, CRC error-status valid at the end of a message). When the CPU is operated in a polling fashion, one of the SIO's two status registers is used to indicate whether the SIO has some data or needs some data. Depending on the contents of this register, the CPU will either write data, read data, or just go on. Two bits in the register indicate that a data transfer is needed. In addition, error and other conditions are indicated. The second status register (special receive conditions) does not have to be read in a polling sequence, until a character has been received. All interrupt modes are disabled when operating the device in a polled environment. Interrupts. The SIO has an elaborate interrupt scheme to provide fast interrupt service in real-time applications. A control register and a status register in Channel B contain the interrupt vector. When programmed to do so, the SIO can modify three bits of the interrupt vector in the status register so that it points directly to one of eight interrupt service routines in memory, thereby servicing conditions in both channels and eliminating most of the needs for a status-analysis routine. Transmit interrupts, receive interrupts and external/status interrupts are the main sources of interrupts. Each interrupt source is enabled under program control, with Channel A having a higher priority than Channel B, and with receive, transmit and external/status interrupts prioritized in that order within each channel. When the transmit interrupt is enabled, the CPU is interrupted by the transmit buffer becoming empty. (This implies that the transmitter must have had a data character written into it so it can become empty.) The receiver can interrupt the CPU in one of two ways: - Interrupt on first received character - Interrupt on all received characters Interrupt-on-first-received-character is typically used with the block-transfer mode. Interrupt-on-all-received-characters has the option of modifying the interrupt vector in the event of a parity error. Both of these interrupt modes will also interrupt under special receive conditions on a character or message basis (end-of-frame interrupt in SDLC, for example). This means that the special-receive condition can cause an interrupt only if the interrupt-onfirst-received-character or interrupt-on-allreceived-characters mode is selected. In interrupt-on-first-received-character, an interrupt can occur from special-receive conditions (except parity error) after the first-receivedcharacter interrupt (example: receive-overrun interrupt). The main function of the external/status interrupt is to monitor the signal transitions of the Clear To Send (CTS), Data Carrier Detect (DCD) and Synchronization (SYNC) pins (Figures 1 through 6). In addition, an external/status interrupt is also caused by a CRCsending condition or by the detection of a break sequence (asynchronous mode) or abort sequence (SDLC mode) in the data stream. The interrupt caused by the break/abort sequence allows the SIO to interrupt when the break/abort sequence is detected or terminated. This feature facilitates the proper termination of the current message, correct initialization of the next message, and the accurate timing of the break/abort condition in external logic. #### I/O Interface Capabilities (Continued) In a Z-80 CPU environment (Figure 11), SIO interrupt vectoring is "automatic": the SIO passes its internally-modifiable 8-bit interrupt vector to the CPU, which adds an additional 8 bits from its interrupt-vector (I) register to form the memory address of the interrupt-routine table. This table contains the address of the beginning of the interrupt routine itself. The process entails an indirect transfer of CPU control to the interrupt routine, so that the next instruction executed after an interrupt acknowledge by the CPU is the first instruction of the interrupt routine itself. **CPU/DMA Block Transfer.** The SIO's block-transfer mode accommodates both CPU block transfers and DMA controllers (Z-80 DMA or other designs). The block-transfer mode uses the Wait/Ready output signal, which is selected with three bits in an internal control register. The Wait/Ready output signal can be programmed as a WAIT line in the CPU block-transfer mode or as a READY line in the DMA block-transfer mode. To a DMA controller, the SIO $\overline{READY}$ output indicates that the SIO is ready to transfer data to or from memory. To the CPU, the $\overline{WAIT}$ output indicates that the SIO is not ready to transfer data, thereby requesting the CPU to extend the I/O cycle. Figure 11. Typical Z-80 Environment #### Internal Structure The internal structure of the device includes a Z-80 CPU interface, internal control and interrupt logic, and two full-duplex channels. Each channel contains its own set of control and status (write and read) registers, and control and status logic that provides the interface to modems or other external devices. The registers for each channel are designated as follows: WR0-WR7 — Write Registers 0 through 7 RR0-RR2 — Read Registers 0 through 2 The register group includes five 8-bit control registers, two sync-character registers and two status registers. The interrupt vector is written into an additional 8-bit register (Write Register 2) in Channel B that may be read through another 8-bit register (Read Register 2) in Channel B. The bit assignment and functional grouping of each register is configured to simplify and organize the programming process. Table 1 lists the functions assigned to each read or write register. #### **Read Register Functions** | RR0 | Transmit/Receive buffer status, interrup | |-----|------------------------------------------| | | status and external status | RR1 Special Receive Condition status RR2 Modified interrupt vector (Channel B only) #### Write Register Functions | WR0 | Register pointers, CRC initialize, initializa- | |-----|------------------------------------------------| | | tion commands for the various modes, etc. | WR1 Transmit/Receive interrupt and data transfer mode definition. WR2 Interrupt vector (Channel B only) WR3 Receive parameters and control WR4 Transmit/Receive miscellaneous parameters and modes WR5 Transmit parameters and controls WR6 Sync character or SDLC address field WR7 Sync character or SDLC flag #### Internal Structure (Continued) The logic for both channels provides formats, synchronization and validation for data transferred to and from the channel interface. The modem control inputs, Clear To Send (CTS) and Data Carrier Detect (DCD), are monitored by the external control and status logic under program control. All external control-and-status-logic signals are general-purpose in nature and can be used for functions other than modem control. Data Path. The transmit and receive data path illustrated for Channel A in Figure 12 is identical for both channels. The receiver has three 8-bit buffer registers in a FIFO arrangement, in addition to the 8-bit receive shift register. This scheme creates additional time for the CPU to service an interrupt at the beginning of a block of high-speed data. Incoming data is routed through one of several paths (data or CRC) depending on the selected mode and—in asynchronous modes—the character length. The transmitter has an 8-bit transmit data buffer register that is loaded from the internal data bus, and a 20-bit transmit shift register that can be loaded from the sync-character buffers or from the transmit data register. Depending on the operational mode, outgoing data is routed through one of four main paths before it is transmitted from the Transmit Data output (TxD). Figure 12. Transmit and Receive Data Path (Channel A) 2042-0112 #### Programming The system program first issues a series of commands that initialize the basic mode of operation and then other commands that qualify conditions within the selected mode. For example, the asynchronous mode, character length, clock rate, number of stop bits, even or odd parity might be set first; then the interrupt mode; and finally, receiver or transmitter enable. Both channels contain registers that must be programmed via the system program prior to operation. The channel-select input $(B/\overline{A})$ and the control/data input $(C/\overline{D})$ are the command-structure addressing controls, and are normally controlled by the CPU address bus. Figures 15 and 16 illustrate the timing relationships for programming the write registers and transferring data and status. Read Registers. The SIO contains three read registers for Channel B and two read registers for Channel A (RR0-RR2 in Figure 13) that can be read to obtain the status information; RR2 contains the internally-modifiable interrupt vector and is only in the Channel B register set. The status information includes error conditions, interrupt vector and standard communications-interface signals. To read the contents of a selected read register other than RRO, the system program must first write the pointer byte to WRO in exactly the same way as a write register operation. Then, by executing a read instruction, the contents of the addressed read register can be read by the CPU. The status bits of RRO and RR1 are carefully grouped to simplify status monitoring. For example, when the interrupt vector indicates that a Special Receive Condition interrupt has occurred, all the appropriate error bits can be read from a single register (RR1). Write Registers. The SIO contains eight write registers for Channel B and seven write registers for Channel A (WR0-WR7 in Figure 14) that are programmed separately to configure the functional personality of the channels; WR2 contains the interrupt vector for both channels and is only in the Channel B register set. With the exception of WR0, programming the write registers requires two bytes. The first byte is to WR0 and contains three bits ( $D_0$ – $D_2$ ) that point to the selected register; the second byte is the actual control word that is written into the register to configure the SIO. WR0 is a special case in that all of the basic commands can be written to it with a single byte. Reset (internal or external) initializes the pointer bits $D_0$ – $D_2$ to point to WR0. This implies that a channel reset must not be combined with the pointing to any register. Figure 13. Read Register Bit Functions 102 #### Programming WRITE REGISTER 0 WRITE REGISTER 4 (Continued) D<sub>7</sub> D<sub>6</sub> D<sub>5</sub> D<sub>4</sub> D<sub>3</sub> D<sub>2</sub> D<sub>1</sub> D<sub>0</sub> D<sub>7</sub> D<sub>6</sub> D<sub>5</sub> D<sub>4</sub> D<sub>3</sub> D<sub>2</sub> D<sub>1</sub> D<sub>0</sub> -PARITY ENABLE -PARITY EVEN/ODD 0 REGISTER 0 1 REGISTER 1 0 REGISTER 2 1 REGISTER 3 0 REGISTER 4 1 REGISTER 6 0 REGISTER 6 1 REGISTER 7 0 0 1 1 0 0 1 1 SYNC MODES ENABLE 1 STOP BIT/CHARACTER 1½ STOP BITS/CHARACTER 2 STOP BITS/CHARACTER 0 8 BIT SYNC CHARACTER 16 BIT SYNC CHARACTER SDLC MODE (01111110 FLAG) EXTERNAL SYNC MODE 0 1 0 1 NULL CODE SEND ABORT (SDLC) RESET EXT/STATUS INTERRUPTS CHANNEL RESET ENABLE INT ON NEXT RX CHARACTER RESET TX INT PENDING ERROR RESET RETURN FROM INT (CH-A ONLY) 0 0 0 0 1 1 0 1 1 0 0 1 0 1 0 1 0 1 0 1 X1 CLOCK MODE X16 CLOCK MODE X32 CLOCK MODE X64 CLOCK MODE NULL CODE RESET RX CRC CHECKER RESET TX CRC GENERATOR RESET TX UNDERRUN/EOM LATCH 0 0 WRITE REGISTER 5 WRITE REGISTER 1 D<sub>7</sub> D<sub>6</sub> D<sub>5</sub> D<sub>4</sub> D<sub>3</sub> D<sub>2</sub> D<sub>1</sub> D<sub>0</sub> D<sub>7</sub> D<sub>6</sub> D<sub>5</sub> D<sub>4</sub> D<sub>3</sub> D<sub>2</sub> D<sub>1</sub> D<sub>0</sub> -EXT INT ENABLE -TX INT ENABLE -STATUS AFFECTS VECTOR (CH B ONLY) Tx CRC ENABLE - RTS - SDLC/CRC-16 Tx ENABLE SEND BREAK RX INT DISABLE RX INT ON FIRST CHARACTER INT ON ALL RX CHARACTERS (PARITY AFFECTS VECTOR) INT ON ALL RX CHARACTERS (PARITY DOES NOT AFFECT 0 1 0 1 Tx 5 BITS (OR LESS)/CHARACTER Tx 7 BITS/CHARACTER Tx 6 BITS/CHARACTER Tx 8 BITS/CHARACTER 0 1 0 1 -WAIT/READY ON R/T -WAIT/READY FUNCTION -WAIT/READY ENABLE Special Condition WRITE REGISTER 2 (CHANNEL B ONLY) WRITE REGISTER 6 $lacksquare D_7 \ D_8 \ D_5 \ D_4 \ D_3 \ D_2 \ D_1 \ D_0$ D<sub>7</sub> D<sub>6</sub> D<sub>5</sub> D<sub>4</sub> D<sub>3</sub> D<sub>2</sub> D<sub>1</sub> D<sub>0</sub> SYNC BIT 0 SYNC BIT 1 SYNC BIT 2 SYNC BIT 3 SYNC BIT 4 SYNC BIT 5 SYNC BIT 6 SYNC BIT 7 - V0 - V1 - V2 - V3 - V4 - V5 INTERRUPT \*Also SDLC Address Field WRITE REGISTER 7 WRITE REGISTER 3 D<sub>7</sub> | D<sub>8</sub> | D<sub>5</sub> | D<sub>4</sub> | D<sub>3</sub> | D<sub>2</sub> | D<sub>1</sub> | D<sub>0</sub> D7 D6 D5 D4 D3 D2 D1 D0 SYNC BIT 8 SYNC BIT 9 SYNC BIT 10 SYNC BIT 11 SYNC BIT 12 SYNC BIT 13 SYNC BIT 14 SYNC BIT 15 RX ENABLE -SYNC CHARACTER LOAD INHIBIT -ADDRESS SEARCH MODE (SDLC) -RX CRC ENABLE -ENTER HUNT PHASE -AUTO ENABLES Figure 14. Write Register Bit Functions \*For SDLC It Must Be Programmed to 011111110 For Flag Recognition 2042-0113 Rx 5 BITS/CHARACTER Rx 7 BITS/CHARACTER Rx 6 BITS/CHARACTER Rx 8 BITS/CHARACTER 0 #### Timing The SIO must have the same clock as the CPU (same phase and frequency relationship, not necessarily the same driver). **Read Cycle.** The timing signals generated by a Z-80 CPU input instruction to read a data or status byte from the SIO are illustrated in Figure 15. **Write Cycle.** Figure 16 illustrates the timing and data signals generated by a Z-80 CPU output instruction to write a data or control byte into the SIO. Interrupt-Acknowledge Cycle. After receiving an interrupt-request signal from an SIO (INT pulled Low), the Z-80 CPU sends an interrupt-acknowledge sequence (MI Low, and IORO Low a few cycles later) as in Figure 17. The SIO contains an internal daisy-chained interrupt structure for prioritizing nested interrupts for the various functions of its two channels, and this structure can be used within an external user-defined daisy chain that prioritizes several peripheral circuits. The IEI of the highest-priority device is terminated High. A device that has an interrupt pending or under service forces its IEO Low. For devices with no interrupt pending or under service. IEO = IEI. To insure stable conditions in the daisy chain, all interrupt status signals are prevented from changing while M1 is Low. When IORQ is Low, the highest priority interrupt requestor (the one with IEI High) places its interrupt vector on the data bus and sets its Return From Interrupt Cycle. Figure 18 illustrates the return from interrupt cycle. Normally, the Z-80 CPU issues a RETI (Return From Interrupt) instruction at the end of an interrupt service routine. RETI is a 2-byte opcode (ED-4D) that resets the interrupt-under-service latch in the SIO to terminate the interrupt that has just been processed. This is accomplished by manipulating the daisy chain in the following way. The normal daisy-chain operation can be used to detect a pending interrupt; however, it cannot distinguish between an interrupt under service and a pending unacknowledged interrupt of a higher priority. Whenever "ED" is decoded, the daisy chain is modified by forcing High the IEO of any interrupt that has not yet been acknowledged. Thus the daisy chain identifies the device presently under service as the only one with an IEI High and an IEO Low. If the next opcode byte is "4D," the interrupt-under-service latch is reset. The ripple time of the interrupt daisy chain (both the High-to-Low and the Low-to-High transitions) limits the number of devices that can be placed in the daisy chain. Ripple time can be improved with carry-look-ahead, or by extending the interrupt-acknowledge cycle. For further information about techniques for increasing the number of daisy-chained devices, refer to the *Z-80 CPU Product Specification*. Figure 15. Read Cycle Figure 16. Write Cycle Figure 17. Interrupt Acknowledge Cycle Figure 18. Return from Interrupt Cycle | Absolute<br>Maximum | Voltages on all inputs and with respect to GND | • | |---------------------|------------------------------------------------|----------------| | Ratings | Operating Ambient Temperature | • | | | 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. #### Test Conditions The characteristics below apply for the following 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: - $S^* = 0^{\circ}C \text{ to } +70^{\circ}C,$ +4.75 $V \le V_{CC} \le +5.25 V$ - $E^* = -40^{\circ}\text{C to } +85^{\circ}\text{C},$ +4.75 $V \le V_{CC} \le +5.25 \text{ V}$ - $M^* = -55^{\circ}C \text{ to } + 125^{\circ}C,$ + 4.5 $V \le V_{CC} \le +5.5 \text{ V}$ #### DC Characteristics | Symbol | Parameter | Min | Max | Unit | Test Condition | |---------------|-----------------------------------------------|---------------------|-------|---------|-------------------------------| | $v_{\rm ILC}$ | Clock Input Low Voltage | -0.3 | +0.45 | V | | | $V_{IHC}$ | Clock Input High Voltage | $V_{\rm CC}^{-0.6}$ | +5.5 | V | | | $V_{\rm IL}$ | Input Low Voltage | -0.3 | +0.8 | V | | | $V_{IH}$ | Input High Voltage | +2.0 | +5.5 | V | | | $V_{OL}$ | Output Low Voltage | | +0.4 | V | $I_{OL} = 2.0 \text{ mA}$ | | $V_{OH}$ | Output High Voltage | +2.4 | | V | $I_{OH} = -250 \mu\text{A}$ | | $I_{LI}$ | Input Leakage Current | -10 | + 10 | $\mu$ A | $0 < V_{\rm IN} < V_{\rm CC}$ | | $I_Z$ | 3-State Output/Data Bus Input Leakage Current | -10 | + 10 | $\mu$ A | $0 < V_{\rm IN} < V_{\rm CC}$ | | $I_{L(SY)}$ | SYNC Pin Leakage Current | -40 | +10 | $\mu$ A | $0 < V_{\rm IN} < V_{\rm CC}$ | | $I_{CC}$ | Power Supply Current | | 100 | mA | | Over specified temperature and voltage range. | Ca | pa | cit | an | ce | |----|----|-----|----|----| | Symbol | Parameter | Min | Мах | Unit | Test Condition | |-----------|--------------------|-----|-----|------|----------------| | С | Clock Capacitance | - | 40 | рF | Unmeasured | | $C_{IN}$ | Input Capacitance | | 5 | pF | pins returned | | $C_{OUT}$ | Output Capacitance | | 10 | рF | to ground | Over specified temperature range, $f = 1MH_z$ <sup>\*</sup>See Ordering Information section for package temperature range and product number. AC Electrical Characteristics | Number | Symbol | Parameter | | SIO<br>Max | | A SIO<br>Max | | SIO*†<br>Max | |--------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|-------|-----------------------|-------|-----------------------------|-------------------|-------------------| | 1 | TcC | Clock Cycle Time | 400 | 4000 | 250 | 4000 | 165 | 4000 | | 2 | TwCh | Clock Width (High) | 170 | 2000 | 105 | 2000 | 70 | 2000 | | 3 | TfC | Clock Fall Time | | 30 | | 30 | | 15 | | 4 | TrC | Clock Rise Time | | 30 | | 30 | | 15 | | 5 — | -TwCl | - Clock Width (Low) | 170 - | -2000 — | 105 - | -2000 — | <del> 7</del> 0 - | -2000 - | | 6 | TsAD(C) | $\overline{CE}$ , C/ $\overline{D}$ , B/ $\overline{A}$ to Clock † Setup Time | 160 | | 145 | | 60 | | | 7 | TsCS(C) | $\overline{\text{IORQ}}$ , $\overline{\text{RD}}$ to Clock † Setup Time | 240 | | 115 | | 60 | | | 8 | TdC(DO) | Clock † to Data Out Delay | | 240 | | 220 | | 150 | | 9 | TsDI(C) | Data In to Clock † Setup (Write or $\overline{\text{Ml}}$ Cycle) | 50 | | 50 | | 30 | | | 10 — | -TdRD(DOz)- | - RD † to Data Out Float Delay | | <b>–</b> 230 <b>–</b> | | <del></del> 110 | | <del></del> 90 - | | 11 | TdIO(DOI) | IORQ ↓ to Data Out Delay (INTACK Cycle) | | 340 | | 160 | | 100 | | 12 | TsM1(C) | $\overline{\mathrm{Ml}}$ to Clock † Setup Time | 210 | | 90 | | 75 | | | 13 | TsIEI(IO) | IEI to <del>IORQ</del> ↓ Setup Time (INTACK Cycle) | 200 | | 140 | | 120 | | | 14 | TdM1(IEO) | $\overline{\mathrm{Ml}}\ \downarrow$ to IEO $\downarrow$ Delay (interrupt before $\overline{\mathrm{Ml}}$ ) | | 300 | | 190 | 160 | | | 15 — | - TdIEI(IEOr)— | - IEI † to IEO † Delay (after ED decode)————— | | <del></del> 150 | | <del></del> 100 <del></del> | | <del></del> 70 · | | 16 | TdIEI(IEOf) | IEI ↓ to IEO ↓ Delay | | 150 | | 100 | | 70 | | 17 | TdC(INT) | Clock ↑ to INT ↓ Delay | | 200 | | 200 | | 150 | | 18 | TdIO(W/RWf) | $\overline{\text{IORQ}} \downarrow \text{ or } \overline{\text{CE}} \downarrow \text{ to } \overline{\text{W/RDY}} \downarrow \text{(Delay Wait Mode)}$ | | 300 | | 210 | | 175 | | 19 | TdC(W/RR) | Clock † to $\overline{W}/\overline{RDY}$ † Delay (Ready Mode) | | 120 | | 120 | | 100 | | 20 — | - TdC(W/RWz)- | - Clock ↓ to W/RDY Float Delay (Wait Mode)——— | | <del></del> 150 | | <del></del> 130 | | <del></del> 110 · | | 21 | Th | Any unspecified Hold when Setup is specified | 0 | | 0 | | 0 | | <sup>\*</sup> Z-80 SIO timings are preliminary and subject to change. † Units in nanoseconds (ns) 2044-012 AC Electrical Characteristics (Continued) | Number | Symbol | Parameter | Z-80<br>Min | SIO<br>Max | Z-80A<br>Min | | Z-80B<br>Min | SIO¹<br>Max | Notes† | |--------|--------------|------------------------------------------------------------------------------------------------------------|--------------------|------------------|-----------------|------------------|-----------------|----------------|--------| | 1 | TwPh | Pulse Width (High) | 200 | | 200 | | 200 | | 2 | | 2 | TwPl | Pulse Width (Low) | 200 | | 200 | | 200 | | 2 | | 3 | TcTxC | TxC Cycle Time | 400 | <b>∞</b> | 400 | <b>∞</b> | 330 | <b>∞</b> | 2 | | 4 | TwTxCl | TxC Width (Low) | 180 | <b>∞</b> | 180 | <b>∞</b> | 100 | <b>∞</b> | 2 | | 5 — | TwTxCh | TxC Width (High) | <del>-</del> 180 - | — <sub>∞</sub> — | <del></del> 180 | — <sub>∞</sub> — | <del></del> 100 | - <sub>∞</sub> | 2 | | 6 | TdTxC(TxD) | TxC ↓ to TxD Delay (x1 Mode) | | 400 | | 300 | | 220 | 2 | | 7 | TdTxC(W/RRf) | $\overline{\text{TxC}} \downarrow \text{to } \overline{\text{W/RDY}} \downarrow \text{Delay (Ready Mode)}$ | 5 | 9 | 5 | 9 | 5 | 9 | 3 | | 8 | TdTxC(INT) | TxC ↓ to INT ↓ Delay | 5 | 9 | 5 | 9 | 5 | 9 | 3 | | 9 | TcRxC | RxC Cycle Time | 400 | <b>∞</b> | 400 | <b>∞</b> | 330 | <b>∞</b> | 2 | | 10 | TwRxCl | RxC Width (Low) | <del>-</del> 180 - | — <sub>∞</sub> – | <del></del> 180 | - <b></b> - | <del></del> 100 | - <sub>∞</sub> | 2 | | 11 | TwRxCh | RxC Width (High) | 180 | <b>∞</b> | 180 | <b>∞</b> | 100 | <b>∞</b> | 2 | | 12 | TsRxD(RxC) | RxD to $\overline{RxC}$ † Setup Time (x1 Mode) | 0 | | 0 | | 0 | | 2 | | 13 | ThRxD(RxC) | RxC † to RxD Hold Time (x1 Mode) | 140 | | 140 | | 100 | | 2 | | 14 | TdRxC(W/RRf) | $\overline{RxC}$ † to $\overline{W}/\overline{RDY}$ Delay (Ready Mode) | 10 | 13 | 10 | 13 | 10 | 13 | 3 | | 15 | TdRxC(INT) | RxC ↑ to INT ↓ Delay | 10 | 13 | 10 | 13 | 10 | 13 | 3 | | 16 | TdRxC(SYNC) | $\overline{RxC}$ † to $\overline{SYNC}$ Delay (Output Modes) | 4 | 7 | 4 | 7 | 4 | 7 | 3 | | 17 | TsSYNC(RxC) | SYNC ↓ to RxC ↑ Setup (External Sync Modes) | -100 | | -100 | | | 100 | 2 | NOTES: † In all modes, the System Clock rate must be at least five times the maximum data rate. 1. Z-80 SIO timings are preliminary and subject to change. Units in nanoseconds (ns). Units equal to System Clock Periods. | Ordering<br>Information | Product<br>Number | Package/<br>Temp | Speed | Description | Product<br>Number | Package/<br>Temp | Speed | Description | |-------------------------|-------------------|------------------|---------|-----------------------|-------------------|------------------|---------|------------------------| | | Z8440 | CE,CM | 2.5 MHz | Z80 SIO/0<br>(40-pın) | Z8441A | DE,DS | 4.0 MHz | Z80B SIO/1<br>(40-pın) | | | Z8440 | CMB,CS | 2.5 MHz | Same as above | Z8441A | PE,PS | 4.0 MHz | Same as above | | | Z8440 | DE,DS | 2.5 MHz | Same as above | Z8441B | CS | 6.0 MHz | Z80B SIO/1 | | | Z8440 | PE,PS | 2.5 MHz | Same as above | | | | (40-pın) | | | Z8440A | CE,CM | 4.0 MHz | Z80A SIO/0 | Z8441B | DS | 6.0 MHz | Same as above | | | | | | (40-pın) | Z8441B | PS | 6.0 MHz | Same as above | | | Z8440A | CMB,CS | 4.0 MHz | Same as above | Z8442 | CE,CM | 2.5 MHz | Z80 SIO/2 | | | Z8440A | DE,DS | 4.0 MHz | Same as above | | | | (40-pın) | | | Z8440A | PE,PS | 4.0 MHz | Same as above | Z8442 | CMB,CS | 2.5 MHz | Same as above | | | Z8440B | CS | 6.0 MHz | Z80B SIO/0 | Z8442 | DE,DS | 2.5 MHz | Same as above | | | | | | (40-pin) | Z8442 | PE,PS | 2.5 MHz | Same as above | | | Z8440B | DS | 6.0 MHz | Same as above | Z8442A | CE,CM | 4.0 MHz | Z80A SIO/2 | | | Z8440B | PS | 6.0 MHz | Same as above | | | | (40-pın) | | | Z8441 | CE,CM | 2.5 MHz | Z80 SIO/1 | Z8442A | CMB,CS | 4.0 MHz | Same as above | | | | | | (40-pin) | Z8442A | DE,DS | 4.0 MHz | Same as above | | | Z8441 | CMB,CS | 2.5 MHz | Same as above | Z8442A | PE,PS | 4.0 MHz | Same as above | | | Z8441 | DE,DS | 2.5 MHz | Same as above | Z8442B | CS | 6.0 MHz | Z80B SIO/2 | | | Z8441 | PE,PS | 2.5 MHz | Same as above | | | | (40-pin) | | | Z8441A | CE,CM | 4.0 MHz | Z80A SIO/1 | Z8442B | DS | 6.0 MHz | Same as above | | | | | | (40-pın) | Z8442B | PS | 6.0 MHz | Same as above | | | Z8441A | CMB,CS | 4.0 MHz | Same as above | | | | | <sup>\*</sup>NOTES C = Ceramic, D = Cerdip, P = Plastic, E = -40°C to +85°C, M = -55°C to +125°C, MB = -55°C to +125°C with MIL-STD-883 with Class B processing, S = 0°C to +70°C ### Z8470 Z80° DART Dual Asynchronous Receiver/Transmitter ## Product Specification #### June 1982 #### **Features** - Two independent full-duplex channels with separate modem controls. Modem status can be monitored. - In x1 clock mode, data rates are 0 to 500K bits/second with a 2.5 MHz clock, or 0 to 800K bits/second with a 4.0 MHz clock. - Receiver data registers are quadruply buffered; the transmitter is doubly buffered. - Programmable options include 1, 1½ or 2 stop bits; even, odd or no parity; and x1, x16, x32 and x64 clock modes. - June 1002 - parity-, overrun- and framing-error detection are available. Interrupt features include a programmable interrupt vector, a "status affects vector" mode for fast interrupt processing, and the ■ Break generation and detection as well as - standard Z-80 peripheral daisy-chain interrupt structure that provides automatic interrupt vectoring with no external logic. - On-chip logic for ring indication and carrier-detect status. #### Description The Z-80 DART (Dual-Channel Asynchronous Receiver/Transmitter) is a dual-channel multi-function peripheral component that satisfies a wide variety of asynchronous serial data communications requirements in microcomputer systems. The Z-80 DART is used as a serial-to-parallel, parallel-to-serial converter/controller in asynchronous applications. In addition, the device also provides modem controls for both channels. In applications where modem controls are not needed, these lines can be used for general-purpose I/O. Zilog also offers the Z-80 SIO, a more versatile device that provides synchronous (Bisync, HDLC and SDLC) as well as asynchronous operation. The Z-80 DART is fabricated with n-channel silicon-gate depletion-load technology, and is packaged in a 40-pin plastic or ceramic DIP. Figure 1. Z80 DART Pin Functions Figure 2. Pin Assignments #### Pin Description - **B**/**Ā**. Channel A Or B Select (input, High selects Channel B). This input defines which channel is accessed during a data transfer between the CPU and the Z-80 DART. - $\mathbf{C}/\overline{\mathbf{D}}$ . Control Or Data Select (input, High selects Control). This input specifies the type of information (control or data) transferred on the data bus between the CPU and the Z-80 DART. - **CE.** Chip Enable (input, active Low). A Low at this input enables the Z-80 DART to accept command or data input from the CPU during a write cycle, or to transmit data to the CPU during a read cycle. - **CLK.** System Clock (input). The Z-80 DART uses the standard Z-80 single-phase system clock to synchronize internal signals. - CTSA, CTSB. Clear To Send (inputs, active Low). When programmed as Auto Enables, a Low on these inputs enables the respective transmitter. If not programmed as Auto Enables, these inputs may be programmed as general-purpose inputs. Both inputs are Schmitt-trigger buffered to accommodate slow-risetime signals. - **D<sub>0</sub>-D<sub>7</sub>.** System Data Bus (bidirectional, 3-state) transfers data and commands between the CPU and the Z-80 DART. - **DCDA.** DCDB. Data Carrier Detect (inputs, active Low). These pins function as receiver enables if the Z-80 DART is programmed for Auto Enables; otherwise they may be used as general-purpose input pins. Both pins are Schmitt-trigger buffered. - **DTRA**, **DTRB**. Data Terminal Ready (outputs, active Low). These outputs follow the state programmed into the DTR bit. They can also be programmed as general-purpose outputs. - **IEI.** Interrupt Enable In (input, active High) is used with IEO to form a priority daisy chain when there is more than one interrupt-driven device. A High on this line indicates that no other device of higher priority is being serviced by a CPU interrupt service routine. - **IEO.** Interrupt Enable Out (output, active High). IEO is High only if IEI is High and the CPU is not servicing an interrupt from this Z-80 DART. Thus, this signal blocks lower priority devices from interrupting while a higher priority device is being serviced by its CPU interrupt service routine. - **INT.** Interrupt Request (output, open drain, active Low). When the Z-80 DART is requesting an interrupt, it pulls INT Low. - $\overline{ extbf{M1.}}$ Machine Cycle One (input from Z-80 CPU, active Low). When $\overline{ extbf{M1}}$ and $\overline{ extbf{RD}}$ are both active, the Z-80 CPU is fetching an instruction from memory; when $\overline{ extbf{M1}}$ is active while $\overline{\overline{ ext{IORO}}}$ is active, the Z-80 DART accepts $\overline{ extbf{M1}}$ and $\overline{\overline{ ext{IORO}}}$ - as an interrupt acknowledge if the Z-80 DART is the highest priority device that has interrupted the Z-80 CPU. - $\overline{\text{IORQ}}$ . Input/Output Request (input from CPU, active Low). $\overline{\text{IORQ}}$ is used in conjunction with B/ $\overline{\text{A}}$ , C/ $\overline{\text{D}}$ , $\overline{\text{CE}}$ and $\overline{\text{RD}}$ to transfer commands and data between the CPU and the Z-80 DART. When $\overline{\text{CE}}$ , $\overline{\text{RD}}$ and $\overline{\text{IORQ}}$ are all active, the channel selected by B/ $\overline{\text{A}}$ transfers data to the CPU (a read operation). When $\overline{\text{CE}}$ and $\overline{\text{IORQ}}$ are active, but $\overline{\text{RD}}$ is inactive, the channel selected by B/ $\overline{\text{A}}$ is written to by the CPU with either data or control information as specified by C/ $\overline{\text{D}}$ . - RxCA, RxCB. Receiver Clocks (inputs). Receive data is sampled on the rising edge of RxC. The Receive Clocks may be 1, 16, 32 or 64 times the data rate. - **RD.** Read Cycle Status. (input from CPU, active Low). If RD is active, a memory or I/O read operation is in progress. - **RxDA**, **RxDB**. Receive Data (inputs, active High). - **RESET.** Reset (input, active Low). Disables both receivers and transmitters, forces TxDA and TxDB marking, forces the modem controls High and disables all interrupts. - RIA . RIB. Ring Indicator (inputs, Active Low). These inputs are similar to CTS and DCD. The Z-80 DART detects both logic level transitions and interrupts the CPU. When not used in switched-line applications, these inputs can be used as general-purpose inputs. - RTSA, RTSB. Request to Send (outputs, active Low). When the RTS bit is set, the RTS output goes Low. When the RTS bit is reset, the output goes High after the transmitter empties. - TxCA. TxCB. Transmitter Clocks (inputs). TxD changes on the falling edge of TxC. The Transmitter Clocks may be 1, 16, 32 or 64 times the data rate; however, the clock multiplier for the transmitter and the receiver must be the same. The Transmit Clock inputs are Schmitt-trigger buffered. Both the Receiver and Transmitter Clocks may be driven by the Z-80 CTC Counter Time Circuit for programmable baud rate generation. - **TxDA. TxDB.** Transmit Data (outputs, active High). - W/RDYA. W/RDYB. Wait/Ready (outputs, open drain when programmed for Wait function, driven High and Low when programmed for Ready function). These dual-purpose outputs may be programmed as Ready lines for a DMA controller or as Wait lines that synchronize the CPU to the Z-80 DART data rate. The reset state is open drain. # Functional Description The functional capabilities of the Z-80 DART can be described from two different points of view: as a data communications device, it transmits and receives serial data, and meets the requirements of asynchronous data communications protocols; as a Z-80 family peripheral, it interacts with the Z-80 CPU and other Z-80 peripheral circuits, and shares the data, address and control buses, as well as being a part of the Z-80 interrupt structure. As a peripheral to other microprocessors, the Z-80 DART offers valuable features such as nonvectored interrupts, polling and simple handshake capability. Communications Capabilities. The Z-80 DART provides two independent full-duplex channels for use as an asynchronous receiver/transmitter. The following is a short description of receiver/transmitter capabilities. For more details, refer to the Asynchronous Mode section of the Z-80 SIO Technical Manual. The Z-80 DART offers transmission and reception of five to eight bits per character, plus optional even or odd parity. The transmitter can supply one, one and a half or two stop bits per character and can provide a break output at any time. The receiver break detection logic interrupts the CPU both at the start and end of a received break. Reception is protected from spikes by a transient spike rejection mechanism that checks the signal onehalf a bit time after a Low level is detected on the Receive Data input. If the Low does not persist—as in the case of a transient—the character assembly process is not started. I/O Interface Capabilities. The Z-80 DART offers the choice of Polling, Interrupt (vectored or non-vectored) and Block Transfer modes to transfer data, status and control information to The first part of the following functional description introduces Z-80 DART data communications capabilities; the second part describes the interaction between the CPU and the Z-80 DART. The Z-80 DART offers RS-232 serial communications support by providing device signals for external modem control. In addition to dual-channel Request To Send, Clear To Send, and Data Carrier Detect ports, the Z-80 DART also features a dual channel Ring Indicator (RIA, RIB) input to facilitate local/remote or station-to-station communication capability. Framing errors and overrun errors are detected and buffered together with the character on which they occurred. Vectored interrupts allow fast servicing of interrupting conditions using dedicated routines. Furthermore, a built-in checking process avoids interpreting a framing error as a new start bit: a framing error results in the addition of one-half a bit time to the point at which the search for the next start bit is begun. The Z-80 DART does not require symmetric Transmit and Receive Clock signals—a feature that allows it to be used with a Z-80 CTC or any other clock source. The transmitter and receiver can handle data at a rate of 1, 1/16, 1/32 or 1/64 of the clock rate supplied to the Receive and Transmit Clock inputs. When using Channel B, the bit rates for transmit and receive operations must be the same because $\overline{\text{RxC}}$ and $\overline{\text{TxC}}$ are bonded together ( $\overline{\text{RxTxCB}}$ ). and from the CPU. The Block Transfer mode can be implemented under CPU or DMA control. Figure 3. Block Diagram 2044-001 Functional Description (Continued) POLLING. There are no interrupts in the Polled mode. Status registers RR0 and RR1 are updated at appropriate times for each function being performed. All the interrupt modes of the Z-80 DART must be disabled to operate the device in a polled environment. While in its Polling sequence, the CPU examines the status contained in RRO for each channel; the RRO status bits serve as an acknowledge to the Poll inquiry. The two RRO status bits $D_0$ and $D_2$ indicate that a data transfer is needed. The status also indicates Error or other special status conditions (see "Z-80 DART Programming"). The Special Receive Condition status contained in RR1 does not have to be read in a Polling sequence because the status bits in RR1 are accompanied by a Receive Character Available status in RR0. INTERRUPTS. The Z-80 DART offers an elaborate interrupt scheme that provides fast interrupt response in real-time applications. As a member of the Z-80 family, the Z-80 DART can be daisy-chained along with other Z-80 peripherals for peripheral interrupt-priority resolution. In addition, the internal interrupts of the Z-80 DART are nested to prioritize the various interrupts generated by Channels A and B. Channel B registers WR2 and RR2 contain the interrupt vector that points to an interrupt service routine in the memory. To eliminate the necessity of writing a status analysis routine, the Z-80 DART can modify the interrupt vector in RR2 so it points directly to one of eight interrupt service routines. This is done under program control by setting a program bit (WR1, D2) in Channel B called "Status Affects Vector." When this bit is set, the interrupt vector in RR2 is modified according to the assigned priority of the various interrupting conditions. Transmit interrupts, Receive interrupts and External/Status interrupts are the main sources of interrupts. Each interrupt source is enabled under program control with Channel A having a higher priority than Channel B, and with Receiver, Transmit and External/Status interrupts prioritized in that order within each channel. When the Transmit interrupt is enabled, the CPU is interrupted by the transmit buffer becoming empty. (This implies that the transmitter must have had a data character written into it so it can become empty.) When enabled, the receiver can interrupt the CPU in one of three ways: - Interrupt on the first received character - Interrupt on all received characters - Interrupt on a Special Receive condition Interrupt On First Character is typically used with the Block Transfer mode. Interrupt On All Receive Characters can optionally modify the interrupt vector in the event of a parity error. The Special Receive Condition interrupt can occur on a character basis. The Special Receive condition can cause an interrupt only if the Interrupt On First Receive Character or Interrupt On All Receive Characters mode is selected. In Interrupt On First Receive Character, an interrupt can occur from Special Receive conditions (except Parity Error) after the first receive character interrupt (example: Receive Overrun interrupt). The main function of the External/Status interrupt is to monitor the signal transitions of the $\overline{CTS}$ , $\overline{DCD}$ and $\overline{RI}$ pins; however, an External/Status interrupt is also caused by the detection of a Break sequence in the data stream. The interrupt caused by the Break sequence has a special feature that allows the Z-80 DART to interrupt when the Break sequence is detected or terminated. This feature facilitates the proper termination of the current message, correct initialization of the next message, and the accurate timing of the Break condition. CPU/DMA BLOCK TRANSFER. The Z-80 DART provides a Block Transfer mode to accommodate CPU block transfer functions and DMA block transfers (Z-80 DMA or other designs). The Block Transfer mode uses the WRDY output in conjunction with the Wait/Ready bits of Write Register 1. The WRDY output can be defined under software control as a Wait line in the CPU Block Transfer mode or as a Ready line in the DMA Block Transfer mode. To a DMA controller, the Z-80 DART Ready output indicates that the Z-80 DART is ready to transfer data to or from memory. To the CPU, the Wait output indicates that the Z-80 DART is not ready to transfer data, thereby requesting the CPU to extend the I/O cycle. #### Internal Architecture The device internal structure includes a Z-80 CPU interface, internal control and interrupt logic, and two full-duplex channels. Each channel contains read and write registers, and discrete control and status logic that provides the interface to modems or other external devices. The read and write register group includes five 8-bit control registers and two status registers. The interrupt vector is written into an additional 8-bit register (Write Register 2) in Channel B that may be read through Read Register 2 in Channel B. The registers for both channels are designated as follows: WR0-WR5 — Write Registers 0 through 5 RR0-RR2 — Read Registers 0 through 2 The bit assignment and functional grouping of each register is configured to simplify and **Data Path.** The transmit and receive data path illustrated for Channel A in Figure 4 is identical for both channels. The receiver has three 8-bit buffer registers in a FIFO arrangement in addition to the 8-bit receive shift register. This scheme creates additional time for the CPU to organize the programming process. The logic for both channels provides formats, bit synchronization and validation for data transferred to and from the channel interface. The modem control inputs Clear to Send $(\overline{CTS})$ , Data Carrier Detect $(\overline{DCD})$ and Ring Indicator $(\overline{RI})$ are monitored by the control logic under program control. All the modem control signals are general purpose in nature and can be used for functions other than modem control. For automatic interrupt vectoring, the interrupt control logic determines which channel and which device within the channel has the highest priority. Priority is fixed with Channel A assigned a higher priority than Channel B; Receive, Transmit and External/Status interrupts are prioritized in that order within each channel. service a Receive Character Available interrupt in a high-speed data transfer. The transmitter has an 8-bit transmit data register that is loaded from the internal data bus, and a 9-bit transmit shift register that is loaded from the transmit data register. Figure 4. Data Path Read, Write and Interrupt Timing **Read Cycle.** The timing signals generated by a Z-80 CPU input instruction to read a Data or Status byte from the Z-80 DART are illustrated in Figure 5a. Write Cycle. Figure 5b illustrates the timing and data signals generated by a Z-80 CPU out- put instruction to write a Data or Control byte into the Z-80 DART. Interrupt Acknowledge Cycle. After receiving an Interrupt Request signal ( $\overline{\text{INT}}$ pulled Low), the Z-80 CPU sends an Interrupt Acknowledge signal ( $\overline{\text{MI}}$ and $\overline{\text{IORQ}}$ both Low). The daisy-chained interrupt circuits determine the highest priority interrupt requestor. The IEI of the highest priority peripheral is terminated High. For any peripheral that has no interrupt pending or under service, IEO=IEI. Any peripheral that does have an interrupt pending or under service forces its IEO Low. To insure stable conditions in the daisy chain, all interrupt status signals are prevented from changing while $\overline{M1}$ is Low. When $\overline{IORQ}$ is Low, the highest priority interrupt requestor (the one with IEI High) places its interrupt vector on the data bus and sets its internal interrupt-under-service latch. Refer to the *Z-80 SIO Technical Manual* for additional details on the interrupt daisy chain and interrupt nesting. Return From Interrupt Cycle. Normally, the Z-80 CPU issues an RETI (Return From Interrupt) instruction at the end of an interrupt service routine. RETI is a 2-byte opcode (ED-4D) that resets the interrupt-under-service latch to terminate the interrupt that has just been processed. When used with other CPUs, the Z-80 DART allows the user to return from the interrupt cycle with a special command called "Return From Interrupt" in Write Register 0 of Channel A. This command is interpreted by the Z-80 DART in exactly the same way it would interpret an RETI command on the data bus. Figure 5a. Read Cycle Figure 5b. Write Cycle Figure 5c. Interrupt Acknowledge Cycle Figure 5d. Return from Interrupt Cycle #### Z-80 DART Programming To program the Z-80 DART, the system program first issues a series of commands that initialize the basic mode and then other commands that qualify conditions within the selected mode. For example, the character length, clock rate, number of stop bits, even or odd parity are first set, then the Interrupt mode and, finally, receiver or transmitter enable. Both channels contain command registers that must be programmed via the system program prior to operation. The Channel Select input $(B/\overline{A})$ and the Control/Data input $(C/\overline{D})$ are the command structure addressing controls, and are normally controlled by the CPU address bus. Write Registers. The Z-80 DART contains six registers (WR0-WR5) in each channel that are programmed separately by the system program to configure the functional personality of the channels (Figure 4). With the exception of WR0, programming the write registers requires two bytes. The first byte contains three bits $(D_0-D_2)$ that point to the selected register; the second byte is the actual control word that is written into the register to configure the Z-80 DART. WRO is a special case in that all the basic commands ( $CMD_0$ - $CMD_2$ ) can be accessed with a single byte. Reset (internal or external) initializes the pointer bits $D_0$ - $D_2$ to point to WRO. This means that a register cannot be pointed to in the same operation as a channel reset. #### Write Register Functions WRO Register pointers, initialization commands for the various modes, etc. WR1 Transmit/Receive interrupt and data transfer mode definition. WR2 Interrupt vector (Channel B only) WR3 Receive parameters and control WR4 Transmit/Receive miscellaneous parameters and modes WR5 Transmit parameters and controls **Read Registers.** The Z-80 DART contains three registers (RR0-RR2) that can be read to obtain the status information for each channel (except for RR2, which applies to Channel B only). The status information includes error conditions, interrupt vector and standard communications-interface signals. To read the contents of a selected read register other than RR0, the system program must first write the pointer byte to WR0 in exactly the same way as a write register operation. Then, by executing an input instruction, the contents of the addressed read register can be read by the CPU. The status bits of RRO and RR1 are carefully grouped to simplify status monitoring. For example, when the interrupt vector indicates that a Special Receive Condition interrupt has occurred, all the appropriate error bits can be read from a single register (RR1). #### **Read Register Functions** RRO Transmit/Receive buffer status, interrupt status and external status RR1 Special Receive Condition status RR2 Modified interrupt vector (Channel B only) #### Z-80 DART Read and Write Registers #### **READ REGISTER 0** #### READ REGISTER 1\* #### **READ REGISTER 2** #### WRITE REGISTER 0 #### WRITE REGISTER 1 #### WRITE REGISTER 2 (CHANNEL B ONLY) #### WRITE REGISTER 3 #### WRITE REGISTER 4 #### WRITE REGISTER 5 | Ratings Operating Ambient As Specified in Temperature | Stresses greater than those listed under Absolute Maximum Ratings may cause permanent damage to the device. This is a stress rating only; operation of the device at any condition above those indicated in the operational sections of these specifications is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability. | |-------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| |-------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| #### Test Conditions The characteristics below apply for the following 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: - $S^* = 0$ °C to +70°C, $+4.75 \text{ V} \le \text{V}_{CC} \le +5.25 \text{ V}$ - $E^* = -40$ °C to +85°C, +4.75 V $\leq$ V<sub>CC</sub> $\leq$ +5.25 V - $M^* = -55^{\circ}C \text{ to } + 125^{\circ}C,$ + $4.5 \text{ V} \le \text{V}_{CC} \le +5.5 \text{ V}$ \*See Ordering Information section for package temperature range and product number | DC<br>Charac- | Symbol | Parameter | Min | Мах | Unit | Test Condition | |---------------|---------------|--------------------------------------|----------------------|-------|---------|-----------------------------| | teristics | $V_{\rm ILC}$ | Clock Input Low Voltage | -0.3 | +0.45 | V | | | | $V_{IHC}$ | Clock Input High Voltage | V <sub>CC</sub> -0.6 | +5.5 | V | | | | $V_{\rm IL}$ | Input Low Voltage | -0.3 | +0.8 | V | | | | $V_{IH}$ | Input High Voltage | +2.0 | +5.5 | V | | | | $V_{OL}$ | Output Low Voltage | | +0.4 | V | $I_{OL} = 2.0 \text{ mA}$ | | | $V_{OH}$ | Output High Voltage | +2.4 | | V | $I_{OH} = -250 \mu\text{A}$ | | | $I_L$ | Input/3-State Output Leakage Current | -10 | + 10 | $\mu$ A | 0.4 < V < 2.4V | | | $I_{L(R1)}$ | RI Pın Leakage Current | -40 | +10 | $\mu$ A | 0.4 < V < 2.4V | | | $I_{CC}$ | Power Supply Current | | 100 | mA | | $T_A = 0$ °C to 70°C, $V_{CC} = +5V$ , $\pm 5\%$ AC Electrical Characteristics | Number | Symbol | Parameter | Z-80<br>Min | DART<br>Max | Z-80A<br>Min | DART<br>Max | Z-80B<br>Min | DART*†<br>Max | |--------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------|-----------------|--------------|---------------------------------|--------------|----------------| | 1 | TcC | Clock Cycle Time | 400 | 4000 | 250 | 4000 | 165 | 4000 | | 2 | TwCh | Clock Width (High) | 170 | 2000 | 105 | 2000 | 70 | 2000 | | 3 | TfC | Clock Fall Time | | 30 | | 30 | | 15 | | 4 | TrC | Clock Rise Time | | 30 | | 30 | | 15 | | 5 | TwCl — | · Clock Width (Low) | <del></del> 170 - | - 2000 - | 105 | 2000 — | 70 - | -2000 | | 6 | TsAD(C) | $\overline{CE}$ , C/ $\overline{D}$ , B/ $\overline{A}$ to Clock † Setup Time | 160 | | 145 | | 60 | | | 7 | TsCS(C) | IORQ, RD to Clock † Setup Time | 240 | | 115 | | 60 | | | 8 | TdC(DO) | Clock † to Data Out Delay | | 240 | | 220 | | 150 | | 9 | TsDI(C) | Data In to Clock † Setup (Write or $\overline{\text{Ml}}$ Cycle) | 50 | | 50 | | 30 | | | 10 | - TdRD(DOz) — | · RD † to Data Out Float Delay ———————————————————————————————————— | | <del></del> 230 | | <del>-</del> 110 <del>-</del> - | | 90 | | 11 | TdIO(DOI) | IORQ ↓ to Data Out Delay (INTACK Cycle) | | 340 | | 160 | | 100 | | 12 | TsMl(C) | $\overline{\mathrm{Ml}}$ to Clock † Setup Time | 210 | | 90 | | 75 | | | 13 | TsIEI(IO) | IEI to <del>IORQ</del> ↓ Setup Time (INTACK Cycle) | 200 | | 140 | | 120 | | | 14 | TdM1(IEO) | $\overline{\mathrm{Ml}}$ \ to IEO \ \ Delay (interrupt before $\overline{\mathrm{Ml}}$ ) | | 300 | | 190 | 160 | | | 15 — | - TdIEI(IEOr)— | - IEI † to IEO † Delay (after ED decode) ————— | | <del></del> 150 | | <del></del> 100 | | <del></del> 70 | | 16 | TdIEI(IEOf) | IEI ↓ to IEO ↓ Delay | | 150 | | 100 | | 70 | | 17 | TdC(INT) | Clock ↑ to INT ↓ Delay | | 200 | | 200 | | 150 | | 18 | TdIO(W/RWf) | $\overline{\text{IORQ}} \downarrow \text{ or } \overline{\text{CE}} \downarrow \text{ to } \overline{\text{W/RDY}} \downarrow \text{Delay Wait Mode})$ | | 300 | | 210 | | 175 | | 19 | TdC(W/RR) | Clock † to $\overline{W}/\overline{RDY}$ Delay (Ready Mode) | | 120 | | 120 | | 100 | | 20 | TdC(W/RWz) | Clock ↓ to W/RDY Float Delay (Wait Mode) | | 150 | | 130 | | 110 | $<sup>^{\</sup>star}$ All timings are preliminary and subject to change. † Units in nanoseconds (ns) AC Electrical Characteristics (Continued) | Number | Symbol | Parameter | Z-80<br>Min | DART<br>Max | | DART<br>Max | | DART <sup>1</sup><br>Max | Notes† | |--------|--------------|-------------------------------------------------------------------------------------------------------------|------------------|-------------|-----------------|-------------|-----------------|--------------------------|---------------| | 1 | TwPh | Pulse Width (High) | 200 | | 200 | | 200 | | 2 | | 2 | TwPl | Pulse Width (Low) | 200 | | 200 | | 200 | | 2 | | 3 | TcTxC | TxC Cycle Time | 400 | ∞ | 400 | ∞ | 330 | ∞ | 2 | | 4 | TwTxCl | TxC Width (Low) | 180 | ∞ | 180 | œ | 100 | ∞ | 2 | | 5 | TwTxCh | TxC Width (High) | 180 - | ∞ | 180 | - oo | | - 220 | <del></del> 2 | | 6 | TdTxC(TxD) | $\overline{TxC} \downarrow to \; TxD \; Delay$ | | 400 | | 300 | | | 2 | | 7 | TdTxC(W/RRf) | $\overline{\text{TxC}} \downarrow \text{ to } \overline{\text{W/RDY}} \downarrow \text{Delay (Ready Mode)}$ | 5 | 9 | 5 | 9 | 5 | 9 | 3 | | 8 | TdTxC(INT) | TxC ↓ to INT ↓ Delay | 5 | 9 | 5 | 9 | 5 | 9 | 3 | | 9 | TcRxC | RxC Cycle Time | 400 | ∞ | 400 | <b>∞</b> | 330 | ∞ | 2 | | 10 | TwRxCl | - RxC Width (Low) | 180 <del>-</del> | — <u> </u> | <del></del> 180 | -∞- | <del></del> 100 | <b>-∞</b> | <u> </u> | | 11 | TwRxCh | RxC Width (High) | 180 | ∞ | 180 | <b>∞</b> | 100 | <b>∞</b> | 2 | | 12 | TsRxD(RxC) | RxD to RxC † Setup Time (x1 Mode) | 0 | | 0 | | 0 | | 2 | | 13 | ThRxD(RxC) | RxD Hold Time (xl Mode) | 140 | | 140 | | 100 | | 2 | | 14 | TdRxC(W/RRf) | RxC † to W/RDY Delay (Ready<br>Mode) | 10 | 13 | 10 | 13 | 10 | 13 | 3 | | 15 | TdRxC(INT) | RxC ↑ to INT ↓ Delay | 10 | 13 | 10 | 13 | 10 | 13 | 3 | #### NOTES. <sup>†</sup> In all modes, the System Clock rate must be at least five times the maximum data rate RESET must be active a minimum of one complete Clock Cycle Timings are preliminary and subject to change. Units in nanoseconds (ns). Units equal to System Clock Periods | Ordering<br>Information | Product<br>Number | Package/<br>Temp | Speed | Description | Product<br>Number | Package/<br>Temp | Speed | Description | |-------------------------|-------------------|------------------|----------|-------------------|-------------------|------------------|---------|---------------| | | Z8470 | CE | 2.5 MHz | Z80 DART (40-pin) | Z8470A | CS | 4.0 MHz | Z80A DART | | | Z8470 | CM | 2.5 MHz | Same as above | | | | (40-pın) | | | Z8470 | CMB | 2.5 MHz | Same as above | Z8470A | DE | 4.0 MHz | Same as above | | | Z8470 | CS | 2.5 MHz | Same as above | Z8470A | DS | 4.0 MHz | Same as above | | | Z8470 | DE | 2.5 MHz | Same as above | Z8470A | PE | 4.0 MHz | Same as above | | | Z8470 | DS | 2.5 MHz | Same as above | Z8470A | PS | 4.0 MHz | Same as above | | | Z8470 | PE | 2.5 MHz | Same as above | Z8470B | CE | 6.0 MHz | Z80B DART | | | Z8470 | PS | 2.5 MHz | Same as above | | | | (40-pın) | | | Z8470A | CE | 4.0 MHz | Z80A DART | Z8470B | CS | 6.0 MHz | Same as above | | | 20410A | CE | 4.0 MIIZ | (40-pin) | Z8470B | DS | 6.0 MHz | Same as above | | | Z8470 <b>A</b> | CM | 4.0 MHz | Same as above | Z8470B | PS | 6.0 MHz | Same as above | | | Z8470 <b>A</b> | CMB | 4.0 MHz | Same as above | | | | | <sup>\*</sup>NOTES C = Ceramic, D = Cerdip, P = Plastic, E = -40 °C to +85 °C, M = -55 °C to +125 °C, MB = -55 °C to +125 °C with MIL-STD-883 Class B processing, S = 0 °C to +70 °C 00-2044-Ā # zero Family Zilog # Zilog Z8000™ Family # The Art of Staying a Generation Ahead June 1982 **280 Tradition in 16 bits.** Continuing the Family concept so successfully introduced by its 8-bit Z80 CPU, Zilog devised the Z8000 Family of 16-bit parts. As you would expect from Zilog, this Family provides much more than an extension of 8-bit architecture: the Z8000 Family lets you design advanced concepts from the mainframe and minicomputer worlds into microcomputer systems. And because the Z8000 Family was built around a unifying set of protocols and interconnections, present and future family members are entirely compatible. Your system can grow as your applications mature or expand. A whole range of functions have been planned for from the beginning; the growing family now includes parts to provide memory management, DMA transfer, and extended processing. System Flexibility. Even the smallest Z8000 systems offer high throughput and easy programming far superior to any existing microprocessor alternative. In mid-range applications, Z8000 components offer very powerful solutions to the design problems of word processing, intelligent terminals, data communications, instrumentation, and process control. In a complex network of multiple processors, smart peripheral components, and a distributed memory configuration, the Z8000 Family provides performance and versatility exceeding that of much larger—and far more expensive—minicomputers. #### Higher Throughput, Reduced Cost. The powerful instruction set, high execution speed, regular architecture, and numerous special features of the Z8000 microprocessors dramatically increase system throughput. Intelligent Z8000 peripheral controllers and extended processing units unburden the CPU and boost throughput even more. Simply put, the Z8000 Family offers more for less money. The Z8000 microprocessors give mid-range minicomputer performance at microprocessor cost. At component prices, Z8000 peripheral controllers perform complex system functions that previously required an entire PC board. The Z8000 Family is designed for multiple-processor operation—an economical way of greatly increasing system performance. Many special features for multiple Z8000 CPUs facilitate the design of multipleprocessor systems that share access to a common memory. The Memory Management Units can dynamically relocate code and protect memory areas. The Z8034 Z-UPC Universal Peripheral Controller, a complete slave microcomputer, and the Z8070 Floating Point Emulation Package for high speed arithmetic, can manipulate data off-line. Asynchronous parts of multiple-processor systems can be joined by the Z8038 Z-FIO FIFO Interface Unit. An Unmatched CPU. The Z8000 microprocessor is not just a wider data path, more registers, more data types, more addressing modes, more instructions and more addressing space. It brings big-machine concepts to the level of components. Its general-register architecture avoids bottlenecks associated with dedicated or implied registers. Special features support parallel processors, operating systems, compilers, and the implementation of virtual memory. The Z8000 CPU is also a very fast machine. Its throughput is greater than that of any other 16-bit microprocessor with comparable clock speeds. And the Z8000 CPU is available with speeds ranging from a moderate 4 MHz clock rate that allows you the choice of slowaccess, low-cost memories to a highspeed 10 MHz clock rate for highperformance systems. From the four versions of the Z8000 microprocessors, you can select the one best suited to your needs: the Z8001 for large memory applications, the Z8002 for small memory applications, the Z8003 for virtual memory, the Z8004 for multiprocessors sharing a common, small memory. How to Manage Your Memory Better. Trends are increasingly toward systems with multiple users, complex programs, security requirements and memories that don't stop growing. These design problems pose questions not sufficiently answered by other microprocessor families. Exemplifying the Z-Family commitment to advanced architecture, the Z8010 Memory Management Unit (MMU) and the Z8015 Paged Virtual Memory Management Unit (PMMU) both provide flexibility in code segmenter page relocation and sophistication in memory protection rarely found in the microprocessor world. These devices encourage modular software development—a critical factor as programs reach new levels of complexity. You are free from specifying where information is actually located in physical memory because the MMU and PMMU make software addresses totally independent from the actual physical memory address. While some microprocessor CPUs do have internal CPU relocation registers, they are dedicated and support few segments. These CPUs also restrict memory protection. Not true for the MMU or PMMU. Various configurations of these devices can randomly relocate all 128-segments output by the Z8000 CPU in any of its available memory systems. For even more sophisticated memory management, the Z8000 microprocessors include a new member that supports virtual memory via an instruction abort mechanism. The Z8003 Virtual Memory Processing Unit can implement either segmented virtual memory that allows demand swapping of segments, or a paged virtual memory in which the unit of memory allocation is a page within a segment. But the memory management units are more than relocation devices. They offer you a host of memory protection features that allow the system to protect its software from unwanted uses and users. Segments or pages can be specified as read-only to protect them from being overwritten, as system-only to protect the operating system from inadvertent user access, as execute-only, and so on. A write warning zone is especially useful in stack operations so the operating system can deal with growing stacks. Peripheral Problem Solvers. Z8000 peripheral components are not dumb I/O circuits. They perform intelligent, complicated tasks on their own. They unburden the CPU, reduce bus traffic, and increase system throughput. Complex system tasks that previously required burdensome conglomerations of MSI can now be handled off-line by Z-BUS peripherals with little CPU overhead. Multifunction Z-BUS peripherals are extensively programmable, so each can be precisely tailored to its application. Counting, timing, and parallel I/O problems seem less tiresome with the Z8036 Z-CIO Counter and Parallel I/O device. It has three 16-bit counter/ timers, and three I/O ports. It can even double as a programmable interruptpriority controller. Data communications are neatly handled by the Z8030 Z-SCC Serial Communication Controller and the Z8033 Z-ASCC Asynchronous Serial Communications Controller, dual-channel multi-protocol components that support between them all popular communications formats. Direct memory access is amply supported by the Z8016 DTC DMA Transfer Controller, a fast dual-channel device that enhances the addressing power of the Z8000 CPU in stand-alone or parallel-processor environments. General purpose control and datamanipulation problems are smoothly solved by the Z8034 Z-UPC Universal Peripheral Controller, a complete offline microcomputer-on-a-chip with three I/O ports. This processor executes the same friendly, capable instruction set as our Z8 Microcomputer. Bits and pieces of asynchronous parallel-processing systems are interconnected by the Z8038 Z-FIO FIFO Input/Output, a surprisingly flexible device that can interface any major microprocessor and most peripherals to the Z-BUS. Its buffer depth can be expanded without limit using the Z8060 FIFO. Where high-speed error detection and correction are essential, the 78065 Burst Error Processor (Z-BEP) offers a choice of four selectable industrystandard polynomials and three corrections algorithms. It is effective for data rates of up to 20M bits per second. If encryption or decryption of data is necessary, the Z8068 Data Ciphering Processor (Z-DCP) supports three standard ciphering options and key parity check. It can also input, output, and encipher simultaneously. To perform high-speed arithmetic now, the Z8070 Floating Point Emulation Package (with IEEE P754 Standard format) can be implemented with any Z8000 microprocessor. Later this software package will be replaceable by the Z8070 Floating Point Arithmetic Processing Unit itself. ## Z8001/2 Z8000™ CPU Central Processing Unit ## Product Specification #### June 1982 #### Features - Regular, easy-to-use architecture - Instruction set more powerful than many minicomputers - Directly addresses 8M bytes - 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-sharing 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-along 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 throughouput 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 modes. 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. Figure 1. Z8000 CPU Pin Functions 2001-0089 # General Description (Continued) The Z8000 CPU is offered in two versions: the Z8001 48-pin segmented CPU and the Z8002 40-pin non-segmented CPU. The main difference between the two is in addressing range. The Z8001 can directly addresses 8 megabytes of memory; 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 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. #### 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 and Z8002 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 non-segmented 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 Z8001 Program Status Registers Z8001 Program Status Area Pointer 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. 2000211091411101111011101111 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 processes 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, 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 in- terrupts is: internal traps, non-maskable 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 trap-acknowledge 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). 2045-0282, 0283 #### 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), 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 non-segmented 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 seqment. 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 non-segmented Z8002 in any one of its 128 segments, provided it is set to the nonseamented mode. 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 address 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. Figure 6. Logical-to-Physical Address Transformation # 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 feature 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. 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 might be 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 Figure 7. Typical Extended Processor Configuration 2007-001 Extended Processing Architecture (Continued) 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 - Indexed 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. $\Delta$ 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 #### 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 4 illustrates the eight addressing modes: Register (R), Immediate (IM), Indirect Register (IR), Direct Address (DA), Indexed (X), Relative Address (RA), Base Address (BA) and Base Indexed (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. Figure 9. Addressing Modes #### Input/ Output A set of I/O instructions performs 8-bit or, 16-bit transfers betwen 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-Micro-Processor 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. #### 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 | | | | | nics Operands | | Clock Cycles* | | | | | | | | | |------------------|---------------|----------------------------|---------------------------|--------------------|-------------------------|----------------------------|--------------------|-------------------------|----------------------------------------|--|--| | Mnemonics | | Addr. | Word, Byte | | Lo | ng W | ord | Operation | | | | | | | Modes | NS | SS | SL | NS | SS | SL | | | | | CLR<br>CLRB | dst | R<br>IR<br>D <b>A</b><br>X | 7<br>8<br>11<br>12 | -<br>12<br>12 | -<br>14<br>15 | | | | Clear<br>dst ← 0 | | | | EX<br>EXB | R, src | R<br>IR<br>DA<br>X | 6<br>12<br>15<br>16 | -<br>16<br>16 | -<br>18<br>19 | | | | Exchange<br>R src | | | | LD<br>LDB<br>LDL | R, src | R<br>IM<br>IM | | -<br>byte o | -<br>only) | 5<br>11 | - | - | Load into Register R ← src | | | | | | IR<br>DA<br>X<br>BA<br>BX | 7<br>9<br>10<br>14<br>14 | 10<br>10<br>- | 12<br>13<br>- | 11<br>12<br>13<br>17<br>17 | 13<br>13<br>- | 15<br>16<br>-<br>- | | | | | LDL<br>LDB | dst, R | IR<br>DA<br>X<br>BA<br>BX | 8<br>11<br>12<br>14<br>14 | -<br>12<br>12<br>- | -<br>14<br>15<br>-<br>- | 11<br>14<br>15<br>17 | -<br>15<br>15<br>- | -<br>17<br>18<br>-<br>- | Load into Memory (Store) dst R | | | | LD<br>LDB | dst, IM | IR<br>DA<br>X | 11<br>14<br>15 | -<br>15<br>15 | -<br>17<br>18 | | | | Load Immediate into Memory<br>dst ← IM | | | <sup>\*</sup> NS = Non-Segmented SS = Segmented Short Offset SL = Segmented Long Offset | Load and | | Operands R, src | Addr.<br>Modes | *** | | Clock | Cycles | | | | |--------------------------------|---------------------|-----------------|--------------------------|---------------------------|-------------------------|-------------------------|---------------------------|-------------------------|--------------------|--------------------------------------------------------------------------------------------------| | <b>Exchange</b><br>(Continued) | Mnemonics LDĀ | | | Word, Byte | | | Lo:<br>NS | ng W | ord<br>SL | Operation | | | | | | 12 | 13 | | | | | Load Address | | | | , | X | 13 | 13 | 16 | | | | R ← source address | | | | | BA<br>BX | 15<br>15 | - | - | | | | | | | | | | | | | | | | | | | LDAR | R, src | RA | 15 | - | - | | | | Load Address Relative R ← source address | | | LDK | R, src | IM | 5 | _ | - | | | | <b>Load Constant</b> R ← n (n = 0 15) | | | LDM | R, src, n | IR<br>DA<br>X | 11<br>14<br>15 | -<br>15<br>15 | -<br>17<br>18 | +3n | | | Load Multiple R $\leftarrow$ src (n consecutive words) (n = 1 16) | | | LDM | dst, R, n | IR<br>DA<br>X | 11<br>14<br>15 | -<br>15<br>15 | -<br>17<br>18 | +3n | | | Load Multiple (Store Multiple)<br>$dst \leftarrow R$ (n consecutive words)<br>$(n = 1 \dots 16)$ | | | LDR<br>LDRB<br>LDRL | R, src | RA | 14 | _ | - | 17 | - | - | <b>Load Relative</b> R ← src (range -32768 +32767) | | | LDR<br>LDRB<br>LDRL | dst, R | RA | 14 | - | - | 17 | | - | Load Relative (Store Relative)<br>dst ← R<br>(range -32768 +32767) | | | POP<br>POPL | dst, IR | R<br>IR<br>DA<br>X | 8<br>12<br>16<br>16 | -<br>16<br>16 | -<br>18<br>19 | 12<br>19<br>23<br>23 | -<br>23<br>23 | -<br>-<br>25<br>26 | Pop dst — IR Autoincrement contents of R | | | PUSH<br>PUSHL | IR, src | R<br>IM<br>IR<br>DA<br>X | 9<br>12<br>13<br>14<br>14 | -<br>-<br>-<br>14<br>14 | -<br>-<br>-<br>16<br>17 | 12<br>-<br>20<br>21<br>21 | -<br>-<br>-<br>21<br>21 | -<br>-<br>23<br>24 | Push Autodecrement contents of R IR ← src | | Arithmetic | ADC<br>ADCB | R, src | R | 5 | - | - | | | | Add with Carry R - R + src + carry | | | ADD<br>ADDB | R, src | R<br>IM | 4<br>7 | - | - | 8<br>14 | _ | - | Add<br>R ← R + src | | | ADDL | | IR | 7 | _ | _ | 14 | _ | _ | n — n + sic | | | | | DA<br>X | 9<br>10 | 10<br>10 | 12<br>13 | 15<br>16 | 16<br>16 | 18<br>19 | | | | СР | R, src | R | 4 | _ | | 8 | _ | _ | Compare with Register | | | CPB | | MI | 7 | - | - | 14 | - | - | R - src | | | CPL | | IR<br>D <b>A</b> | 7<br>9 | -<br>10 | -<br>12 | 14<br>15 | -<br>16 | -<br>18 | | | | | | X | 10 | 10 | 13 | 16 | 16 | 19 | | | | CP<br>CPB | dst, IM | IR<br>DA<br>X | 11<br>14<br>15 | -<br>15<br>15 | -<br>17<br>18 | | | | <b>Compare with Immediate</b><br>dst - IM | | | DAB | dst | R | 5 | - | - | | | | Decimal Adjust | | | DEC | dst, n | R | 4 | - | - | | | | Decrement by n | | | DECB | | IR<br>DA<br>X | 11<br>13<br>14 | -<br>14<br>14 | -<br>16<br>17 | | | | $dst \leftarrow dst - n$ $(n = 1 16)$ | | Arithmetic | | | | | | Clock | Cycles | | | | |-------------|------------------------|----------|----------------------------|---------------------------------|--------------------|-------------------------|---------------------------|-------------------------|---------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | (Continued) | Mnemonics | Operands | Addr.<br>Modes | Wo<br>NS | ord, B<br>SS | - | | ng W<br>SS | | Operation | | | DIAT | R, src | R<br>IM<br>IR<br>DA<br>X | 107<br>107<br>107<br>108<br>109 | -<br>107<br>109 | -<br>107<br>111<br>112 | 745 | -<br>-<br>744 | -<br>-<br>744<br>748 | $\begin{array}{l} \textbf{Divide} \text{ (signed)} \\ \text{Word: } R_{n+1} \leftarrow R_{n,n+1} + \text{src} \\ R_n \leftarrow \text{remainder} \\ \text{Long Word: } R_{n+2,n+3} \leftarrow R_{n\ldotsn+3} + \text{sr} \\ R_{n,n+1} \leftarrow \text{remainder} \end{array}$ | | | EXTS<br>EXTSB<br>EXTSL | dst | R | 11 | _ | _ | 11 | - | - | Extend Sign Extend sign of low order half of dst through high order half of dst | | | INC<br>INCB | dst, n | R<br>IR<br>DA<br>X | 4<br>11<br>13<br>14 | -<br>14<br>14 | -<br>-<br>16<br>17 | | | | Increment by n<br>$dst \leftarrow dst + n$<br>$(n = 1 \dots 16)$ | | | MULT<br>MULTL | R, src | R<br>IM<br>IR<br>DA<br>X | 70<br>70<br>70<br>71<br>72 | -<br>-<br>72<br>72 | -<br>-<br>-<br>74<br>75 | | -<br>-<br>284 | -<br>-<br>-<br>* 286*<br>* 287* | $\label{eq:multiply} \begin{array}{ll} \textbf{Multiply} \ (\text{signed}) \\ \text{Word:} \ R_{n,n+1} \leftarrow R_{n+1} \bullet \text{src} \\ \text{Long Word:} \ R_{n} _{n+3} \leftarrow R_{n+2,n+3} \\ {}^{\star} \text{Plus seven cycles for each 1 in the multiplicand} \end{array}$ | | | NEG<br>NEGB | dst | R<br>IR<br>DA<br>X | 7<br>12<br>15<br>16 | -<br>16<br>16 | -<br>-<br>18<br>19 | | | | <b>Negate</b> dst ← 0 - dst | | | SBC<br>SBCB | R, src | R | 5 | - | - | | | | Subtract with Carry R + R - src - carry | | | SUB<br>SUBB<br>SUBL | R, src | R<br>IM<br>IR<br>DA<br>X | 4<br>7<br>7<br>9<br>10 | -<br>-<br>10<br>10 | -<br>-<br>-<br>12<br>13 | 8<br>14<br>14<br>15<br>16 | -<br>-<br>-<br>16<br>16 | -<br>-<br>-<br>18<br>19 | Subtract<br>R ← R - src | | Logical | AND<br>ANDB | R, src | R<br>IM<br>IR<br>DA<br>X | 4<br>7<br>7<br>9<br>10 | -<br>-<br>10<br>10 | -<br>-<br>12<br>13 | | | | AND<br>R — R AND src | | | COMB | dst | R<br>IR<br>DA<br>X | 7<br>12<br>15<br>16 | -<br>16<br>16 | -<br>18<br>19 | | | | Complement dst NOT dst | | | OR<br>ORB | R, src | R<br>IM<br>IR<br>DA<br>X | 4<br>7<br>7<br>9<br>10 | -<br>-<br>10<br>10 | -<br>-<br>12<br>13 | | | | OR<br>R ← R OR src | | | TCC<br>TCCB | cc, dst | R | 5 | - | _ | | | | Test Condition Code Set LSB if cc is true | | | TEST<br>TESTB<br>TESTL | dst | R<br>IR<br>D <b>A</b><br>X | 7<br>8<br>11<br>12 | -<br>12<br>12 | -<br>-<br>14<br>15 | 13<br>13<br>16<br>17 | -<br>17<br>17 | -<br>19<br>20 | <b>Test</b><br>dst OR 0 | | | XOR<br>XORB | R, src | R<br>IM<br>IR<br>DA<br>X | 4<br>7<br>7<br>9<br>10 | -<br>-<br>10<br>10 | -<br>-<br>-<br>12<br>13 | | | | Exclusive OR R — R XOR src | | Program | | | | | | Clock | Cycles | | | | |--------------------------|---------------|----------|---------------------|---------------------|--------------------|---------------------|-----------|------------------|-----------|---------------------------------------------------------------------------------------------------------------| | Control | Mnemonics | Operands | Addr.<br>Modes | Wo<br>NS | ord, B | yte<br>SL | Lo:<br>NS | ng W<br>SS | ord<br>SL | Operation | | | CALL | dst | IR<br>DA<br>X | 10<br>12<br>13 | -<br>18<br>18 | 15<br>20<br>21 | NS | 33 | 9L | Call Subroutine Autodecrement SP @ SP ← PC PC ← dst | | | CALR | dst | RA | 10 | - | 15 | | | | Call Relative Autodecrement SP @ SP ← PC PC ← PC + dst (range -4094 to +4096) | | | DJNZ<br>DBJNZ | R, dst | RA | 11 | - | - | | | | Decrement and Jump if Non-Zero $R \leftarrow R - 1$ If $R \neq 0$ : PC $\leftarrow$ PC + dst (range -254 to 0 | | | IRET* | _ | _ | 13 | _ | 16 | | | | Interrupt Return PS ← @ SP Autoincrement SP | | | JP | cc, dst | IR<br>IR<br>DA<br>X | 10<br>7<br>7<br>8 | -<br>-<br>8<br>8 | 15<br>7<br>10<br>11 | | taken<br>ot tak | | Jump Conditional If cc 1s true: PC ← dst | | | JR | cc, dst | RA | 6 | - | - | | | | Jump Conditional Relative If cc is true: PC ← PC + dst (range -256 to +254) | | | RET | СС | - | 10<br>7 | - | 13<br>7 | | taken<br>ot take | | Return Conditional If cc is true: PC — @ SP Autoincrement SP | | | sc | src | IM | 33 | - | 39 | | | | System Call Autodecrement SP @ SP old PS Push instruction PS System Call PS | | Bit<br>Manipula-<br>tion | BIT<br>BITB | dst, b | R<br>IR<br>DA<br>X | 4<br>8<br>10<br>11 | -<br>-<br>11<br>11 | -<br>13<br>14 | | | | <b>Test Bit Static</b> Z flag ← NOT dst bit specified by b | | | BIT<br>BITB | dst, R | R | 10 | - | - | | utu ake manen | | <b>Test Bit Dynamic</b> Z flag ← NOT dst bit specified by contents of R | | | RES<br>RESB | dst,b | R<br>IR<br>DA<br>X | 4<br>11<br>13<br>14 | -<br>14<br>14 | -<br>16<br>17 | | | | Reset Bit Static<br>Reset dst bit specified by b | | | RES<br>RESB | dst, R | R | 10 | - | - | | | | Reset Bit Dynamic Reset dst bit specified by contents R | | | SET<br>SETB | dst, b | R<br>IR<br>DA<br>X | 4<br>11<br>13<br>14 | -<br>-<br>14<br>14 | -<br>16<br>17 | | | | Set Bit Static<br>Set dst bit specified by b | | | SET<br>SETB | dst, R | R | 10 | _ | - | | | | Set Bit Dynamic Set dst bit specified by contents of R | | | TSET<br>TSETB | dst | R<br>IR<br>DA<br>X | 7<br>11<br>14<br>15 | -<br>-<br>15<br>15 | -<br>-<br>17<br>18 | | | | Test and Set S flag ← MSB of dst dst ← all 1s | | Rotate | | | | Clock | Cycles | | |----------------------------------------------|---------------------|-------------------------------------------|----------------|-------------------------------|---------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------| | and<br>Shift | Mnemonics | Operands | Äddr.<br>Modes | Word, Byte<br>NS SS SL | Long Word<br>NS SS SL | Operation | | | RL<br>RLB | dst, n | R<br>R | 6 for n = 1<br>7 for n = 2 | | Rotate Left by n bits (n = 1, 2) | | | RLC<br>RLCB | dst, n | R<br>R | 6 for n = 1<br>7 for n = 2 | | Rotate Left through Carry by n bits $(n = 1, 2)$ | | | RLDB | R, src | R | 9 | | Rotate Digit Left | | | RR<br>RRB | dst, n | R<br>R | 6 for n = 1<br>7 for n = 2 | | Rotate Right by n bits (n = 1, 2) | | | RRC<br>RRCB | dst, n | R<br>R | 6 for n = 1 $7 for n = 2$ | | Rotate Right through Carry by n bits $(n = 1, 2)$ | | | RRDB | R, src | R | 9 | | Rotate Digit Right | | | SDA<br>SDAB<br>SDAL | dst, R | R | (15 + 3 n) | (15 + 3 n) | <b>Shift Dynamic Arithmetic</b><br>Shift dst left or right<br>by contents of R | | | SDL<br>SDLB<br>SDLL | dst, R | R | (15 + 3 n) | (15 + 3 n) | Shift Dynamic Logical Shift dst left or right by contents of R | | | SLA<br>SLAB<br>SLAL | dst, n | R | (13 + 3 n) | (13 +3 n) | Shift Left Arithmetic<br>by n bits | | | SLL<br>SLLB<br>SLLL | dst, n | R | (13 + 3 n) | (13 + 3 n) | Shift Left Logical<br>by n bits | | | SRA<br>SRAB<br>SRAL | dst, n | R | (13 + 3 n) | (13 + 3 n) | Shift Right Arithmetic<br>by n bits | | | SRL<br>SRLB<br>SRLL | dst, n | R | (13 + 3 n) | (13 + 3 n) | Shift Right Logical<br>by n bits | | Block<br>Fransfer<br>and String<br>Manipula- | CPD<br>CPDB | $R_X$ , src, $R_Y$ , cc | IR | 20 | e e e e e e e e e e e e e e e e e e e | Compare and Decrement $R_X$ - src Autodecrement src address $R_Y \leftarrow R_Y - 1$ | | ion | CPDR<br>CPDRB | R <sub>X</sub> , src, R <sub>Y</sub> , cc | IR | (11 + 9 n) | | Compare, Decrement and Repeat $R_X$ – src Autodecrement src address $R_Y \leftarrow R_Y - 1$ Repeat until cc is true or $R_Y = 0$ | | | CPI<br>CPIB | $R_X$ , src, $R_Y$ , cc | IR | 20 | | Compare and Increment R <sub>X</sub> - src Autoincrement src address R <sub>Y</sub> ← R <sub>Y</sub> - 1 | | | CPIR<br>CPIRB | R <sub>X</sub> , src, R <sub>Y</sub> , cc | IR | (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 | | Compare String and Decrement dst – sro<br>Autodecrement dst and src addresses $R \leftarrow R-1$ | | ock Transfer | i | | | | | ( | Clock | Cycles | | | | |------------------------------------------|-----------------|-----------------|----------------|----------|-----|------------|-------|----------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------| | and String<br>Manipulation<br>Continued) | Mnemonics | Operands | Addr.<br>Modes | Wo<br>NS | | , By<br>SS | | Lo<br>NS | ng V<br>SS | <b>V</b> oi | Operation | | ontinued) | CPSDR<br>CPSDRB | dst, src, R, cc | IR | | | 14 | | | | | Compare String, Decr. and Repeat dst - src Autodecrement dst and src addresses $R \leftarrow R - 1$ Repeat until cc is true or $R = 0$ | | | CPSI<br>CPSIB | dst, src, R, cc | IR | 25 | = | _ | _ | | | | Compare String and Increment dst – src Autoincrement dst and src addresses $R \leftarrow R-1$ | | | CPSIR<br>CPSIRB | dst, src, R, cc | IR | (11 | + | 14 | n) | | | | Compare String, Incr. and Repeat dst – src Autoincrement dst and src addresses $R \leftarrow R - 1$ Repeat until cc is true or $R = 0$ | | | LDD<br>LDDB | dst, src, R | IR | 20 | - | _ | - | | | | Load and Decrement dst src Autodecrement dst and src addresses R R - 1 | | | LDDR<br>LDDRB | dst, src, R | IR | (11 | l + | - 9 r | n) | | | | Load, Decrement and Repeat<br>dst ← src<br>Autodecrement dst and src addresses<br>R ← R − 1<br>Repeat until R = 0 | | | LDI<br>LDIB | dst, src, R | IR | 20 | - | - | - | | | | Load and Increment dst ← src Autoincrement dst and src addresses R ← R - 1 | | | LDIR<br>LDIRB | dst, src, R | IR | (11 | l + | - 9 r | n) | | | | <br>Load. Increment and Repeat dst $\leftarrow$ src Autoincrement dst and src addresses $R \leftarrow R - 1$ Repeat until $R = 0$ | | | TRDB | dst, src, R | IR | 25 | - | _ | _ | | | 1 | Translate and Decrement dst ← src (dst) Autodecrement dst address R ← R - 1 | | | TRDRB | dst, src, R | IR | (11 | + | 14 : | n) | | | | Translate, Decrement and Repeat dst $\leftarrow$ src (dst) Autodecrement dst address R $\leftarrow$ R - 1 Repeat until R = 0 | | | TRIB | dst, src, R | IR | 25 | - | - | - | | | | Translate and Increment dst ← src (dst) Autoincrement dst address R ← R - 1 | | | TRIRB | dst, src, R | IR | (11 | + | 14: | n) | | | | Translate, Increment and Repeat dst $\leftarrow$ src (dst) Autoincrement dst address $R \leftarrow R-1$ Repeat until $R=0$ | | | TRTDB | srcl, src2, R | IR | 25 | - | | - | | | | Translate and Test, Decrement RH1 ← src 2 (src 1) Autodecrement src 1 address R ← R - 1 | | Block Transfer | • | | | Clock | Cycles | ×1 | |-------------------------------------|-----------------|---------------|------------------|------------------------|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------| | and String Manipulation (Continued) | Mnemonics | Operands | Addr.<br>Modes | Word, Byte<br>NS SS SL | Long Word | Operation | | | TRTDRB | srcl, src2, R | IR | (11 + 14 n) | | Translate and Test, Decr. and Repeat RH1 $\leftarrow$ src 2 (src 1) Autodecrement src 1 address R $\leftarrow$ R - 1 Repeat until R = 0 or RH1 = 0 | | | TRTIB | srcl, src2, R | IR | 25 | | Translate and Test, Increment RH1 — src 2 (src 1) Autoincrement src 1 address R — R – 1 | | | TRTIRB | srcl, src2, R | IR | (11 + 14 n) | | Translate and Test, Incr. and Repeat RH1 ← src 2 (src 1) Autoincrement src 1 address R ← R - 1 Repeat until R = 0 or RH1 = 0 | | input/<br>Output | IN*<br>INB* | R, src | IR<br>D <b>A</b> | 10<br>12 | | Input<br>R ← src | | | IND*<br>INDB* | dst, src, R | IR | 21 | | Input and Decrement dst ← src Autodecrement dst address R ← R - 1 | | | INDR* | dst, src, R | IR | (11 + 10 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 | | Input and Increment dst ← src Autoincrement dst address R ← R - 1 | | | INIR*<br>INIRB* | dst, src, R | IR | (11 + 10 n) | | Input, Increment and Repeat dst ← src Autoincrement dst address R ← R - 1 Repeat until R = 0 | | | OUT* | dst, R | IR<br>DA | 10<br>12 | | Output<br>dst ← R | | | OUTD* | dst, src, R | IR | 21 | | Output and Decrement dst — src Autodecrement src address R — R - 1 | | | OTDR* 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* | dst, src, R | IR | 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 dst — src Autoincrement src address R — R – 1 | | nput/Output | | | | | | CIOCK | Cycles | | | | |--------------|-------------------|-------------|----------------|-----|-------|-------|--------|------|----|-----------------------------------------------------------------------------------| | Continued) | Mnemonics | Operands | Addr.<br>Modes | | rd, I | _ | | ng W | | Operation | | | - | | | NS | SS | SL | NS | SS | SL | | | | SIN*<br>SINB* | R, src | DA | 12 | - | - | | | | Special Input<br>R ← src | | | SIND*<br>SINDB* | dst, src, R | IR | 21 | _ | - | | | | Special Input and Decrement | | | | | | | | | | | | Autodecrement dst address<br>R ← R - 1 | | | SINDR* | dst, src, R | IR | (11 | + 1 | 0 n) | | | | Special Input, Decrement and Repeadst ← src | | | | | | | | | | | | Autodecrement dst address<br>R ← R - 1<br>Repeat until R = 0 | | | SINI*<br>SINIB* | dst, src, R | IR | 21 | - | _ | | | | Special Input and Increment<br>dst ← src | | | | | | | | | | | | Autoincrement dst address<br>R ← R - 1 | | | SINIR*<br>SINIRB* | dst, src, R | IR | (11 | + l | 0 n) | | | | Special Input, Increment and Repeateds to src Autoincrement dst address R + R - 1 | | | SOUT* | dst, src | DA | 12 | _ | - | | | | Repeat until R = 0 Special Output dst src | | | SOUTD*<br>SOUTDB* | dst, src, R | IR | 21 | - | - | | | | Special Output and Decrement dst src Autodecrement src address | | | SOTDR* | dst, src, R | IR | (11 | . + 1 | 0 n) | | | | R ← R - 1 Special Output, Decr. and Repeat | | | SOTDRB* | 22,22,2 | | , | | , | | | | dst ← src<br>Autodecrement src address<br>R ← R – 1<br>Repeat until R = 0 | | | SOUTI*<br>SOUTIB* | dst, src, R | IR | 21 | - | - | | | | Special Output and Increment dst src Autoincrement src address R R - 1 | | | SOTIR*<br>SOTIRB* | dst, src, R | R | (11 | + 1 | 0 n) | | | | Special Output, Incr. and Repeat<br>dst ← src<br>Autoincrement src address | | | | | | | | | | | | $R \leftarrow R - 1$ Repeat until R = 0 | | PU<br>ontrol | COMFLG | flags | - | 7 | - | - | | | | Complement Flag (Any combination of C, Z, S, P/V) | | | DI* | ınt | _ | 7 | - | - | | | | Disable Interrupt<br>(Any combination of NVI, VI) | | | EI* | ınt | | 7 | - | - | | | | Enable Interrupt (Any combination of NVI, VI) | | | HALT* | - | - | 8) | + 3 | n) | | | | HALT | | | LDCTL* | CTLR, src | R | 7 | _ | - | | | | Load into Control Register CTLR ← src | | | LDCTL* | dst, CTLR | R | 7 | _ | - | | | | Load from Control Register | | CPU | | | | | | Clock | Cycles | | | | |-------------------------------|-----------|-----------|---------------|----------------|---------------|----------------|--------|------|-------|---------------------------------------------------------------------------------------------------| | <b>Control</b><br>(Continued) | Mnemonics | Operands | Addr. | Wo | rd, B | yte | Lo | ng W | ord | Operation | | (Commuea) | | | Modes | NS | SS | SL | NS | SS | SL | | | | LDCTLB | FLGR, src | R | 7 | - | _ | | | | Load into Flag Byte Register<br>FLGR ← src | | | LDCTLB | dst, FLGR | R | 7 | _ | | | | | Load from Flag Byte Register<br>dst ← FLGR | | | LDPS* | src | IR<br>DA<br>X | 12<br>16<br>17 | -<br>20<br>20 | 16<br>22<br>23 | | | | <b>Load Program Status</b><br>PS ← src | | | MBIT* | - | _ | 7 | _ | - | | | | <b>Test Multi-Micro Bit</b> Set S if $\overline{M_I}$ is Low; reset S if $\overline{M_I}$ is High | | | MREQ* | dst | R | (12 | 2 + 7 | n) | | | | Multi-Micro Request | | | MRES* | - | _ | 5 | _ | - | | | | Multi-Micro Reset | | | MSET * | - | - | 5 | - | - | | | | Multi-Micro Set | | | NOP | - | _ | 7 | _ | _ | | | | No Operation | | | RESFLG | flag | - | 7 | - | - | | | | Reset Flag (Any combination of C, Z, S, P/V) | | | SETFLG | flag | _ | 7 | - | _ | | | ,,,,, | Set Flag (Any combination of C, Z, S, P/V) | | Condition | Code | Meaning | Flag Settings | CC Field | |-----------|------|--------------------------------|-----------------------------|----------| | Codes | | Always false | _ | 0000 | | | | Always true | _ | 1000 | | | Z | Zero | Z = 1 | 0110 | | | NZ | Not zero | Z = 0 | 1110 | | | C | 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 OR (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) AND (Z = 0)] = 1 | 1011 | | | ULE | Unsigned less than or equal | (C OR Z) = 1 | 0011 | \*Privileged instructions Executed in system mode only 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 | $ST_3-ST_0$ | Definition | ST <sub>3</sub> -ST <sub>0</sub> | Definition | |-------------|-----------------------------------------|----------------------------------|-------------------------------| | 0000 | Internal operation | 1000 | Data memory request | | 0001 | Memory refresh | 1001 | Stack memory request | | 0010 | I/O reference | 1010 | Data memory request (EPU) | | 0011 | Special I/O reference (e.g., to an MMU) | 1011 | Stack memory request (EPU) | | 0100 | Segment trap acknowledge | 1100 | Program reference, nth word | | 0101 | Non-maskable interrupt acknowledge | 1101 | Instruction fetch, first word | | 0110 | Non-vectored interrupt acknowledge | 1110 | Extension processor transfer | | 0 1 1 1 | Vectored interrupt acknowledge | ÎÎÎÎ | 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 both 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. MMI. Non-Maskable Interrupt (edge triggered, input, active Low). A high-to-low transition on NMI requests a non-maskable interrupt. The Figure 10. Z8001 Pin Assignments 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. $\mathbf{R}/\overline{\mathbf{W}}$ . Read/Write (output, Low = Write, 3-state). R/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 table). **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. Reserved. Do not connect. Figure 11. Z8002 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 $\overline{\text{WAIT}}$ input is not synchronized in the Z8000 and that the setup and hold times for $\overline{\text{WAIT}}$ relative to the clock must be met. If asynchronous $\overline{\text{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, Figure 12. Memory Read and Write Timing #### Memory Read and Write (Continued) the 7-bit segment number is output on SN<sub>0</sub>-SN<sub>6</sub> one clock period earlier than the 16-bit address offset to compensate for the delay in the memory management circuitry.) 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<sub>2</sub> and T<sub>3</sub>. 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 = \text{Low})$ , and the least significant byte $(D_0-D_7)$ is addressed by the high-order address $(A_0 = \text{High})$ . #### Input/ Output I/O timing is similar to memory read/write timing, except that one wait state is automatically inserted between T<sub>2</sub> and T<sub>3</sub> (Figure 13). Both the segmented Z8001 and the non-segmented Z8002 use 16-bit I/O addresses. Figure 13. Input/Output Timing 2045-0289 143 Interrupt and Segment Trap Request and The Z8000 CPU recognizes three interrupt inputs (non-maskable, vectored and nonvectored) and a segmentation trap input. Any High-to-Low transition on the NMI input is Acknowledge asynchronously edge detected and sets the internal NMI latch. The VI, NVI and SEGT inputs as well as the state of the internal NMI latch are sampled at the beginning of T<sub>3</sub> in the last machine cycle of any instruction. > In response to an interrupt or trap, the subsequent IF1 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 and 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 AD0-AD15 and stores it temporarily, to be saved on the stack later in the acknowledge sequence. This word identifies the source of the interrupt or trap. For the non-vectored and non-maskable 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 (Figure 12) in the following order: the 16-bit program counter; the 7-bit segment number (Z8001 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. #### **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). 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 ### Bus Request/ (Continued) requesting device-typically a DMA-can then Acknowledge control the bus. When BUSREQ is released, it is synchronized with the rising clock edge and 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 preceeding any IF1 cycle (Figure 16) and before the second word of an EPA instruction is fetched. If STOP is found Low between the IF1 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 T3 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 divideby-four clock prescaler; rather, it doubleincrements 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 IF1 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 #### 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_0-AD_8)$ ; $AD_9-AD_{15}$ are undefined (Figure 18). Since the memory is word-organized, $A_0$ 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 #### Halt A HALT instruction executes an unlimited number of 3-cycle internal operations, inter-spersed 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. #### Reset A Low on the 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_0$ - $SN_6$ are forced Low - Refresh is disabled - $\blacksquare$ R/ $\overline{W}$ , B/ $\overline{W}$ and N/ $\overline{S}$ are not affected When $\overline{\text{RESET}}$ has been High for three clock periods, two consecutive memory read cycles are executed in the system mode. 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 $\mathrm{IF}_1$ 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 $\mathrm{IF}_1$ cycle starts the program. Figure 19. Reset Timing 2045-0295 147 #### Composite AC Timing Diagram | Number | Symbol | Parameter | Z8001<br>Min | /Z8002<br>Max | Z8001A<br>Min | /Z8002Ā<br>Max | Z8001B.<br>Min | /Z8002B†<br>Max | |----------|------------------------|--------------------------------------------------------------------------------------------|------------------|-------------------|-----------------------------|----------------|-----------------|-----------------| | 1 | TcC | Clock Cycle Time | 250 | 2000 | 165 | 2000 | 100 | 2000 | | 1<br>2 | TwCh | Clock Width (High) | 250<br>105 | 2000 | 70 | 2000 | 40 | 2000 | | 3 | TwCl | Clock Width (High) Clock Width (Low) | 105 | 2000 | 70 | 2000 | 40 | | | 4 | TiC | Clock Fall Time | 105 | 2000 | 10 | 10 | 40 | 10 | | 5 | -TrC | — Clock Rise Time———————————————————————————————————— | | 20 - | | 15- | | 10- | | 6 | TdC(SNv) | Clock † to Segment Number Valid | | 130 | | 110 | | 70 | | 7 | TdC(SNn) | (50 pF load) Clock † to Segment Number Not Valid | 20 | | 10 | | 5 | | | 8 | TdC(Bz) | Clock to Bus Float | 20 | 65 | 10 | 55 | 5 | 40 | | 9 | TdC(A) | Clock † to Address Valid | | 100 | | 75 | | 50 | | 10 | - TdC(Az) | — Clock † to Address Float | | 65- | | 55 | | 40- | | 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 1 to Address Active | 80* | | 45* | | 20* | | | 14 | TdC(DW) | Clock to Write Data Valid | | 100 | | 75 | | 50 | | 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 | 00 | 35* | 70 | 20* | 40 | | 18 | TdC(MR) | Clock to MREQ Delay | 210* | 80 | 105* | 70 | 00* | 40 | | 19<br>20 | TwMRh | MREQ Width (High) MREQ I to Address Not Active | 210*<br>70* | | 135*<br>35* | | 80*<br>20* | | | 21 | - TdMR(A)<br>TdDW(DSW) | Write Data Valid to DS (Write) Delay | 70<br>55* | | 35<br>35* | | 20<br>15* | | | 22 | TdMR(DR) | MREQ 1 to Read Data Required Valid | 375* | | 230* | | 140* | | | 23 | TdC(MR) | Clock MREQ Delay | 313 | 80 | 250 | 60 | 140 | 45 | | 24 | TdC(ASf) | Clock to AS Delay | | 80 | | 60 | | 40 | | 25 | - TdA(AS) | — Address Valid to AS † Delay | 55* | | 35*- | | 20* | | | 26 | TdC(ASr) | Clock ↓ to ĀS↑ Delay | - | 90 | | 80 | | 40 | | 27 | TdAS(DR) | AS † to Read Data Required Valid | 360* | | 220* | | 140* | | | 28 | TdDS(AS) | DS ↑ to AS ↓ Delay | 70* | | 35* | | 15* | | | 29 | TwAS | AS Width (Low) | <b>8</b> 5* | | 55* | | 30* | | | 30 | – TdAS(A) ——— | — AS 1 to Address Not Active Delay———— | <del> 70*</del> | | <del> 4</del> 5* | | 20* | | | 31 | TdAz(DSR) | Address Float to DS (Read) ↓ Delay | 0 | | 0 | | 0 | | | 32 | TdAS(DSR) | AS 1 to DS (Read) Delay | 80* | | 55* | | 30* | | | 33 | TdDSR(DR) | DS (Read) to Read Data Required Valid | 205* | 70 | 130* | C.F. | 70* | 40 | | 34<br>35 | TdC(DSr) | Clock ↓ to DS ↑ Delay DS ↑ to Write Data Not Valid | <del></del> 75* | 70 | <del>45*</del> | 65 | — 25* <b>—</b> | 45 | | 36 | -TdDS(DW)<br>TdA(DSR) | Address Valid to DS (Read) Delay | 75<br>180* | | 110* | | — 25 —<br>65* | | | 37 | TdC(DSR) | Clock † to DS (Read) Delay | 100 | 120 | 110 | <b>8</b> 5 | 00 | 60 | | 38 | TwDSR | DS (Read) Width (Low) | 275* | 120 | 185* | 00 | 110* | 00 | | 39 | TdC(DSW) | Clock to DS (Write) Delay | 210 | 95 | 100 | 80 | 110 | 60 | | 40 | - TwDSW | - DS (Write) Width (Low) | 185* <del></del> | | 110* | | <del> 75*</del> | | | 41 | TdDSI(DR) | DS (I/O) ↓ to Read Data Required Valid | 330* | | 210* | | 120* | | | 42 | TdC(DSf) | Clock I to $\overline{\rm DS}$ (I/O) I Delay | | 120 | | 90 | | 60 | | 43 | TwDS | DS (I/O) Width (Low) | 410* | | 255* | | 160* | | | 44 | TdAS(DSA) | AS t to DS (Acknowledge) Delay | 1065* | | 690* | | 410* | | | 45 | - TdC(DSA) | — Clock † to DS (Acknowledge) Delay——— | 400+ | <del></del> 120 - | 0054 | <del>8</del> 5 | 1054 | <del>65</del> | | 46 | TdDSA(DR) | DS (Acknowledge) to Read Data | 455* | | 295* | | 165* | | | 47 | TdC(S) | Required Delay Clock † to Status Valid Delay | | 110 | | 85 | | 60 | | 48 | TdS(AS) | Status Valid to AS † Delay | 50* | 110 | 30* | 65 | 10* | 00 | | 49 | TsR(C) | RESET to Clock † Setup Time | 180 | | 70 | | 50 | | | 50 | - ThR(C) | - RESET to Clock Hold Time | 0_ | | o | | <u> </u> | | | 51 | TwNMI | NMI Width (Low) | 100 | | 70 | | 50 | | | 52 | TsNMI(C) | NMI to Clock † Setup Time | 140 | | 70 | | 50 | | | 53 | TsVI(C) | $\overline{\mathrm{VI}}$ , $\overline{\mathrm{NVI}}$ to Clock † Setup Time | 110 | | 50 | | <b>4</b> 0 | | | 54 | ThVI(C) | $\overline{\text{VI}}$ , $\overline{\text{N}}$ $\overline{\text{VI}}$ to Clock † Hold Time | 20 | | 20 | | 10 | | | 55 | -TsSGT(C) | - SEGT to Clock † Setup Time | <del></del> 70 | | <del> 55</del> | | <del>4</del> 0 | | | 56 | ThSGT(C) | SEGT to Clock † Hold Time | 0 | | 0 | | 0 | | | 57 | TsMI(C) | MI to Clock † Setup Time | 180 | | 140 | | 80 | | | 58<br>59 | ThMI(C) | MI to Clock 1 Hold Time | 0 | 120 | 0 | 85 | 0 | 70 | | 60 | TdC(MO)<br>-TsSTP(C) | Clock † to MO Delay<br>— STOP to Clock ↓ Setup Time | <del>140</del> | 120 | <del></del> 100 <del></del> | 60 | 50 | 70 | | 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 | <del>1</del> 0 | | 10 | | <del></del> 5 | | | 66 | TdC(BAKr) | Clock † to BUSACK † Delay | | 100 | | 75 | | 60 | | 67 | TdC(BAKf) | Clock ↑ to BUSACK ↓ Delay | | 100 | | 75 | | 60 | | 68 | TwA | Address Valid Width | 150* | | 95* | | 50* | | | 69 | TdDS(S) | DS 1 to STATUS Not Valid | 80* | | 55* | | 30* | | | | | | | | | | | | | Number | Symbol | Z8001/Z8002<br>Equation | Z8001A/Z8002A<br>Equation | Z8001B/Z8002B<br>Equation | |--------|-------------|-------------------------|---------------------------|---------------------------| | 11 | TdA(DR) | 2TcC + TwCh - 130 ns | 2TcC + TwCh - 95 ns | 2TcC + TwCh - 60 ns | | 13 | TdDS(A) | TwCl - 25 ns | TWCl – 25 ns | TwCl - 20 ns | | 16 | TdDW(DS) | TcC + TwCh - 60 ns | TcC + TwCh - 40 | TcC+ TwCh - 30 ns | | 17 | TdA(MR) | TwCh - 50 ns | TwCh – 35 ns | TwCh - 20 ns | | 19 | -TwMRh | — TcC - 40 ns | TcC - 30 ns | TcC - 20 ns | | 20 | TdMR(A) | TwCl – 35 ns | TwCl - 35 ns | TwCl - 20 ns | | 21 | TdDW(DSW) | TwCh – 50 ns | TwCh – 35 ns | TwCh - 25 ns | | 22 | TdMR(DR) | 2TcC - 130 ns | 2TcC - 100 ns | 2TcC - 60 ns | | 25 | TdA(AS) | TwCh – 50 ns | TwCh – 35 ns | TwCh - 20 ns | | 27 | - TdAS(DR) | - 2TcC - 140 ns | 2TcC - 110 ns | 2TcC - 60 ns | | 28 | TdDS(AS) | TwCl - 35 ns | TwCl - 35 ns | TwCl - 25 ns | | 29 | TwAS | TwCh - 20 ns | TwCh - 15 ns | TwCh - 10 ns | | 30 | TdAS(A) | TwCl – 35 ns | TwCl – 25 ns | TwCl - 20 ns | | 32 | TdAS(DSR) | TwCl – 25 ns | TwCl – 15 ns | TwCl - 10 ns | | 33 | - TdDSR(DR) | - TcC + TwCh - 150 ns | | TcC + TwCh - 70 ns | | 35 | TdDS(DW) | TwCl - 30 ns | TwCl – 25 ns | TwCl - 15 ns | | 36 | TdA(DSR) | TcC - 70 ns | TcC – 55 ns | TcC - 35 ns | | 38 | TwDSR | TcC + TwCh - 80 ns | TcC + TwCh - 50 ns | TcC + TwCh - 30 ns | | 40 | TwDSW | TcC - 65 ns | TcC - 55 ns | TcC - 25 ns | | 41 | TdDSI(DR) | _ 2TcC - 170 ns | 2TcC - 120 ns | 2TcC - 80 ns | | 43 | TwDS | 2TcC - 90 ns | 2TcC - 75 ns | 2TcC - 40 ns | | 44 | TdAS(DSA) | 4TcC + TwCl - 40 ns | 4TcC + TwCl - 40 ns | 4TcC + TwCl - 30 ns | | 46 | TdDSA(DR) | 2TcC + TwCh - 150 ns | 2TcC + TwCh - 105 ns | 2TcC + TwCh - 75 ns | | 48 | TdS(AS) | TwCh - 55 ns | TwCh – 40 ns | TwCh - 30 ns | | 68 | - TwA | — TcC - 90 ns———— | TcC - 70 ns | TcC - 50 ns | | 69 | TdDS(s) | TwCl – 25 ns | TwCl – 15 ns | TwCl - 10 ns | #### Absolute Maximum Ratings Voltages on all inputs and outputs with respect to GND.....-0.3 V to +7.0 V 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. #### Test Conditions The characteristics below apply for the following 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: - S\* = 0°C to +70°C, +4.75 V $\leq$ V<sub>CC</sub> $\leq$ +5.25 V - $E^* = -40$ °C to +85°C, +4.75 V $\leq$ V<sub>CC</sub> $\leq$ +5.25 V - $M^* = -55$ °C to +125°C, +4.5 $V \le V_{CC} \le +5.5 V$ All ac parameters assume a total load capacitance (including parasitic capacitances) of 100 pF max, except for parameter 6 (50 pF max). Timing references between two output signals assume a load difference of 50 pF max. #### DC Characteristics | Symbol | Parameter | Min | Max | Unit | Condition | |-----------------------|---------------------------------|----------------------|-----------------------|------|---------------------------------------| | $v_{\mathrm{CH}}$ | Clock Input High Voltage | V <sub>CC</sub> -0.4 | V <sub>CC</sub> + 0.3 | V | Driven by External Clock<br>Generator | | $v_{CL}$ | Clock Input Low Voltage | -0.3 | 0.45 | V | Driven by External Clock<br>Generator | | $v_{IH}$ | Input High Voltage | 2.0 | V <sub>CC</sub> +0.3 | V | | | V <sub>IH RESET</sub> | Input High Voltage on RESET pin | 2.4 | V <sub>CC</sub> to .3 | V | | | $v_{IL}$ | Input Low Voltage | -0.3 | 0.8 | V | | | V <sub>OH</sub> | Output High Voltage | 2.4 | | V | $I_{OH} = -250 \mu\text{A}$ | | $v_{OL}$ | Output Low Voltage | | 0.4 | V | $I_{OL} = +2.0 \text{ mA}$ | | $I_{\mathrm{IL}}$ | Input Leakage | | ±10 | μΑ | $0.4 \leq V_{\rm IN} \leq +2.4~\rm V$ | | I <sub>IL SEGT</sub> | Input Leakage on SEGT pın | - 100 | 100 | μΑ | | | $I_{OL}$ | Output Leakage | | ±10 | μΑ | $0.4 \leq V_{\rm IN} \leq +2.4~\rm V$ | | $I_{CC}$ | V <sub>CC</sub> Supply Current | | 300 | mA | | <sup>\*</sup>See Ordering Information section for package temperature range and product number. | Ordering<br>nformation | Product<br>Number | Package/<br>Temp | Speed | Description | Product<br>Number | Package/<br>Temp | Speed | Description | |------------------------|-------------------|------------------|---------|-------------------------|-------------------|------------------|----------|---------------------------------| | | Z8001 | CE | 4.0 MHz | CPU (segmented, 48-pin) | Z8002 | DS | 4.0 MHz | CPU (nonseg-<br>mented, 40-pin) | | | Z8001 | CM | 4.0 MHz | Same as above | Z8002 | PE | 4.0 MHz | Same as above | | | Z8001 | CMB | 4.0 MHz | Same as above | Z8002 | PS | 4.0 MHz | Same as above | | | Z8001 | CS | 4.0 MHz | Same as above | Z8002A | CE | 6.0 MHz | Same as above | | | Z8001 | DE | 4.0 MHz | Same as above | Z8002A | CM | 6.0 MHz | Same as above | | | Z8001 | DS | 4.0 MHz | Same as above | Z8002A | CMB | 6.0 MHz | Same as above | | | Z8001 | PE | 4.0 MHz | Same as above | Z8002A | CS | 6.0 MHz | Same as above | | | Z8001 | PS | 4.0 MHz | Same as above | Z8002A | DE | 6.0 MHz | Same as above | | | Z8001A | CE | 6.0 MHz | Same as above | Z8002A | DS | 6.0 MHz | Same as above | | | Z8001A | CS | 6.0 MHz | Same as above | Z8002A | PE | 6.0 MHz | Same as above | | | Z8001A | DE | 6.0 MHz | Same as above | Z8002A | PS | 6.0 MHz | Same as above | | | Z8001A | DS | 6.0 MHz | Same as above | Z8002B | CE | 10.0 MHz | Same as above | | | Z8001A | PE | 6.0 MHz | Same as above | Z8002B | CM | 10.0 MHz | Same as above | | | Z8001A | PS | 6.0 MHz | Same as above | Z8002B | CMB | 10.0 MHz | Same as above | | | Z8002 | CE | 4.0 MHz | CPU (nonseg- | Z8002B | CS | 10.0 MHz | Same as above | | | | | | mented, 40-pin) | Z8002B | DE | 10.0 MHz | Same as above | | | Z8002 | CM | 4.0 MHz | Same as above | Z8002B | DS | 10.0 MHz | Same as above | | | Z8002 | CMB | 4.0 MHz | Same as above | Z8002B | PE | 10.0 MHz | Same as above | | | Z8002 | CS | 4.0 MHz | Same as above | Z8002B | PS | 10.0 MHz | Same as above | | | Z8002 | DE | 4.0 MHz | Same as above | | | | | <sup>\*</sup>NOTES C = Ceramic, D = Cerdip, P = Plastic, E = $-40\,^{\circ}$ C to $+85\,^{\circ}$ C, M = $-55\,^{\circ}$ C to $+125\,^{\circ}$ C, MB = $-55\,^{\circ}$ C to $+125\,^{\circ}$ C with MIL-STD-883 with Class B processing, S = $0\,^{\circ}$ C to $+70\,^{\circ}$ C 00-2045-02 ## Z8003/4 Z8000<sup>™</sup> VMPU Virtual Memory Processing Unit ### Product Brief #### June 1982 #### Features - Binary, function, and pin compatibility with the Z8001/2 microprocessors. - Designed-in compatibility with present and future Zilog Memory Management Units (MMUs). - Operates with up to a 10 MHz clock. - Status lines indicate the read/write phase of the Test and Set instruction for use in multiprocessor systems. - 23-bit segmented addresses for Z8003. - 16-bit non-segmented addresses for Z8004. #### Description 2096-001, 002 The Z8003/4 Virtual Memory Processor Unit (VMPU), a 16-bit MOS microprocessor, offers integral provisions for operation in a virtual memory environment, in addition to the features of the Z8001 CPU. The Z8003 VMPU generates 23-bit addresses. The address space is organized into 128 segments, each up to 64K bytes in length. The Z8004 generates 16-bit addresses. The Z8003/4 VMPU addressing scheme distinguishes between memory space for program, data, and stack in each of two modes, System and Normal. For use in shared-memory multiprocessor systems, the Z8003/4 VMPU provides an output Figure 1. Pin Assignments on the status lines $(ST_0-ST_3)$ , indicating the read/write phase of the Test and Set (TSET) instruction. This status output can be used externally for arbitration of bus control. In a virtual memory environment, the programs and data being operated on need not reside simultaneously in main memory. Thus, provision must be made for retrieving parts of a program or data located in "secondary" storage (such as a disk). Attempts by the microprocessor to access instructions or data not in main memory are called "accesses to nonresident data." When this is done, the transaction accessing the nonresident data must be interrupted, the state of the microprocessor saved, the program or data in secondary storage moved to main memory, the state of the microprocessor restored, and the interrupted instruction restarted. The Z8003/4 VMPU provides an external abort pin to permit the interruption of instruc- Figure 2. Virtual Memory Environment 153 ## **Description** (Continued) tion execution before the instruction completes. When the Z8003/4 VMPU is used in a multiprocessor system, there may be dual-ported memories used by the processors. In this type of system, a resources manager arbitrates simultaneously attempted accesses to shared resources. When a processor tests to see if a resource is in use, the read/write portion of the test transaction must not be interrupted or the probability of a collision increases greatly. The Z8003/4 VMPU provides features that help to avoid collisions during accesses to shared resources via the enhanced TSET instruction. # Functional Description The Z8003/4 VMPU can operate in a virtual memory environment. The virtual memory capability is provided by an instruction abort function on pin 33 of the Z80<u>03 and</u> on pin <u>28</u> of the Z8004. When this pin WAIT, and SAT are activated at the same time, an instruction abort sequence begins. This abort sequence leaves the VMPU in a well-defined state, allowing a software recovery. To make this recovery smoothly, the software must know which instruction was aborted and how much of the instruction was executed. Figure 3 shows the timing sequence for the abort function. Figure 4 shows the sequence of hardware and software events that occurs when an instruction is aborted. During the read phase of the TSET instruction on the Z8003/4 VMPU, the status lines $ST_0\text{-}ST_3$ are all set to 1s. On the Z8001/2 all 1s on the status lines is a reserved status encoding. The Z8003/4 VMPU is compatible with the Z8000 Family of microprocessor and peripheral devices. Instruction set and bus transaction protocols of the VMPU can be found in the Z8000 CPU Technical Manual (document number 00-2010-C). The VMPU enhancements are described in the VMPU Product Specification. NOTES: \* = Clock Sample Points NOTE. The abort sequence is initiated when $\overline{ABORT}$ , $\overline{SAT}$ , and $\overline{WAIT}$ are activated. Figure 3. Instruction Abort Timing Figure 4. Instruction Abort Function Flow #### Summary The Zilog VMPU is the first 16-bit microprocessor that offers integral provision for operation in a virtual memory environment. The upward compatibility of the VMPU with the Z8001/2 CPU means that applications software developed for a Z8001/2 CPU will execute directly on the VMPU, preserving investments in software and development tools. 154 2096-003, 004 ### **Z8010** Z8000™Z-MMU Memory **Management Unit** ### **Product Specification** #### June 1982 #### **Features** - Dynamic segment relocation makes software addresses independent of physical memory addresses. - Sophisticated memory-management features include access validation that protects memory areas from unauthorized or unintentional access, and a write-warning indicator that predicts stack overflow. - For use with both Z8001 and Z8003 CPU. - 64 variable-sized segments from 256 to 65,536 bytes can be mapped into a total physical address space of 16M bytes; all 64 segments are randomly accessible. - Multiple MMUs can support several translation tables for each Z8001/3 address space. - MMU architecture supports multi-programming systems and virtual memory implementations. #### General Description The Z8010 Memory Management Unit (MMU) manages the large 8M byte addressing spaces of the Z8001 CPU. The MMU provides dynamic segment relocation as well as numerous memory protection features. Dynamic segment relocation makes user software addresses independent of the physical memory addresses, thereby freeing the user from specifying where information is actually located in the physical memory. It also provides a flexible, efficient method for supporting multi-programming systems. The MMU uses a translation table to transform the 23-bit logical address output from the Z8001 CPU into a 24-bit address for the physical memory. (Only logical memory addresses go to an MMU for translation: I/O addresses and data, in general, must by pass this component.) Figure 2. Pin Assignments # General Description (Continued) Memory segments are variable in size from 256 bytes to 64K bytes, in increments of 256 bytes. Pairs of MMUs support the 128 segment numbers available for the various Z8001 CPU address spaces. Within an address space, any number of MMUs can be used to accommodate multiple translation tables for System and Normal operating modes, or to support more sophisticated memory-management systems. MMU memory-protection features safeguard memory areas from unauthorized or unintended access by associating special access restrictions with each segment. A segment is assigned a number of attributes when its descriptor is entered into the MMU. When a memory reference is made, these attributes are checked against the status information supplied by the Z8001/3 CPU. If a mismatch oc- curs, a trap is generated and the CPU is interrupted. The CPU can then check the status registers of the MMU to determine the cause. Segments are protected by modes of permitted use, such as read only, system only, execute only and CPU-access only. Other segment management features include a writewarning zone useful for stack operations and status flags that record read or write accesses to each segment. The MMU is controlled via 22 Special I/O instructions from the Z8000 CPU in System mode. With these instructions, system software can assign program segments to arbitrary memory locations, restrict the use of segments and monitor whether segments have been read or written. Figure 3. The shaded areas in these block diagrams illustrate the resources used in the two modes of MMU operation. In the Address Translation Mode shown on the left, addresses are translated automatically. In the Command Mode shown on the right, specific registers are accessed using Special I/O commands. 156 2046-028 #### Segmented Addressing A segmented addressing space—compared with linear addressing—is closer to the way a programmer uses memory because each procedure and data set can reside in its own segment. The 8M byte Z8001 addressing spaces are divided into 128 relocatable segments of up to 64K bytes 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 byte relative to the beginning of the segment. The two parts of the segmented address may be manipulated separately. The MMU divides the physical memory into 256-byte blocks. Segments consist of physically contiguous blocks. Certain segments may be designated so that writes into the last block generate a warning trap. If such a segment is used as a stack, this warning can be used to increase the segment size and prevent a stack overflow error. The addresses manipulated by the programmer, used by instructions and output by the Z8001 are called *logical addresses*. The MMU takes the logical addresses and transforms them into the *physical addresses* required for accessing the memory (Figure 4). This address transformation process is called *relocation*. The relocation process is transparent to user software. A translation table in the MMU associates the 7-bit segment number with the base address of the physical memory segment. The 16-bit logical address offset is added to the physical base address to obtain the actual physical memory location. Because a base address always has a low byte equal to zero, only the high-order 16 bits are stored in the MMU and used in the addition. Thus the low-order byte of the physical memory location is the same as the low-order byte of the logical address offset. This low-order byte therefore bypasses the MMU, thus reducing the number of pins required. Figure 4. Logical-to-Physical Address Translation Each memory segment is assigned several attributes that are used to provide memory access protection. A memory request from the Z8001/3 CPU is accompanied by status information that indicates the attributes of the memory request. The MMU compares the memory request attributes with the segment attributes and generates a Trap Request whenever it detects an attribute violation. Trap Request informs the Z8001/3 CPU and the system control program of the violation so that appropriate action can be taken to recover. The MMU also generates the Suppress signal SUP in the event of an access violation. Suppress can be used by a memory system to inhibit stores into the memory and thus protect the contents of the memory from erroneous Five attributes can be associated with each segment. When an attempted access violates any one of the attributes associated with a segment, a Trap Request and a Suppress signal are generated by the MMU. These attributes are read only, execute only, system access only, inhibit CPU accesses and inhibit DMA accesses. changes. Segments are specified by a base address and a range of legal offsets to this base address. On each access to a segment, the offset is checked against this range to insure that the access falls within the allowed range. If an access that lies outside the segment is attempted, Trap Request and Suppress are generated. Normally the legal range of offsets within a segment is from 0 to 256N + 255 bytes, where $0 \le N \le 255$ . However, a segment may be specified so that legal offsets range from 256N to 65,535 bytes, where $0 \le N \le 255$ . The later type of segment is useful for stacks since the Z8000 stack manipulation instructions cause stacks to grow toward lower memory locations. Thus when a stack grows to the limit of its allocated segment, additional memory can be allocated on the correct end of the segment. As an aid in maintaining stacks, the MMU detects when a write is performed to the lowest allocated 256 bytes of these segments and generates a Trap Request. No Suppress signal is generated so the write is allowed to proceed. This write warning can then be used to indicate that more memory should be allocated to the segment. #### Memory Protection #### MMU Register Organization The MMU contains three types of registers: Segment Descriptor, Control and Status. A set of 64 Segment Descriptor Registers supplies the information needed to map logical memory addresses to physical memory locations. The segment number of a logical address determines which Segment Descriptor Register is used in address translation. Each Descriptor Register also contains the necessary information for checking that the segment location referenced is within the bounds of the segment and that the type of reference is permitted. It also indicates whether the segment has been read or written. In addition to the Segment Descriptor Registers, the Z8010 MMU contains three 8-bit control registers for programming the device and six 8-bit status registers that record information in the event of an access violation. Segment Descriptor Registers. Each of the 64 Descriptor Registers contains a 16-bit base address field, an 8-bit limit field and an 8-bit attribute field (Figure 5). The base address field is subdivided into high- and low-order bytes that are loaded one byte at a time when the descriptor is initialized. The limit field contains a value N that indicates N+1 blocks of 256 bytes have been allocated to the segment.\* The attribute field contains eight flags (Figure 6). Five are related to protecting the segment against certain types of access, one indicates the special structure of the segment, and two encode the types of accesses that have been made to the segment. A flag is set when its value is 1. The following brief descriptions indicate how these flags are used. Read-Only (RD). When this flag is set, the segment is read only and is protected against any write access. System-Only (SYS). When this flag is set, the segment can be accessed only in System mode, and is protected against any access in Normal mode. CPU-Inhibit (CPUI). When this flag is set, the segment is not accessible to the currently executing process, and is protected against any memory access by the CPU. The segment is, however, accessable under DMA. Execute-Only (EXC). When this flag is set, the segment can be accessed only during an instruction fetch or access by the relative addressing mode cycle, and thus is protected against any access during other cycles. **DMA-Inhibit (DMAI).** When this flag is set, the segment can be accessed only by the CPU, and thus is protected against any access under DMA. Direction and Warning (DIRW). When this flag is set, the segment memory locations are considered to be organized in descending order and each write to the segment is checked for access to the last 256-byte block. Such an access generates a trap to warn of potential segment overflow, but no Suppress signal is generated. Changed (CHG). When this flag is set, the segment has been changed (written). This bit is set automatically during any write access to this segment if the write access does not cause any violation. Referenced (REF). When this flag is set, the segment has been referenced (either read or written). This bit is set automatically during any access to the segment if the access does not cause a violation. Figure 5. Segment Descriptor Registers Figure 6. Attribute Field in Segment Descriptor Register Control Registers. The three user-accessible 8-bit control registers in the MMU direct the functioning of the MMU (Figure 7). The Mode Register provides a sophisticated method for selectively enabling MMUs in multiple-MMU configurations. The Segment Address Register (SAR) selects a particular Segment Descriptor Register to be accessed during a control operation. The Descriptor Selection Counter Register points to a byte within the Segment Descriptor Register to be accessed during a control operation. Figure 7. Control Registers The Mode Register contains a 3-bit identification field (ID) that distinguishes among eight enabled MMUs in a multiple-MMU configuration. This field is used during the segment trap acknowledge sequence (refer to the section on Segment Trap and Acknowledge). In addition, the Mode Register contains five flags. Multiple Segment Table (MST). This flag indicates whether multiple segment tables are present in the hardware configuration. When this flag is set, more than one table is present and the N/S line must be used to determine whether the MMU contains the appropriate table. Normal Mode Select (NMS). This flag indicates whether the MMU is to translate addresses when the $N/\overline{S}$ line is High or Low. If the MST flag is set, the $N/\overline{S}$ line must match the NMS flag for the MMU to translate segment addresses, otherwise the MMU Address lines remain 3-stated. #### MMU Register Organization (Continued) Upper Range Select (URS). This flag is used to indicate whether the MMU contains the lower-numbered segment descriptors or the higher-numbered segment descriptors. The most significant bit of the segment number must match the URS flag for the MMU to translate segment addresses, otherwise the MMU Address lines remain 3-stated Translate (TRNS). This flag indicates whether the MMU is to translate logical program addresses to physical memory locations or is to pass the logical addresses unchanged to the memory and without protection checking. In the non-translation mode, the most significant byte of the output is the 7-bit segment number and the most significant bit is 0. When this flag is set, the MMU performs address translation and attribute checking. Master Enable (MSEN). This flag enables or disables the MMU from performing its address translation and memory protection functions. When this flag is set, the MMU performs these tasks; when the flag is clear the Address lines of the MMU remain 3-stated. The Segment Address Register (SAR) points to one of the 64 segment descriptors. Control commands to the MMU that access segment descriptors implicitly use this pointer to select one of the descriptors. This register has an auto-incrementing capability so that multiple descriptors can be accessed in a block read/write fashion. The Descriptor Selection Counter Register holds a 2-bit counter that indicates which byte in the descriptor is being accessed during the reading or writing operation. A value of zero in this counter indicates the high-order byte of the base address field is to be accessed, one indicates the low-order byte of the base address, two indicates the limit field and three indicates the attribute field. Status Registers. Six 8-bit registers contain information useful in recovering from memory access violations (Figure 8). The Violation Type Register describes the conditions that generated the trap. The Violation Segment Number and Violation Offset Registers record the most-significant 15 bits of the logical address that causes a trap. The Instruction Segment Number and Offset Registers record the most-significant 15 bits of the logical address of the last instruction fetched before the first accessing violation. These two registers can be used in conjunction with external circuitry that records the low-order offset byte. At the time of the addressing violation, the Bus Cycle Status Register records the bus cycle status (status code, read/write mode and normal/system mode). The MMU generates a Trap Request for two general reasons: either it detects an access violation, such as an attempt to write into a read-only segment, or it detects a warning condition, which is a write into the lowest 256 bytes of a segment with the DIRW flag set. When a violation or warning condition is detected, the MMU generates a Trap Request and automatically sets the appropriate flags. The eight flags in the Violation Type Register describe the cause of a trap. **Read-Only Violation (RDV).** Set when the CPU attempts to access a read-only segment and the $R/\overline{W}$ line is Low. System Violation (SYSV). Set when the CPU accesses a system-only segment and the $\overline{N}/S$ line is High. CPU-Inhibit Violation (CPUIV). Set when the CPU attempts to access a segment with the CPU-inhibit flag set. Execute-Only Violation (EXCV). Set when the CPU attempts to access an execute-only segment in other than an instruction fetch or load relative instructions cycle. Segment Length Violation (SLV). Set when an offset falls outside of the legal range of a segment. Primary Write Warning (PWW). Set when an access is made to the lowest 256 bytes of a segment with the DIRW flag set. Secondary Write Warning (SWW). Set when the CPU pushes data into the last 256 bytes of the system stack and EXCV, CPUIV, SLV, SYSV, RDV or PWW is set. Once this flag is set, subsequent write warnings for accessing the system stack do not generate a Segment Trap request. Fatal Condition (FATL). Set when any other flag in the Violation Type Register is set and either a violation is detected or a write warning condition occurs in Normal mode. This flag is not set during a stack push in System mode that results in a warning condition. This flag indicates a memory access error has occurred in the trap processing routine. Once set, no Trap Request signals are generated on subsequent violations. However, Suppress signals are generated on this and subsequent CPU violations until the FATL flag has been reset. Figure 8. Status Registers #### Segment Trap and Acknowledge The Z8010 MMU generates a Segment Trap when it detects an access violation or a write warning condition. In the case of an access violation, the MMU also activates Suppress, which can be used to inhibit memory writes and to flag special data to be returned on a read access. Segment Trap remains Low until a Trap Acknowledge signal is received. If a CPU-generated violation occurs, Suppress is asserted for that cycle and all subsequent CPU instruction execution cycles until the end of the instruction. Intervening DMA cycles are not suppressed, however, unless they generate a violation. Violations detected during DMA cycles cause Suppress to be asserted during that cycle only—no Segment Trap Requests are ever generated during DMA cycles. Segment traps to the Z8001/3 CPU are handled similarly to other types of interrupts. To service a segment trap, the CPU issues a segment trap acknowledge cycle. The acknowledge cycle is always preceded by an instruction fetch cycle that is ignored (the MMU has been designed so that this dummy cycle is ignored). During the acknowledge cycle all enabled MMUs use the Address/Data lines to indicate their status. An MMU that has generated a Segment Trap Request outputs a 1 on the A/D line associated with the number in its ID field; an MMU that has not generated a segment trap request outputs a 0 on its associated A/D line. A/D lines for which no MMU is associated remain 3-stated. During a segment trap acknowledge cycle, an MMU uses A/D line 8+i if its ID field is 1. Following the acknowledge cycle the CPU automatically pushes the Program Status onto the system stack and loads another Program Status from the Program Status Area. The Segment Trap line is reset during the segment trap acknowledge cycle. Suppress is not generated during the stack push. If the store creates a write warning condition, a Segment Trap Request is generated and is serviced at the end of the Program Status swap. The SWW flag is also set. Servicing this second Segment Trap Request also creates a write warning condition, but because the SWW flag is set, no Segment Trap Request is generated. If a violation rather than a write warning occurs during the Program Status swap, the FATL flag is set rather than the SWW flag. Subsequent violations cause Suppress to be asserted but not Segment Trap Request. Without the SWW and FATL flags, trap processing routines that generate memory violations would repeatedly be interrupted and called to process the trap they created. The CPU routine to process a trap request should first check the FATL flag to determine if a fatal system error has occurred. If not, the SWW flag should be checked to determine if more memory is required for the system stack. Finally, the trap itself should be processed and the Violation Type Register reset. #### Virtual Memory Several features of the MMU can be used in conjunction with external circuitry to support virtual memory for the Z8001/3. Segment Trap Request can be used to signal the CPU in the event that a segment is not in primary memory. The CPU-Inhibit Flag can be used to indicate whether a segment is in the memory or in secondary storage. The Changed and Altered Flags in the attribute field for each segment can aid in implementing efficient segment management policies. The Status Registers can be used in recovering from virtual memory access faults. #### Multiple MMUs MMU architecture directly supports two methods for multiple MMU configurations. The first approach extends single-MMU capability for handling 64 segments to a dual-MMU configuration that manages the 128 different segments the Z8001/3 can address. This scheme uses the URS flag in the Mode Register in connection with the high-order bit of the segment number ( $\mathrm{SN}_6$ ). The second approach uses several MMUs to implement multiple translation tables. Multiple tables can be used to reduce the time required to switch tasks by assigning separate tables to each task. Multiple translation tables for multi- task environments can use the Master Enable Flag to enable the appropriate MMUs through software. Multiple translation tables may also be used to extend the physical memory size beyond 16 megabytes by separating system from normal memory and/or program from data memory. The MST and NMS flags in the Mode Register can be used in conjunction with the $N\!/\!\overline{S}$ line to select the MMU that contains the appropriate table. Special external circuitry that monitors the CPU Status lines can manipulate the MMU $N\!/\!\overline{S}$ line to perform this selection. #### DMA Operation Direct memory access operations may occur between Z8001 instruction cycles and can be handled through the MMU. The MMU permits DMA in either the System or Normal mode of operation. For each memory access, the segment attributes are checked and if a violation is detected, Suppress is activated. Unlike a CPU violation that automatically causes Suppress signals to be generated on subsequent memory accesses until the next instruction, DMA violations generate a Suppress only on a per memory access basis. The DMA device should note the Suppress signal and record sufficient information to enable the system to recover from the access violation. No Segment Trap Request is ever generated during DMA, hence warning conditions are not signaled. Trap Requests are not issued because the CPU cannot acknowledge such a request. At the start of a DMA cycle, DMASYNC must go Low for at least two clock cycles, indicating to the MMU the beginning of a DMA cycle, A Low DMASYNC inhibits the MMU from using an indeterminate segment number on lines SN<sub>0</sub>-SN<sub>6</sub>. When the DMA logical memory address is valid, the DMASYNC line must be High before a rising edge of Clock and the MMU then performs its address translation and access protection functions. Upon the release of the bus at the termination of the DMA cycle the DMASYNC line must again be High. After two clock cycles of DMASYNC High, the MMU assumes that the CPU has control of the bus and that subsequent memory references are CPU accesses. The first instruction fetch occurs at least two cycles after the CPU regains control of the bus. During CPU cycles, DMASYNC should always be High. #### MMU Commands The various registers in the MMU can be read and written using Z8001 CPU special I/O commands. These commands have machine cycles that cause the Status lines to indicate an SIO operation is in progress. During these machine cycles the MMU enters command mode. In this mode, the rising edge of the Address Strobe indicates a command is present on the AD8-AD15. If Chip Select is asserted and if this command indicates that data is to be written into one of the MMU registers, the data is read from AD<sub>8</sub>-AD<sub>15</sub> while Data Strobe is Low. If the command indicates that data is to be read from one of the MMU registers, the data is placed on AD8-AD15 while Data Strobe is Low. There are ten commands that read or write various fields in the Segment Descriptor Register. The status of the Read/Write line indicates whether the command is a read or a write The auto-incrementing feature of the Segment Address Register (SAR) can be used to block load segment descriptors using the repeat forms of the Special I/O instructions. The SAR is autoincremented at the end of the field. In accessing the base field, first the high-order byte is selected and then the low-order byte. The command accessing the entire Descriptor Register references the fields in the order of base address, limit and attribute. | Opcode (Hex) | Instruction | |--------------|-------------------------------------------| | 08 | Read/Write Base Field | | 09 | Read/Write Limit Field | | OΑ | Read/Write Attribute Field | | 0B | Read/Write Descriptor (all fields) | | 0C | Read/Write Base Field; Increment SAR | | 0D | Read/Write Limit Field; Increment SAR | | OE | Read/Write Attribute Field; Increment SAR | | OF | Read/Write Descriptor; Increment SAR | | 15 | Set All CPU-Inhibit Attribute Flags | Three commands are used to read and write the control registers. Set All DMA-Inhibit Attribute Flags 16 | Opcode (Hex) | Instruction | |--------------|----------------------------------------| | 00 | Read/Write Mode Register | | 01 | Read/Write Segment Address Register | | 20 | Read/Write Descriptor Selector Counter | | | Register | The Status Registers are read-only registers, although the Violation Type Register (VTR) can be reset. Nine instructions access these registers. | Opcode (Hex) | Instruction | |--------------|-------------------------------------------------| | 02 | Read Violation Type Register | | 03 | Read Violation Segment Number Register | | 04 | Read Violation Offset (High-byte) Register | | 05 | Read Bus Status Register | | 06 | Read Instruction Segment Number<br>Register | | 07 | Read Instruction Offset (High-byte)<br>Register | | 11 | Reset Violation Type Register | | 13 | Reset SWW Flag in VTR | | 14 | Reset FATL Flag in VTR | #### MMU Timing The Z8010 translates addresses and checks for access violations by stepping through sequences of basic clock cycles corresponding to the cycle structure of the Z8001 CPU. The following timing diagrams show the relative timing relationships of MMU signals during the basic operations of memory read/write and MMU control commands. For exact timing information, refer to the composite timing diagram. **Memory Read and Write.** Memory read and instruction fetch cycles are identical, except for the status information on the $ST_0$ – $ST_3$ inputs. During a memory read cycle (Figure 9) the 7-bit segment number is input on $SN_0$ – $SN_6$ one clock period earlier than the address offset; a High on DMASYNC during $T_3$ indicates that the segment offset data is valid. The most significant eight bits of the address offset are placed on the $AD_0$ – $AD_{15}$ inputs early in the Figure 9. Memory Read Timing # MMU Timing (Continued) first clock period. Valid address offset data 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 most significant 16-bits of the address (physical memory location) remain valid until the end of T<sub>3</sub>. Segment Trap Request and Suppress are asserted in T<sub>2</sub>. Segment Trap Request remains Low until Segment Trap Acknowledge is received. Suppress is asserted during the current machine cycle and terminates during $T_3$ . Suppress is repeatedly asserted during CPU instruction execution cycles until the current instruction has terminated. Figure 10. Memory Write Timing 2046-198 MMU Timing (Continued) **MMU Command Cycle.** During the command cycle of the MMU (Figure 11), commands are placed on the Address/Data lines during $T_1$ . The Status lines indicate that a Special I/O instruction is in progress, and the Chip Select line enables the appropriate MMU for that command. Data to be written to a register in the MMU must be valid on the Address/Data lines late in $T_2$ . Data read from the MMU is placed on the Address/Data lines late in the $T_{\mbox{\scriptsize WA}}$ cycle. **Input/Output and Refresh.** Input/Output and Refresh operations are indicated by the status lines $ST_0$ – $ST_3$ . During these operations, the MMU refrains from any address translation or protection checking. The address lines $A_8$ – $A_{23}$ remain 3-stated. Figure 11. I/O Command Timing 164 2046-199 # MMU Timing (Continued) Reset. The MMU can be reset by either hard ware or software mechanisms. A hardware reset occurs on the falling edge of the Reset signal; a software reset is performed by a Z8000 Special I/O command. A hardware reset clears the Mode Register, Violation Type Register and Descriptor Selection Counter. If the Chip Select line is Low, the Master Enable Flag in the Mode Register is set to 1. All other registers are undefined. After reset, the AD8-AD15 and A8-A23 lines are 3-stated. The SUPand SEGT open-drain outputs are not driven. If the Master Enable flag is not set during reset, the MMU does not respond to subsequent addresses on its A/D lines. To enable an MMU after a hardware reset, an MMU command must be used in conjunction with the Chip Select line. A software reset occurs when the Reset Violation Type Register command is issued. This command clears the Violation Type Register and returns the MMU to its initial state (as if no violations or warnings had occurred). Note that the hardware and software resets have different effects. Segment Trap and Acknowledge. The Z8010 MMU generates a segment trap whenever it detects an access violation or a write into the lowest block of a segment with the DIRW flag set. In the case of an access violation, the MMU also activates Suppress. This Suppress signal can be used to inhibit memory writes. The Segment Trap remains Low until a Trap Acknowledge signal is received. If a violation occurs, Suppress is asserted for that cycle and all subsequent CPU cycles until the end of the instruction; intervening DMA cycles are not suppressed, however, unless they generate a violation. Violations detected during DMA cycles cause Suppress to be asserted during that cycle only, but no Trap Request is generated. When the MMU issues a Segment Trap Request it awaits a Segment Trap Acknowledge. Subsequent violations occurring before the Trap Acknowledge is received are still detected and handled appropriately. During the Seament Trap Acknowledge cycle, the MMU drives one of its Address/Data lines High; the particular line selected is a function of the identification field of the mode register. After the Segment Trap has been acknowledged by the Z8001/3 CPU, the Violation Status Register should be read via the Special I/O commands in order to determine the cause of the trap. The Trap Type Register should also be reset so that subsequent traps will be recorded correctly. Figure 12. Segment Trap and Acknowledge Timing 2046-123 #### Pin Description **A<sub>8</sub>-A<sub>23</sub>.** Address Bus (outputs, active High, 3-state). These address lines are the 16 most-significant bits of the physical memory location. **AD8-AD15.** Address/Data Bus (inputs/outputs, active High, 3-state). These multiplexed address and data lines are used both for commands and for logical addresses intended for translation. **AS.** Address Strobe (input, active Low). The rising edge of $\overline{AS}$ indicates that $AD_0$ - $AD_{15}$ , $ST_0$ - $ST_3$ , $R/\overline{W}$ and $N/\overline{S}$ are valid. **CLK.** System Clock (input). CLK is the 5 V single-phase time-base input used for both the CPU and MMU. **CS.** Chip Select (input, active Low). This line selects an MMU for a control command. **DMASYNC.** DMA/Segment Number Synchronization Strobe (input, active High). A Low on this line indicates the segment number lines are 3-state; a High indicates the segment number is valid. It must always be High during CPU cycles and Low when the SN lines are invalid. If a DMA device does not use the MMU for address translation, the BUSACK signal from the CPU may be used as an input to DMASYNC. **DS.** Data Strobe (input, active Low). This line provides timing for the data transfer between the MMU and the Z8001/3 CPU. **N/S.** Normal/System Mode (input, Low = System Mode). N/S indicates the Z8001/3 CPU or Z8016 DMA is in the Normal or System Mode. The signal can also be used to switch between MMUs during different phases of an instruction. Reserved. Do not connect. **RESET.** Reset (input, active Low). A Low on this line resets the MMU. $\mathbf{R}/\overline{\mathbf{W}}$ . Read/Write (input, Low = write). R/ $\overline{\mathbf{W}}$ indicates the Z8001/3 CPU or Z8016 DMA is reading from or writing to memory or the MMU. **SEGT.** Segment Trap Request (output, active Low, open drain). The MMU interrupts the Z8001/3 CPU with a Low on this line when the MMU detects an access violation or write warning. **SN<sub>0</sub>-SN<sub>6</sub>.** Segment Number (inputs, active High). The SN<sub>0</sub>-SN<sub>5</sub> lines are used to address one of 64 segments in the MMU; SN<sub>6</sub> is used to selectively enable the MMU. **ST<sub>0</sub>-ST<sub>3</sub>.** Status (inputs, active High). These lines specify the Z8001/3 CPU status. | ST3-ST0 | Definition | |----------|--------------------------------------------| | 0 0 0 0, | 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 | Status memory request (EPU) | | 1100 | Instruction space access | | 1101 | Instruction fetch, first word | | 1110 | Extension processor transfer | | 1111 | Bus Lock, Data Memory Request (Z8003 only) | Figure 13. The MMU in a Z8001 System 2046-052 # Pin Description (Continued) **SUP**. Suppress (output, active Low, open drain). This signal is asserted during the cur- rent bus cycle when any access violation except write warning occurs. #### Absolute Maximum Ratings Voltages on all inputs and outputs with respect to GND.....-0.3 V to +7.0 V 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 characteristics below apply for the following standard test conditions, unless otherwise noted. All voltages are referenced to GND. Positive current flows into the referenced pin. Standard conditions are as follows: $\blacksquare$ GND = 0 V ■ $0^{\circ}$ C $\leq T_{A} \leq +70^{\circ}$ C #### DC Characteristics | Symbol | Parameter | Min | <b>Max</b> V <sub>CC</sub> + 0.3 | Unit | Condition | | | | |-----------------|--------------------------------|----------------------|----------------------------------|------|-------------------------------------|--|--|--| | V <sub>CH</sub> | Clock Input High Voltage | V <sub>CC</sub> -0.4 | | V | Driven by External Clock Generator | | | | | $v_{CL}$ | Clock Input Low Voltage | -0.3 | 0.45 | V | Driven by External Clock Generator | | | | | $v_{IH}$ | Input High Voltage | 2.0 | V <sub>CC</sub> + 0.3 | V | | | | | | $V_{\rm IL}$ | Input Low Voltage | -0.3 | 0.8 | V | | | | | | V <sub>OH</sub> | Output High Voltage | 2.4 | | V | $I_{OH} = -250 \mu\text{A}$ | | | | | V <sub>OL</sub> | Output Low Voltage | | 0.4 | V | $I_{OL} = +2.0 \text{ mA}$ | | | | | I <sub>IL</sub> | Input Leakage | | ±10 | μΑ | $0.4 \le V_{IN} \le +2.4 \text{ V}$ | | | | | IOL | Output Leakage | | ±10 | μΑ | $0.4 \le V_{IN} \le +2.4 \text{ V}$ | | | | | I <sub>CC</sub> | V <sub>CC</sub> Supply Current | | 300 | mA | | | | | NOTE The on-chip back-bias voltage generator takes approximately 20 ms to pump the back-bias voltage to -2 5 V after the power has been turned on the performance of the Z8010 Z-MMU is not guaranteed during this period. #### Ordering Information | Product<br>Number | Package/<br>Temp | Speed | Description | Product<br>Number | Package/<br>Temp | Speed | Description | |-------------------|------------------|---------|----------------|-------------------|------------------|---------|----------------| | Z8010 | CE | 4.0 MHz | Z-MMU (48-pin) | Z8010 <b>A</b> | CE | 6.0 MHz | Z-MMU (48-pin) | | Z8010 | CM | 4.0 MHz | Same as above | Z8010A | CM | 6.0 MHz | Same as above | | Z8010 | CMB | 4.0 MHz | Same as above | Z8010A | CMB | 6.0 MHz | Same as above | | Z8010 | CS | 4.0 MHz | Same as above | Z8010A | CS | 6.0 MHz | Same as above | | Z8010 | PE | 4.0 MHz | Same as above | Z8010 <b>A</b> | PE | 6.0 MHz | Same as above | | Z8010 | PS | 4.0 MHz | Same as above | Z8010A | PS | 6.0 MHz | Same as above | NOTES C = Ceramic, P = Plastic, E = -40 $^{\circ}C$ to +85 $^{\circ}C$ , M = -55 $^{\circ}C$ to +125 $^{\circ}C$ , MB = -55 $^{\circ}C$ to +125 $^{\circ}C$ with MIL-STD-883 Class B processing, S = 0 $^{\circ}C$ to +70 $^{\circ}C$ | AC Characteristics | | 4 1 | Z8010<br>4 MHz | | Z8010<br>6 MHz | | Z8010<br>10 MHz | | | |--------------------|----------------|-----------------------------------------------------------------------------|-----------------------------------------|-----------------------------|----------------|-------------------|-----------------|-----------------------------|---------| | No. | Symbol | Parameter | Min | Max | Min | Max | Min | Мах | Notes*† | | 1 | TcC | Clock Cycle Time | 250 | | 165 | | 100 | | | | 2 | TwCh | Clock Width (High) | 105 | | 70 | | 40 | | | | 3 | TwCl | Clock Width (Low) | 105 | | 70 | | 40 | | | | 4 | TfC | Clock Fall Time | | 20 | | 10 | | 10 | | | 5- | - TrC | — Clock Rise Time | | 20 | | <del></del> 15 | | <del></del> 10 | | | 6 | TdDSA(RDv) | DS ↓ (Acknowledge) to Read Data<br>Valid Delay | | 100 | | 80 | | 60 | 1 | | 7 | TdDSA(RDf) | DS † (Acknowledge) to Read Data<br>Float Delay | | 75 | | 60 | | 45 | 1 | | 8 | TdDSR(RDv) | DS ↓ (Read) to AD Output Driven Delay | | 100 | | 80 | | 60 | 1 | | 9 | TdDSR(RDf) | DS † (Read) to Read Data Float Delay | | 75 | 60 | 60 | | 45 | 1 | | 10 - | - TdC(WDv) | — CLK † to Write Data Valid Delay——— | | 125 | ******* | 80 | | <del> 50</del> | | | 11 | ThC(WDn) | CLK ↓ to Write Data Not Valid<br>Hold Time | 30 | | 20 | | 10 | | | | 12 | TwAS | Address Strobe Width | 60 | | 50 | | 30 | | | | 13 | TsOFF(AS) | Offset Valid to AS: † Setup Time | 45 | | 35 | | 20 | | | | 14 | ThAS(OFFn) | ĀS ↑ to Offset Not Valid Hold Time | 60 | | 40 | | 20 | | | | 15 — | - TdAS(C) | — AS↓to CLK↑Delay———— | —110 — | | <del> 90</del> | | 50 | | | | 16 | TdDS(AS) | DS ↑ to AS ↓ Delay | 50 | | 30 | | 15 | | | | 17 | TdAS(DS) | ĀS ↑ to DS ↓ Delay | 50 | | 40 | | 30 | | | | 18 | TsSN(C) | SN Data Valid to CLK † Setup Time | 100 | | 40 | | 20 | | | | 19 | ThC(SNn) | CLK † to SN Data not Valid Hold Time | 0 | | 0 | | 0 | | | | 20 — | - TdDMAS(C) - | — DMASYNC Valid to CLK † Delay | — 120 — | ~ | 80 | | <del></del> 60 | | | | 21 | TdSTNR(AS) | Status (ST <sub>0</sub> -ST <sub>3</sub> , N/S, R/W) Valid to<br>AS † Delay | 50 | | 30 | | 10 | | | | 22 | TdC(DMA) | CLK ↑ to DMASYNC ↓ Delay | 20 | | 15 | | 10 | | | | 23 | TdST(C) | Status (ST <sub>0</sub> -ST <sub>3</sub> ) Valid to CLK † Delay | 100 | | 60 | | 30 | | | | 24 | TdDS(STn) | DS 1 to Status Not Valid Delay | 0 | | 0 | | 0 | | | | 25 — | TdOFF(Av) | Offset Valid to Address Output Valid Delay | | <del></del> 175 <del></del> | | 90 | | 60 | ——1— | | 26 | TdST(Ad) | Status Valıd to Address Output<br>Drıven Delay | | 155 | | 75 | | 45 | 1 | | 27 | TdDS(Af) | DS † to Address Output Float Delay | | 160 | | 130 | | 100 | 1 | | 28 | TdAS(Ad) | ĀS ↓ to Addres Output Driven Delay | | 145 | | 70 | | 40 | 1 | | 29 | TdC(Av) | CLK † to Address Output Valid Delay | | 255 | | 155 | | 100 | 1 | | 30 — | - TdAS(SEGT) - | — AS ↑ to SEGT ↓ Delay | | <del></del> 160 <del></del> | | <del>-</del> 100- | | 60 | 1,2 | | 31 | TdC(SEGT) | CLK † to SEGT † Delay | | 300 | | 200 | | 100 | 1,2 | | 32 | TdAS(SUP) | ĀS † to SUP ↓ Delay | | 150 | | 90 | | 55 | 1,2 | | 33 | TdDS(SUP | DS † to SUP † Delay | | 155 | | 100 | | 60 | 1,2 | | 34 | TsCS(AS) | Chip Select Input Valid to $\overline{AS}$ † Setup Time | 10 | | 10 | | 10 | | , | | 35 — | - ThAS(CSn) | — AS 1 to Chip Select Input Not Valid——<br>Hold Time | 60 | | 40 | | 20 | | - | | 36 | TdAS(C) | $\overline{\mathrm{AS}}$ † to CLK † Delay | 0 | | 0 | | 0 | | | | 37 | TsCS(RST) | Chip Select Input Valid to RESET † Setup Time | 150 | | 100 | | 60 | | | | 38 | ThRST(CSn) | RESET † to Chip Select Input Not<br>Valid Hold Time | 0 | | 0 | | 0 | | | | 39 | TwRST | RESET Width (Low) | 2TcC | | 2TcC | | 2TcC | | | | 40 — | - TdC(RDv) | — CLK † to Read Data Valid Delay ——— | *************************************** | <del>460</del> | | 300 | | <del></del> 190 <del></del> | | | | TADG(C) | DS † to CLK † Delay | 30 | | 20 | | 10 | | | | 41 | TdDS(C) | DO I TO CLY I Delay | 50 | | 20 | | 10 | | | #### NOTES - NOIES 1. 50 pF Load 2 2 2K Pull-up 4 All 6 MHz timings are preliminary - † Units in nanoseconds (ns) ## Z8015 Z8000™ PMMU Paged Memory Management Unit ### Product Brief #### June 1982 #### **Features** - PMMU architecture supports paged, virtual memory systems for the Z8003 VMPU. - Dynamic page relocation makes software addresses independent of physical memory addresses. - Memory-management features provide access validation to protect memory areas from unauthorized or unintentional access, and a write-warning indicator to prevent stack overflow. #### June 1902 - 64 pages, each 2048 bytes in length, can be mapped into a total physical address space of 16 megabytes. - PMMU can be used to implement systems with larger or smaller page sizes. - The number of accessible pages can be increased by using multiple PMMUs to support separate translation tables for each Z8003 VMPU address space. #### Description The Z8015 Paged Memory Management Unit (PMMU) is designed to support a paged virtual memory system for the Z8003 Virtual Memory Processor Unit (VMPU). Although designed primarily for the Z8003, the PMMU can also be used to support the other CPUs in the Z8000 Family. Memory-management features allow access validation for memory protection and a write-warning to prevent stack overflow. An instruction abort for accesses to pages not in main memory allows restarting of instructions in the Z8003 VMPU. Each PMMU can manage a basic memory area of sixty-four 2048-byte, fixed-size pages. The VMPU's 8M byte logical address space is translated by the PMMU into a 16M byte physical address space. Page size can be easily changed and multiple PMMUs can be combined to support more pages. The PMMU is produced in a 64-pin package. Figure 1. Pin Functions 8074-001 # Functional Description The Z8015 Paged Memory Management Unit (PMMU) manages the 8M byte addressing spaces of the Z8003 VMPU. The PMMU provides dynamic page relocation as well as numerous memory protection features. Dynamic page relocation makes user software addresses independent of the physical memory addresses, thereby freeing the user from specifying where information is located in the physical memory. It also provides a flexible, efficient method for supporting multiprogramming systems. The PMMU uses a content-addressable translation table to transform the 23-bit logical address output from the VMPU into a 24-bit address for the physical memory. (Only logical memory addresses go to a PMMU for translation; I/O addresses and data bypass this component.) The PMMU is designed to use a memory page 2048 bytes in length. Multiple PMMUs can be used to support more than 64 pages within a given address space. In addition, PMMUs can be used to accommodate separate translation tables for system and normal operating modes. The basic page length of 2048 bytes can be increased or decreased using a minimal amount of external circuitry. The PMMU is designed to implement a paged virtual memory using the Z8003 VMPU. The PMMU saves sufficient information to recover from an instruction abort due to a page fault. The instruction can be restarted after the required information has been placed in primary memory and the PMMU's descriptors updated to allow address translation to the selected primary memory locations. As an aid in implementing efficient paging algorithms, the PMMU provides Changed and Referenced flags for each page. The Changed flag indicates that a page has been altered and hence must be copied to secondary storage before that physical memory can be used for another page. The Referenced flag can be used to determine which pages have not been accessed by an executing program. This information is useful in a variety of memorymanagement algorithms. PMMU memory protection features safeguard memory areas from unauthorized or unintended access by associating special access restirctions with each page. A page is assigned a number of attributes when its descriptor is initially entered into the PMMU. Pages are protected by modes of permitted use, such as read only, system only, and execute only. The Valid flag indicates whether or not a descriptor has been initialized. When a memory reference is made, these attributes are checked against the status information supplied by the VMPU. If a mismatch occurs, the instruction is aborted, a Trap Request signal is generated and the VMPU is interrupted. The VMPU then checks the status registers of the PMMU to determine the cause of the abort. The PMMU is controlled by 20 special I/O instructions, which can be issued from the VMPU in system mode only. With these instructions, system software can assign program pages to arbitrary memory locations, restrict the use of pages, and monitor whether pages have been read or written. The PMMU has two operating modes: an address translation mode in which addresses are translated automatically as they are received, and a command mode, during which specific registers in the PMMU are accessed using special I/O commands. #### Segmented Addressing and Address Translation The addresses manipulated by the programmer, used by instructions, and output by the VMPU are called logical addresses. The PMMU translates logical addresses into the physical addresses required for accessing the memory. The 23-bit logical addresses output by the VMPU divide an 8M byte addressing space into 128 segments of up to 64K bytes each. A 23-bit segmented address consists of a 7-bit segment number and a 16-bit offset used to address any byte relative to the beginning of the segment. The two parts of the segmented address (segment number and offset) can be manipulated separately. The PMMU divides physical memory into 2048-byte pages. Pages are assumed to be allocated in memory on 2048-byte boundaries so that the 11 low-order bits of the starting location of each page are always equal to zero. Segments in a virtual memory system can consist of pages that need not be in physical storage. Those segment pages in main memory need not be contiguous. Segments can have a variable number of pages. Any page can be designated so that writes into the lowest numbered 128 bytes generate a warning trap without an instruction abort. If such a page is used as the last page of the system stack, the warning trap can be used to allocate another page to the stack segment and prevent a stack overflow error. ### **Z8016 Z8000™ DTC Direct Memory Access Transfer Controller** ### **Product Brief** #### June 1982 #### Features - Memory-to-peripheral transfer up to 2.66M bytes/second at 4 MHz. - Memory-to-memory transfer up to 1.33M bytes/second at 4 MHz. - Two fully independent, multi-function channels. - Masked data pattern matching for search and search-and-transfer operations. - Funneling option permits mixing of byte and word data during transfer operations. - May be operated in logical address space in - conjunction with the Z8010 Memory Management Unit. - Software- or hardware-controlled Wait state insertion. - Programmable chaining operation provides automatic loading of control parameters from memory by each channel. - Automatic loading from base registers on each channel for efficient repetitive operations. - Z-BUS daisy-chain interrupt hierarchy and bus-request structure. #### Description The Z8016 DMA Transfer Controller (DTC) is a high-performance data transfer device designed to match the power and addressing capability of the Z8000 CPUs. In addition to providing block data transfer capability between memory and peripherals, each of the DTC's two channels can perform peripheral-toperipheral and memory-to-memory transfers. A special Search mode of operation compares data read from a memory or peripheral source Figure 1. Pin Functions Figure 2. Pin Assignments **Description** (Continued) with the contents of a pattern register. A search can be performed concurrently with transfers or as an operation in itself. For all operations (Search, Transfer, and Transfer-and-Search), the DTC can operate in either Flowthrough or Flyby Transfer mode. In the Flowthrough mode data is stored temporarily within the DTC on its way from source to destination. In this mode transfers can be made between a word-oriented memory and a byte-oriented peripheral through the bidirectional byte-word funneling option. In Flyby mode, data is transferred in a single step (from source to destination), thus providing extremely high throughput. The Z8016 DTC takes full advantage of the Z8000 memory management scheme by interfacing directly to the Z8010 Memory Management Unit (MMU). In this configuration, 8M bytes of logical address range are provided for each CPU address space. Alternatively, the Z8016 DTC can operate independently of the Z8010 MMU and directly address up to 16M bytes of physical address space. In addition to providing a hardware WAIT input to accommodate different memory or peripheral speeds, the Z8016 DTC allows the user to select the automatic insertion of 0, 1, 2, or 4 Wait states for either source or destination addresses. Alternatively, the user can disable the WAIT input pin function and use these software programmed Wait states exclusively. High throughput and powerful transfer options are of limited usefulness if a DMA device requires frequent reloading by the host CPU. The Z8016 DTC minimizes CPU involve- ment by allowing each channel to load its control registers from memory automatically when a DMA operation is complete. By loading the address of subsequent control parameters as part of this operation, command chaining is accomplished. The only action required of the CPU is to load the address of the control parameter table into the channel's Chain Address register and then issue a "Start Chain" command. Some DMA applications may transfer data continuously between the same two locations. To service these repetitive DMA operations, base registers are provided on each channel that re-initialize the current source and destination address registers. This remitialization eliminates the need for reloading registers from memory tables. The Z8016 DTC is directly Z-BUS compatible and operates within the Z8000 daisy-chain vectored-priority interrupt scheme. Additionally, a demand interleave operation is supported which allows the DTC to surrender the system bus to the external system or to alternate between internal channels. This capability allows for virtually parallel operations between dual channels or between a DTC channel and the CPU. The DTC may be used to provide a central DMA function in close cooperation with the CPU or to provide dispersed DMA operations in conjunction with a wide variety of Z8000 Family peripheral controllers. The Z8016 DTC is packaged in a 48-pin DIP and uses a single +5 V power supply. ### Z8030 Z8000<sup>™</sup> Z-SCC Serial Communications Controller ### Product Specification June 1982 #### **Features** - Two independent, 0 to 1M bit/second, full-duplex channels, each with a separate crystal oscillator, baud rate generator, and Digital Phase-Locked Loop for clock recovery. - Multi-protocol operation under program control; programmable for NRZ, NRZI, or FM data encoding. - Asynchronous mode with five to eight bits and one, one and one-half, or two stop bits per character; programmable clock factor; break detection and generation; parity, overrun, and framing error detection. - Synchronous mode with internal or external character synchronization on one or two synchronous characters and CRC generation and checking with CRC-16 or CRC-CCITT preset to either 1s or 0s. - SDLC/HDLC mode with comprehensive frame-level control, automatic zero insertion and deletion, I-field residue handling, abort generation and detection, CRC generation and checking, and SDLC Loop mode operation. - Local Loopback and Auto Echo modes. #### General Description The Z8030 Z-SCC Serial Communications Controller is a dual-channel, multi-protocol data communications peripheral designed for use with the Zilog Z-Bus. The Z-SCC functions as a serial-to-parallel, parallel-to-serial converter/controller. The Z-SCC can be software-configured to satisfy a wide variety of serial communications applications. The device contains a variety of new, sophisticated internal functions including on-chip baud rate generators, Digital Phase-Locked Loops, and crystal oscillators that dramatically reduce the need for external logic. Figure 1. Pin Functions Figure 2. Pin Assignments # General Description (Continued) The Z-SCC handles asynchronous formats, synchronous byte-oriented protocols such as IBM Bisync, and Synchronous bit-oriented protocols such as HDLC and IBM SDLC. This versatile device supports virtually any serial data transfer application (cassette, diskette, tape drives, etc.). The device can generate and check CRC codes in any Synchronous mode and can be programmed to check data integrity in various modes. The Z-SCC also has facilities for modem controls in both channels. In applications where these controls are not needed, the modem controls can be used for general-purpose I/O. The Z-Bus daisy-chain interrupt hierarchy is also supported—as is standard for Zilog peripheral components. The Z8030 Z-SCC is packaged in a 40-pin ceramic DIP and uses a single +5 V power supply. #### Pin Description The following section describes the pin functions of the Z-SCC. Figures 1 and 2 detail the respective pin functions and pin assignments. **AD<sub>0</sub>-AD<sub>7</sub>.** Address/Data Bus (bidirectional, active High, 3-state). These multiplexed lines carry register addresses to the Z-SCC as well as data or control information to and from the Z-SCC. $\overline{\textbf{AS}}$ . Address Strobe (input, active Low). Addresses on AD<sub>0</sub>-AD<sub>7</sub> are latched by the rising edge of this signal. $\overline{\textbf{CS_0}}$ . Chip Select 0 (input, active Low). This signal is latched concurrently with the addresses on AD<sub>0</sub>-AD<sub>7</sub> and must be active for the intended bus transaction to occur. **CS<sub>1</sub>.** Chip Select 1 (input, active High). This second select signal must also be active before the intended bus transaction can occur. CS<sub>1</sub> must remain active throughout the transaction. CTSA. CTSB. Clear to Send (inputs, active Low). If these pins are programmed as Auto Enables, a Low on the inputs enables their respective transmitters. If not programmed as Auto Enables, they may be used as general-purpose inputs. Both inputs are Schmitt-trigger buffered to accommodate slow rise-time inputs. The Z-SCC detects pulses on these inputs and can interrupt the CPU on both logic level transitions. **DCDA. DCDB.** Data Carrier Detect (inputs, active Low). These pins function as receiver enables if they are programmed for Auto Enables; otherwise they may be used as general-purpose input pins. Both pins are Schmitt-trigger buffered to accommodate slow rise-time signals. The Z-SCC detects pulses on these pins and can interrupt the CPU on both logic level transitions. $\overline{\text{DS.}}$ Data Strobe (input, active Low). This signal provides timing for the transfer of data into and out of the Z-SCC. If $\overline{\text{AS}}$ and $\overline{\text{DS}}$ coincide, this is interpreted as a reset. DTR/REQA, DTR/REQB. Data Terminal Ready/Request (outputs, active Low). These outputs follow the state programmed into the DTR bit. They can also be used as general-purpose outputs or as Request lines for a DMA controller. **IEI.** Interrupt Enable In (input, active High). IEI is used with IEO to form an interrupt daisy chain when there is more than one interrupt-driven device. A High IEI indicates that no other higher priority device has an interrupt under service or is requesting an interrupt. **IEO.** Interrupt Enable Out (output, active High). IEO is High only if IEI is High and the CPU is not servicing a Z-SCC interrupt or the Z-SCC is not requesting an interrupt (Interrupt Acknowledge cycle only). IEO is connected to the next lower priority device's IEI input and thus inhibits interrupts from lower priority devices. **INT.** Interrupt Request (output, open-drain, active Low). This signal is activated when the Z-SCC requests an interrupt. **PCLK.** Clock (input). This is the master Z-SCC clock used to synchronize internal signals. PCLK is not required to have any phase relationship with the master system clock, although the frequency of this clock must be at least 90% of the CPU clock frequency for a Z8000. PCLK is a TTL level signal. **RxDA**, **RxDB**. Receive Data (inputs, active High). These input signals receive serial data at standard TTL levels. RTxCA, RTxCB. Receive/Transmit Clocks (inputs, active Low). These pins can be programmed in several different modes of operation. In each channel, RTxC may supply the receive clock, the transmit clock, the clock for the baud rate generator, or the clock of the Digital Phase-Locked Loop. These pins can also be programmed for use with the respective SYNC pins as a crystal oscillator. The receive clock may be 1, 16, 32, or 64 times the data rate in Asynchronous modes. RTSA, RTSB. Request To Send (outputs, active Low). When the Request To Send (RTS) bit in Write Register 5 (Figure 11) is set, the # Pin Description (Continued) RTS signal goes Low. When the RTS bit is reset in the Asynchronous mode and Auto Enable is on, the signal goes High after the transmitter is empty. In Synchronous mode or in Asynchronous mode with Auto Enable off, the RTS pin strictly follows the state of the RTS bit. Both pins can be used as general-purpose outputs. $\mathbf{R}/\overline{\mathbf{W}}$ . Read/Write (input). This signal specifies whether the operation to be performed is a read or a write. **SYNCA. SYNCB.** Synchronization (inputs or outputs, active Low). These pins can act either as inputs, outputs, or part of the crystal oscillator circuit. In the Asynchronous Receive mode (crystal oscillator option not selected), these pins are inputs similar to $\overline{\text{CTS}}$ and $\overline{\text{DCD}}$ . In this mode, transitions on these lines affect the state of the Synchronous/Hunt status bits in Read Register 0 (Figure 10) but have no other function. In External Synchronization mode with the crystal oscillator not selected, these lines also act as inputs. In this mode, SYNC must be driven Low two receive clock cycles after the last bit in the synchronous character is received. Character assembly begins on the rising edge of the receive clock immediately preceding the activation of SYNC. In the Internal Synchronization mode (Monosync and Bisync) with the crystal oscillator not selected, these pins act as outputs and are active only during the part of the receive clock cycle in which synchronous characters are recognized. The synchronous condition is not latched, so these outputs are active each time a synchronization pattern is recognized (regardless of character boundaries). In SDLC mode, these pins act as outputs and are valid on receipt of a flag. **TxDB.** TxDB. Transmit Data (outputs, active High). These output signals transmit serial data at standard TTL levels. TRXCA, TRXCB. Transmit/Receive Clocks (inputs or outputs, active Low). These pins can be programmed in several different modes of operation. TRXC may supply the receive clock or the transmit clock in the input mode or supply the output of the Digital Phase-Locked Loop, the crystal oscillator, the baud rate generator, or the transmit clock in the output mode. W/REQA, W/REQB. Wait/Request (outputs, open-drain when programmed for a Wait function, driven High or Low when programmed for a Request function). These dual-purpose outputs may be programmed as Request lines for a DMA controller or as Wait lines to synchronize the CPU to the Z-SCC data rate. The reset state is Wait. #### Functional Description The functional capabilities of the Z-SCC can be described from two different points of view: as a data communications device, it transmits and receives data in a wide variety of data communications protocols; as a Z8000 Family peripheral, it interacts with the Z8000 CPU and other peripheral circuits and is part of the Z-Bus interrupt structure. **Data Communications Capabilities.** The Z-SCC provides two independent full-duplex channels programmable for use in any common Asynchronous or Synchronous datacommunication protocol. Figure 3 and the following description briefly detail these protocols. Asynchronous Modes. Transmission and reception can be accomplished independently on each channel with five to eight bits per character, plus optional even or odd parity. The transmitters can supply one, one-and-ahalf, or two stop bits per character and can provide a break output at any time. The receiver break-detection logic interrupts the CPU both at the start and at the end of a received break. Reception is protected from spikes by a transient spike-rejection mechanism that checks the signal one-half a Figure 3. Some Z-SCC Protocols bit time after a Low level is detected on the receive data input (RxDA or RxDB in Figure 1). If the Low does not persist (as in the case of a transient), the character assembly process does not start. Framing errors and overrun errors are detected and buffered together with the partial character on which they occur. Vectored interrupts allow fast servicing or error conditions using dedicated routines. Furthermore, a built-in checking process avoids the interpretation of a framing error as a new start bit: a framing error results in the addition of one-half a bit time to the point at which the search for the next start bit begins. The Z-SCC does not require symmetric transmit and receive clock signals—a feature allowing use of the wide variety of clock sources. The transmitter and receiver can handle data at a rate of 1, 1/16, 1/32, or 1/64 of the clock rate supplied to the receive and transmit clock inputs. In Asynchronous modes, the SYNC pin may be programmed as an input used for functions such as monitoring a ring indicator. Synchronous Modes. The Z-SCC supports both byte-oriented and bit-oriented synchronous communication. Synchronous byte-oriented protocols can be handled in several modes, allowing character synchronization with a 6-bit or 8-bit synchronous character (Monosync), any 12-bit synchronization pattern (Bisync), or with an external synchronization signal. Leading synchronous characters can be removed without interrupting the CPU. Five- or 7-bit synchronous characters are detected with 8- or 16-bit patterns in the Z-SCC by overlapping the larger pattern across multiple incoming synchronous characters as shown in Figure 4. CRC checking for Synchronous byteoriented modes is delayed by one character time so that the CPU may disable CRC checking on specific characters. This permits the implementation of protocols such as IBM Bisync. Both CRC-16 ( $X^{16} + X^{15} + X^2 + 1$ ) and CCITT ( $X^{16} + X^{12} + X^5 + 1$ ) error checking polynomials are supported. Either polynomial may be selected in all Synchronous modes. Users may preset the CRC generator and checker to all 1s or all 0s. The Z-SCC also provides a feature that automatically transmits CRC data when no other data is available for transmission. This allows for high speed transmissions under DMA control, with no need for CPU intervention at the end of a message. When there is no data or CRC to send in Synchronous modes, the transmitter inserts 6-, 8-, or 16-bit synchronous characters, regardless of the programmed character length. The Z-SCC supports Synchronous bitoriented protocols, such as SDLC and HDLC, by performing automatic flag sending, zero insertion, and CRC generation. A special command can be used to abort a frame in transmission. At the end of a message, the Z-SCC automatically transmits the CRC and trailing flag when the transmitter underruns. The transmitter may also be programmed to send an idle line consisting of continuous flag characters or a steady marking condition. If a transmit underrun occurs in the middle of a message, an external/status interrupt warns the CPU of this status change so that an abort may be issued. The Z-SCC may also be programmed to send an abort itself in case of an underrun, relieving the CPU of this task. One to eight bits per character can be sent, allowing reception of a message with no prior information about the character structure in the information field of a frame. The receiver automatically acquires synchronization on the leading flag of a frame in SDLC or HDLC and provides a synchronization signal on the SYNC pin (an interrupt can also be programmed). The receiver can be programmed to search for frames addressed by a single byte (or four bits within a byte) of a user-selected address or to a global broadcast address. In this mode, frames not matching either the user-selected or broadcast address are ignored. The number of address bytes can be extended under software control. For receiving data, an interrupt on the first received character, or an interrupt on every character, or on special condition only (endof-frame) can be selected. The receiver automatically deletes all 0s inserted by the transmitter during character assembly. CRC is also calculated and is automatically checked to validate frame transmission. At the end of transmission, the status of a received frame is available in the status registers. In SDLC mode, the Z-SCC must be programmed to use the SDLC CRC polynomial, but the generator and checker may be preset to all 1s or all 0s. Figure 4. Detecting 5- or 7-Bit Synchronous Characters 2042-109 The CRC is inverted before transmission and the receiver checks against the bit pattern 0001110100001111. NRZ, NRZI or FM coding may be used in any lx mode. The parity options available in Asynchronous modes are available in Synchronous modes. The Z-SCC can be conveniently used under DMA control to provide high-speed reception or transmission. In reception, for example, the Z-SCC can interrupt the CPU when the first character of a message is received. The CPU then enables the DMA to transfer the message to memory. The Z-SCC then issues an end-of-frame interrupt and the CPU can check the status of the received message. Thus, the CPU is freed for other service while the message is being received. The CPU may also enable the DMA first and have the Z-SCC interrupt only on end-of-frame. This procedure allows all data to be transferred via the DMA. **SDLC Loop Mode.** The Z-SCC supports SDLC Loop mode in addition to normal SDLC. In an SDLC Loop, there is a primary controller station that manages the message traffic flow on the loop and any number of secondary stations. In SDLC Loop mode, the Z-SCC performs the functions of a secondary station while a Z-SCC operating in regular SDLC mode can act as a controller (Figure 5). A secondary station in an SDLC Loop is always listening to the messages being sent around the loop, and in fact must pass these messages to the rest of the loop by retransmitting them with a one-bit-time delay. The secondary station can place its own message on the loop only at specific times. The controller signals that secondary stations may transmit messages by sending a special character, called an EOP (End Of Poll), around the loop. The EOP character is the bit pattern 11111110. Because of zero insertion during messages, this bit pattern is unique and easily recognized. When a secondary station has a message to transmit and recognizes an EOP on the line, it Figure 5. An SDLC Loop changes the last binary 1 of the EOP to a 0 before transmission. This has the effect of turning the EOP into a flag sequence. The secondary station now places its message on the loop and terminates the message with an EOP. Any secondary stations further down the loop with messages to transmit can then append their messages to the message of the first secondary station by the same process. Any secondary stations without messages to send merely echo the incoming messages and are prohibited from placing messages on the loop (except upon recognizing an EOP). SDLC Loop mode is a programmable option in the Z-SCC. NRZ, NRZI, and FM coding may all be used in SDLC Loop mode. Baud Rate Generator. Each channel in the Z-SCC contains a programmable baud rate generator. Each generator consists of two 8-bit time constant registers that form a 16-bit time constant, a 16-bit down counter, and a flip-flop on the output producing a square wave. On startup, the flip-flop on the output is set in a High state, the value in the time constant register is loaded into the counter, and the counter starts counting down. The output of the baud rate generator toggles upon reaching 0, the value in the time constant register is loaded into the counter, and the process is repeated. The time constant may be changed at any time, but the new value does not take effect until the next load of the counter. The output of the baud rate generator may be used as either the transmit clock, the receive clock, or both. It can also drive the Digital Phase-Locked Loop (see next section). If the receive clock or transmit clock is not programmed to come from the $\overline{TRxC}$ pin, the output of the baud rate generator may be echoed out via the $\overline{TRxC}$ pin. The following formula relates the time constant to the baud rate (the baud rate is in bits/second and the BR clock period is in seconds): baud rate = $$\frac{1}{2 \text{ (time constant } + 2) \times \text{ (BR clock period)}}$$ Digital Phase-Locked Loop. The Z-SCC contains a Digital Phase-Locked Loop (DPLL) to recover clock information from a data stream with NRZI or FM encoding. The DPLL is driven by a clock that is nominally 32 (NRZI) or 16 (FM) times the data rate. The DPLL uses this clock, along with the data stream, to construct a clock for the data. This clock may then be used as the Z-SCC receive clock, the transmit clock, or both. For NRZI encoding, the DPLL counts the 32x clock to create nominal bit times. As the 32x clock is counted, the DPLL is searching the incoming data stream for edges (either 1 to 0 or 0 to 1). Whenever an edge is detected, the DPLL makes a count adjustment (during the next counting cycle), producing a terminal count closer to the center of the bit cell. For FM encoding, the DPLL still counts from 0 to 31, but with a cycle corresponding to two bit times. When the DPLL is locked, the clock edges in the data stream should occur between counts 15 and 16 and between counts 31 and 0. The DPLL looks for edges only during a time centered on the 15 to 16 counting transition. The 32x clock for the DPLL can be programmed to come from either the $\overline{RTxC}$ input or the output of the baud rate generator. The DPLL output may be programmed to be echoed out of the Z-SCC via the $\overline{TRxC}$ pin (if this pin is not being used as an input). Data Encoding The Z-SCC may be programmed to encode and decode the serial data in four different ways (Figure 6). In NRZ encoding, a 1 is represented by a High level and a 0 is represented by a Low level. In NRZI encoding, a l is represented by no change in level and a 0 is represented by a change in level. In FM1 (more properly, bi-phase mark) a transition occurs at the beginning of every bit cell. A l is represented by an additional transition at the center of the bit cell and a 0 is represented by no additional transition at the center of the bit cell. In FMO (bi-phase space), a transition occurs at the beginning of every bit cell. A 0 is represented by an additional transition at the center of the bit cell, and a l is represented by no additional transition at the center of the bit cell. In addition to these four methods, the Z-SCC can be used to decode Manchester (bi-phase level) data by using the DPLL in the FM mode and programming the receiver for NRZ data. Manchester encoding always produces a transition at the center of the bit cell. If the transition is 0 to 1, the bit is a 0. If the transition is 1 to 0 the bit is a 1. Auto Echo and Local Loopback. The Z-SCC is capable of automatically echoing everything it receives. This feature is useful mainly in Asynchronous modes, but works in Synchronous and SDLC modes as well. In Auto Echo mode, TxD is RxD. Auto Echo mode can be used with NRZI or FM encoding with no additional delay, because the data stream is not decoded before retransmission. In Auto Echo mode, the $\overline{CTS}$ input is ignored as a transmitter enable (although transitions on this input can still cause interrupts if programmed to do so). In this mode, the transmitter is actually bypassed and the programmer is responsible for disabling transmitter interrupts and WAIT/REQUEST on transmit. The Z-SCC is also capable of Local Loopback. In this mode TxD is RxD, just as in Auto Echo mode. However, in Local Loopback mode, the internal transmit data is tied to the internal receive data and RxD is ignored (except to be echoed out via TxD). The CTS and DCD inputs are also ignored as transmit and receive enables. However, transitions on these inputs can still cause interrupts. Local Loopback works in Asynchronous, Synchronous and SDLC modes with NRZ, NRZI or FM coding of the data stream. I/O Interface Capabilities. The Z-SCC offers the choice of Polling, Interrupt (vectored or nonvectored), and Block Transfer modes to transfer data, status, and control information to and from the CPU. The Block Transfer mode can be implemented under CPU or DMA control. **Polling.** All interrupts are disabled. Three status registers in the Z-SCC are automatically updated whenever any function is performed. For example, end-of-frame in SDLC mode sets a bit in one of these status registers. The idea behind polling is for the CPU to periodically read a status register until the register contents indicate the need for data to be transferred. Only one register needs to be Figure 6. Data Encoding Methods read; depending on its contents, the CPU either writes data, reads data, or continues. Two bits in the register indicate the need for data transfer. An alternative is a poll of the Interrupt Pending register to determine the source of an interrupt. The status for both channels resides in one register. Interrupts. The Z-SCC interrupt scheme conforms to the Z-Bus specification. When a Z-SCC responds to an Interrupt Acknowledge signal (INTACK) from the CPU, an interrupt vector may be placed on the A/D bus. This vector is written in WR2 and may be read in RR2A or RR2B (Figures 10 and 11). To speed interrupt response time, the Z-SCC can modify three bits in this vector to indicate status. If the vector is read in Channel A, status is never included; if it is read in Channel B, status is always included. Each of the six sources of interrupts in the Z-SCC (Transmit, Receive, and External/Status interrupts in both channels) has three bits associated with the interrupt source: Interrupt Pending (IP), Interrupt Under Service (IUS), and Interrupt Enable (IE). Operation of the IE bit is straightforward. If the IE bit is set for a given interrupt source, then that source can request interrupts. The exception is when the MIE (Master Interrupt Enable) bit in WR9 is reset and no interrupts may be requested. The IE bits are write only. The other two bits are related to the Z-Bus interrupt priority chain (Figure 7). As a Z-Bus peripheral, the Z-SCC may request an interrupt only when no higher priority device is requesting one, e.g., when IEI is High. If the device in question requests an interrupt, it pulls down INT. The CPU then responds with INTACK, and the interrupting device places the vector on the A/D bus. In the Z-SCC, the IP bit signals a need for interrupt servicing. When an IP bit is 1 and the IEI input is High, the $\overline{\rm INT}$ output is pulled Low, requesting an interrupt. In the Z-SCC, if the IE bit is not set by enabling interrupts, then the IP for that source can never be set. The IP is set two or three $\overline{\rm AS}$ cycles after the insing edges are required from the time an interrupt condition occurs until $\overline{\rm INT}$ is activated. The IP bits are readable in RR3A. The IUS bits signal that an interrupt request is being serviced. If an IUS is set, all interrupt sources of lower priority in the Z-SCC and external to the Z-SCC are prevented from requesting interrupts. The internal interrupt sources are inhibited by the state of the internal daisy chain, while lower priority devices are inhibited by the IEO output of the Z-SCC being pulled Low and propagated to subsequent peripherals. An IUS bit is set during an Interrupt Acknowledge cycle if there are no higher priority devices requesting interrupts. There are three types of interrupts: Transmit, Receive, and External/Status. Each interrupt type is enabled under program control with Channel A having higher priority than Channel B, and with Receiver, Transmit, and External/Status interrupts prioritized in that order within each channel. When the Transmit interrupt is enabled, the CPU is interrupted when the transmit buffer becomes empty. (This implies that the transmitter must have had a data character written into it so that it can become empty.) When enabled, the receiver can interrupt the CPU in one of three ways: - Interrupt on First Receive Character or Special Receive Condition. - Interrupt on All Receive Characters or Special Receive Condition. - Interrupt on Special Receive Condition Only. Interrupt on First Character or Special Condition and Interrupt on Special Condition Only are typically used with the Block Transfer mode. A Special Receive Condition is one of the following: receiver overrun, framing error in Asynchronous mode, end-of-frame in SDLC mode and, optionally, a parity error. The Special Receive Condition interrupt is different from an ordinary receive character available interrupt only in the status placed in the vector during the Interrupt Acknowledge cycle. In Interrupt on First Receive Character, an interrupt can occur from Special Receive Conditions any time after the first receive character interrupt. The main function of the External/Status interrupt is to monitor the signal transitions of the CTS, DCD, and SYNC pins; however, an External/Status interrupt is also caused by a Transmit Underrun condition, or a zero count Figure 7. Z-BUS Interrupt Schedule in the baud rate generator, or by the detection of a Break (Asynchronous mode), Abort (SDLC mode) or EOP (SDLC Loop mode) sequence in the data stream. The interrupt caused by the Abort or EOP has a special feature allowing the Z-SCC to interrupt when the Abort or EOP sequence is detected or terminated. This feature facilitates the proper termination of the current message, correct initialization of the next message, and the accurate timing of the Abort condition in external logic in SDLC mode. In SDLC Loop mode, this feature allows secondary stations to recognize the wishes of the primary station to regain control of the loop during a poll sequence. **CPU/DMA Block Transfer.** The Z-SCC provides a Block Transfer mode to accommodate CPU block transfer functions and DMA controllers. The Block Transfer mode uses the WAIT/REQUEST output in conjunction with the Wait/Request bits in WR1. The WAIT/REQUEST output can be defined under software control as a WAIT line in the CPU Block Transfer mode or as a REQUEST line in the DMA Block Transfer mode. To a DMA controller, the Z-SCC $\overline{\text{REQUEST}}$ output indicates that the Z-SCC is ready to transfer data to or from memory. To the CPU, the $\overline{\text{WAIT}}$ line indicates that the Z-SCC is not ready to transfer data, thereby requesting that the CPU extend the I/O cycle. The $\overline{\text{DTR}}/\overline{\text{REQUEST}}$ line allows full-duplex operation under DMA control. #### Architecture The Z-SCC internal structure includes two full-duplex channels, two baud rate generators, internal control and interrupt logic, and a bus interface to the Zilog Z-Bus. Associated with each channel are a number of read and write registers for mode control and status information, as well as logic necessary to interface to modems or other external devices (Figure 8). The logic for both channels provides Figure 8. Block Diagram of Z-SCC Architecture Figure 9. Data Path Architecture (Continued) formats, synchronization, and validation for data transferred to and from the channel interface. The modem control inputs are monitored by the control logic under program control. All of the modem control signals are generalpurpose in nature and can optionally be used for functions other than modem control. The register set for each channel includes ten control (write) registers, two sync character (write) registers, and four status (read) registers. In addition, each baud rate generator has two (read/write) registers for holding the time constant that determines the baud rate. Finally, associated with the interrupt logic is a write register for the interrupt vector accessible through either channel, a write-only Master Interrupt Control register and three read registers; one containing the vector with status infomation (Channel B only), one containing the vector without status (Channel A only), and one containing the Interrupt Pending bits (Channel A only). The registers for each channel are designated as follows: WR0-WR15 — Write Registers 0 through 15. RRO-RR3, RR10, RR12, RR13, RR15 — Read Registers 0 through 3, 10, 12, 13, 15. Table 1 lists the functions assigned to each read or write register. The Z-SCC contains only one WR2 and WR9, but they can be accessed by either channel. All other registers are paired (one for each channel). Data Path. The transmit and receive data path illustrated in Figure 9 is identical for both channels. The receiver has three 8-bit buffer registers in an FIFO arrangement, in addition to the 8-bit receive shift register. This scheme creates additional time for the CPU to service an interrupt at the beginning of a block of high speed data. Incoming data is routed through one of several paths (data or CRC) depending on the selected mode (the character length in Asynchronous modes also determines the data path). The transmitter has an 8-bit Transmit Data buffer register loaded from the internal data bus and a 20-bit Transmit Shift register that can be loaded either from the synchronous character registers or from the Transmit Data register. Depending on the operational mode, outgoing data is routed through one of four main paths before it is transmitted from the Transmit Data output (TxD) | Read | Register | Functions | |------|----------|-----------| | | | | | RRO | Transmit/Receive buffer status and External status | |------|-----------------------------------------------------------------------------------------| | RR1 | Special Receive Condition status | | RR2 | Modified interrupt vector (Channel B only) Unmodified interrupt vector (Channel A only) | | RR3 | Interrupt Pending bits (Channel A only) | | RR8 | Receive buffer | | RR10 | Miscellaneous status | | RR12 | Lower byte of baud rate generator time constant | | RR13 | Upper byte of baud rate generator time constant | | RR15 | External/Status interrupt information | | | | #### Write Register Functions CRC initialize, initialization commands for the | | various modes, shift right/shift left command | |------|---------------------------------------------------------------------------------------| | WRl | $\label{transmit} Transmit/Receive\ interrupt\ and\ data\ transfer\ mode\ definition$ | | WR2 | Interrupt vector (accessed through either channel) | | WR3 | Receive parameters and control | | WR4 | Transmit/Receive miscellaneous parameters and modes | | WR5 | Transmit parameters and controls | | WR6 | Sync characters or SDLC address field | | WR7 | Sync character or SDLC flag | | WR8 | Transmit buffer | | WR9 | Master interrupt control and reset (accessed through either channel) | | WR10 | Miscellaneous transmitter/receiver control bits | | WR11 | Clock mode control | | | | WR0 WR12 Lower byte of baud rate generator time constant WR13 Upper byte of baud rate generator time constant WR14 Miscellaneous control bits External/Status interrupt control WR15 Table 1. Read and Write Register Functions #### Programming The Z-SCC contains 13 write registers in each channel that are programmed by the system separately to configure the functional personality of the channels. All of the registers in the Z-SCC are directly addressable. How the Z-SCC decodes the address placed on the address/data bus at the beginning of a Read or Write cycle is controlled by a command issued in WROB. In the Shift Right mode the channel select $A/\overline{B}$ is taken from $AD_0$ and the state of $AD_5$ is ignored. In the Shift Left mode $A/\overline{B}$ is taken from AD<sub>5</sub> and the state of AD<sub>0</sub> is ignored. AD7 and AD6 are always ignored as address bits and the register address itself occupies AD<sub>4</sub>-AD<sub>1</sub>. The system program first issues a series of commands to initialize the basic mode of operation. This is followed by other commands to qualify conditions within the selected mode. For example, the Asynchronous mode, character length, clock rate, number of stop bits, even or odd parity might be set first. Then the Interrupt mode would be set, and finally, receiver or transmitter enable. (Continued) Programming Read Registers. The Z-SCC contains eight read registers (actually nine, counting the receive buffer [RR8]) in each channel. Four of these may be read to obtain status information (RRO, RRI, RRIO, and RRI5). Two registers (RR12 and RR13) may be read to learn the baud rate generator time constant. RR2 contains either the unmodified interrupt vector (Channel A) or the vector modified by status information (Channel B). RR3 contains the #### Read Register 0 #### Read Register 1 #### Read Register 2 #### Read Register 3 Interrupt Pending (IP) bits (Channel A). Figure 10 shows the formats for each read register. The status bits of RRO and RR1 are carefully grouped to simplify status monitoring; e.g., when the interrupt vector indicates a Special Receive Condition interrupt, all the appropriate error bits can be read from a single register (RR1). #### Read Register 10 #### Read Register 12 #### Read Register 13 #### Read Register 15 Figure 10. Read Register Bit Functions 2016-005 ## Programming (Continued) Write Registers. The Z-SCC contains 13 write registers (14 counting WR8, the transmit buffer) in each channel. These write registers are programmed separately to configure the functional "personality" of the channels. In addition, there are two registers (WR2 and WR9) shared by the two channels that may be accessed through either of them. WR2 contains the interrupt vector for both channels, while WR9 contains the interrupt control bits. Figure 11 shows the format of each write register. #### Write Register 0 <sup>\*</sup> B CHANNEL ONLY #### Write Register 1 #### Write Register 2 #### Write Register 3 #### Write Register 4 #### Write Register 5 #### Write Register 6 Figure 11. Write Register Bit Functions # Programming (Continued) #### Write Register 9 #### Write Register 10 #### Write Register 11 #### Write Register 12 #### Write Register 13 #### Write Register 14 #### Write Register 15 Figure 11. Write Register Bit Functions (Continued) 2016-006 #### Timing The Z-SCC generates internal control signals from $\overline{AS}$ and $\overline{DS}$ that are related to PCLK. Since PCLK has no phase relationship with $\overline{AS}$ and $\overline{DS}$ , the circuitry generating these internal control signals must provide time for metastable conditions to disappear. This gives rise to a recovery time related to PCLK. The recovery time applies only between bus transactions involving the Z-SCC. The recovery time required for proper operation is specified from the rising edge of $\overline{DS}$ in the first transaction involving the Z-SCC to the falling edge of $\overline{\text{DS}}$ in the second transaction involving the Z-SCC. This time must be at least 6 PCLK cycles plus 200 ns. **Read Cycle Timing.** Figure 12 illustrates read cycle timing. The address on $AD_0$ - $AD_7$ and the state of $\overline{CS}_0$ and $\overline{INTACK}$ are latched by the rising edge of $\overline{AS}$ . $R/\overline{W}$ must be High to indicate a Read cycle. $CS_1$ must also be High for the Read cycle to occur. The data bus drivers in the Z-SCC are then enabled while $\overline{DS}$ is Low. Figure 12. Read Cycle Timing **Write Cycle Timing.** Figure 13 illustrates Write cycle timing. The address on $AD_0$ - $AD_7$ and the state of $\overline{CS_0}$ and $\overline{INTACK}$ are latched by the rising edge of $\overline{AS}$ . $R/\overline{W}$ must be Low to indicate a Write cycle. $CS_1$ must be High for the Write cycle to occur. $\overline{DS}$ Low strobes the data into the Z-SCC. Figure 13. Write Cycle Timing Interrupt Acknowledge Cycle Timing. Figure 14 illustrates Interrupt Acknowledge cycle timing. The address on $AD_0$ - $AD_7$ and the state of $\overline{CS}_0$ and $\overline{INTACK}$ are latched by the rising edge of $\overline{AS}$ . However, if $\overline{INTACK}$ is Low, the address and $\overline{CS}_0$ are ignored. The state of the $R/\overline{W}$ and $CS_1$ are also ignored for the duration of the Interrupt Acknowledge 189 Timing (Continued) cycle. Between the rising edge of $\overline{AS}$ and the falling edge of $\overline{DS}$ , the internal and external IEI/IEO daisy chains settle. If there is an interrupt pending in the Z-SCC and IEI is High when $\overline{DS}$ falls, the Acknowledge cycle was intended for the Z-SCC. In this case, the Z-SCC may be programmed to respond to $\overline{\rm DS}$ Low by placing its interrupt vector on AD<sub>0</sub>-AD<sub>7</sub>. It then sets the appropriate Interrupt-Under-Service latch internally. Figure 14. Interrupt Acknowledge Cycle Timing #### Absolute Maximum Ratings Voltages on all inputs and outputs with respect to GND....-0.3 V to +7.0 V Operating Ambient Temperature . . . . . . As Specified in 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 characteristics below apply for the following standard test conditions, unless otherwise noted. All voltages are referenced to GND. Positive current flows into the referenced pin. Standard conditions are as follows: - $\blacksquare$ GND = 0 V - T<sub>A</sub> as specified in Ordering Information All ac parameters assume a load capacitance of $50~\mathrm{pF}$ max. Figure 15. Standard Test Load Figure 16. Open-Drain Test Load | DC | Symbol | Parameter | Min | Max | Unit | Condition | |----------------------|--------------|--------------------------------|------|--------------------|---------|-----------------------------| | Charac-<br>teristics | $V_{IH}$ | Input High Voltage | 2.0 | $V_{\rm CC} + 0.3$ | V | | | ici isiics | $V_{\rm IL}$ | Input Low Voltage | -0.3 | 0.8 | V | | | | $V_{OH}$ | Output High Voltage | 2.4 | | V | $I_{OH} = -250 \mu A$ | | | $V_{OL}$ | Output Low Voltage | | 0.4 | V | $I_{OL} = +2.0 \text{ mA}$ | | | $I_{IL}$ | Input Leakage | | ±10.0 | $\mu$ A | $0.4 \le V_{IN} \le +2.4V$ | | | $I_{OL}$ | Output Leakage | | ±10.0 | $\mu$ A | $0.4 \le V_{OUT} \le +2.4V$ | | | $I_{CC}$ | V <sub>CC</sub> Supply Current | | 250 | mA | | V<sub>CC</sub> = 5 V ± 5% unless otherwise specified, over specified temperature range. | Capacitance | Symbol | Parameter | Min | Max | Unit | Test Condition | |-------------|-----------------|---------------------------|-----|-----|------|--------------------| | | C <sub>IN</sub> | Input Capacitance | | 10 | рF | Unmeasured Pins | | | $C_{OUT}$ | Output Capacitance | | 15 | рF | Returned to Ground | | | $C_{I/O}$ | Bidirectional Capacitance | | 20 | рF | | Read and Write Timing | N. | C | Parameter | 4 MHz | 6 MHz | N-4++ | |-------------|---------------|------------------------------------------------------------------|-----------------|-----------------------------|-----------| | No. | Symbol | Parameter | Min Max | Min Ma | k Notes*† | | 1 | TwAS | AS Low Width | 70 | 50 | | | 2 | TdDS(AS) | DS ↑ to AS ↓ Delay | 50 | 25 | | | 3 | TsCSO(AS) | $\overline{\text{CS}_0}$ to $\overline{\text{AS}}$ † Setup Time | 0 | 0 | 1 | | 4 | ThCSO(AS) | $\overline{\text{CS}_0}$ to $\overline{\text{AS}}$ † Hold Time | 60 | 40 | 1 | | 5 — | -TsCS1(DS) | CS <sub>1</sub> to DS ↓ Setup Time | 100 <del></del> | 80 | l | | 6 | ThCS1(DS) | $CS_1$ to $\overline{DS}$ † Hold Time | <b>5</b> 5 | 40 | 1 | | 7 | TsIA(AS) | INTACK to AS Setup Time | 0 | 0 | | | 8 | ThIA(AS) | INTACK to AS Hold Time | 250 | 250 | | | 9 | TsRWR(DS) | $R/\overline{W}$ (Read) to $\overline{DS} \downarrow Setup Time$ | 100 | 80 | | | 10 — | —ThRW(DS)—— | —R/W to DS ↑ Hold Time ———— | <del> 55</del> | <del> 4</del> 0 <del></del> | | | 11 | TsRWW(DS) | R/W (Write) to DS ↓ Setup Time | 0 | 0 | | | 12 | TdAS(DS) | AS ↑ to DS ↓ Delay | 60 | 40 | | | 13 | TwDS1 | DS Low Width | 390 | 250 | | | 14 | TrC | Valid Access Recovery Time | 6TcPC | 6TcPC | 2 | | | | | + 200 | +130 | | | 15 <b>—</b> | - TsA(AS) | —Address to AS † Setup Time ———— | 30 <del></del> | 10 <del></del> | l | | 16 | ThA(AS) | Address to AS † Hold Time | 50 | 30 | 1 | | 17 | TsDW(DS) | Write Data to $\overline{\rm DS}$ Setup Time | 30 | 20 | | | 18 | ThDW(DS) | Write Data to $\overline{\rm DS}$ † Hold Time | 30 | 20 | | | 19 | TdDS(DA) | DS ↓ to Data Active Delay | 0 | 0 | | | 20 — | —TdDSr(DR) —— | —DS † to Read Data Not Valid Delay ——— | 0 | 0 | | | 21 | TdDSf(DR) | DS ↓ to Read Data Valıd Delay | 250 | 180 | 1 | | 22 | TdAS(DR) | AS ↑ to Read Data Valıd Delay | 520 | 335 | | NOTES 1. Parameter does not apply to Interrupt Acknowledge transactions <sup>2</sup> Parameter applies only between transactions involving the SCC \*Timings are preliminary and subject to change $\dagger Units$ in nanoseconds (ns) | No. | Symbol | Parameter | 4<br>Min | MHz<br>Max | 6 I<br>Min | MHz<br>Max | Notes*† | |----------|---------------|------------------------------------------------------------------|----------------|-------------|----------------------------|-----------------|---------| | | | = | | | | 45 | | | 23 | TdDS(DRz) | DS 1 to Read Data Float Delay | | 70 | | 45 | 3 | | 24 | TdA(DR) | Address Required Valid to Read Data Valid Delay | | 570 | | 420 | 4 | | 25<br>26 | TdDS(W) | DS to Wait Valid Delay | | 240<br>240 | | 200<br>200 | 4 | | | TdDSf(REQ) | DS ↓ to W/REQ Not Valid Delay<br>DS ↑ to DTR/REQ Not Valid Delay | | – 5TcPC – | | _200<br>- 5TcPC | | | 21 - | — TdDSr(REQ)— | - DS 1 to DIN/REQ Not Valid Delay | | + 300 | | + 250 | | | 28 | TdAS(INT) | AS † to INT Valid Delay | | 500 | | 500 | 4 | | 28<br>29 | TdAS(DSA) | AS 1 to IN1 Valid Delay AS 1 to DS 1 (Acknowledge) Delay | 250 | 300 | 250 | 300 | 5 | | 30 | TwDSA | DS (Acknowledge) Low Width | 390 | | 250<br>250 | | 3 | | 31 | TdDSA(DR) | DS (Acknowledge) to Read Data Valid Delay | 390 | 250 | 250 | 180 | | | | TsIEI(DSA) | — IEI to DS ↓ (Acknowledge) Setup Time ————— | <u> </u> | 250 | 100 | 100 | | | 33 | ThIEI(DSA) | IEI to DS † (Acknowledge) Betap Time | 120 | | 100 | | | | 34 | TdIEI(IEO) | IEI to IEO Delay | U | 120 | v | 100 | | | 35 | TdAS(IEO) | AS t to IEO Delay | | 250 | | 250 | 6 | | 36 | TdDSA(INT) | $\overline{DS}$ (Acknowledge) to $\overline{INT}$ Inactive Delay | | 500 | | 500 | 4 | | | -TdDS(ASO)- | — DS † to AS Delay for No Reset | 30 | | <del></del> 15 <del></del> | | * | | 38 | TdASQ(DS) | AS 1 to DS 1 Delay for No Reset | 30 | | 30 | | | | 39 | TwRES | AS and DS Coincident Low for Reset | 250 | | 250 | | 7 | | 40 | TwPC1 | PCLK Low Width | 105 | 2000 | 70 | 1000 | - | | 41 | TwPCh | PCLK High Width | 105 | 2000 | 70 | 1000 | | | | - TcPC | — PCLK Cycle Time | 250 <b>-</b> - | <del></del> | <del>165</del> | <del></del> | | | 43 | TrPC | PCLK Rise Time | | 20 | | 15 | | | 44 | TfPC | PCLK Fall Time | | 20 | | 10 | | #### NOTES: - 3 Float delay is defined as the time required for a $\pm 0.5 \text{ V}$ change in the output with a maximum dc load and minimum ac load. - 4 Open-drain output, measured with open-drain test load. 5. Parameter is system dependent. For any Z-SCC in the daisy chain, TdAS(DSA) must be greater than the sum of TdAS(IEO) for the highest priority device in the daisy chain, TsIEI(DSA) for the Z-SCC, and TdIEIf(IEO) for each device separating them in the daisy chain. - 6. Parameter applies only to a Z-SCC pulling $\overline{\mbox{INT}}$ Low at the beginning of the Interrupt Acknowledge transaction. - 7. Internal circuitry allows for the reset provided by the Z8 to be recognized as a reset by the Z-SCC. - recognized as a reset by the 2-300. Timings are preliminary and subject to change. All timing references assume 2.0 V for a logic "1" and 0.8 V for a logic "0". † Units in nanoseconds (ns). 2016-014 | | | | 4 1 | MHz | 6 N | | | |------|----------------|--------------------------------------------------------------|-----------------|------|-----------------------------|------|---------| | No. | Symbol | Parameter | Min | Max | Min | Max | Notes*† | | 1 | TdPC(REQ) | PCLK ↓ to W/REQ Valid | | 250 | | 250 | | | 2 | TdPC(W) | PCLK ↓ to Wait Inactive Delay | | 350 | | 350 | | | 3 | TsRXC(PC) | RxC ↑ to PCLK ↑ Setup Time | 50 | | 50 | | 1,4 | | 4 | TsRXD(RXCr) | RxD to $\overline{RxC}$ † Setup Time (X1 Mode) | 0 | | 0 | | 1 | | 5 - | —ThRXD(RXCr) - | —RxD to RxC ↑ Hold Time (X1 Mode) | 150- | | 150 <del></del> | | —— l —— | | 6 | TsRXD(RXCf) | RxD to $\overline{RxC} \downarrow Setup Time (X1 Mode)$ | 0 | | 0 | | 1,5 | | 7 | ThRXD(RXCf) | $RxD$ to $\overline{RxC} \downarrow Hold Time (X1 Mode)$ | 150 | | 150 | | 1,5 | | 8 | TsSY(RXC) | SYNC to RxC Setup Time | -200 | | -200 | | 1 | | 9 | ThSY(RXC) | SYNC to RxC † Hold Time | 3TcPC<br>+ 200 | | 3TcPC<br>+200 | | 1 | | 10 - | -TsTXC(PC) - | — TxC ↓ to PCLK ↑ Setup Time ———— | 0 | | 0 <del></del> | | 2,4— | | 11 | TdTXCf(TXD) | TxC ↓ to TxD Delay (X1 Mode) | | 300 | | 300 | 2 | | 12 | TdTXCr(TXD) | TxC † to TxD Delay (X1 Mode) | | 300 | | 300 | 2,5 | | 13 | TdTXD(TRX) | TxD to TRxC Delay (Send Clock Echo) | | 200 | | 200 | | | 14 | TwRTXh | RTxC High Width | 180 | | 180 | | | | 15 – | -TwRTX1 | - RTxC Low Width | 180 <del></del> | | <del></del> 180 <del></del> | | | | 16 | TcRTX | RTxC Cycle Time | 400 | | 400 | | | | 17 | TcRTXX | Crystal Oscillator Period | 250 | 1000 | 250 | 1000 | 3 | | 18 | TwTRXh | TRxC High Width | 180 | | 180 | | | | 19 | TwTRX1 | TRxC Low Width | 180 | | 180 | | | | 20 - | —TcTRX ——— | TRxC Cycle Time | 400 — | | <del> 400</del> | | | | 21 | TwEXT | $\overline{ ext{DCD}}$ or $\overline{ ext{CTS}}$ Pulse Width | 200 | | 200 | | | | 22 | TwSY | SYNC Pulse Width | 200 | | | | | NOTES 1 RxC is RTxC or TRxC, whichever is supplying the receive clock 2 TxC is TRxC or RTxC, whichever is supplying the transmit clock. 3 Both RTxC and SYNC have 30 pf capacitors to the ground connected to them <sup>4</sup> Parameter applies only if the data rate is one-fourth the PCLK rate. In all other cases, no phase relationship between RxC and PCLK or TxC and PCLK is required. 5 Parameter applies only to FM encoding/decoding. \* Timings are preliminary and subject to change. † Units in nanoseconds (ns) #### System Timing | | | | 41 | MHz | 61 | | | |-----|--------------|---------------------------------------------------------------------------------------------------|----------|---------------|---------------|---------------|-----------------------------| | No. | Symbol | Parameter | Min | Max | Min | Max | Notes* | | 1 | TdRXC(REQ) | RxC † to W/REQ Valid Delay | 8 | 12 | 8 | 12 | 2,4 | | 2 | TdRXC(W) | RxC † to Wait Inactive Delay | 8 | 12 | 8 | 12 | 1,2,4 | | 3 | TdRXC(SY) | RxC † to SYNC Valid Delay | 4 | 7 | 4 | 7 | 2,4 | | 4 | TdRXC(INT) | RxC † INT Valid Delay | 8<br>+ 2 | 12<br>+3 | 8<br>+2 | 12<br>+3 | 1,2,4<br>5 | | 5 — | -TdTXC(REQ)- | —TxC ↓ to W/REQ Valid Delay ———— | 5 — | <del></del> 8 | <del> 5</del> | <del></del> 8 | <del></del> 3,4 <del></del> | | 6 | TdTXC(W) | TxC ↓ to Wait Inactive Delay | 5 | 8 | 5 | 8 | 1,3,4 | | 7 | TdTXC(DRQ) | TxC to DTR/REQ Valid Delay | 4 | 7 | 4 | 7 | 3,4 | | 8 | TdTXC(INT) | TxC ↓ to INT Valid Delay | 4<br>+ 2 | 6<br>+3 | 4<br>+2 | 6<br>+3 | 1,3,4<br>5 | | 9 | TdSY(INT) | SYNC Transition to INT Valid Delay | 2 | 3 | 2 | 3 | 1,5 | | 10 | TdEXT(INT) | $\overline{ ext{DCD}}$ or $\overline{ ext{CTS}}$ Transition to $\overline{ ext{INT}}$ Valid Delay | 2 | 3 | 2 | 3 | 1,5 | #### NOTES - Open-drain output, measured with open-drain test load. RxC is RTxC or TRxC, whichever is supplying the receive - $\frac{\text{clock.}}{\text{TxC is TRxC}} \text{ or } \frac{\text{RTxC}}{\text{RTxC}}, \text{ whichever is supplying the transmit}$ clock. - Units equal to TcPC Units equal to AS. Timings are preliminary and subject to change | Ordering<br>Information | Product<br>Number | Package<br>Temp | /<br>Speed | Description | Product<br>Number | Package/<br>Temp | Speed | Description | |-------------------------|-------------------|-----------------|------------|----------------|-------------------|------------------|---------|----------------| | | Z8030 | CE | 4.0 MHz | Z-SCC (40-pin) | Z8030A | CE | 6.0 MHz | Z-SCC (40-pin) | | | Z8030 | CM | 4.0 MHz | Same as above | Z8030A | CM | 6.0 MHz | Same as above | | | Z8030 | CMB | 4.0 MHz | Same as above | Z8030A | CMB | 6.0 MHz | Same as above | | | Z8030 | CS | 4.0 MHz | Same as above | Z8030A | CS | 6.0 MHz | Same as above | | | Z8030 | DE | 4.0 MHz | Same as above | Z8030A | DE | 6.0 MHz | Same as above | | | Z8030 | DS | 4.0 MHz | Same as above | Z8030A | DS | 6.0 MHz | Same as above | | | Z8030 | PE | 4.0 MHz | Same as above | Z8030A | PE | 6.0 MHz | Same as above | | | Z8030 | PS | 4.0 MHz | Same as above | Z8030A | PS | 6.0 MHz | Same as above | NOTES: C = Ceramic, D = Cerdip, P = Plastic; E = -40°C to +85°C, M = -55°C to 125°C, MB = -55°C to 125°C with MIL-STD-883 with Class B processing, S = 0°C to +70°C 00-2016-A | | | | - | |--|--|---|---| | | | | | | | | | | | | | | | | | | | | | | | | | | | | , | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | ### Z8031 Z8000<sup>™</sup> Z-ASCC Asynchronous Serial Communications Controller ### Product Specification #### June 1982 #### Features - Two independent, 0 to 1M bit/second, full-duplex channels, each with a separate crystal oscillator, baud rate generator, and Digital Phase-Locked Loop for clock recovery. - Programmable for NRZ, NRZI, or FM data encoding. - Asynchronous communications with five to - eight bits per character and one, one and one-half, or two stop bits per character; programmable clock factor; break detection and generation; parity, overrun, and framing error detection. - Local Loopback and Auto Echo modes. #### General Description The Z8031 Z-ASCC Asynchronous Serial Communications Controller is a dual-channel data communications peripheral designed for use with the Zilog Z-BUS. The Z-ASCC functions as a serial-to-parallel, parallel-to-serial converter/controller. The device contains a variety of new, sophisticated internal functions including on-chip baud rate generators, Digital Phase-Locked Loops, and crystal oscillators that dramatically reduce the need for external logic. The Z-ASCC has facilities for modem controls in both channels. In applications where these controls are not needed, the modem controls can be used for general-purpose I/O. The Z-BUS daisy-chain interrupt hierarchy is also supported—as is standard for Zilog peripheral components. The Z8031 Z-ASCC is packaged in a 40-pin ceramic DIP and uses a single +5 V power supply. Figure 2. Pin Assignments 2245-001, 002 #### Pin Description The following section describes the pin functions of the Z-ASCC. Figures 1 and 2 detail the respective pin functions and pin assignments. **AD<sub>0</sub>-AD<sub>7</sub>.** Address/Data Bus (bidirectional, active High, 3-state). These multiplexed lines carry register addresses to the Z-ASCC as well as data or control information to and from the Z-ASCC. $\overline{\mathbf{AS}}$ . Address Strobe (input, active Low). Addresses on $AD_0$ - $AD_7$ are latched by the rising edge of this signal. **CS<sub>0</sub>.** Chip Select 0 (input, active Low). This signal is latched concurrently with the addresses on AD<sub>0</sub>–AD<sub>7</sub> and must be active for the intended bus transaction to occur. **CS<sub>1</sub>.** Chip Select 1 (input, active High). This second select signal must also be active before the intended bus transaction can occur. CS<sub>1</sub> must remain active throughout the transaction. CTSA, CTSB. Clear to Send (inputs, active Low). If these pins are programmed as Auto Enables, a Low on the inputs enables their respective transmitters. If not programmed as Auto Enables, they may be used as general-purpose inputs. Both inputs are Schmitt-trigger buffered to accommodate slow rise-time inputs. The Z-ASCC detects pulses on these inputs and can interrupt the CPU on both logic level transitions. **DCDA.** DCDB. Data Carrier Detect (inputs, active Low). These pins function as receiver enables if they are programmed for Auto Enables; otherwise they may be used as general-purpose input pins. Both pins are Schmitt-trigger buffered to accommodate slow rise-time signals. The Z-ASCC detects pulses on these pins and can interrupt the CPU on both logic level transitions. **DS.** Data Strobe (input, active Low). This signal provides timing for the transfer of data into and out of the Z-ASCC. If $\overline{AS}$ and $\overline{DS}$ coincide, this is interpreted as a reset. DTR/REQA, DTR/REQB. Data Terminal Ready/Request (outputs, active Low). These outputs follow the state programmed into the DTR bit. They can also be used as general-purpose outputs or as Request lines for a DMA controllor. **IEI.** Interrupt Enable In (input, active High). IEI is used with IEO to form an interrupt daisy chain when there is more than one interrupt-driven device. A High IEI indicates that no other higher priority device has an interrupt under service or is requesting an interrupt. **IEO.** Interrupt Enable Out (output, active High). IEO is High only if IEI is High and the CPU is not servicing a Z-ASCC interrupt or the Z-ASCC is not requesting an interrupt (Interrupt Acknowledge cycle only). IEO is connected to the next lower priority device's IEI input and thus inhibits interrupts from lower priority devices. **INT.** Interrupt Request (output, open-drain, active Low). This signal is activated when the Z-ASCC requests an interrupt. INTACK. Interrupt Acknowledge (input, active Low). This signal indicates an active Interrupt Acknowledge cycle. During this cycle, the Z-ASCC interrupt daisy chain settles. When DS becomes active, the Z-ASCC places an interrupt vector on the data bus (if IEI is High). INTACK is latched by the rising edge of AS. **PCLK.** Clock (input). This is the master Z-ASCC clock used to synchronize internal signals. PCLK is not required to have any phase relationship with the master system clock, although the frequency of this clock must be at least 90% of the CPU clock frequency for a Z8000. PCLK is a TTL level signal. **RxDA**, **RxDB**. Receive Data (inputs, active High). These input signals receive serial data at standard TTL levels. RIA, RIB. Ring Indicator (inputs, active Low). These pins can act either as inputs or as part of the crystal oscillator circuit. In normal operation (crystal oscillator option not selected), these pins are inputs similar to CTS and DCD. In this mode, transitions on these lines affect the state of the Ring Indicator status bits in Read Register 0 (Figure 8) but have no other function. RTxCA, RTxCB. Receive/Transmit Clocks (inputs, active Low). These pins can be programmed in several different modes of operation. In each channel, $\overline{RTxC}$ may supply the receive clock, the transmit clock, the clock for the baud rate generator, or the clock of the Digital Phase-Locked Loop. These pins can also be programmed for use with the respective $\overline{RI}$ pins as a crystal oscillator. The receive clock may be 1, 16, 32, or 64 times the data rate in Asynchronous modes. RTSA, RTSB. Request To Send (outputs, active Low). When the Request To Send (RTS) bit in Write Register 5 (Figure 9) is set, the $\overline{\text{RTS}}$ signal goes Low. When the RTS bit is reset and Auto Enable is on, the signal goes High after the transmitter is empty. With Auto Enable off, the $\overline{\text{RTS}}$ pin strictly follows the state of the RTS bit. Both pins can be used as general-purpose outputs. **R/W.** Read/Write (input). This signal specifies whether the operation to be performed is a read or a write. **TxDA. TxDB.** Transmit Data (outputs, active High). These output signals transmit serial data at standard TTL levels. # Pin Description (Continued) TRxCA, TRxCB. Transmit/Receive Clocks (inputs or outputs, active Low). These pins can be programmed in several different modes of operation. TRxC may supply the receive clock or the transmit clock in the input mode or supply the output of the Digital Phase-Locked Loop, the crystal oscillator, the baud rate generator, or the transmit clock in the output mode. W/REQA, W/REQB. Watt/Request (outputs, open-drain when programmed for a Wait function, driven High or Low when programmed for a Request function). These dual-purpose outputs may be programmed as Request lines for a DMA controller or as Wait lines to synchronize the CPU to the Z-ASCC data rate. The reset state is Wait. #### Functional Description The functional capabilities of the Z-ASCC can be described from two different points of view: as a data communications device, it transmits and receives data in a wide variety of data communications protocols; as a Z8000 peripheral, it interacts with the CPU and other peripheral circuits and is part of the system interrupt structure. **Data Communications Capabilities.** The Z-ASCC provides two independent full-duplex channels programmable for use in any common Asynchronous data communication protocol. Figure 3 and the following description briefly detail this protocol. Asynchronous Modes. Transmission and reception can be accomplished independently on each channel with five to eight bits per character, plus optional even or odd parity. The transmitters can supply one, one-and-ahalf, or two stop bits per character and can provide a break output at any time. The receiver break-detection logic interrupts the CPU both at the start and at the end of a received break. Reception is protected from spikes by a transient spike-rejection mechanism that checks the signal one-half a bit time after a Low level is detected on the receive data input (RxDA or RxDB in Figure 1). If the Low does not persist (as in the case of a transient), the character assembly process does not start. Framing errors and overrun errors are detected and buffered together with the partial character on which they occur. Vectored interrupts allow fast servicing of error conditions using dedicated routines. Furthermore, a built-in checking process avoids the interpretation of a framing error as a new start bit: a framing error results in the addition of one-half a bit time to the point at which the search for the next start bit begins. The Z-ASCC does not require symmetric transmit and receive clock signals—a feature allowing use of the wide variety of clock sources. The transmitter and receiver can handle data at a rate of 1, 1/16, 1/32, or 1/64 of the clock rate supplied to the receive and transmit clock inputs. Baud Rate Generator. Each channel in the Z-ASCC contains a programmable baud rate generator. Each generator consists of two 8-bit time constant registers that form a 16-bit time constant, a 16-bit down counter, and a flip-flop on the output producing a square wave. On startup, the flip-flop on the output is set in a High state, the value in the time constant register is loaded into the counter, and the counter starts counting down. The output of the baud rate generator toggles upon reaching 0, the value in the time constant register is loaded into the counter, and the process is repeated. The time constant may be changed at any time, but the new value does not take effect until the next load of the counter. The output of the baud rate generator may be used as either the transmit clock, the receive clock, or both. It can also drive the Digital Phase-Locked Loop (see next section). If the receive clock or transmit clock is not programmed to come from the $\overline{TRxC}$ pin, the output of the baud rate generator may be echoed out via the $\overline{TRxC}$ pin. The following formula relates the time constant to the baud rate (the baud rate is in bits/second and the BR clock period is in seconds): baud rate = $\frac{1}{2 \text{ (time constant + 2)} \times \text{ (BR clock period)}}$ Digital Phase-Locked Loop. The Z-ASCC contains a Digital Phase-Locked Loop (DPLL) to recover clock information from a data stream with NRZI or FM encoding. The DPLL is driven by a clock that is nominally 32 (NRZI) or 16 (FM) times the data rate. The DPLL uses this clock, along with the data stream, to construct a clock for the data. This clock may then be used as the Z-ASCC receive clock, the transmit clock, or both. Figure 3. Z-ASCC Protocol For NRZI encoding, the DPLL counts the 32x clock to create nominal bit times. As the 32x clock is counted, the DPLL is searching the incoming data stream for edges (either 1 to 0 or 0 to 1). Whenever an edge is detected, the DPLL makes a count adjustment (during the next counting cycle), producing a terminal count closer to the center of the bit cell. For FM encoding, the DPLL still counts from 0 to 31, but with a cycle corresponding to two bit times. When the DPLL is locked, the clock edges in the data stream should occur between counts 15 and 16 and between counts 31 and 0. The DPLL looks for edges only during a time centered on the 15 to 16 counting transition. The 32x clock for the DPLL can be programmed to come from either the $\overline{RTxC}$ input or the output of the baud rate generator. The DPLL output may be programmed to be echoed out of the Z-ASCC via the $\overline{TRxC}$ pin (if this pin is not being used as an input). Data Encoding The Z-ASCC may be programmed to encode and decode the serial data in four different ways (Figure 4). In NRZ encoding, a l is represented by a High level and a 0 is represented by a Low level. In NRZI encoding, a l is represented by no change in level and a 0 is represented by a change in level. In FM1 (more properly, bi-phase mark) a transition occurs at the beginning of every bit cell. A 1 is represented by an additional transition at the center of the bit cell and a 0 is represented by no additional transition at the center of the bit cell. In FMO (bi-phase space), a transition occurs at the beginning of every bit cell. A 0 is represented by an additional transition at the center of the bit cell, and a l is represented by no additional transition at the center of the bit cell. In addition to these four methods, the Z-ASCC can be used to decode Manchester (bi-phase level) data by using the DPLL in the FM mode and programming the receiver for NRZ data. Manchester encoding always produces a transition at the center of the bit cell. If the transition is 0 to 1, the bit is a 0. If the transition is 1 to 0 the bit is a 1. Auto Echo and Local Loopback. The Z-ASCC is capable of automatically echoing everything it receives. In Auto Echo mode, RxD is connected to TxD internally. Auto Echo mode can be used with NRZI or FM encoding with no additional delay, because the data stream is not decoded before retransmission. In Auto Echo mode, the CTS input is ignored as a transmitter enable (although transitions on this input can still cause interrupts if programmed to do so). In this mode, the transmitter is actually bypassed and the programmer is responsible for disabling transmitter interrupts and WAIT/REQUEST on transmitt. The Z-ASCC is also capable of Local Loopback. In this mode TxD is connected to RxD internally, just as in Auto Echo mode. However, in Local Loopback mode, the internal transmit data is tied to the internal receive data and RxD is ignored (except to be echoed out via TxD). The CTS and DCD inputs are also ignored as transmit and receive enables. However, transitions on these inputs can still cause interrupts. Local Loopback works with NRZ, NRZI or FM coding of the data stream. I/O Interface Capabilities. The Z-ASCC offers the choice of Polling, Interrupt (vectored or nonvectored), and Block Transfer modes to transfer data, status, and control information to and from the CPU. The Block Transfer mode can be implemented under CPU or DMA control. Polling. All interrupts are disabled. Three status registers in the Z-ASCC are automatically updated whenever any function is performed. The idea behind polling is for the CPU to periodically read a status register until the register contents indicate the need for data to be transferred. Only one register needs to be read; depending on its contents, the CPU either writes data, reads data, or continues. Two bits in the register indicate the need for data transfer. An alternative is a poll of the Figure 4. Data Encoding Methods Interrupt Pending register to determine the source of an interrupt. The status for both channels resides in one register. Interrupts. The Z-ASCC interrupt scheme conforms to the Z-BUS specification. When a Z-ASCC responds to an Interrupt Acknowledge signal (INTACK) from the CPU, an interrupt vector may be placed on the A/D bus. This vector is written in WR2 and may be read in RR2A or RR2B (Figures 8 and 9). To speed interrupt response time, the Z-ASCC can modify three bits in this vector to indicate status. If the vector is read in Channel A, status is never included; if it is read in Channel B, status is always included. Each of the six sources of interrupts in the Z-ASCC (Transmit, Receive, and External/Status interrupts in both channels) has three bits associated with the interrupt source: Interrupt Pending (IP), Interrupt Under Service (IUS), and Interrupt Enable (IE). Operation of the IE bit is straightforward. If the IE bit is set for a given interrupt source, then that source can request interrupts. The exception is when the MIE (Master Interrupt Enable) bit in WR9 is reset and no interrupts may be requested. The IE bits are write only. The other two bits are related to the Z-BUS interrupt priority chain (Figure 5). The Z-ASCC may request an interrupt only when no higher priority device is requesting one, e.g., when IEI is High. If the device in question requests an interrupt, it <u>pulls down INT.</u> The CPU then responds with <u>INTACK</u>, and the interrupting device places the vector on the A/D bus. In the Z-ASCC, the IP bit signals a need for interrupt servicing. When an IP bit is 1 and the IEI input is High, the $\overline{\text{INT}}$ output is pulled Low, requesting an interrupt. In the Z-ASCC, if the IE bit is not set by enabling interrupts, then the IP for that source can never be set. The IP is set two or three $\overline{\text{AS}}$ cycles after the interrupt condition occurs. Two or three $\overline{\text{AS}}$ rising edges are required from the time an interrupt condition occurs until $\overline{\text{INT}}$ is activated. The IP bits are readable in RR3A. The IUS bits signal that an interrupt request is being serviced. If an IUS is set, all interrupt sources of lower priority in the Z-ASCC and external to the Z-ASCC are prevented from requesting interrupts. The internal interrupt sources are inhibited by the state of the internal daisy chain, while lower priority devices are inhibited by the IEO output of the Z-ASCC being pulled Low and propagated to subsequent peripherals. An IUS bit is set during an Interrupt Acknowledge cycle if there are no higher priority devices requesting interrupts. There are three types of interrupts: Transmit, Receive, and External/Status. Each interrupt type is enabled under program control with Channel A having higher priority than Channel B, and with Receiver, Transmit, and External/Status interrupts prioritized in that order within each channel. When the Transmit interrupt is enabled, the CPU is interrupted when the transmit buffer becomes empty. (This implies that the transmitter must have had a data character written into it so that it can become empty.) When enabled, the receiver can interrupt the CPU in one of three ways: - Interrupt on First Receive Character or Special Receive Condition. - Interrupt on All Receive Characters or Special Receive Condition. - Interrupt on Special Receive Condition Only. Interrupt on First Character or Special Condition and Interrupt on Special Condition Only are typically used with the Block Transfer mode. A Special Receive Condition is receiver overrun, and, optionally, a parity error. The Special Receive Condition interrupt is different from an ordinary receive character available interrupt only in the status placed in the vector during the Interrupt Acknowledge cycle. In Interrupt on First Receive Character, an interrupt can occur from Special Receive Conditions any time after the first receive character interrupt. The main function of the External/Status interrupt is to monitor the signal transitions of the $\overline{CTS}$ , $\overline{DCD}$ , and $\overline{RI}$ pins; however, an External/Status interrupt is also caused by a Transmit Underrun condition, or a zero count in the baud rate generator, or by the detection of a Break. Figure 5. Z-BUS Interrupt Schedule CPU/DMA Block Transfer. The Z-ASCC provides a Block Transfer mode to accommodate CPU block transfer functions and DMA controllers. The Block Transfer mode uses the WAIT/REQUEST output in conjunction with the Wait/Request bits in WR1. The WAIT/REQUEST output can be defined under software control as a WAIT line in the CPU Block Transfer mode or as a REOUEST line in the DMA Block Transfer mode. To a DMA controller, the Z-ASCC $\overline{\text{REQUEST}}$ output indicates that the Z-ASCC is ready to transfer data to or from memory. To the CPU, the $\overline{\text{WAIT}}$ line indicates that the Z-ASCC is not ready to transfer data, thereby requesting that the CPU extend the I/O cycle. The $\overline{\text{DTR}}/\overline{\text{REQUEST}}$ line allows full-duplex operation under DMA control. #### Architecture The Z-ASCC internal structure includes two full-duplex channels, two baud rate generators, internal control and interrupt logic, and a bus interface to the Zilog Z-BUS. Associated with each channel are a number of read and write registers for mode control and status information, as well as logic necessary to interface to modems or other external devices (Figure 6). The logic for both channels provides formats, synchronization, and validation for data transferred to and from the channel interface. The modem control inputs are monitored by the control logic under program control. All of the modem control signals are generalpurpose in nature and can optionally be used for functions other than modem control. The register set for each channel includes ten control (write) registers, and four status (read) registers. In addition, each baud rate generator has two (read/write) registers for holding the time constant that determines the Figure 6. Block Diagram of Z-ASCC Architecture Figure 7. Data Path 203 # Architecture (Continued) baud rate. Finally, associated with the interrupt logic is a write register for the interrupt vector accessible through either channel, a write-only Master Interrupt Control register and three read registers: one containing the vector with status infomation (Channel B only), one containing the vector without status (Channel A only), and one containing the Interrupt Pending bits (Channel A only). The registers for each channel are designated as follows: WR0-WR15 — Write Registers 0-5, 8-15. RR0-RR3, RR10, RR12, RR13, RR15 — Read Registers 0 through 3, 10, 12, 13, 15. Table 1 lists the functions assigned to each read or write register. The Z-ASCC contains only one WR2 and WR9, but they can be accessed by either channel. All other registers are paired (one for each channel). Data Path. The transmit and receive data path illustrated in Figure 7 is identical for both channels. The receiver has three 8-bit buffer registers in an FIFO arrangement, in addition to the 8-bit receive shift register. This scheme creates additional time for the CPU to service an interrupt at the beginning of a block of high speed data. Incoming data is routed through one of several paths depending on the selected mode (the character length determines the data path). The transmitter has an 8-bit Transmit Data buffer register loaded from the internal data bus and an 11-bit Transmit Shift register that is loaded from the Transmit Data register. #### Read Register Functions RR0 Transmit/Receive buffer status and External status Special Receive Condition status RR1 RR2 Modified interrupt vector (Channel B only) Unmodified interrupt vector (Channel A only) RR3 Interrupt Pending bits (Channel A only) RR8 Receive buffer RR10 Miscellaneous status Lower byte of baud rate generator time constant RR12 RR13 Upper byte of baud rate generator time constant RR15 External/Status interrupt information #### Write Register Functions | WR0 | CRC initialize, initialization commands for the various modes, shift right/shift left command | |------|-----------------------------------------------------------------------------------------------| | WR1 | Transmit/Receive interrupt and data transfer mode definition | | WR2 | Interrupt vector (accessed through either channel) | | WR3 | Receive parameters and control | | WR4 | Transmit/Receive miscellaneous parameters and modes | | WR5 | Transmit parameters and controls | | WR8 | Transmit buffer | | WR9 | Master interrupt control and reset (accessed through either channel) | | WR10 | Miscellaneous transmitter/receiver control bits | | WR11 | Clock mode control | | WR12 | Lower byte of baud rate generator time constant | | WR13 | Upper byte of baud rate generator time constant | | WR14 | Miscellaneous control bits | | WR15 | External/Status interrupt control | #### Table 1. Read and Write Register Functions #### Programming The Z-ASCC contains 11 write registers in each channel that are programmed by the system separately to configure the functional personality of the channels. All of the registers in the Z-ASCC are directly addressable. How the Z-ASCC decodes the address placed on the address/data bus at the beginning of a Read or Write cycle is controlled by a command issued in WROB. In the shift right mode, the channel select $\overline{A/B}$ is taken from AD0 and the state of AD5 is ignored. In the shift left mode, $\overline{A/B}$ is taken from $AD_5$ and the state of $AD_0$ is ignored. $AD_7$ and $AD_6$ are always ignored as address bits and the register address itself occupies $AD_4$ – $AD_1$ . The system program first issues a series of commands to initialize the basic mode of operation. For example, the character length, clock rate, number of stop bits, even or odd parity might be set first. Then the Interrupt mode would be set, and finally, receiver or transmitter enable. ## (Continued) Programming Read Registers. The Z-ASCC contains eight read registers (actually nine, counting the receive buffer [RR8]) in each channel. Four of these may be read to obtain status information (RRO, RR1, RR10, and RR15). Two registers (RR12 and RR13) may be read to learn the baud rate generator time constant. RR2 contains either the unmodified interrupt vector (Channel A) or the vector modified by status information (Channel B). RR3 contains the #### Read Register 0 #### Read Register 1 #### Read Register 2 #### Read Register 3 Interrupt Pending (IP) bits (Channel A). Figure 8 shows the formats for each read register. The status bits of RRO and RRI are carefully grouped to simplify status monitoring; e.g., when the interrupt vector indicates a Special Receive Condition interrupt, all the appropriate error bits can be read from a single register (RR1). #### Read Register 10 #### Read Register 12 #### Read Register 13 #### Read Register 15 Figure 8. Read Register Bit Functions 2245-005 205 # (Continued) Programming Write Registers. The Z-ASCC contains 11 write registers (12 counting WR8, the transmit buffer) in each channel. These write registers are programmed separately to configure the functional "personality" of the channels. In addition, there are two registers (WR2 and WR9) shared by the two channels that may be accessed through either of them. WR2 contains the interrupt vector for both channels, while WR9 contains the interrupt control bits. Figure 9 shows the format of each write register. ### Write Register 0 ## Write Register 3 ### Write Register 1 ### Write Register 4 ### Write Register 2 ### Write Register 5 Figure 9. Write Register Bit Functions ### Programming Write Register 9 (Continued) ### Writer Register 10 ### Write Register 11 ### Write Register 12 ### Write Register 13 ### Write Register 14 ### Write Register 15 Figure 9. Write Register Bit Functions (Continued) 2245-006 ### Timing The Z-ASCC generates internal control signals from $\overline{AS}$ and $\overline{DS}$ that are related to PCLK. Since PCLK has no phase relationship with $\overline{AS}$ and $\overline{DS}$ , the circuitry generating these internal control signals must provide time for metastable conditions to disappear. This gives rise to a recovery time related to PCLK. The recovery time applies only between bus transactions involving the Z-ASCC. The recovery time required for proper operation is specified from the rising edge of $\overline{DS}$ in the first transaction involving the Z-ASCC to the falling edge of $\overline{\rm DS}$ in the second transaction involving the Z-ASCC. This time must be at least 6 PCLK cycles plus 200 ns. **Read Cycle Timing.** Figure 10 illustrates Read cycle timing. The address on $AD_0$ - $AD_7$ and the state of $\overline{CS_0}$ and $\overline{INTACK}$ are latched by the rising edge of $\overline{AS}$ . $R/\overline{W}$ must be High to indicate a Read cycle to occur. The data bus drivers in the Z-ASCC are then enabled while $\overline{DS}$ is Low. Figure 10. Read Cycle Timing Write Cycle Timing. Figure 11 illustrates Write cycle timing. The address on $AD_0$ - $AD_7$ and the state of $\overline{CS}_0$ and $\overline{INTACK}$ are latched by the rising edge of $\overline{AS}$ . R/W must be Low to indicate a Write cycle. $CS_1$ must be High for the Write cycle to occur. $\overline{DS}$ Low strobes the data into the Z-ASCC. Figure 11. Write Cycle Timing ## Interrupt Acknowledge Cycle Timing. Figure 12 illustrates Interrupt Acknowledge cycle timing. The address on AD<sub>0</sub>–AD<sub>7</sub> and the state of $\overline{\text{CS}_0}$ and $\overline{\text{INTACK}}$ are latched by the rising edge of $\overline{AS}$ . However, if $\overline{INTACK}$ is Low, the address and $\overline{CS}_0$ are ignored. The state of the $R/\overline{W}$ and $CS_1$ are also ignored for the duration of the Interrupt Acknowledge ### Timing (Continued) cycle. Between the rising edge of $\overline{AS}$ and the falling edge of $\overline{DS}$ , the internal and external IEI/IEO daisy chains settle. If there is an interrupt pending in the Z-ASCC and IEI is High when $\overline{DS}$ falls, the Acknowledge cycle was intended for the Z-ASCC. In this case, the $\overline{Z}$ -ASCC may be programmed to respond to $\overline{DS}$ Low by placing its interrupt vector on AD<sub>0</sub>-AD<sub>7</sub>. It then sets the appropriate Interrupt-Under-Service latch internally. Figure 12. Interrupt Acknowledge Cycle Timing ### Absolute Maximum Ratings 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 characteristics below apply for the following standard test conditions, unless otherwise noted. All voltages are referenced to GND. Positive current flows into the referenced pin. Standard conditions are as follows: - $\blacksquare$ GND = 0 V - T<sub>A</sub> as specified in Ordering Information All ac parameters assume a load capacitance of 50 pF max. Figure 13. Standard Test Load Figure 14. Open-Drain Test Load | DC | Symbol | Parameter | Min | Max | Unit | Condition | |----------------------|---------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------|--------------------|----------------------------------------------------------------|------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Charac-<br>teristics | $\begin{array}{c} V_{IH} \\ V_{IL} \\ V_{OH} \\ V_{OL} \\ I_{IL} \\ I_{OL} \\ I_{CC} \end{array}$ | Input High Voltage Input Low Voltage Output High Voltage Output Low Voltage Input Leakage Output Leakage V <sub>CC</sub> Supply Current | 2.0<br>-0.3<br>2.4 | V <sub>CC</sub> + 0.3<br>0.8<br>0.4<br>± 10.0<br>± 10.0<br>250 | V<br>V<br>V<br>V<br>μA<br>μA<br>mA | $\begin{split} &I_{\rm OH} = -250 \; \mu \text{A} \\ &I_{\rm OL} = +2.0 \; \text{mA} \\ &0.4 \leq V_{\rm IN} \leq +2.4 \text{V} \\ &0.4 \leq V_{\rm OUT} \leq +2.4 \text{V} \end{split}$ | V<sub>CC</sub> = 5 V ± 5% unless otherwise specified, over specified temperature range | Capacitance | Symbol | Parameter | Min | Мах | Unit | Test Condition | |-------------|-----------------------------------------------------------|---------------------------|-----|-----|------|--------------------| | | C <sub>tM</sub> | Input Capacitance | | 10 | ηg | Unmeasured Pins | | | $C_{\mathrm{IN}} \\ C_{\mathrm{OUT}} \\ C_{\mathrm{I/O}}$ | Output Capacitance | | 15 | рF | Returned to Ground | | | $C_{I/O}$ | Bidirectional Capacitance | | 20 | рF | | f = 1 MHz, over specified temperature range Read and Write Timing | No. | Symbol | Parameter | 4 MHz<br>Min Max | 6 MHz<br>Min Max | Notes*† | |-----|----------------|------------------------------------------------------------------|------------------|-----------------------------|---------| | 1 | TwAS | ĀS Low Width | 70 | 50 | | | 2 | TdDS(AS) | DS to AS Delay | 50 | 25 | | | 3 | TsCSO(AS) | CS <sub>0</sub> to AS † Setup Time | 0 | 0 | 1 | | 4 | ThCSO(AS) | CSo to AS Setup Time | 60 | 40 | i | | 5- | - TsCS1(DS) | — CS <sub>1</sub> to $\overline{\rm DS}$ Setup Time | 100 | | | | 6 | ThCS1(DS) | $CS_1$ to $\overline{DS}$ † Hold Time | 55 | 40 | i | | 7 | TsIA(AS) | INTACK to AS † Setup Time | 0 | 0 | - | | 8 | ThIA(AS) | INTACK to AS † Hold Time | 250 | 250 | | | 9 | TsRWR(DS) | $R/\overline{W}$ (Read) to $\overline{DS} \downarrow Setup Time$ | 100 | 80 | | | | - ThRW(DS) | - R/W to DS † Hold Time | 55 | <del> 4</del> 0 <del></del> | | | 11 | TsRWW(DS) | R/W (Write) to DS ↓ Setup Time | 0 | 0 | | | 12 | TdAS(DS) | AS ↑ to DS ↓ Delay | 60 | 40 | | | 13 | TwDS1 | DS Low Width | 390 | 250 | | | 14 | TrC | Valid Access Recovery Time | 6TcPC | 6TcPC | 2 | | | | <u> </u> | + 200 | + 130 | | | | — TsA(AS) ——— | — Address to $\overline{\overline{\rm AS}}$ † Setup Time ———— | 30 | 10 | l | | 16 | ThA(AS) | Address to AS 1 Hold Time | 50 | 30 | 1 | | 17 | TsDW(DS) | Write Data to $\overline{\rm DS}$ Setup Time | 30 | 20 | | | 18 | ThDW(DS) | Write Data to DS † Hold Time | 30 | 20 | | | 19 | TdDS(DA) | DS ↓ to Data Active Delay | 0 | 0 | | | | — TdDSr(DR) —— | — DS to Read Data Not Valid Delay ——— | 0 | 0 | | | 21 | TdDSf(DR) | DS I to Read Data Valid Delay | 250 | 180 | | | 22 | TdAS(DR) | AS † to Read Data Valid Delay | 520 | 335 | | NOTES. 1. Parameter does not apply to Interrupt Acknowledge transactions. 2. Parameter applies only between transactions involving the Z-ASCC \*Timings are preliminary and subject to change. † Units in nanoseconds (ns). | | | _ | _ | MHz | _ | MHz | | |------|----------------|------------------------------------------------------------|-----------------|-------------|-----------------|-------------|---------| | No. | Symbol | Parameter | Min | Мах | Min | Мах | Notes*† | | 23 | TdDS(DRz) | DS † to Read Data Float Delay | | 70 | | 45 | 3 | | 24 | TdA(DR) | Address Required Valid to Read Data Valid Delay | | 570 | | 420 | | | 25 | TdDS(W) | DS I to Wait Valid Delay | | 240 | | 200 | 4 | | 26 | TdDSf(REQ) | DS I to W/REO Not Valid Delay | | 240 | | 200 | | | 27 - | - TdDSr(REO) - | | | - 5TcPC - | | - 5TcPC - | | | | ,, | | | +300 | | + 250 | | | 28 | TdAS(INT) | AS t to INT Valid Delay | | 500 | | 500 | 4 | | 29 | TdAS(DSA) | $\overline{AS}$ † to $\overline{DS}$ ↓ (Acknowledge) Delay | | | | | 5 | | 30 | TwDSA | DS (Acknowledge) Low Width | 390 | | 250 | | | | 31 | TdDSA(DR) | DS (Acknowledge) to Read Data Valid Delay | | 250 | | 180 | | | 32 — | - TsIEI(DSA) | | <del></del> 120 | | <del></del> 100 | | | | 33 | ThIEI(DSA) | IEI to DS † (Acknowledge) Hold Time | 0 | | 0 | | | | 34 | TdIEI(IEO) | IEI to IEO Delay | | 120 | | 100 | | | 35 | TdAS(IEO) | AS † to IEO Delay | | 250 | | 250 | 6 | | 36 | TdDSA(INT) | DS (Acknowledge) to INT Inactive Delay | | 500 | | 500 | 4 | | 37 — | - TdDS(ASQ) | — DS ↑ to AS ↓ Delay for No Reset ————— | <del> 30</del> | | 15 | | | | 38 | TdASQ(DS) | AS ↑ to DS ↓ Delay for No Reset | 30 | | 30 | | | | 39 | TwRES | AS and DS Coincident Low for Reset | 250 | | 250 | | 7 | | 40 | TwPC1 | PCLK Low Width | 105 | 2000 | 70 | 1000 | | | 41 | TwPCh | PCLK High Width | 105 | 2000 | 70 | 1000 | | | 42 - | - TcPC | — PCLK Cycle Time ————— | <del> 250</del> | <del></del> | <del></del> 165 | <del></del> | | | 43 | TrPC | PCLK Rise Time | | 20 | | 15 | | | 44 | TfPC | PCLK Fall Time | | 20 | | 10 | | ### NOTES. - 3. Float delay is defined as the time required for a $\pm 0.5 \text{ V}$ change in the output with a maximum dc load and minimum ac load. - 4. Open-drain output, measured with open-drain test load. - 5. Parameter is system dependent. For any Z-ASCC in the daisy chain, TdAS(DSA) must be greater than the sum of TdAS(IEO) for the highest priority device in the daisy chain, TsIEI(DSA) for the Z-ASCC, and TdIEIf(IEO) for each device separating them in the daisy chain. - 6. Parameter applies only to a Z-ASCC pulling INT Low at the beginning of the Interrupt Acknowledge transaction. - Internal circuitry allows for the reset provided by the Z8 to be recognized as a reset by the Z-ASCC - \* Timings are preliminary and subject to change. All timing references assume 2.0 V for a logic "1" and 0.8 V for a logic "0". - † Units in nanoseconds (ns). 2245-007 | | | | 4 | MHz | 6 1 | MHz | | |------|-----------------|---------------------------------------------------------------------------------------|-----------------|------------------------------|-------------|-------------|---------------------| | No. | Symbol | Parameter | Min | Max | Min | Max | Notes*† | | 1 | TdPC(REQ) | PCLK to W/REQ Valid | | 250 | | 250 | | | 2 | TdPC(W) | PCLK ↓ to Wait Inactive Delay | | 350 | | 350 | | | 3 | TsRXC(PC) | RxC † to PCLK † Setup Time | 50 | | 50 | | 1,4 | | 4 | TsRXD(RXCr) | RxD to $\overline{RxC}$ † Setup Time (X1 Mode) | 0 | | 0 | | 1 | | 5 — | – ThRXD(RXCr) – | - RxD to $\overline{\text{RxC}}$ † Hold Time (X1 Mode) | 150 <del></del> | | 150 | | 1 | | 6 | TsRXD(RXCf) | RxD to $\overline{RxC}$ Setup Time (X1 Mode) | 0 | | 0 | | 1,5 | | 7 | ThRXD(RXCf) | $RxD$ to $\overline{RxC} \downarrow Hold Time (X1 Mode)$ | 150 | | 150 | | 1,5 | | 8 | TsTXC(PC) | TxC ↓ to PCLK ↑ Setup Time | 0 | | 0 | | 2,4 | | 9 | TdTXCf(TXD) | TxC ↓ to TxD Delay (X1 Mode) | | 300 | | 300 | 2 | | 10 — | - TdTXCr(TXD) - | TxC † to TxD Delay (X1 Mode) | | 300 | | — 300 — | —— 2,5 <del>—</del> | | 11 | TdTXD(TRX) | TxD to TRxC Delay (Send Clock Echo) | | | | | | | 12 | TwRTXh | RTxC High Width | 180 | | 180 | | | | 13 | TwRTX1 | RTxC Low Width | 180 | | 180 | | | | 14 | TcRTX | RTxC Cycle Time | 400 | | 400 | | | | 15 — | - TcRTXX | Crystal Oscillator Period — | 250 — | <del></del> 1000 <del></del> | <del></del> | <del></del> | 3 <del></del> | | 16 | TwTRXh | TRxC High Width | 180 | | 180 | | | | 17 | TwTRX1 | TRxC Low Width | 180 | | 180 | | | | 18 | TcTRX | TRxC Cycle Time | 400 | | 400 | | | | 19 | TwEXT | $\overline{ ext{DCD}}$ or $\overline{ ext{CTS}}$ or $\overline{ ext{RI}}$ Pulse Width | 200 | | 200 | | | NOTES 1 $\overline{RxC}$ is $\overline{RTxC}$ or $\overline{TRxC}$ , whichever is supplying the receive clock 2 TxC is TRxC or RTxC, whichever is supplying the transmit clock Both RTxC and RI have 30 pf capacitors to the ground connected to them <sup>4</sup> Parameter applies only if the data rate is one-fourth the PCLK rate. In all other cases, no phase relationship between RxC and PCLK or TxC and PCLK is required. 5 Parameter applies only to FM encoding/decoding. 5 Timings are preliminary and subject to change. † Units in nanoseconds (ns) | | | | 4 | MHz | 6 1 | MHz | | |-----|----------------|---------------------------------------------------------------------------------------------------------------------------|---------|---------------|---------|----------|------------| | No. | Symbol | Parameter | Min | Max | Min | Max | Notes* | | 1 | TdRXC(REQ) | RxC t to W/REQ Valid Delay | 8 | 12 | 8 | 12 | 2,4 | | 2 | TdRXC(W) | RxC † to Wait Inactive Delay | 8 | 12 | 8 | 12 | 1,2,4 | | 3 | TdRXC(INT) | RxC † INT Valid Delay | 8<br>+2 | 12<br>+3 | 8<br>+2 | 12<br>+3 | 1,2,4<br>5 | | 4 - | — TdTXC(REQ) — | — TxC ↓ to W/REQ Valid Delay ————— | 5 | <del></del> 8 | 5 — | — 8 — | 3,4 | | 5 | TdTXC(W) | TxC ↓ to Wait Inactive Delay | 5 | 8 | 5 | 8 | 1,3,4 | | 6 | TdTXC(DRQ) | TxC ↓ to DTR/REQ Valid Delay | 4 | 7 | 4 | 7 | 3,4 | | 7 | TdTXC(INT) | TxC ↓ to INT Valid Delay | 4<br>+2 | 6<br>+3 | 4<br>+2 | 6<br>+3 | 1,3,4<br>5 | | 8 | TdEXT(INT) | $\overline{ ext{DCD}}$ , $\overline{ ext{RI}}$ or $\overline{ ext{CTS}}$ Transition to $\overline{ ext{INT}}$ Valid Delay | 2 | 3 | 2 | 3 | 1,5 | NOTES. 1 Open-drain output, measured with open-drain test load. 2. RxC is RTxC or TRxC, whichever is supplying the receive clock. 3. TxC is TRxC or RTxC, whichever is supplying the transmit clock. <sup>4.</sup> Units equal to TcPC. 5. Units equal to ĀS. \* Timings are preliminary and subject to change. | Ordering<br>Information | Product<br>Number | Package/<br>Temp | Speed | Description | Product<br>Number | Package/<br>Temp | Speed | Description | |-------------------------|-------------------|------------------|---------|-----------------|-------------------|------------------|---------|-----------------| | | Z8031 | CE | 4.0 MHz | Z-ASCC (40-pin) | Z8031A | CE | 6.0 MHz | Z-ASCC (40-pin) | | | Z8031 | CM | 4.0 MHz | Same as above | Z8031 <b>A</b> | CM | 6.0 MHz | Same as above | | | Z8031 | CMB | 4.0 MHz | Same as above | Z8031 <b>A</b> | CMB | 6.0 MHz | Same as above | | | Z8031 | CS | 4.0 MHz | Same as above | Z8031 <b>A</b> | CS | 6.0 MHz | Same as above | | | Z8031 | DE | 4.0 MHz | Same as above | Z8031 <b>A</b> | DE | 6.0 MHz | Same as above | | | Z8031 | DS | 4.0 MHz | Same as above | Z8031A | DS | 6.0 MHz | Same as above | | | Z8031 | PE | 4.0 MHz | Same as above | Z8031A | PE | 6.0 MHz | Same as above | | | Z8031 | PS | 4.0 MHz | Same as above | Z8031 <b>A</b> | PS | 6.0 MHz | Same as above | NOTES C = Ceramic, D = Cerdip, P = Plastic, E = -40 °C to +85 °C, M = -55 °C to 125 °C, MB = -55 °C to +125 °C with MIL-STD-883 with Class B processing, S = 0 °C to +70 °C 00-2245-01 ## Z8036 Z8000<sup>™</sup>Z-CIO Counter/Timer and Parallel I/O Unit # **Product Specification** June 1982 ### Features - Two independent 8-bit, double-buffered, bidirectional I/O ports plus a 4-bit special-purpose I/O port. I/O ports feature programmable polarity, programmable direction (Bit mode), "pulse catchers," and programmable opendrain outputs. - Four handshake modes, including 3-Wire (like the IEEE-488). - REQUEST/WAIT signal for high-speed data transfer. - Flexible pattern-recognition logic, programmable as a 16-vector interrupt controller. - Three independent 16-bit counter/timers with up to four external access lines per counter/timer (count input, output, gate, and trigger), and three output duty cycles (pulsed, one-shot, and square-wave), programmable as retriggerable or nonretriggerable. - Easy to use since all registers are read/write and directly addressable. ### General Description The Z8036 Z-CIO Counter/Timer and Parallel I/O element is a general-purpose peripheral circuit, satisfying most counter/timer and parallel I/O needs encountered in system designs. This versatile device contains three I/O ports and three counter/timers. Many programmable options tailor its configuration to specific applications. The use of the device is simplified by making all internal registers (command, status, and data) readable and (except for status bits) writable. In addition, each register is given its own unique address so that it can be accessed directly—no special sequential operations are required. The Z-CIO is directly Z-Bus compatible. Figure 1. Pin Functions Figure 2. Pin Assignments ### Pin Description **AD<sub>0</sub>-AD<sub>7</sub>.** Z-Bus Address/Data lines (bidirectional/3-state). These multiplexed Address/Data lines are used for transfers between the CPU and Z-CIO. Address Strobe (input, active Low). Addresses, INTACK, and CS<sub>0</sub> are sampled while AS is Low. $\overline{\text{CS}_0}$ and $\text{CS}_1$ . Chip Select 0 (input, active Low) and Chip Select 1 (input, active High). $\overline{\text{CS}_0}$ and $\text{CS}_1$ must be Low and High, respectively, in order to select a device. $\overline{\text{CS}_0}$ is latched by $\overline{\text{AS}}$ . **DS\*.** Data Strobe (input, active Low). $\overline{DS}$ provides timing for the transfer of data into or out of the Z-CIO. **IEI.** Interrupt Enable In (input, active High). IEI is used with IEO to form an interrupt daisy chain when there is more than one interrupt-driven device. A High IEI indicates that no other higher priority device has an interrupt under service or is requesting an interrupt. **IEO.** Interrupt Enable Out (output, active High). IEO is High only if IEI is High and the CPU is not servicing an interrupt from the requesting Z-CIO or is not requesting an interrupt (Interrupt Acknowledge cycle only). IEO is connected to the next lower priority device's IEI input and thus inhibits interrupts from lower priority devices. \*When $\overline{AS}$ and $\overline{DS}$ are detected Low at the same time (normally an illegal condition), the Z-CIO is reset **INT.** Interrupt Request (output, open-drain, active Low). This signal is pulled Low when the Z-CIO requests an interrupt. **INTACK.** Interrupt Acknowledge (input, active Low). This signal indicates to the Z-CIO that an Interrupt Acknowledge cycle is in progress. INTACK is sampled while AS is Low. **PA<sub>0</sub>-PA<sub>7</sub>.** Port A I/O lines (bidirectional, 3-state, or open-drain). These eight I/O lines transfer information between the Z-CIO's Port A and external devices. **PB<sub>0</sub>-PB<sub>7</sub>.** Port B I/O lines (bidirectional, 3-state, or open-drain). These eight I/O lines transfer information between the Z-CIO's Port B and external devices. May also be used to provide external access to Counter/Timers 1 and 2. **PC<sub>0</sub>-PC<sub>3</sub>.** Port C I/O lines (bidirectional, 3-state, or open-drain). These four I/O lines are used to provide handshake, WAIT, and REQUEST lines for Ports A and B or to provide external access to Counter/Timer 3 or access to the Z-CIO's Port C. **PCLK.** (input, TTL-compatible). This is a peripheral clock that may be, but is not necessarily, the CPU clock. It is used with timers and REQUEST/WAIT logic. $\mathbf{R}/\overline{\mathbf{W}}$ . Read/Write (input). R/ $\overline{\mathbf{W}}$ indicates that the CPU is reading from (High) or writing to (Low) the Z-CIO. ### Architecture The Z8036 Z-CIO Counter/Timer and Parallel I/O element (Figure 3) consists of a Z-Bus interface, three I/O ports (two general-purpose 8-bit ports and one special-purpose Figure 3. Z-CIO Block Diagram # Architecture (Continued) 4-bit port), three 16-bit counter/timers, an interrupt control logic block, and the internal control logic block. An extensive number of programmable options allow the user to tailor the configuration to best suit the specific application. The two general-purpose 8-bit I/O ports (Figure 4) are identical, except that Port B can be specified to provide external access to Counter/Timers 1 and 2. Either port can be programmed to be a handshake-driven, double-buffered port (input, output, or bidirectional) or a control-type port with the direction of each bit individually programmable. Each port includes pattern-recognition logic, allowing interrupt generation when a specific pattern is detected. The pattern-recognition logic can be programmed so the port functions like a priority-interrupt controller. Ports A and B can also be linked to form a 16-bit I/O port. To control these capabilities, both ports contain 12 registers. Three of these registers, the Input, Output, and Buffer registers, comprise the data path registers. Two registers, the Mode Specification and Handshake Specification registers, are used to define the mode of the port and to specify which handshake, if any, is to be used. The reference pattern for the pattern-recognition logic is defined via three registers: the Pattern Polarity, Pattern Transition, and Pattern Mask registers. The detailed characteristics of each bit path (for example, the direction of data flow or whether a path is inverting or noninverting) are programmed using the Data Path Polarity, Data Direction, and Special I/O Control registers. The primary control and status bits are grouped in a single register, the Command and Status register, so that after the port is initially configured, only this register must be accessed frequently. To facilitate initialization, the port logic is designed so that registers associated with an unrequired capability are ignored and do not have to be programmed. Figure 4. Ports A and B Block Diagram Architecture (Continued) The function of the special-purpose 4-bit port, Port C (Figure 5), depends upon the roles of Ports A and B. Port C provides the required handshake lines. Any bits of Port C not used as handshake lines can be used as I/O lines or to provide external access for the third counter/timer. Since Port C's function is defined primarily by Ports A and B, only three registers (besides the Data Input and Output registers) are needed. These registers specify the details of each bit path: the Data Path Polarity, Data Direction, and Special I/O Control registers. The three counter/timers (Figure 6) are all identical. Each is comprised of a 16-bit down-counter, a 16-bit Time Constant register (which holds the value loaded into the down-counter), a 16-bit Current Counter register (used to read the contents of the down-counter), and two 8-bit registers for control and status (the Mode Specification and the Command and Status registers). The capabilities of the counter/timer are numerous. Up to four port I/O lines can be dedicated as external access lines for each counter/timer: counter input, gate input, trigger input, and counter/timer output. Three different counter/timer output duty cycles are available: pulse, one-shot, or square-wave. The operation of the counter/timer can be programmed as either retriggerable or nonretriggerable. With these and other options, most counter/timer applications are covered. The interrupt control logic provides standard Z-Bus interrupt capabilities. There are five registers (Master Interrupt Control register, three Interrupt Vector registers, and the Current Vector register) associated with the interrupt logic. In addition, the ports' Command and Status registers and the counter/timers' Command and Status registers include bits associated with the interrupt logic. Each of these registers contains three bits for interrupt control and status: Interrupt Pending (IP), Interrupt Under Service (IUS), and Interrupt Enable (IE). Figure 5. Port C Block Diagram Architecture (Continued) Figure 6. Counter/Timer Block Diagram ### Functional Description The following describes the functions of the ports, pattern-recognition logic, counter/timers, and interrupt logic. I/O Port Operations. Of the Z-CIO's three I/O ports, two (Ports A and B) are generalpurpose, and the third (Port C) is a specialpurpose 4-bit port. Ports A and B can be configured as input, output, or bidirectional ports with handshake. (Four different handshakes are available.) They can also be linked to form a single 16-bit port. If they are not used as ports with handshake, they provide 16 input or output bits with the data direction programmable on a bit-by-bit basis. Port B also provides access for Counter/Timers 1 and 2. In all configurations. Ports A and B can be programmed to recognize specific data patterns and to generate interrupts when the pattern is encountered. The four bits of Port C provide the handshake lines for Ports A and B when required. A REQUEST/WAIT line can also be provided so that Z-CIO transfers can be synchronized with DMAs or CPUs. Any Port C bits not used for handshake or REQUEST/WAIT can be used as input or output bits (individually data direction programmable) or external access lines for Counter/Timer 3. Port C does not contain any pattern-recognition logic. It is, however, capable of bit-addressable writes. With this feature, any combination of bits can be set and/or cleared while the other bits remain undisturbed without first reading the register. Bit Port Operations. In bit port operations, the port's Data Direction register specifies the direction of data flow for each bit. A 1 specifies an input bit, and a 0 specifies an output bit. If bits are used as I/O bits for a counter/timer, they should be set as input or output, as required. The Data Path Polarity register provides the capability of inverting the data path. A 1 specifies inverting, and a 0 specifies non-inverting. All discussions of the port operations assume that the path is noninverting. The value returned when reading an input bit reflects the state of the input just prior to the read. A 1's catcher can be inserted into the input data path by programming a 1 to the corresponding bit position of the port's Special I/O Control register. When a 1 is detected at the 1's catcher input, its output is set to a 1 until it is cleared. The 1's catcher is cleared by writing a 0 to the bit. In all other cases, attempted writes to input bits are ignored. When Ports A and B include output bits, reading the Data register returns the value being output. Reads of Port C return the state of the pin. Outputs can be specified as opendrain by writing a 1 to the corresponding bit of the port's Special I/O Control register. Port C has the additional feature of bit-addressable writes. When writing to Port C, the four most significant bits are used as a write protect mask for the least significant bits (0-4, 1-5, 2-6, and 3-7). If the write protect bit is written with a 1, the state of the corresponding output bit is not changed. # Functional Description (Continued) Ports with Handshake Operation. Ports A and B can be specified as 8-bit input, output, or bidirectional ports with handshake. The Z-CIO provides four different handshakes for its ports: Interlocked, Strobed, Pulsed, and 3-Wire. When specified as a port with handshake, the transfer of data into and out of the port and interrupt generation is under control of the handshake logic. Port C provides the handshake lines as shown in Table 1. Any Port C lines not used for handshake can be used as simple I/O lines or as access lines for Counter/Timer 3. When Ports A and B are configured as ports with handshake, they are double-buffered. This allows for more relaxed interrupt service routine response time. A second byte can be input to or output from the port before the interrupt for the first byte is serviced. Normally, the Interrupt Pending (IP) bit is set and an interrupt is generated when data is shifted into the Input register (input port) or out of the Output register (output port). For input and output ports, the IP is automatically cleared when the data is read or written. In bidirectional ports, IP is cleared only by command. When the Interrupt on Two Bytes (ITB) control bit is set to 1, interrupts are generated only when two bytes of data are available to be read or written. This allows a minimum of 16 bits of information to be transferred on each interrupt. With ITB set, the IP is not automatically cleared until the second byte of data is read or When the Single Buffer (SB) bit is set to 1, the port acts as if it is only single-buffered. This is useful if the handshake line must be stopped on a byte-by-byte basis. Ports A and B can be linked to form a 16-bit port by programming a 1 in the Port Link Control (PLC) bit. In this mode, only Port A's Handshake Specification and Command and Status registers are used. Port B must be specified as a bit port. When linked, only Port A has pattern-match capability. Port B's pattern-match capability must be disabled. Also, when the ports are linked, Port B's Data register must be read or written before Port A's. When a port is specified as a port with handshake, the type of port it is (input, output, or bidirectional) determines the direction of data flow. The data direction for the bidirectional port is determined by a bit in Port C (Table 1). In all cases, the contents of the Data Direction register are ignored. The contents of the Special I/O Control register apply only to output bits (3-state or open-drain). Inputs may not have I's catchers; therefore, those bits in the Special I/O Control register are ignored. Port C lines used for handshake should be programmed as inputs. The handshake specification overrides Port C's Data Direction register for bits that must be outputs. The contents of Port C's Data Path Polarity register still apply. Interlocked Handshake. In the Interlocked Handshake mode, the action of the Z-CIO must be acknowledged by the external device before the next action can take place. Figure 7 shows timing for Interlocked Handshake. An output port does not indicate that new data is available until the external device indicates it is ready for the data. Similarly, an input port does not indicate that it is ready for new data until the data source indicates that the previous byte of the data is no longer available. thereby acknowledging the input port's acceptance of the last byte. This allows the Z-CIO to interface directly to the port of a Z8 microcomputer, a UPC, an FIO, an FIFO, or to another Z-CIO port with no external logic. A 4-bit deskew timer can be inserted in the Data Available $(\overline{DAV})$ output for output ports. As data is transferred to the Buffer register, the deskew timer is triggered. After the number of PCLK cycles specified by the deskew timer time constant plus one, $\overline{DAV}$ is | Port A/B Configuration | PC <sub>3</sub> | PC <sub>2</sub> | $PC_1$ | PC <sub>0</sub> | |---------------------------------------------------------------------------------|----------------------------|-----------------|----------------------------|-----------------| | Ports A and B: Bit Ports | Bıt I/O | Bit I/O | Bıt I/O | Bit I/O | | Port A: Input or Output Port<br>(Interlocked, Strobed, or Pulsed<br>Handshake)* | RFD or DAV | ACKIN | REQUEST/WAIT<br>or Bit I/O | Bit I/O | | Port B: Input or Output Port<br>(Interlocked, Strobed, or Pulsed<br>Handshake)* | REQUEST/WAIT<br>or Bit I/O | Bıt I/O | RFD or DAV | ACKIN | | Port A or B: Input Port (3-Wire Handshake) | RFD (Output) | DAV (Input) | REQUEST/WAIT or Bit I/O | DAC (Output) | | Port A or B: Output Port (3-Wire Handshake) | DAV (Output) | DAC (Input) | REQUEST/WAIT or Bit I/O | RFD (Input) | | Port A or B: Bidirectional Port<br>(Interlocked or Strobed Handshake) | RFD or DAV | ACKIN | REQUEST/WAIT<br>or Bit I/O | IN/OUT | <sup>\*</sup>Both Ports A and B can be specified input or output with Interlocked, Strobed, or Pulsed Handshake at the same time if neither uses REQUEST/WAIT. Table 1. Port C Bit Utilization # Functional Description (Continued) allowed to go Low. The deskew timer therefore guarantees that the output data is valid for a specified minimum amount of time before $\overline{\rm DAV}$ goes Low. Deskew timers are available for output ports independent of the type of handshake employed. Strobed Handshake. In the Strobed Handshake mode, data is "strobed" into or out of the port by the external logic. The falling edge of the Acknowledge Input ( $\overline{ACKIN}$ ) strobes data into or out of the port. Figure 7 shows timing for the Strobed Handshake. In contrast to the Interlocked Handshake, the signal indicating the port is ready for another data transfer operates independently of the $\overline{ACKIN}$ input. It is up to the external logic to ensure that data overflows or underflows do not occur. 3-Wire Handshake. The 3-Wire Handshake is designed for the situation in which one output port is communicating with many input ports simultaneously. It is essentially the same as the Interlocked Handshake, except that two signals are used to indicate if an input port is ready for new data or if it has accepted the present data. In the 3-Wire Handshake (Figure 8), the rising edge of one status line indicates that the port is ready for data, and the rising edge of another status line indicates that the data has been accepted. With the 3-Wire Handshake, the output lines of many input ports can be bussed together with open-drain drivers; the output port knows when all the ports have accepted the data and are ready. This is the same handshake as is used on the IEEE-488 bus. Because this handshake requires three lines, only one port (either A or B) can be a 3-Wire Handshake port at a time. The 3-Wire Handshake is not available in the bidirectional mode. Because the port's direction can be changed under software control, however, bidirectional IEEE-488-type transfers can be performed. Pulsed Handshake. The Pulsed Handshake (Figure 9) is designed to interface to mechanical-type devices that require data to be held for long periods of time and need relatively wide pulses to gate the data into or out of the device. The logic is the same as the Interlocked Handshake mode, except that an internal counter/timer is linked to the handshake logic. If the port is specified in the input mode, the timer is inserted in the ACKIN path. The external $\overline{\text{ACKIN}}$ input triggers the timer and its output is used as the Interlocked Handshake's normal acknowledge input. If the port is an output port, the timer is placed in the Data Available $(\overline{DAV})$ output path. The timer is triggered when the normal Interlocked Handshake DAV output goes Low and the timer output is used as the actual DAV output. The counter/timer maintains all of its normal capabilities. This handshake is not available to bidirectional ports. Figure 7. Interlocked and Strobed Handshakes Figure 8. 3-Wire Handshake # Functional Description (Continued) REOUEST/WAIT Line Operation. Port C can be programmed to provide a status signal output in addition to the normal handshake lines for either Port A or B when used as a port with handshake. The additional signal is either a REQUEST or WAIT signal. The REQUEST signal indicates when a port is ready to perform a data transfer via the Z-Bus. It is intended for use with a DMA-type device. The WAIT signal provides synchronization for transfers with a CPU. Three bits in the Port Handshake Specification register provide controls for the REOUEST/WAIT logic. Because the extra Port C line is used, only one port can be specified as a port with a handshake and a REQUEST/WAIT line. The other port must be a bit port. Operation of the REQUEST line is modified by the state of the port's Interrupt on Two Bytes (ITB) control bit. When ITB is 0, the REQUEST line goes active as soon as the Z-CIO is ready for a data transfer. If ITB is 1, REQUEST does not go active until two bytes can be transferred. REQUEST stays active as long as a byte is available to be read or written. The SPECIAL REQUEST function is reserved for use with bidirectional ports only. In this case, the REQUEST line indicates the status of the register not being used in the data path at that time. If the IN/OUT line is High, the REQUEST line is High when the Output register is empty. If IN/OUT is Low, the REQUEST line is High when the Input register is full. Pattern-Recognition Logic Operation. Both Ports A and B can be programmed to generate interrupts when a specific pattern is recognized at the port. The pattern-recognition logic is independent of the port application, thereby allowing the port to recognize patterns in all of its configurations. The pattern can be independently specified for each bit as 1, 0, rising edge, falling edge, or any transition. Individual bits may be masked off. A patternmatch is defined as the simultaneous satisfaction of all nonmasked bit specifications in the AND mode or the satisfaction of any nonmasked bit specifications in either of the OR or OR-Priority Encoded Vector modes. Figure 9. Pulsed Handshake The pattern specified in the Pattern Definition register assumes that the data path is programmed to be noninverting. If an input bit in the data path is programmed to be inverting, the pattern detected is the opposite of the one specified. Output bits used in the patternmatch logic are internally sampled before the invert/noninvert logic. Bit Port Pattern-Recognition Operations. During bit port operations, pattern-recognition may be performed on all bits, including those used as I/O for the counter/timers. The input to the pattern-recognition logic follows the value at the pins (through the invert/noninvert logic) in all cases except for simple inputs with l's catchers. In this case, the output of the l's catcher is used. When operating in the AND or OR mode, it is the transition from a nomatch to a match state that causes the interrupt. In the "OR" mode, if a second match occurs before the first match goes away, it does not cause an interrupt. Since a match condition only lasts a short time when edges are specified, care must be taken to avoid losing a match condition. Bit ports specified in the OR-Priority Encoded Vector mode generate interrupts as long as any match state exists. A transition from a no-match to a match state is not required. The pattern-recognition logic of bit ports operates in two basic modes: Transparent and Latched. When the Latch on Pattern Match (LPM) bit is set to 0 (Transparent mode), the interrupt indicates that a specified pattern has occurred, but a read of the Data register does not necessarily indicate the state of the port at the time the interrupt was generated. In the Latched mode (LPM=1), the state of all the port inputs at the time the interrupt was generated is latched in the input register and held until IP is cleared. In all cases, the PMF indicates the state of the port at the time it is read. If a match occurs while IP is already set, an error condition exists. If the Interrupt On Error bit (IOE) is 0, the match is ignored. However, if IOE is 1, after the first IP is cleared, it is automatically set to 1 along with the Interrupt Error (ERR) flag. Matches occurring while ERR is set are ignored. ERR is cleared when the corresponding IP is cleared. When a pattern-match is present in the OR-Priority Encoded Vector mode, IP is set to 1. The IP cannot be cleared until a match is no longer present. If the interrupt vector is allowed to include status, the vector returned during Interrupt Acknowledge indicates the highest priority bit matching its specification at the time of the Acknowledge cycle. Bit 7 is the highest priority and bit 0 is the lowest. The bit initially causing the interrupt may not be the one indicated by the vector if a higher priority bit matches before the Acknowledge. Once the Acknowledge cycle is initiated, the vector is Functional Description (Continued) frozen until the corresponding IP is cleared. Where inputs that cause interrupts might change before the interrupt is serviced, the 1's catcher can be used to hold the value. Because a no-match to match transition is not required, the source of the interrupt must be cleared before IP is cleared or else a second interrupt is generated. No error detection is performed in this mode and the Interrupt On Error bit should be set to 0. Ports with Handshake Pattern-Recognition Operation. In this mode, the handshake logic normally controls the setting of IP and, therefore, the generation of interrupt requests. The pattern-match logic controls the Pattern Match Flag (PMF). The data is compared with the match pattern when it is shifted from the Buffer register to the Input register (input port) or when it is shifted from the Output register to the Buffer register (output port). The patternmatch logic can override the handshake logic in certain situations. If the port is programmed to interrupt when two bytes of data are available to be read or written, but the first byte matches the specified pattern, the pattern-recognition logic sets IP and generates an interrupt. While PMF is set, IP cannot be cleared by reading or writing the data registers. IP must be cleared by command. The input register is not emptied while IP is set, nor is the output register filled until IP is cleared. If the Interrupt on Match Only (IMO) bit is set, IP is set only when the data matches the pattern. This is useful in DMA-type applications when interrupts are required only after a block of data is transferred. Counter/Timer Operation. The three independent 16-bit counter/timers consist of a presettable 16-bit down counter, a 16-bit Time Constant register, a 16-bit Current Counter register, an 8-bit Mode Specification register, an 8-bit Command and Status register, and the associated control logic that links these registers. | Function | C/T <sub>1</sub> | C/T <sub>2</sub> | C/T <sub>3</sub> | | |----------------------|------------------|------------------|------------------|--| | Counter/Timer Output | PB 4 | PB 0 | PC 0 | | | Counter Input | PB 5 | PB 1 | PC 1 | | | Trigger Input | PB 6 | PB 2 | PC 2 | | | Gate Input | PB 7 | PB 3 | PC 3 | | Table 2. Counter/Timer External Access The flexibility of the counter/timers is enhanced by the provision of up to four lines per counter/timer (counter input, gate input, trigger input, and counter/timer output) for direct external control and status. Counter/ Timer 1's external I/O lines are provided by the four most significant bits of Port B. Counter/Timer 2's are provided by the four least significant bits of Port B. Counter/Timer 3's external I/O lines are provided by the four bits of Port C. The utilization of these lines (Table 2) is programmable on a bit-by-bit basis via the Counter/Timer Mode Specification registers. When external counter/timer I/O lines are to be used, the associated port lines must be vacant and programmed in the proper data direction. Lines used for counter/timer I/O have the same characteristics as simple input lines. They can be specified as inverting or noninverting; they can be read and used with the pattern-recognition logic. They can also include the 1's catcher input. Counter/Timers 1 and 2 can be linked internally in three different ways. Counter/Timer 1's output (inverted) can be used as Counter/Timer 2's trigger, gate, or counter input. When linked, the counter/timers have the same capabilities as when used separately. The only restriction is that when Counter/Timer 1 drives Counter/Timer 2's count input, Counter/Timer 2 must be programmed with its external count input disabled. There are three duty cycles available for the timer/counter output: pulse, one-shot, and square-wave. Figure 10 shows the counter/ Figure 10. Counter/Timer Waveforms Functional Description (Continued) timer waveforms. When the Pulse mode is specified, the output goes High for one clock cycle, beginning when the down-counter leaves the count of 1. In the One-Shot mode, the output goes High when the counter/timer is triggered and goes Low when the downcounter reaches 0. When the square-wave output duty cycle is specified, the counter/timer goes through two full sequences for each cycle. The initial trigger causes the downcounter to be loaded and the normal countdown sequence to begin. If a 1 count is detected on the down-counter's clocking edge, the output goes High and the time constant value is reloaded. On the clocking edge, when both the down-counter and the output are l's. the output is pulled back Low. The Continuous/Single Cycle (C/SC) bit in the Mode Specification register controls operation of the down-counter when it reaches terminal count. If C/SC is 0 when a terminal count is reached, the countdown sequence stops. If the C/SC bit is 1 each time the countdown counter reaches 1, the next cycle causes the time constant value to be reloaded. The time constant value may be changed by the CPU, and on reload, the new time constant value is loaded. Counter/timer operations require loading the time constant value in the Time Constant register and initiating the countdown sequence by loading the down-counter with the time constant value. The Time Constant register is accessed as two 8-bit registers. The registers are readable as well as writable, and the access order is irrelevant. A 0 in the Time Constant register specifies a time constant of 65,536. The down-counter is loaded in one of three ways: by writing a l to the Trigger Command Bit (TCB) of the Command and Status register, on the rising edge of the external trigger input, or, for Counter/Timer 2 only, on the rising edge of Counter/Timer 1's internal output if the counters are linked via the trigger input. The TCB is write-only, and read always returns 0. Once the down-counter is loaded, the countdown sequence continues toward terminal count as long as all the counter/timers' hardware and software gate inputs are High. If any of the gate inputs goes Low (0), the countdown halts. It resumes when all gate inputs are 1 again. The reaction to triggers occurring during a countdown sequence is determined by the state of the Retrigger Enable Bit (REB) in the Mode Specification register. If REB is 0, retriggers are ignored and the countdown continues normally. If REB is 1, each trigger causes the down-counter to be reloaded and the countdown sequence starts over again. If the output is programmed in the Square-Wave mode, retrigger causes the sequence to start over from the initial load of the time constant. The rate at which the down-counter counts is determined by the mode of the counter/timer. In the Timer mode (the External Count Enable [ECE] bit is 0), the down-counter is clocked internally by a signal that is half the frequency of the PCLK input to the chip. In the Counter mode (ECE is 1), the down-counter is decremented on the rising edge of the counter/timer's counter input. Each time the counter reaches terminal count, its Interrupt Pending (IP) bit is set to 1, and if interrupts are enabled (IE=1), an interrupt is generated. If a terminal count occurs while IP is already set, an internal error flag is set. As soon as IP is cleared, it is forced to a 1 along with the Interrupt Error (ERR) flag. Errors that occur after the internal flag is set are ignored. The state of the down-counter can be determined in two ways: by reading the contents of the down-counter via the Current Count register or by testing the Count In Progress (CIP) status bit in the Command and Status register. The CIP status bit is set when the down-counter is loaded; it is reset when the down-counter reaches 0. The Current Count register is a 16-bit register, accessible as two 8-bit registers, which mirrors the contents of the down-counter. This register can be read anytime. However, reading the register is asynchronous to the counter's counting, and the value returned is valid only if the counter is stopped. The down-counter can be reliably read "on the fly" by the first writing of a 1 to the Read Counter Control (RCC) bit in the counter/timer's Command and Status register. This freezes the value in the Current Count register until a read of the least significant byte is performed. Interrupt Logic Operation. The interrupts generated by the Z-CIO follow the Z-Bus operation as described more fully in the Zilog Z-Bus Summary. The Z-CIO has five potential sources of interrupts: the three counter/timers and Ports A and B. The priorities of these sources are fixed in the following order: Counter/Timer 3, Port A, Counter/Timer 2, Port B, and Counter/Timer 1. Since the counter/timers all have equal capabilities and Ports A and B have equal capabilities, there is no adverse impact from the relative priorities. The Z-CIO interrupt priority, relative to other components within the system, is determined by an interrupt daisy chain. Two pins, Interrupt Enable In (IEI) and Interrupt Enable Out (IEO), provide the input and output necessary to implement the daisy chain. When IEI is pulled Low by a higher priority device, # Functional Description (Continued) the Z-CIO cannot request an interrupt of the CPU. The following discussion assumes that the IEI line is High. Each source of interrupt in the Z-CIO contains three bits for the control and status of the interrupt logic: an Interrupt Pending (IP) status bit, an Interrupt Under Service (IUS) status bit, and an Interrupt Enable (IE) control bit. IP is set when an event requiring CPU intervention occurs. The setting of IP results in forcing the Interrupt ( $\overline{\text{INT}}$ ) output Low, if the associated IE is 1. The IUS status bit is set as a result of the Interrupt Acknowledge cycle by the CPU and is set only if its IP is of highest priority at the time the Interrupt Acknowledge commences. It can also be set directly by the CPU. Its primary function is to control the interrupt daisy chain. When set, it disables lower priority sources in the daisy chain, so that lower priority interrupt sources do not request servicing while higher priority devices are being serviced. The IE bit provides the CPU with a means of masking off individual sources of interrupts. When IE is set to 1, an interrupt is generated normally. When IE is set to 0, the IP bit is set when an event occurs that would normally require service; however, the $\overline{\text{INT}}$ output is not forced Low. The Master Interrupt Enable (MIE) bit allows all sources of interrupts within the Z-CIO to be disabled without having to individually set each IE to 0. If MIE is set to 0, all IPs are masked off and no interrupt can be requested or acknowledged. The Disable Lower Chain (DLC) bit is included to allow the CPU to modify the system daisy chain. When the DLC bit is set to 1, the Z-CIO's IEO is forced Low, independent of the state of the Z-CIO or its IEI input, and all lower priority devices' interrupts are disabled. As part of the Interrupt Acknowledge cycle. the Z-CIO is capable of responding with an 8-bit interrupt vector that specifies the source of the interrupt. The Z-CIO contains three vector registers: one for Port A, one for Port B, and one shared by the three counter/timers. The vector output is inhibited by setting the No Vector (NV) control bit to 1. The vector output can be modified to include status information to pinpoint more precisely the cause of interrupt. Whether the vector includes status or not is controlled by a Vector Includes Status (VIS) control bit. Each base vector has its own VIS bit and is controlled independently. When MIE = 1, reading the base vector register always includes status, independent of the state of the VIS bit. In this way, all the information obtained by the vector, including status, can be obtained with one additional instruction when VIS is set to 0. When MIE = 0, reading the vector register returns the unmodified base vector so that it can be verified. Another register, the Current Vector register, allows use of the Z-CIO in a polled environment. When read, the data returned is the same as the interrupt vector that would be output in an acknowledge, based on the highest priority IP set. If no unmasked IPs are set, the value FFH is returned. The Current Vector register is read-only. ### Programming Programming the Z-CIO entails loading control registers with bits to implement the desired operation. Individual enable bits are provided for the various major blocks so that erroneous operations do not occur while the part is being initialized. Before the ports are enabled, IPs cannot be set, REQUEST and WAIT cannot be asserted, and all outputs remain high-impedance. The handshake lines are ignored until Port C is enabled. The counter/timers cannot be triggered until their enable bits are set. The Z-CIO is reset by forcing AS and DS Low simultaneously or by writing a 1 to the Reset bit. Once reset, the only thing that can be done is to read and write the Reset bit. Writes to all other bits are ignored and all reads return 0s. In this state, all control bits are forced to 0. Only after clearing the Reset bit (by writing to it) can the other command bits be programmed. Register Addressing. The Z-CIO allows two schemes for register addressing. Both schemes use only six of the eight bits of the address/data bus. The scheme used is determined by the Right Justify Address (RJA) bit in the Master Interrupt Control register. When RJA equals 0, address bus bits 0 and 7 are ignored, and bits 1 through 6 are decoded for the register address (A<sub>0</sub> from AD<sub>1</sub>). When RJA equals 1, bits 0 through 5 are decoded for the register address (A<sub>0</sub> from AD<sub>0</sub>). In the following register descriptions, only six bits are shown for addresses and represent address/data bus bits 0 through 5 or 1 through 6, depending on the state of the RJA bit. # Registers ### Master Interrupt Control Register Address: 000000 (Read/Write) ### Master Configuration Control Register Address: 000001 (Read/Write) Figure 11. Master Control Registers ### Port Handshake Specification Registers Addresses: 100001 Port A 101001 Port B (Read/Write) ### Port Command and Status Registers Addresses: 001000 Port A 001001 Port B (Read/Partial Write) Figure 12. Port Specification Registers ### Registers **Data Path Polarity Registers Data Direction Registers** (Continued) Addresses: 100010 Port A Addresses: 100011 Port A 101010 Port B 101011 Port B 000110 Port C (4 LSBs only) 000101 Port C (4 LSBs only) (Read/Write) (Read/Write) D<sub>7</sub> | D<sub>6</sub> | D<sub>5</sub> | D<sub>4</sub> | D<sub>3</sub> | D<sub>2</sub> | D<sub>1</sub> | D<sub>0</sub> D<sub>7</sub> D<sub>6</sub> D<sub>5</sub> D<sub>4</sub> D<sub>3</sub> D<sub>2</sub> D<sub>1</sub> D<sub>0</sub> DATA DIRECTION (DD) 0 = OUTPUT BIT 1 = INPUT BIT DATA PATH POLARITY (DPP) 0 = NON-INVERTING 1 = INVERTING Special I/O Control Registers Addresses: 100100 Port A 101100 Port B 000111 Port C (4 LSBs only) (Read/Write) Figure 13. Bit Path Definition Registers D<sub>7</sub> D<sub>8</sub> D<sub>5</sub> D<sub>4</sub> D<sub>3</sub> D<sub>2</sub> D<sub>1</sub> D<sub>0</sub> SPECIAL INPUT/OUTPUT (SIO) 0 = NORMAL INPUT OR OUTPUT 1 = OUTPUT WITH OPEN DRAIN OR INPUT WITH 1's CATCHER Figure 14. Port Data Registers Figure 15. Pattern Definition Registers 2014-011, 012, 013 ### Registers Counter/Timer Command and Status Registers Addresses: 001010 Counter/Timer 1 (Continued) 001011 Counter/Timer 2 001100 Counter/Timer 3 (Read/Partial Write) D<sub>7</sub> D<sub>6</sub> D<sub>5</sub> D<sub>4</sub> D<sub>3</sub> D<sub>2</sub> D<sub>1</sub> D<sub>0</sub> COUNT IN PROGRESS (CIP) (READ ONLY) INTERRUPT UNDER SERVICE (IUS) TRIGGER COMMAND BIT (TCB) (WRITE ONLY - READ RETURNS 0) INTERRUPT ENABLE (IE) GATE COMMAND BIT (GCB) INTERRUPT PENDING (IP) IUS, IE, AND IP ARE WRITTEN USING THE FOLLOWING CODE: READ COUNTER CONTROL (RCC) (READ/SET ONLY — CLEARED BY READING CCR LSB) NULL CODE **CLEAR IP & IUS** 0 SET IUS CLEAR IUS SET IP CLEAR IP SET IE CLEAR IF INTERRUPT ERROR (ERR) (READ ONLY) Counter/Timer Mode Specification Registers Addresses: 011100 Counter/Timer 1 011101 Counter/Timer 2 011110 Counter/Timer 3 (Read/Write) D7 D6 D5 D4 D3 D2 D1 D0 OUTPUT DUTY CYCLE SELECTS (DCS) CONTINUOUS SIN-GLE CYCLE (C/SC) DCS1 DCS0 EXTERNAL OUTPUT ENABLE (EOE) PULSE OUTPUT ONE-SHOT OUTPUT SQUARE-WAVE OUTPUT DO NOT SPECIFY EXTERNAL COUNT ENABLE (ECE) EXTERNAL TRIGGER ENABLE (ETE) RETRIGGER ENABLE BIT (REB) EXTERNAL GATE ENABLE (EGE) Counter/Timer Current Count Registers Addresses: 010000 Counter/Timer 1's MSB 010001 Counter/Timer 1's LSB 010010 Counter/Timer 2's MSB 010011 Counter/Timer 2's LSB 010100 Counter/Timer 3's MSB 010101 Counter/Timer 3's LSB (Read Only) D<sub>7</sub> D<sub>6</sub> D<sub>5</sub> D<sub>4</sub> D<sub>3</sub> D<sub>2</sub> D<sub>1</sub> D<sub>0</sub> D<sub>7</sub> D<sub>6</sub> D<sub>5</sub> D<sub>4</sub> D<sub>3</sub> D<sub>2</sub> D<sub>1</sub> D<sub>0</sub> LEAST SIGNIFICANT BYTE MOST SIGNIFICANT BYTE **Counter/Timer Time Constant Registers** Addresses: 010110 Counter/Timer 1's MSB 010111 Counter/Timer 1's LSB 011000 Counter/Timer 2's MSB 011001 Counter/Timer 2's LSB 011010 Counter/Timer 3's MSB 011011 Counter/Timer 3's LSB (Read/Write) Figure 16. Conter/Timer Registers MOST SIGNIFICANT BYTE **Current Vector Register** Address: 011111 (Read Only) INTERRUPT VECTOR BASED ON HIGHEST PRIORITY UNMASKED IP. IF NO INTERRUPT PENDING ALL 1'S OUTPUT Figure 17. Interrupt Vector Registers | Register<br>Address | Address* | Main Control Registers Register Name | Address* | Port A Specification Registers<br>Register Name | |---------------------|-----------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Summary | 000000<br>000001<br>000010<br>000011<br>000100<br>000101<br>000110 | Master Interrupt Control Master Configuration Control Port A's Interrupt Vector Port B's Interrupt Vector Counter/Timer's Interrupt Vector Port C's Data Path Polarity Port C's Data Direction Port C's Special I/O Control | 100000<br>100001<br>100010<br>100011<br>100100<br>100101<br>100110 | Port A's Mode Specification Port A's Handshake Specification Port A's Data Path Polarity Port A's Data Direction Port A's Special I/O Control Port A's Pattern Polarity Port A's Pattern Transition Port A's Pattern Mask | | | Address* | Most Often Accessed Registers Register Name | Address* | Port B Specification Registers Register Name | | | 001000<br>001001<br>001010<br>001011<br>001100<br>001101<br>001110<br>001111 | Port A's Command and Status Port B's Command and Status Counter/Timer 1's Command and Status Counter/Timer 2's Command and Status Counter/Timer 3's Command and Status Port A's Data Port B's Data Port C's Data | 101000<br>101001<br>101010<br>101011<br>101100<br>101101 | Port B's Mode Specification Port B's Handshake Specification Port B's Data Path Polarity Port B's Data Direction Port B's Special I/O Control Port B's Pattern Polarity Port B's Pattern Transition Port B's Pattern Mask | | | Address* | Counter/Timer Related Registers Register Name | | | | | 010000<br>010001<br>010010<br>010011<br>010100<br>010101<br>010111<br>01000<br>011001<br>011010<br>011011 | Counter/Timer 1's Current Count-MSBs Counter/Timer 1's Current Count-LSBs Counter/Timer 2's Current Count-LSBs Counter/Timer 2's Current Count-LSBs Counter/Timer 3's Current Count-MSBs Counter/Timer 3's Current Count-LSBs Counter/Timer 1's Time Constant-MSBs Counter/Timer 1's Time Constant-LSBs Counter/Timer 2's Time Constant-LSBs Counter/Timer 2's Time Constant-LSBs Counter/Timer 3's Time Constant-LSBs Counter/Timer 3's Time Constant-LSBs Counter/Timer 3's Time Constant-LSBs Counter/Timer 3's Time Constant-LSBs Counter/Timer 3's Mode Specification Counter/Timer 3's Mode Specification Counter/Timer 3's Mode Specification Counter/Timer 3's Mode Specification Counter/Timer 3's Mode Specification Current Vector | | | ### Timing **Read Cycle.** The CPU places an address on the address/data bus. The more significant bits and status information are combined and decoded by external logic to provide two Chip Selects ( $\overline{\text{CS}}_0$ and $\text{CS}_1$ ). Six bits of the least significant byte of the address are latched within the Z-CIO and used to specify a Z-CIO register. The data from the register specified is strobed onto the address/data bus when the CPU issues a Data Strobe ( $\overline{\text{DS}}$ ). If the register indicated by the address does not exist, the Z-CIO remains high-impedance. Write Cycle. The CPU places an address on the address/data bus. The more significant bits and status information are combined and decoded by external logic to provide two Chip Selects ( $\overline{\text{CS}}_0$ and $\text{CS}_1$ ). Six bits of the least significant byte of the address are latched within the Z-CIO and used to specify a Z-CIO register. The CPU places the data on the address/data bus and strobes it into the Z-CIO register by issuing a Data Strobe ( $\overline{\text{DS}}$ ). Figure 18. Read Cycle Timing Figure 19. Write Cycle Timing Interrupt Acknowledge Cycle. When one of the IP bits in the Z-CIO goes High and interrupts are enabled, the Z-CIO pulls its $\overline{\text{INT}}$ output line Low, requesting an interrupt. The CPU responds with an Interrupt Acknowledge cycle. When $\overline{\text{INTACK}}$ goes Low with IP set, the Z-CIO pulls its Interrupt Enable Out (IEO) Low, disabling all lower priority devices on the daisy chain. The CPU reads the Z-CIO interrupt vector by issuing a Low $\overline{\rm DS}$ , thereby strobing the interrupt vector onto the address/data bus. The IUS that corresponds to the IP is also set, which causes IEO to remain Low. Figure 20. Interrupt Acknowledge Timing | Storage Temperature65°C to +150°C | |-----------------------------------| |-----------------------------------| ### Standard Test Conditions The characteristics below apply for the following standard test conditions, unless otherwise noted. All voltages are referenced to GND. Positive current flows into the referenced pin. Standard conditions are as follows: - $\blacksquare$ +4.75 V $\leq$ V<sub>CC</sub> $\leq$ +5.25 V - GND = 0 V - T<sub>A</sub> as specified in Ordering Information All ac parameters assume a load capacitance of 50 pF max. Figure 21. Standard Test Load Figure 22. Open-Drain Test Load | DC | Symbol | Parameter | Min | Мах | Unit | Condition | |----------------------|-------------------|---------------------------------|------|-----------------------|---------|--------------------------------------| | Charac-<br>teristics | $V_{\mathrm{IH}}$ | Input High Voltage | 2.0 | V <sub>CC</sub> + 0.3 | V | | | 101101100 | $V_{\mathrm{IL}}$ | Input Low Voltage | -0.3 | 0.8 | V | | | | $V_{OH}$ | Output High Voltage | 2.4 | | V | $I_{OH} = -250 \mu A$ | | | $V_{\mathrm{OL}}$ | Output Low Voltage | | 0.4 | V | $I_{OL} = +2.0 \text{ mA}$ | | | | | | 0.5 | V | $I_{OL} = +3.2 \text{ mA}$ | | | $I_{\mathrm{IL}}$ | Input Leakage | | ± 10.0 | $\mu$ A | $0.4 \le V_{IN} \le +2.4 \text{ V}$ | | | $I_{OL}$ | Output Leakage | | ± 10.0 | $\mu$ A | $0.4 \le V_{OUT} \le +2.4 \text{ V}$ | | | $I_{CC}$ | ${ m V}_{ m CC}$ Supply Current | | 200 | mA | | $V_{CC}$ = 5 V $\pm$ 5% unless otherwise specified, over specified temperature range | Capacitance | Symbol | Parameter | Min | Max | Unit | Test Condition | |-------------|-----------|---------------------------|-----|-----|------|--------------------| | | $C_{IN}$ | Input Capacitance | | 10 | рF | Unmeasured Pins | | | $C_{OUT}$ | Output Capacitance | | 15 | рF | Returned to Ground | | | $C_{I/O}$ | Bidirectional Capacitance | | 20 | рF | notariou to Ground | f = 1 MHz, over specified temperature range | No. | Symbol | Symbol Parameter | | | 6 I<br>Min | Notes*† | | |------|----------------|---------------------------------------------------------------------------------|------------------|-----------------------------|---------------|-----------------------------|----------------------------| | 1 | TwAS | AS Low Width | <b>Min</b><br>70 | <b>Max</b> 2000 | 50 | <b>Μαχ</b><br>2000 | | | 2 | TsA(AS) | Address to $\overline{AS}$ † Setup Time | 30 | 2000 | 10 | 2000 | 1 | | 3 | ThA(AS) | Address to AS † Hold Time | 50 | | 30 | | 1 | | 4 - | — TsA(DS) | — Address to DS Setup Time | 130 | | —— 100 — | | 1 | | 5 | TsCSO(AS) | $\overline{\text{CS}}_0$ to $\overline{\text{AS}}$ † Setup Time | 0 | | 0 | | 1 | | 6 | ThCSO(AS) | CS <sub>0</sub> to AS † Hold Time | 60 | | 40 | | 1 | | 7 | TdAS(DS) | ĀS ↑ to DS ↓ Delay | 60 | | 40 | | 1 | | 8 - | — TsCS1(DS) | — CS₁ to DS ↓ Setup Time | 100 <b>-</b> | | 80 | | | | 9 | TsRWR(DS) | R/W (Read) to DS ↓ Setup Time | 100 | | 80 | | | | 10 | TsRWW(DS) | $R/\overline{W}$ (Write) to $\overline{DS}$ ! Setup Time | 0 | | 0 | | | | 11 | TwDS | DS Low Width | 390 | | 250 | | | | 12- | — TsDW(DSf) | — Write Data to <del>DS</del> ↓ Setup Time ———————————————————————————————————— | 30 - | | 20 — | | | | 13 | TdDS(DRV) | DS (Read) ↓ to Address Data Bus Driven | 0 | | 0 | | | | 14 | TdDSf(DR) | DS I to Read Data Valid Delay | | 250 | | 180 | | | 15 | ThDW(DS) | Write Data to $\overline{\rm DS}$ † Hold Time | 30 | | 20 | | | | 16- | — TdDSr(DR) — | — DS † to Read Data Not Valid Delay ————— | 0 - | | 0 <del></del> | | | | 17 | TdDS(DRz) | DS † to Read Data Float Delay | | 70 | | 45 | 2 | | 18 | ThRW(DS) | $R/\overline{W}$ to $\overline{DS}$ † Hold Time | 55 | | 40 | | | | 19 | ThCS1(DS) | $CS_1$ to $\overline{DS}$ † Hold Time | 55 | | 40 | | | | 20 | TdDS(AS) | DS ↑ to AS ↓ Delay | 50 | | 25 | | | | 21 | Trc | Valid Access Recovery Time | 1000 | | 650 | | 3 | | 22 | TdPM(INT) | Pattern Match to INT Delay (Bit Port) | | 1 | | 1 | 6 | | 23 | TdACK(INT) | ACKIN to INT Delay (Port with Handshake) | | 4 | | 4 | 4,6 | | 24 – | — TdCI(INT)—— | — Counter Input to INT Delay (Counter Mode)——— | | —— 1 —— | | —— 1 — | <del></del> 6- <del></del> | | 25 | TdPC(INT) | PCLK to INT Delay (Timer Mode) | | l | | 1 | 6 | | 26 | TdAS(INT) | AS to INT Delay | | | | | | | 27 | TsIA(AS) | <u>INTACK</u> to <u>AS</u> ↑ Setup Time | 0 | | 0 | | | | 28 | ThIA(AS) | $\overline{\text{INTACK}}$ to $\overline{\text{AS}}$ † Hold Time | 250 | | 250 | | | | 29 | TsAS(DSA) | $\overline{AS}$ † to $\overline{DS}$ (Acknowledge) ↓ Setup Time | 350 | | 250 | | 5 | | 30 - | — TdDSA(DR)— | — DS (Acknowledge)↓ to Read Data Valid Delay — | | <del></del> 250 <del></del> | | <del></del> 180 <del></del> | | | 31 | TwDSA | DS (Acknowledge) Low Width | 390 | | 250 | | | | 32 | TdAS(IEO) | AS ↑ to IEO ↓ Delay (INTACK Cycle) | | 350 | | 250 | 5 | | 33 – | — TdIEI(IEO)—— | — IEI to IEO Delay — | | <del></del> 150 | | <del></del> 100 | —— 5 <del>—</del> | | 34 | TsIEI(DSA) | IEO to $\overline{\rm DS}$ (Acknowledge) $\downarrow$ Setup Time | 100 | | 70 | | 5 | | 35 | ThIEI(DSA) | IEI to $\overline{\rm DS}$ (Acknowledge) † Hold Time | 100 | | 70 | | | | 36 | TdDSA(INT) | DS (Acknowledge) ↓ to INT † Delay | | 600 | | 600 | | ### NOTES: <sup>1.</sup> Parameter does not apply to Interrupt Acknowledge transactions. Float delay is measured to the time when the output has changed $0.5\ V$ from steady state with minimum ac load and maxımum de load This is the delay from DS t of one CIO access to DS t of another CIO access The delay is from DAV t for 3-Wire Input Handshake The delay is from DAC t for 3-Wire Output Handshake One additional AS cycle is required for ports in the Single Buffered mode <sup>5</sup> The parameters for the devices in any particular daisy chain must meet the following constraint the delay from $\overline{AS}$ 1 to $\overline{DS}$ 1 must be greater than the sum of TdAS(IEO) for the highest priority peripheral, TsIEI(DSA) for the lowest priority peripheral, and TdIEI(IEO) for each peripheral separating them in the chain 6 Units equal to $\overline{AS}$ cycle + ns \* Timings are preliminary and subject to change. <sup>†</sup> Units in nanoseconds(ns), except as noted | | | | | MHz | 6 MHz | | | | |-----|---------------|-------------------------------------------------------------------------------------------------|----------------|-----|---------------|-----|---------|--| | No. | Symbol | Parameter | Min | Max | Min | Мах | Notes*† | | | 1 | TsDI(ACK) | Data Input to ACKIN Setup Time | 0 | | 0 | | | | | 2 | ThDI(ACK) | Data Input to ACKIN Hold Time - Strobed Handshake | | | | | | | | 3 | TdACKf(RFD) | ACKIN ↓ to RFD ↓ Delay | 0 | | 0 | | | | | 4- | -TwACK1 | - ACKIN Low Width – Strobed Handshake ———— | | | | | | | | 5 | TwACKh | ACKIN High Width - Strobed Handshake | | | | | | | | 6 | TdRFDr(ACK) | RFD ↑ to ĀCKIN ↓ Delay | 0 | | 0 | | | | | 7 | TsDO(DAV) | Data Out to DAV Setup Time | 25 | | 20 | | 1 | | | 8 | TdDAVf(ACK) | DAV ↓ to ACKIN ↓ Delay | 0 | | 0 | | | | | 9- | -ThDO(ACK) | - Data Out to ĀCKIN ↓ Hold Time | <del></del> 1 | | 1 | | 2 | | | 10 | TdACK(DAV) | ACKIN ↓ to DAV ↑ Delay | 1 | | l | | 2 | | | 11 | ThDI(RFD) | Data Input to RFD Hold Time – Interlocked<br>Handshake | 0 | | 0 | | | | | 12 | TdRFDf(ACK) | RFD to ACKIN Delay - Interlocked Handshake | 0 | | 0 | | | | | 13— | -TdACKr(RFD)- | <ul> <li>- ACKIN † (DAV † ) to RFD † Delay - Interlocked ——<br/>and 3-Wire Handshake</li> </ul> | <del></del> 0- | | 0 | | | | | 14 | TdDAVr(ACK) | $\overline{\rm DAV}$ † to $\overline{\rm ACKIN}$ † (RFD † ) - Interlocked and 3-Wire Handshake | 0 | | 0 | | | | | 15 | TdACK(DAV) | ACKIN ↑ (RFD ↑ )to DAV ↓ Delay - Interlocked and 3-Wire Handshake | 0 | | 0 | | | | | 16- | TdDAVIf(DAC) | - DAV ↓ to DAC ↑ Delay – Input 3-Wire Handshake — | <del></del> 0- | | <del></del> 0 | | | | | 17 | ThDI(DAC) | Data Input to DAC † Hold Time – 3-Wire<br>Handshake | 0 | | 0 | | | | | 18 | TdDACOr(DAV) | DAC † to DAV † Delay – Input 3-Wire Handshake | 0 | | 0 | | | | | 19 | TdDAVIr(DAC) | DAV ↑ to DAC ↓ Delay – Input 3-Wire Handshake | 0 | | 0 | | | | | 20- | -TdDAVOf(DAC) | – <del>DAV</del> ↓ to DAC↑ Delay – Output 3-Wire Handshake - | <u> </u> | | <del></del> 0 | | | | | 21 | ThDO(DAC) | Data Output to DAC † Hold Time – 3-Wire<br>Handshake | 1 | | 1 | | 2 | | | 22 | TdDACIr(DAV) | DAC † to $\overline{\text{DAV}}$ † Delay – Output 3-Wire Handshake | 1 | | 1 | | 2 | | | 23 | TdDAVOr(DAC) | DAV ↑ to DAC ↓ Delay – Output 3-Wire Handshake | 0 | | 0 | | | | NOTES: 1. This time can be extended through the use of the deskew timers. 2 Units equal to $\overline{AS}$ cycle. <sup>\*</sup> Timings are preliminary and subject to change. All timing references assume 2.0 V for a logic "1" and 0.8 V for a logic "0". † Units in nanoseconds (ns), except as noted. Counter/ Timer Timing | | | | | MHz | 6 MHz | | | |-----|-----------|----------------------------------------------------------------|--------------------|------|-------|------|---------------------------------------| | No. | Symbol | Parameter | Min | Max | Min | Max | Notes*† | | l | TcPC | PCLK Cycle Time | 250 | 4000 | 165 | 4000 | 1 | | 2 | TwPCh | PCLK High Width | 105 | 2000 | 70 | 2000 | | | 3 | TwPCl | PCLK Low Width | 105 | 2000 | 70 | 2000 | | | 4 | TfPC | PCLK Fall Time | | 20 | | 10 | | | 5 | TrPC | PCLK Rise Time | | 20 | | 15 | | | 6- | TcCI —— | Counter Input Cycle Time | <del>-</del> 500 — | | 330 | | · · · · · · · · · · · · · · · · · · · | | 7 | TCIh | Counter Input High Width | 230 | | 150 | | | | 8 | TwCIl | Counter Input Low Width | 230 | | 150 | | | | 9 | TfCI | Counter Input Fall Time | | 20 | | 15 | | | 10 | TrCI | Counter Input Rise Time | | 20 | | 15 | | | 11- | TsTI(PC) | Trigger Input to PCLK Setup Time (Timer Mode) | | | | | 2 | | 12 | TsTI(CI) | Trigger Input to Counter Input Setup<br>Time (Counter Mode) | | | | | 2 | | 13 | TwTI | Trigger Input Pulse Width (High or Low) | | | | | | | 14- | TsGI(PC) | Gate Input to PCLK Setup Time (Timer Mode) | | | | | 2 | | 15 | TsGI(CI) | Gate Input to Counter Input Setup<br>Time (Counter Mode) | | | | | 2 | | 16 | ThGI(PC) | Gate Input to PCLK ↓ Hold Time (Timer Mode) | | | | | 2 | | 17— | -ThGI(CI) | — Gate Input to Counter Input Hold ——<br>Time (Counter Mode) | | | | | 2 | | 18 | TdPC(CO) | PCLK to Counter Output Delay (Timer Mode) | | | | | | | 19 | TdCI(CO) | Counter Input to Counter Output Delay (Counter Mode) | | | | | | are valid for the next counter/timer cycle. NOTES 1 PCLK is only used with the counte<u>r/time</u>rs (in Timer mode), the deskew timers, and the REQUEST/WAIT logic. If these functions are not used, the PCLK input can be held low. These properties of the PCLK input can be held low. <sup>2</sup> These parameters must be met to guarantee that trigger or gate <sup>•</sup> Timings are preliminary and subject to change. All timing references assume 2 0 V for a logic "1" and 0 8 V for a logic "0". <sup>†</sup> Units in nanoseconds (ns) ### REQUEST/ WAIT Timing | | | | 4 MHz | | 6 MHz | | | | |-----|-------------|-------------------------|-------|-----|-------|-----|---------|--| | No. | Symbol | Parameter | Min | Max | Min | Max | Notes*† | | | 1 | TdDS(REQ) | DS ↓ to REQ ↓ Delay | | | | | | | | 2 | TdDS(WAIT) | DS ↓ to WAIT ↓ Delay | | | | | | | | 3 | TdPC(REQ) | PCLK ↓ to REQ ↑ Delay | | | | | | | | 4 | TdPC(WAIT) | PCLK ↓ to WAIT ↑ Delay | | | | | | | | 5 | TdACK(REQ) | ACKIN ↓ to REQ ↑ Delay | | | | | 1,2 | | | 6 | TdACK(WAIT) | ACKIN ↓ to WAIT ↑ Delay | | | | | 3 | | - NOIES: 1. The Delay is from DAV 1 for the 3-Wire Input Handshake The delay is from DAC 1 for the 3-Wire Output Handshake. 2. Units equal to AS cycles + PCLK cycles + ns. - 3 Units equal to PCLK cycles + ns. \* Timings are preliminary and subject to change. All timing references assume 2.0 V for a logic "1" and 0.8 V for a logic "0". † Units in nanoseconds (ns), except as noted. ### Reset Timing | | | | | 4 MHz | | 6 MHz | | |-----|-----------|-------------------------------------------------------------------------|-----|-------|-----|-------|---------| | No. | Symbol | Parameter | Min | Max | Min | Max | Notes*† | | 1 | TdDSQ(AS) | Delay from <del>DS</del> ↑ to <del>AS</del> ↓ for No Reset | 40 | | 15 | | | | 2 | TdASQ(DS) | Delay from $\overline{AS}$ † to $\overline{DS}$ ↓ for No Reset | 50 | | 30 | | | | 3 | Twres | Minimum Width of $\overline{AS}$ and $\overline{DS}$ both Low for Reset | 250 | | 170 | | 1 | ### NOTES Internal circuitry allows for the reset provided by the Z8 ( $\overline{\rm DS}$ held Low while $\overline{\rm AS}$ pulses) to be sufficient - \* Timings are preliminary and subject to change. All timing references assume 2.0 V for a logic "1" and 0.8 V for a logic "0". † Units in nanoseconds (ns) ### Miscellaneous Port Timing | | | | 4 MHz | | 6 MHz | | | | |-----|--------|-----------------------------------------------------|-------|-----|-------|-----|---------|--| | No. | Symbol | Parameter | Min | Max | Min | Max | Notes*† | | | 1 | TrI | Any Input Rise Time | | 100 | | 100 | | | | 2 | TfI | Any Input Fall Time | | 100 | | 100 | | | | 3 | Twl's | l's Catcher High Width | 250 | | 170 | | 1 | | | 4 | TwPM | Pattern Match Input Valid (Bit Port) | 750 | | 500 | | | | | 5 | TsPMD | Data Latched on Pattern Match Setup Time (Bit Port) | 0 | | 0 | | | | | 6 | ThPMD | Data Latched on Pattern Match Hold Time (Bit Port) | 1000 | | 650 | | | | NOTES <sup>\*</sup> Timings are preliminary and subject to change. All timing references assume 2.0 V for a logic "1" and 0.8 V for a logic "0", † Units in nanoseconds (ns) | Ordering<br>Information | Product<br>Number | Package/<br>Temp | Speed | Description | Product<br>Number | Package/<br>Temp | Speed | Description | |-------------------------|-------------------|------------------|---------|----------------|-------------------|------------------|---------|----------------| | | Z8036 | CE | 4.0 MHz | Z-CIO (40-pın) | Z8036A | CE | 6.0 MHz | Z-CIO (40-pin) | | | Z8036 | CM | 6.0 MHz | Same as above | Z8036A | CM | 6.0 MHz | Same as above | | | Z8036 | СМВ | 6.0 MHz | Same as above | Z8036A | CMB | 6.0 MHz | Same as above | | | Z8036 | CS | 4.0 MHz | Same as above | Z8036A | CS | 6.0 MHz | Same as above | | | Z8036 | DE | 4.0 MHz | Same as above | Z8036A | DE | 6.0 MHz | Same as above | | | Z8036 | DS | 4.0 MHz | Same as above | Z8036A | DS | 6.0 MHz | Same as above | | | Z8036 | PE | 4.0 MHz | Same as above | Z8036A | PE | 6.0 MHz | Same as above | | | Z8036 | PS | 4.0 MHz | Same as above | Z8036A | PS | 6.0 MHz | Same as above | NOTES C = Ceramic, D = Cerdip, P = Plastic, E = -40 °C to +85 °C, MB = -55 °C to 125 °C with MIL-STD-883 with Class B processing, S = 0 °C to +70 °C 240 2014-028 00-2014-A <sup>1</sup> If the input is programmed inverting, a Low-going pulse of the same width will be detected ## Z8038 Z8000<sup>™</sup> Z-FIO FIFO Input/ Output Interface Unit ## Product Specification June 1982 ### **Features** - 128-byte FIFO buffer provides asynchronous bidirectional CPU/CPU or CPU/peripheral interface, expandable to any width in byte increments by use of multiple FIOs. - Interlocked 2-Wire or 3-Wire Handshake logic port mode; Z-BUS or non-Z-BUS interface. - Pattern-recognition logic stops DMA transfers and/or interrupts CPU; preset byte count can initiate variable-length DMA transfers. - Seven sources of vectored/nonvectored interrupt which include pattern-match, byte count, empty or full buffer status; a dedicated "mailbox" register with interrupt capability provides CPU/CPU communication. - REQUEST/WAIT lines control high-speed data transfers. - All functions are software controlled via directly addressable read/write registers. ### General Description The Z8038 FIO provides an asynchronous 128-byte FIFO buffer between two CPUs or between a CPU and a peripheral device. This buffer interface expands to a 16-bit or wider data path and expands in depth to add as many Z8060 FIFOs (and an additional FIO) as are needed. The FIO manages data transfers by assuming Z-BUS, non-Z-BUS microprocessor (a generalized microprocessor interface), Interlocked 2-Wire Handshake, and 3-Wire Handshake operating modes. These modes interface dissimilar CPUs or CPUs and peripherals running under differing speeds or protocols, allowing asynchronous data transactions and improving I/O overhead by as much as two orders of magnitude. Figures 1 and 2 show how the signals controlling these operating modes are mapped to the FIO pins. Figure 1. Pin Functions Figure 3. FIO Block Diagram # General Description (Continued) The FIO supports the Z-BUS interrupt protocols, generating seven sources of interrupts upon any of the following events: a write to a message register, change in data direction, pattern match, status match, over/underflow error, buffer full and buffer empty status. Each interrupt source can be enabled or disabled, and can also place an interrupt vector on the port address/data lines. The data transfer logic of the FIO has been specially designed to work with DMA (Direct Memory Access) devices for high-speed transfers. It provides for data transfers to or from memory each machine cycle, while the DMA device generates memory address and control signals. The FIO also supports the variably sized block length, improving system throughput when multiple variable length messages are transferred amongst several sources. ### Functional Description **Operating Modes.** Ports 1 and 2 operate in any of twelve combinations of operating modes, listed in Table 2. Port 1 functions in either the Z-BUS or non-Z-BUS microprocessor modes, while Port 2 functions in Z-BUS, non-Z-BUS, Interlocked 2-Wire Handshake, and 3-Wire Handshake modes. Table 1 describes the signals and their corresponding pins in each of these modes. The pin diagrams of the FIO are identical, except for two pins on the Port 1 side, which select that port's operating mode. Port 2's operating mode is programmed by two bits in Port 1's Control register 0. Table 2 describes the combinations of operating modes; Table 3 describes the control signals mapped to pins A-J in the five possible operating modes. | Control<br>Signal<br>Pins | Z-BUS<br>Low Byte | Z-BUS<br>High Byte | Non-Z-BUS | Interlocked<br>HS Port* | 3-Wire<br>HS Port* | |---------------------------|-------------------|--------------------|-----------|-------------------------|--------------------| | A | REQ/WT | REQ/WT | REQ/WT | RFD/DAV | RFD/DAV | | В | DMASTB | DMASTB | DACK | ACKIN | DAV/DAC | | C | DS | DS | RD | FULL | DAC/RFD | | D | $R/\overline{W}$ | $R/\overline{W}$ | WR | EMPTY | EMPTY | | E | CS | CS | CE | CLEAR | CLEAR | | F | ĀS | AS | C/D | DATA DIR | DATA DIR | | G | INTACK | A <sub>0</sub> | INTACK | IN <sub>O</sub> | IN <sub>0</sub> | | H | IEO | $\mathtt{A}_1$ | IEO | $OUT_1$ | $out_1$ | | I | IEI | A <sub>2</sub> | IEI | ŌĒ | ŌĒ | | 1 | ĪNT | A <sub>3</sub> | INT | OUT3 | OUT <sub>3</sub> | <sup>\*2</sup> side only. Table 1. Pin Assignments | Functional | |-------------| | Description | | (Continued) | | Mode | M1 | M <sub>0</sub> | Bl | В0 | Port 1 | Port 2 | |------|----|----------------|----|----|-----------------|------------------| | 0 | 0 | 0 | 0 | 0 | Z-BUS Low Byte | Z-BUS Low Byte | | 1 | 0 | 0 | 0 | 1 | Z-BUS Low Byte | Non-Z-BUS | | 2 | 0 | 0 | 1 | 0 | Z-BUS Low Byte | 3-Wire Handshake | | 3 | 0 | 0 | 1 | 1 | Z-BUS Low Byte | 2-Wire Handshake | | 4 | 0 | 1 | 0 | 0 | Z-BUS High Byte | Z-BUS High Byte | | 5 | 0 | 1 | 0 | 1 | Z-BUS High Byte | Non-Z-BUS | | 6 | 0 | 1 | 1 | 0 | Z-BUS High Byte | 3-Wire Handshake | | 7 | 0 | 1 | 1 | l | Z-BUS High Byte | 2-Wire Handshake | | 8 | 1 | 0 | 0 | 0 | Non-Z-BUS | Z-BUS Low Byte | | 9 | 1 | 0 | 0 | 1 | Non-Z-BUS | Non-Z-BUS | | 10 | 1 | 0 | 1 | 0 | Non-Z-BUS | 3-Wire Handshake | | 11 | 1 | 0 | 1 | 1 | Non-Z-BUS | 2-Wire Handshake | Table 2. Operating Modes Figure 4. CPU to CPU Configuration Figure 5. CPU to I/O Configuration | Pins Common<br>To Both Sides | Pin<br>Signals | Pin<br>Names | Pi:<br>Numl | | Signal<br>Description | |------------------------------|-----------------------------------------------------|--------------------------------|---------------------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------| | | M <sub>0</sub> | М0 | 21 | | M <sub>1</sub> and M <sub>0</sub> program Port 1 | | | M <sub>1</sub> | $M_1$ | 19 | ) | side CPU interface | | | +5 Vdc | +5 Vdc | 40 | | DC power source | | | GND | GND | 20 | | DC power ground | | Z-BUS<br>Low Byte<br>Mode | Pin<br>Signals | Pin<br>Names | Pin Nui<br>Poi<br>l | | Signal<br>Description | | | AD <sub>0</sub> -AD <sub>7</sub><br>(Address/Data) | D <sub>0</sub> -D <sub>7</sub> | 11-18 | 29-22 | Multiplexed bidirectional address/data lines, Z-BUS compatible. | | | REQ/WAIT<br>(Request/Wait) | A | 1 | 39 | Output, <u>active Low</u> , REQUEST (ready) line for DMA transfer; WAIT line (open-drain) output for synchronized CPU and FIO data transfers. | | | DMASTB<br>(Direct Memory<br>Access Strobe) | В | 2 | 38 | Input, active Low. Strobes DMA data to and from the FIFO buffer. | | | <del>DS</del><br>(Data Strobe) | С | 3 | 37 | Input, active Low. Provides timing for data transfer to or from FIO. | | | R/W<br>(Read/Write) | D | 4 | 36 | Input; active High signals CPU read from FIO; active Low signals CPU write to FIO. | | | CS<br>(Chip Select) | E | 5 | 35 | Input, active Low. Enables FIO. Latched on the rising edge of AS. | | | AS<br>(Address Strobe) | F | 6 | 34 | Input, active Low. Addresses, $\overline{\text{CS}}$ and $\overline{\text{INTACK}}$ sampled while $\overline{\text{AS}}$ Low. | | | INTACK<br>(Interrupt<br>Acknowledge) | G | 7 | 33 | Input, active Low. Acknowledges an interrupt.<br>Latched on the rising edge of AS. | | | IEO<br>(Interrupt<br>Enable Out) | Н | 8 | 32 | Output, active High. Sends interrupt enable to lower priority device IEI pin. | | | IEI<br>(Interrupt<br>Enable In) | I | 9 | 31 | Input, active High. Receives interrupt enable from higher priority device IEO signal. | | | INT<br>(Interrupt) | J | 10 | 30 | Output, open drain, active Low. Signals FIO interrupt request to CPU. | | Z-BUS | Di | D | Pin Nu | | G!1 | | High Byte<br>Mode | Pin<br>Signals | Pin<br>Names | Po: | 2 | Signal<br>Description | | Mode | AD <sub>0</sub> -AD <sub>7</sub><br>(Address/Data) | D <sub>0</sub> -D <sub>7</sub> | 11-18 | 29-22 | Multiplexed bidirectional address/data lines, Z-BUS compatible. | | | REQ/WAI'ſ<br>(Request/Wait) | A | 1 | 39 | Output, <u>active Low</u> , REQUEST (ready) line for DMA transfer; WAIT line (open-drain) output for synchronized CPU and FIO data transfers. | | | DMASTB<br>(Direct Memory<br>Access Strobe) | В | 2 | 38 | Input, active Low. Strobes DMA data to and from the FIFO buffer. | | | DS<br>(Data Strobe) | С | 3 | 37 | Input, active Low. Provides timing for transfer of data to or from FIO. | | | R/W<br>(Read/Write)<br> | D | 4 | 36 | Input, active High. Signals CPU read from FIO; active Low signals CPU write to FIO. | | | CS<br>(Chip Select) | E | 5 | 35 | Input, active Low. Enables FIO. Latched on the rising edge of AS. | | | AS<br>(Address Strobe) | F | 6 | 34 | Input, active Low. Addresses, $\overline{CS}$ and $\overline{INTACK}$ are sampled while $\overline{AS}$ is Low. | | | A <sub>0</sub><br>(Address Bit 0)<br>A <sub>1</sub> | G<br>H | 7<br>8 | 33<br>32 | Input, active High. With $A_1$ , $A_2$ , and $A_3$ , addresses FIO internal registers. Input, active High. With $A_0$ , $A_2$ , and $A_3$ , addresses | | | (Address Bit 1) A <sub>2</sub> | I | 9 | 31 | FIO internal registers. Input, active High. With A <sub>0</sub> , A <sub>1</sub> , and A <sub>3</sub> , addresses | | | (Address Bit 2)<br>A <sub>3</sub> | J | 10 | 30 | FIO internal registers. Input, active High. With A <sub>0</sub> , A <sub>1</sub> , and A <sub>2</sub> , addresses | | | (Address Bit 3) | | | | FIO internal registers. | Table 3. Signal/Pin Descriptions | Non-Z-BUS<br>Mode | Pin | Pin | Pin Nu<br>Po | | | Signal | |-------------------------|-----------------------------------------------|--------------------------------|----------------|-------|-------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | Signals | Names | 1 | 4 | | Description | | | D <sub>0</sub> -D <sub>7</sub><br>(Data) | D <sub>0</sub> -D <sub>7</sub> | 11-18 | 29-22 | | Bidirectional data bus. | | | REQ/WT<br>(Request/Wait) | A | 1 | 39 | | Output, <u>active</u> Low, REQUEST (ready) line for DMA transfer, WAIT line (open-drain) output for synchronized CPU and FIO data transfer. | | | DACK<br>(DMA Acknowledge) | В | 2 | 38 | | Input, active Low DMA acknowledge | | | RD<br>(Read) | С | 3 | 37 | | Input, active Low Signals CPU read from FIO | | | WR<br>(Write) | D | 4 | 36 | | Input, active Low Signals CPU write to FIO | | | CE<br>(Chip Select) | E | 5 | 35 | | Input, active Low. Used to select FIO. | | | C/D<br>(Control/Data) | F | 6 | 34 | | Input, active High Identifies control byte on D <sub>0</sub> -D <sub>7</sub> ; active Low identifies data byte on D <sub>0</sub> -D <sub>7</sub> . | | | INTACK<br>(Interrupt<br>Acknowledge) | G | 7 | 33 | | Input, active Low Acknowledges an interrupt. | | | IEO<br>(Interrupt<br>Enable Out) | Н | 8 | 32 | | Output, active High Sends interrupt enable to lower priority device IEI pin. | | | IEI<br>(Interrupt<br>Enable In) | Ι | 9 | 31 | | Input, active High. Receives interrupt enable from higher priority device IEO signal | | | INT<br>(Interrupt) | J | 10 | 30 | | Output, open drain, active Low Signals FIO interrupt to CPU | | Port 2—I/O<br>Port Mode | Pin<br>Signals | Pin<br>Names | Pin<br>Numbers | | Mode | Signal<br>Description | | | D <sub>0</sub> -D <sub>7</sub><br>(Data) | D <sub>0</sub> -D <sub>7</sub> | 29-22 | | 2-Wire HS*<br>3-Wire HS | Bidirectional data bus | | | RFD/DAV<br>(Ready for Data/Data<br>Available) | A | 39 | | 2-Wire HS<br>3-Wire HS | Output, RFD active High. Signals peripherals that FIO is ready to receive data DAV active Low signals that FIO is ready to send data to peripherals. | | | ACKIN<br>(Acknowledge Input) | В | 38 | | 2-Wire HS | Input, active Low Signals FIO that output data is received by peripherals or that input data is valid. | | | DAV/DAC<br>(Data Available/Data<br>Accepted) | В | 38 | | 3-Wire HS | Input; $\overline{\text{DAV}}$ (active Low) signals that data is valid on bus. DAC (active High) signals that output data is accepted by peripherals | | | FULL | С | 37 | | 2-Wire HS | Output, open drain, active High Signals that FIO buffer is full. | | | DAC/RFD<br>(Data Accepted/Ready<br>for Data) | C<br>' | 37 | | 3-Wire HS | Direction controlled by internal programming. Both active High DAC (an output) signals that FIO has received data from peripheral; RFD (an input) signals that the listeners are ready for data. | | | EMPTY | D | 36 | | 2-Wire HS<br>3-Wire HS | Output, open drain, active High Signals that FIFO buffer is empty. | | | CLEAR | E | 35 | | 2-Wire HS<br>3-Wire HS | Programmable input or output, active Low. Clears all data from FIFO buffer | | | DATA DIR<br>(Data Direction) | F | 34 | | 2-Wire HS<br>3-Wire HS | Programmable input or output. Active High signals data input to Port 2; Low signals data output from Port 2 | | | IN <sub>0</sub> | G | 33 | | 2-Wire HS<br>3-Wire HS | Input line to $D_0$ of Control Register 3. | | | $OUT_1$ | Н | 32 | | 2-Wire HS<br>3-Wire HS | Output line from $\mathrm{D}_1$ of Control Register 3 | | | | | | | | | | | OE<br>(Output Enable) | I | 31 | | 2-Wire HS<br>3-Wire HS | Input, active Low When Low, enables bus drivers<br>When High, floats bus drivers at high impedance | <sup>\*</sup>Handshake J 30 OUT<sub>3</sub> Table 3. Signal/Pin Descriptions (Continued) Output line from $D_3$ of Control register 3. 2-Wire HS 3-Wire HS #### Reset The FIO can be reset under either hardware or software control by one of the following methods: - By forcing both AS and DS Low simultaneously in Z-BUS mode (normally illegal). - By forcing RD and WR Low simultaneously in non-Z-BUS mode. - By writing a 1 to the Reset bit in Control register 0 for software reset. In the Reset state, all control bits are cleared to 0. Only after clearing the Reset bit (by writing a 0 to it) can the other command bits be programmed. This action is true for both sides of the FIO when programmed as a CPU interface. For proper system control, when Port 1 is reset, Port 2 is also reset. In addition, all Port 2's outputs are floating and all inputs are ignored. To initiate the data transfer, Port 2 must be enabled by Port 1. The Port 2 CPU can determine when it is enabled by reading Control register 0, which reads "floating" data bus if not enabled and " $01_{\rm H}$ " if enabled. #### CPU Interfaces The FIO is designed to work with both Z-BUS- and non-Z-BUS-type CPUs on both Port 1 and Port 2. The Z-BUS configuration interfaces CPUs with time-multiplexed address and data information on the same pins. The Z8001, Z8002, and Z8 are examples of this type of CPU. The $\overline{\rm AS}$ (Address Strobe) pin is used to latch the address and chip select information sent out by the CPU. The R/ $\overline{\rm W}$ (Read/Write) pin and the $\overline{\rm DS}$ (Data Strobe) pin are used for timing reads and writes from the CPU to the FIO (Figures 6 and 7). The non-Z-BUS configuration is used for CPUs where the address and data buses are separate. Examples of this type of CPU are the Z80 and 8080. The $\overline{\rm RD}$ (Read) and $\overline{\rm WR}$ (Write) pins are used to time reads and writes from the CPU to the FIO (Figures 9 and 10). The C/ $\overline{\rm D}$ (Control/Data) pin is used to directly access the FIFO buffer (C/ $\overline{\rm D}$ =0) and to access the other registers (C/ $\overline{\rm D}$ =1). Read and write to all Figure 6. Z-BUS Read Cycle Timing Figure 7. Z-BUS Write Cycle Timing 246 2020-004, 005 ### CPU Interfaces (Continued) registers except the FIFO buffer $^l$ are two-step operations, described as follows (Figure 8). First, write the address ( $C/\overline{D}=1$ ) of the register to be accessed into the Pointer Register (State 0); second, read or write ( $C/\overline{D}=1$ ) to the register pointed at previously (State 1). Continuous status monitoring can be performed in State 1 by continuous Control Read operations ( $C/\overline{D}=1$ ). <sup>1</sup>The FIFO buffer can also be accessed by this two-step operation Figure 8. Register Access in Non-Z-BUS Mode Figure 9. Non-Z-BUS Read Cycle Timing Figure 10. Non-Z-BUS Write Cycle Timing #### WAIT Operation When data is output by the CPU, the REQ/WT (WAIT) pin is active (Low) only when the FIFO buffer is full, the chip is selected, and the FIFO buffer is addressed. WAIT goes inactive when the FIFO buffer is not full. When data is input by the CPU, the REQ/WT pin becomes active (Low) only when the FIFO buffer is empty, the chip is selected, and the FIFO buffer is addressed. WAIT goes inactive when the FIFO buffer is not empty. #### Interrupt Operation The FIO supports Zilog's prioritized daisy chain interrupt protocol for both Z-BUS and non-Z-BUS operating modes (for more details refer to the Zilog *Z-BUS Summary*). Each side of the FIO has seven sources of interrupt. The priorities of these devices are fixed in the following order (highest to lowest): Mailbox Message, Change in Data Direction, Pattern Match, Status Match, Overflow/ Underflow Error, Buffer Full, and Buffer Empty. Each interrupt source has three bits that control how it generates the interrupt. These bits are Interrupt Pending (IP), Interrupt Enable (IE), and Interrupt Under Service (IUS). In addition, each side of the FIO has an interrupt vector and four bits controlling the FIO interrupt logic. These bits are Vector 2020-006, 007, 008 #### Interrupt Operation (Continued) Includes Status (VIS), Master Interrupt Enable (MIE), Disable Lower Chain (DLC), and No Vector (NV). A typical Interrupt Acknowledge cycle for Z-BUS operation is shown in Figure 11 and for non-Z-BUS operation in Figure 12. The only difference is that in Z-BUS mode, INTACK is latched by $\overline{\text{AS}}$ , and in non-Z-BUS mode $\overline{\text{INTACK}}$ is not latched. When MIE = 1, reading the vector always includes status, independent of the state of the VIS bit. In this way, when VIS = 0, all information can be obtained with one additional read, thus conserving vector space. When MIE = 0, reading the vector register returns the unmodified base vector so that it can be verified. In non-Z-BUS mode, the IPs do not get set while in State 1. Therefore, to minimize interrupt latency, the FIO should be left in State 0. In Z-BUS mode IPS are set by an $\overline{\rm AS}$ following the event. Figure 11. Z-BUS Interrupt Acknowledge Cycle Figure 12. Non-Z-BUS Interrupt Acknowledge Cycle ### CPU to CPU Operation **DMA Operation.** The FIO is particularly well suited to work with a DMA in both Z-BUS and non-Z-BUS modes. A data transfer between the FIO and system memory can take place during every machine cycle on both sides of the FIO simultaneously. In Z-BUS mode, the $\overline{\text{DMASTB}}$ pin (DMA Strobe) is used to read or write into the FIFO buffer. The R/ $\overline{\text{W}}$ (Read/Write) and $\overline{\text{DS}}$ (Data Strobe) signals are ignored by the FIO; however, the $\overline{\text{CS}}$ (Chip Select) signal is not ignored and therefore must be kept invalid. Figures 13 and 14 show typical timing. In Non-Z-BUS mode, the DACK pin (DMA Acknowledge) is used to tell the FIO that its DMA request is granted. After DACK goes Low, every read or write to the FIO goes into the FIFO buffer. Figures 15 and 16 show typical timing. Figure 13. Z-BUS FIO to Memory Data Transaction Figure 14. Z-BUS Memory to FIO Data Transaction Figure 15. Non-Z-BUS FIO to Memory Transaction Figure 16. Non-Z-BUS Memory to FIO Data Transaction 2020-011, 012, 013, 014 # CPU to CPU Operation (Continued) The FIO provides a special mode to enhance its DMA transfer capability. When data is written into the FIFO buffer, the REQ/WT (REQUEST) pin is active (Low) until the FIFO buffer is full. It then goes inactive and stays inactive until the number of bytes in the FIFO buffer is equal to the value programmed into the Byte Count Comparison register. Then the REQUEST signal goes active and the sequence starts over again (Figure 17). When data is read from the FIO, the $\overline{\text{REQ/WT}}$ pin (REQUEST) is inactive until the number of bytes in the FIFO buffer is equal to the value programmed in the Byte Count Comparison register. The REQUEST signal then goes active and stays active until the FIFO buffer is empty. When empty, REQUEST goes inactive and the sequence starts over again (Figure 18). #### NOTES: - l FIFO empty. - 2. REQUEST enabled, FIO requests DMA transfer. - DMA transfers data into the FIO. - 4. FIFO full, REOUEST mactive. - The FIFO empties from the opposite port until the number of bytes in the FIFO buffer is the same as the number programmed in the Byte Count Comparison register. Figure 17. Byte Count Control: Write to FIO e Byte Count Comparison register. NOTES: - 1. FIFO empty. - CPU/DMA fills FIFO buffer from the opposite port. - Number of bytes in FIFO buffer is the same as the number of bytes programmed in the Byte Count Comparison register. REQUEST goes active. - 5. DMA transfers data out of FIFO until it is empty. Figure 18. Byte Count Control: Read from FIO Message Registers. Two CPUs can communicate through a dedicated "mailbox" register without involving the 128 × 8 bit FIFO buffer (Figure 19). This mailbox approach is useful for transferring control parameters between the interfacing devices on either side of the FIO without using the FIFO buffer. For example, when Port 1's CPU writes to the Message Out register, Port 2's message IP is set. If interrupts are enabled, Port 2's CPU is interrupted. Port 2's message IP status is readable from the Port 1 side. When Port 2's CPU reads the data from its Message In register, the Port 2 IP is cleared. Thus, Port 1's CPU can read when the message has been read and can now send another message or follow whatever protocol that is set up between the two CPU's. The same transfer can also be made from Port 2's CPU to Port 1's CPU. NOTE: Usable only for CPU/CPU interface. Figure 19. Message Register Operation # CPU to CPU Operation (Continued) CLEAR (Empty) FIFO Operation. The CLEAR FIFO bit (active Low) clears the FIFO buffer of data. Writing a 0 to this bit empties the FIFO buffer, inactivates the REQUEST line, and disables the handshake (if programmed). The CLEAR bit does not affect any control or data register. To remove the CLEAR state, write a 1 to the CLEAR bit. In CPU/CPU mode, under program control, only one of the ports can empty the FIFO by writing to its Control Register 3, bit 6. The Port 1 CPU must program bit 7 in Control Register 3 to determine which port controls the CLEAR FIFO operation (0 = Port 1 control; 1 = Port 2 control). Direction of Data Transfer Operation. The Data Direction bit controls the direction of data transfer in the FIFO buffer. The Data Direction bit is defined as 0 = output from CPU and 1 = input to CPU. This bit reads correctly when read by either port's CPU. For example, if Port 1's CPU reads a 0 (CPU output) in its Data Direction bit, then Port 2's CPU reads a 1 (input to CPU) in its Data Direction bit. In CPU/CPU mode, under program control, only one of the ports can control the direction of data transfer. The Port 1 CPU must program bit 5 in Control Register 3 to determine which port controls the data direction (0 = Port 1 control; 1 = Port 2 control). Figure 20 shows FIO data transfer options. Figure 20. FIO Data Transfer Options 2020-018 ### CPU to I/O Operation When Port 2 is programmed in the Interlocked 2-Wire Handshake mode or the 3-Wire Handshake mode, and Port A is programmed in Z-BUS or non-Z-BUS Microprocessor mode, the FIO interfaces a CPU and a peripheral device. In the Interlocked 2-Wire Handshake mode, RFD/ $\overline{DAV}$ and $\overline{ACKIN}$ strobe data to and from Port 2. In the 3-Wire Handshake mode, RFD/ $\overline{DAV}$ , $\overline{DAV}$ / $\overline{DAC}$ , and DAC/RFD signals control data flow. Interlocked 2-Wire Handshake. In the Interlocked Handshake, the action of the FIO must be acknowledged by the other half of the handshake before the next action can take place. In output mode, Port 2 does not indicate that new data is available until the external device indicates it is ready for the data. Similarly, in input mode, Port 2 does not indicate that it is ready for new data until the data source indicates that the previous byte of the data is no longer available, thereby acknowledging Port 2's acceptance of the last byte. This allows the FIO to directly interface to a Z8's port, a CIO's port, a UPC's port, another FIO port, or another FIFO Z8060, with no external logic (Figures 21 and 22). 3-Wire Handshake. The 3-Wire Handshake is designed for applications in which one output port is communicating with many input ports simultaneously. It is essentially the same as the Interlocked Handshake, except that two signals are used to indicate that an input port is ready for new data or that it has accepted the present data. In the 3-Wire Handshake, the rising edge of the RFD status line indicates that the port is ready for data, and the rising edge of the DAC status line indicates that the data has been accepted. With 3-Wire Handshake, the lines of many input ports can be bussed together with open-drain drivers and the out- put port knows when all of the ports are ready and have accepted the data. This handshake is the same handshake used in the IEEE-488 Instruments. Since the port's direction can be changed under software control, bidirectional IEEE-488-type transfers can be performed. Figures 23 and 24 show the timings associated with 3-Wire Handshake communications. CLEAR FIFO Operation. In CPU-to-I/O operation, the CLEAR FIFO operation can be performed by the CPU side (Port 1) under software control as previously explained. The CLEAR FIFO operation can also be performed under hardware control by defining the CLEAR pin of Port 2 as an input (Control Register 3, bit 7 = 1). For cascading purposes, the $\overline{\text{CLEAR}}$ pin can also be defined as an output (Control Register 3, bit 7 = 0), which reflects the current state of the $\overline{\text{CLEAR}}$ FIFO bit. It can then empty other FIOs or initialize other devices in the system. **Data Direction Control.** In CPU-to-I/O mode, the direction of data transfer can be controlled by the CPU side (Port 1) under software control as previously explained. The data direction can also be determined by hardware control by defining the Data Direction pin of Port 2 as an input (Control Register 3, bit 5 = 1). For cascading purposes, the Data Direction pin can also be defined as an output (Control Register 3, bit 5=0) pin which reflects the current state of the Data Direction bit. It can then be used to control the direction of data transfer for other FIOs or for external logic. On the Port 2 side, when data direction is 0, Port 2 is in Output Handshake mode. When data direction is 1, Port 2 is in Input Handshake mode. Figure 21. Interlocked Handshake Timing (Input) Port 2 Side Only Figure 22. Interlocked Handshake Timing (Output) Port 2 Side Only Figure 23. Input (Acceptor) Timing IEEE-488 HS Port: Port 2 Side Only Figure 24. Output (Source) Timing IEEE-488 HS Port: Port 2 Side Only 2020-019, 020, 021, 022 #### Programming The programming of the FIO is greatly simplified by the efficient grouping of the various operation modes in the control registers. Since all of the control registers are read/write, the need for maintaining their image in system memory is eliminated. Also, the read/write feature of the registers aids in system debugging. Each side of the FIO has 16 registers. All 16 registers are used by the Port 1 side; Control register 2 is not used on the Port 2 side. All registers are addressable 0<sub>H</sub> through F<sub>H</sub>. In the Z-BUS Low Byte mode, the FIO allows two methods for register addressing under control of the Right Justify Address (RJA) bit in Control register 0. When RJA = 0, address bus bits 1-4 are used for register addressing and bits 1, 5, 6, and 7 are ignored (Table 4). When RJA = 1, bits 0-3 are used for the register addresses, and bits 4-7 are ignored. **Control Registers.** These four registers specify FIO operation. The Port 2 side control registers operate only if the Port 2 device is a CPU. The Port 2 CPU can control interface operations, including data direction, only when enabled by the setting of bit 0 in the Port 1 side of Control Register 2. A 1 in bit 1 of the same register enables the handshake logic. **Interrupt Status Registers.** These four registers control and monitor the priority interrupt functions for the FIO. Interrupt Vector Register. This register stores the interrupt service routine address. This vector is placed on $D_0$ - $D_7$ when IUS is set by the Interrupt Acknowledge signal from the CPU. When bit 4 (Vector Includes Status) is set in Control Register 0, the reason for the interrupt is encoded within the vector address in bits 1, 2, and 3. If bit 5 is set in Control register 0, no vector is output by the FIO during an Interrupt Acknowledge cycle. However, IUS is set as usual. | Non Z-BUS | D <sub>7</sub> -D <sub>4</sub> | $D_3$ | $\mathbf{D_{2}}$ | $D_1$ | $D_0$ | | |------------------------------------------------------|----------------------------------------------------------------------|------------------------------------|------------------------------------|------------------------------------|------------------------------------|-----------------| | Z-BUS High | | A <sub>3</sub> | A <sub>2</sub> | A <sub>1</sub> | A <sub>0</sub> | | | Z-BUS Low $\begin{cases} RJA=0 \\ RJA=1 \end{cases}$ | AD <sub>7</sub> -AD <sub>5</sub><br>AD <sub>7</sub> -AD <sub>4</sub> | AD <sub>4</sub><br>AD <sub>3</sub> | AD <sub>3</sub><br>AD <sub>2</sub> | AD <sub>2</sub><br>AD <sub>1</sub> | AD <sub>1</sub><br>AD <sub>0</sub> | AD <sub>0</sub> | | Description | | | | | | | | Control Register 0 | x | 0 | 0 | 0 | 0 | х | | Control Register 1 | x | 0 | 0 | 0 | 1 | x | | Interrupt Status Register 0 | x | 0 | 0 | 1 | 0 | x | | Interrupt Status Register 1 | x | 0 | 0 | 1 | 1 | x | | Interrupt Status Register 2 | x | 0 | 1 | 0 | 0 | x | | Interrupt Status Register 3 | x | 0 | 1 | 0 | 1 | x | | Interrupt Vector Register | x | 0 | 1 | 1 | 0 | x | | Byte Count Register | x | 0 | l | l | 1 | x | | Byte Count Comparison<br>Register | x | 1 | 0 | 0 | 0 | x | | Control Register 2* | x | 1 | 0 | 0 | 1 | x | | Control Register 3 | x | 1 | 0 | 1 | 0 | x | | Message Out Register | x | 1 | 0 | 1 | 1 | x | | Message In Register | x | 1 | 1 | 0 | 0 | x | | Pattern Match Register | x | 1 | 1 | 0 | 1 | x | | Pattern Mask Register | x | 1 | 1 | 1 | 0 | x | | Data Buffer Register | x | 1 | 1 | 1 | 1 | x | x = Don't Care Table 4. FIO Register Address Summary <sup>\*</sup>Register is only on Port 1 side (Continued) Programming Byte Count Compare Register. This register contains a value compared with the byte count in the Byte Count register. If the Byte Count Compare interrupt is enabled, an interrupt will occur upon compare. > Message Out Register. Either CPU can place a message in its Message Out register. If the opposite side Message register interrupt is enabled, the receiving side CPU will receive an interrupt request, advising that a message is present in its Message In register. Bit 5 in Control Register 1 on the initiating side is set when a message is written. It is cleared when the message is read by the receiving CPU. Message In Register. This register receives a message placed in the Message Out register by the opposite side CPU. Pattern Match Register. This register contains a bit pattern matched against the byte in the Data Buffer register. When these patterns match, a Pattern Match interrupt will be generated, if previously enabled. Pattern Mask Register. The Pattern Mask register may be programmed with a bit pattern mask that limits comparable bits in the Pattern Match register to non-masked bits (1 = mask). Data Buffer Register. This register contains the data to be read from or written to the FIFO buffer. Byte Count Register. This is a read-only register, containing the byte count for the FIFO buffer. The byte count is derived by subtracting the number of bytes read from the buffer from the number of bytes written into the buffer. The count is "frozen" for an accurate reading by setting bit 6 (Freeze Status register) in Control Register 1. This bit is cleared when the Byte Count register read is completed. Figure 25. Typical Application: Node Controller 2020-033 Figure 26. Control Registers Figure 27. Interrupt Status Registers #### Registers (Continued) #### Interrupt Status Register 1 Address: 0011 (Read/Write) \*READ ONLY BITS #### **Interrupt Status Register 2** Address: 0100 (Read/Write) #### **Interrupt Status Register 3** Address: 0101 (Read/Write) \*READ-ONLY BITS Figure 27. Interrupt Status Registers (Continued) 2020-024 | Registers | Byte Count Register | Interrupt Vector Register | | | | | |-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--| | (Continued) | Address: 0111 | Address: 0110<br>(Read/Write) | | | | | | | (Read Only) | , , | | | | | | | $\begin{bmatrix} \mathbf{D_7} & \mathbf{D_6} & \mathbf{D_5} & \mathbf{D_4} & \mathbf{D_3} & \mathbf{D_2} & \mathbf{D_1} & \mathbf{D_0} \end{bmatrix}$ | $\begin{array}{c ccccccccccccccccccccccccccccccccccc$ | | | | | | | <u> </u> | | | | | | | | REFLECTS NUMBER OF BYTES IN BUFFER | NO INTERRUPTS PENDING 0 0 0 | | | | | | | Figure 28. Byte Count Register | BUFFER EMPTY 0 0 1 1 BUFFER FULL 0 1 0 | | | | | | | | VECTOR STATUS | | | | | | | | BYTE COUNT MATCH 1 0 0 PATTERN MATCH 1 0 1 | | | | | | | | DATA DIRECTION CHANGE 1 1 0 | | | | | | | | MAILBOX MESSAGE 1 1 1 | | | | | | | | Figure 29. Interrupt Vector Register | | | | | | | Pattern Match Register | Pattern Mask Register | | | | | | | Address: 1101 | Āddress: 1110 | | | | | | | (Read/Write) | (Read/Write) | | | | | | | $\begin{bmatrix} \mathbf{D_7} & \mathbf{D_6} & \mathbf{D_5} & \mathbf{D_4} & \mathbf{D_3} & \mathbf{D_2} & \mathbf{D_1} & \mathbf{D_0} \end{bmatrix}$ | $\begin{bmatrix} \mathbf{D_7} & \mathbf{D_8} & \mathbf{D_5} & \mathbf{D_4} & \mathbf{D_3} & \mathbf{D_2} & \mathbf{D_4} & \mathbf{D_0} \end{bmatrix}$ | | | | | | | 111111 | 111111 | | | | | | | STORES BYTE COMPARED WITH<br>BYTE IN DATA BUFFER REGISTER | IF SET, BITS 0-7 MASK BITS 0-7<br>IN PATTERN MATCH REGISTER. | | | | | | | | MATCH OCCURS WHEN ALL<br>NON-MASKED BITS AGREE. | | | | | | | Figure 30. Pattern Match Register | | | | | | | | | Figure 31. Pattern Mask Register | | | | | | _ | Data Buffer Register | Byte Count Comparison Register | | | | | | | Address: 1111 | Address: 1000 | | | | | | | (Read/Write) | (Read/Write) | | | | | | | $\begin{bmatrix} \mathbf{D_7} & \mathbf{D_6} & \mathbf{D_5} & \mathbf{D_4} & \mathbf{D_3} & \mathbf{D_2} & \mathbf{D_1} & \mathbf{D_0} \end{bmatrix}$ | $\begin{array}{ c c c c c c c c c c c c c c c c c c c$ | | | | | | | 111111 | 111111 | | | | | | | CONTAINS THE BYTE TRANSFERRED<br>TO OR FROM FIFO BUFFER RAM | CONTAINS VALUE COMPARED TO BYTE COUNT<br>REGISTER TO ISSUE INTERRUPTS ON MATCH<br>(BIT 7 ALWAYS 0.) | | | | | | | Figure 32. Data Buffer Register | Figure 33. Byte Count Comparison Register | | | | | | | Message Out Register | Message In Register | | | | | | | Address: 1011 | Address: 1100 | | | | | | | (Read/Write) | (Read Only) | | | | | | | $D_7$ $D_8$ $D_5$ $D_4$ $D_3$ $D_2$ $D_1$ $D_0$ | $D_7$ $D_6$ $D_5$ $D_4$ $D_3$ $D_2$ $D_1$ $D_0$ | | | | | | | | | | | | | | | STORES MESSAGE SENT TO MESSAGE<br>IN REGISTER ON OPPOSITE PORT OF FIO | STORES MESSAGE RECEIVED FROM MESSAGE<br>OUT REGISTER ON OPPOSITE PORT OF CPU | | | | | Figure 34. Message Out Register Figure 35. Message In Register | Absolute<br>Maximum<br>Ratings | Voltages on all inputs and outputs with respect to GND0.3 V to +7.0 V Operating Ambient Temperature0°C to +70°C Storage Temperature65°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 characteristics below apply for the following standard test conditions, unless otherwise noted. All voltages are referenced to GND. Positive current flows into the referenced pin. Standard conditions are as follows: - $+4.75 \text{ V} \le \text{V}_{\text{CC}} \le +5.25 \text{ V}$ - GND = 0 V - T<sub>A</sub> as specified in Ordering Information Standard Test Load Open-Drain Test Load | DC | Symbol | Parameter | Min | Мах | Unit | Condition | |----------------------|-------------------|---------------------------------------------|------|-----------------------|---------|-------------------------------| | Charac-<br>teristics | $V_{\mathrm{IH}}$ | Input High Voltage | 2.0 | V <sub>CC</sub> + 0.3 | V | | | | $V_{\mathrm{IL}}$ | Input Low Voltage | -0.3 | 0.8 | V | | | | $v_{OH}$ | Output High Voltage | 2.4 | | V | $I_{OH} = -250 \mu A$ | | | $V_{OL}$ | Output Low Voltage | | 0.4 | V | $I_{OL} = +2.0 \text{ mA}$ | | | | | | 0.5 | V | $I_{OL} = +3.2 \text{ mA}$ | | | $I_{\mathrm{IL}}$ | Input Leakage | | ± 10.0 | $\mu$ A | $0.4 \le V_{IN} \le +2.4V$ | | | $I_{OL}$ | Output Leakage | | ± 10.0 | $\mu$ A | $0.4 \le V_{OUT} \le +2.4V$ | | | $I_{LM}$ | Mode Pins Input Leakage<br>(Pins 19 and 21) | -100 | +10.0 | μΑ | $0 < V_{\rm IN} < V_{\rm CC}$ | | | $I_{\rm CC}$ | V <sub>CC</sub> Supply Current | | 200 | mA | | $V_{CC}$ = 5 V ± 5% unless otherwise specified, over specified temperature range. | Capacitance | Symbol | Parameter | Min | Max | Unit | Test Condition | |-------------|------------------|---------------------------|-----|-----|------|--------------------| | | $C_{IN}$ | Input Capacitance | | 10 | рF | | | | C <sub>OUT</sub> | Output Capacitance | | 15 | рF | Unmeasured Pins | | | | Bidirectional Capacitance | | 20 | pF ` | Returned to Ground | | Inputs | tr | Any Input Rise Time | | 100 | ns | | | | tf | Any Input Fall Time | | 100 | ns | | f = 1 MHz, over specified temperature range. | | | <b>.</b> | | MHz | | MHz | <b>.</b> | |------|---------------|----------------------------------------------------------------------------------------------------------------------|-------|-----|-----|------------|-------------------| | No. | Symbol | Parameter | Min | Max | Min | Max | Notes*† | | 1 | TwAS | AS Low Width | 70 | | 50 | | 1 | | 2 | TsA(AS) | Address to AS † Setup Time | 30 | | 10 | | 1 | | 3 | ThA(AS) | Address to $\overline{\rm AS}$ † Hold Time | 50 | , | 30 | | 1 | | 4 | TsCSO(AS) | CS to AS ↑ Setup Time | 0 | | 0 | | 1 | | 5 – | - ThCSO(AS) - | — <del>CS</del> to <del>AS</del> ↑ Hold Time | 60 | | 40 | | —— 1 <del>—</del> | | 6 | TdAS(DS) | $\overline{\mathrm{AS}}$ † to $\overline{\mathrm{DS}}$ † Delay | 60 | | 40 | | 1 | | 7 | TsA(DS) | Address to $\overline{DS} \downarrow$ (with $\overline{AS} \uparrow$ to $\overline{DS} \downarrow = 60 \text{ ns}$ ) | 120 | | 100 | | | | 8 | TsRWR(DS) | $R/\overline{W}$ (Read) to $\overline{DS}$ $\downarrow$ Setup Time | 100 | | 80 | | | | 9 | TsRWW(DS) | R/W (Write) to DS ↓ Setup Time | 0 | | 0 | | | | 10 - | - TwDS | — DS Low Width — | 390 - | | 250 | | | | 11 | TsDW(DSf) | Write Data to DS ↓ Setup Time | 30 | | 20 | | | | 12 | TdDS(DRV) | $\overline{\text{DS}}$ (Read) ↓ to Address Data Bus Driven | 0 | | 0 | | | | 13 | TdDSf(DR) | <del>DS</del> ↓ to Read Data Valıd Delay | | 250 | | 180 | | | 14 | ThDW(DS) | Write Data to $\overline{\text{DS}}$ † Hold Time | 30 | | 20 | | | | 15 - | – TdDSr(DR) – | — DS † to Read Data Not Valid Delay ———— | 0 - | | 0 - | | | | 16 | TdDS(DRz) | <del>DS</del> ↑ to Read Data Float Delay | | 70 | | <b>4</b> 5 | 2 | | 17 | ThRW(DS) | $R/\overline{W}$ to $\overline{DS}$ † Hold Time | 55 | | 40 | | | | 18 | TdDS(AS) | $\overline{\mathrm{DS}}$ ↑ to $\overline{\mathrm{AS}}$ ↓ Delay | 50 | | 25 | | | | 19 | Trc | Valid Access Recovery Time | 1000 | | 650 | | 3 | #### NOTES **AC** Characteristics - 3. This is the delay from $\overline{DS}$ of one CIO access to $\overline{DS}$ of another FIO access (either read or write). \* All timing references assume 2.0 V for a logic "1" and 0.8 V for a logic "0" All timings are preliminary and subject to change. † Units in nanoseconds (ns) Figure 36. Z-BUS CPU Interface Timing <sup>1.</sup> Parameter does not apply to Interrupt Acknowledge transactions. Float delay is measured to the time when the output has changed 0.5 V from steady state with minimum as load and load and maximum de load. #### **AC Characteristics** | | | | 4 | MHz | 6 1 | | | |-----|------------|-------------------------------------------------------------------|-----|-----------------|-----|-----------------|---------| | No. | Symbol | Parameter | Min | Max | Min | Max | Notes*† | | 20 | TsIA(AS) | INTACK to AS † Setup Time | 0 | | | 0 | | | 21 | ThIA(AS) | INTACK to AS † Hold Time | 250 | | 250 | | | | 22 | TsDSA(DR) | $\overline{\mathrm{DS}}$ (Acknowledge) ↓ to Read Data Valid Delay | | 250 | | 180 | | | 23 | TwDSA | DS (Acknowledge) Low Width | 390 | | 250 | | | | 24— | -TdAS(IEO) | — AS ↑ to IEO ↓ Delay (INTACK Cycle)———— | | <del> 350</del> | | <del></del> 250 | 4 | | 25 | TdIEI(IEO) | IEI to IEO Delay | | 150 | | 100 | 4 | | 26 | TsIEI(DSA) | IEI to $\overline{\rm DS}$ (Acknowledge) $\downarrow$ Setup Time | 100 | | 70 | | | | 27 | ThIEI(DSA) | IEI to $\overline{ ext{DS}}$ (Acknowledge) $\dagger$ Hold Time | 50 | | 30 | | 4 | | 28 | TdDS(INT) | DS (INTACK Cycle) to INT Delay | | 900 | | 800 | | | 29 | TdDCST | Interrupt Daisy Chain Settle Time | | | | | 4 | #### NOTES and TdIEI(IEO) for each peripheral, separating them in the - \* Timings are preliminary and subject to change † Units in nanoseconds (ns) Figure 37. Z-BUS CPU Interrupt Acknowledge Timing 2020-035 NOTES 4 The parameters for the devices in any particular daisy chain must meet the following constraint. The delay from AS to DS must be greater than the sum of TdAS(IEO) for the highest priority peripheral. TsIEI(DSA) for the lowest priority peripheral. | AC C | haracteristics | | | | | | | |------|----------------|-----------------------------------------|------------|---------------|------------|-----|---------| | No. | Symbol | Parameter | 4 M<br>Min | Mux<br>Max | 6 I<br>Min | Max | Notes*† | | 30 | TdMW(INT) | Message Write to INT Delay | | 1 | | 1 | 5 | | 31 | TdDC(INT) | Data Direction Change to INT Delay | | 1 | | 1 | 6 | | 32 | TdPMW(INT) | Pattern Match to INT Delay (Write Case) | | 1 | | 1 | | | 33 | TdPMR(INT) | Pattern Match (Read Case) to INT Delay | | 1 | | 1 | | | 34 | -TdSC(INT) | —Status Compare to INT Delay————— | | <del></del> 1 | | l | 6 | | 35 | TdER(INT) | Error to INT Delay | | 1 | | 1 | | | 36 | TdEM(INT) | Empty to INT Delay | | 1 | | 1 | 6 | | 37 | TdFL(INT) | Full to INT Delay | | 1 | | 1 | 6 | | 38 | TdAS(INT) | AS to INT Delay | | | | | | #### 38 NOTES: Figure 38. Z-BUS Interrupt Timing Write is from the other side of FIO. Write can be from either side, depending on programming of FIO. <sup>\*</sup> Timings are preliminary and subject to change. † Units equal to $\overline{AS}$ Cycles + ns. #### **AC Characteristics** 4 MHz 6 MHz Min Min No. Symbol **Parameter** Max Max Notes\*† AS ↑ to WAIT ↓ Delay 1 TdDS(WAIT) 190 160 2 DSI t to WAIT t Delay 1000 1000 TdDS1(WAIT) 3 ACKIN ↓ to WAIT ↑ Delay 1000 1000 TdACK(WAIT) 1 4 TdDS(REQ) -DS I to REQ 1 Delay 350 300 5 DMASTB ↓ to REQ ↑ Delay 350 300 TdDMA(REQ) 6 TdDS1(REQ) DS1 1 to REQ ↓ Delay 1000 1000 7 TdACK(REQ) ACKIN ↓ to REQ ↓ Delay 1000 1000 8 TdSU(DMA)-Data Setup Time to DMASTB 200 150 9 TdH(DMA) Data Hold Time to DMASTB 30 20 DMASTB | to Valid Data 10 TdDMA(DR) 150 100 #### 12 NOTES 11 l The delay is from $\overline{DAV}$ for 3-Wire Input Handshake. The delay DMASTB † to Data Not Valid DMASTB | to Data Bus Float is from DAC for 3-Wire Handshake. TdDMA(DRH) TdDMA(DR2) \* Timings are preliminary and subject to change. 70 0 45 0 Figure 39. Z-BUS Request/Wait Timing | AC C | Characteristics | | | | | | | |------|-----------------|--------------------------------------------------------------------------|-----|-----|-----|-----|---------| | | | | 41 | MHz | 6 1 | MHz | | | No. | Symbol | Parameter | Min | Max | Min | Max | Notes*† | | 1 | TdDSQ(AS) | Delay from $\overline{\rm DS}$ † to $\overline{\rm AS}$ ↓ for No Reset | 40 | | 20 | | | | 2 | TdASQ(DS) | Delay for $\overline{AS}$ 1 to $\overline{DS}$ 1 for No Reset | 50 | | 30 | | | | 3 | Tw(AS + DS) | Minimum Width of $\overline{AS}$ and $\overline{DS}$ Both Low for Reset. | 500 | | 350 | | 1 | #### MOTEC. 1 Internal circuitry allows for the reset provided by the Z8 (DS held Low while AS pulses) to be sufficient - \* Timings are preliminary and subject to change. - † Units in nanoseconds (ns) Figure 40. Z-BUS Reset Timing | AC C | Characteristics | | 4 N | (Hz | 61 | MHz | | |------|-----------------|------------------------------------------------------------------|---------------|-----|-----------------|-----|-------------| | No. | Symbol | Parameter | Min | Мах | Min | Мах | Notes* | | 1 | TsA(RD) | Address Setup to $\overline{\text{RD}}$ ↓ | 80 | | 80 | | 1 | | 2 | TsA(WR) | Address Setup to $\overline{ m WR}\ ightarrow$ | 80 | | 80 | | | | 3 | ThA(RD) | Address Hold Time to $\overline{\text{RD}}$ † | 0 | | 0 | | 1 | | 4 - | — ThA(WR) —— | — Address Hold Time to WR †———— | 0 | | 0 - | | | | 5 | TsCEI(RD) | $\overline{\text{CE}}$ Low Setup Time to $\overline{\text{RD}}$ | 0 | | 0 | | 1 | | 6 | TsCEI(WR) | $\overline{\text{CE}}$ Low Setup Time to $\overline{\text{WR}}$ | 0 | 0 0 | | | | | 7 | ThCEI(RD) | CE Low Hold Time to RD | 0 | | 0 | | 1 | | 8 – | — ThCEI(WR) — | — CE Low Hold Time to WR | 0 | | 0 <del>-</del> | | | | 9 | TsCEh(RD) | $\overline{\text{CE}}$ High Setup Time to $\overline{\text{RD}}$ | 100 | | 70 | | 1 | | 10 | TsCEh(WR) | $\overline{\text{CE}}$ High Setup Time to $\overline{\text{WR}}$ | 100 | | 70 | | | | 11 | TwRD1 | RD Low Width | 390 | | 250 | | | | 12 - | — TdRD(DRA) — | — RD ↓ to Read Data Active Delay ——— | 0 <del></del> | | 0 - | | | | 13 | TdRDf(DR) | RD ↓ to Valıd Data Delay | | 250 | | 180 | | | 14 | TdRDr(DR) | RD ↑ to Read Data Not Valıd Delay | 0 | | 0 | | | | 15 | TdRD(DRz) | RD ↑ to Data Bus Float | | 70 | | 45 | 2 | | 16 - | TwWR1 | | <del></del> | | <del> 250</del> | | <del></del> | | 17 | TsDW(WR) | Data Setup Time to WR | 0 | | 0 | | | | 18 | ThDW(WR) | Data Hold Time to $\overline{ m WR}$ | 30 | | 20 | | | | 19 | Trc | Valid Access Recovery Time | 1000 | | 650 | | 3 | #### NOTES - 1 Parameter does not apply to Interrupt Acknowledge transactions - 2 Float delay is measured to the time the output has changed 0 5 V from steady state with minimum ac load and maximum dc load - 3 This is the delay from $\overline{RD}$ 1 to $\overline{WR}$ 1 of one FIO access to $\overline{RD}$ 4 or $\overline{WR}$ 4 of another FIO access - \* Timings are preliminary and subject to change - † Units in nanoseconds (ns) Figure 41. Non-Z-BUS CPU Interface Timing Figure 42. Non-Z-BUS Interface Timing 264 2020-039, 040 4 #### **AC** Characteristics 4 MHz 6 MHz No. Symbol **Parameter** Min Max Min Max Notes†\* 20 IEI to IEO Delay 150 100 4 TdIEI(IEO) 21 INTACK ↓ to IEO ↓ Delay 350 250 TdI(IEO) 4 IEI Setup Time to $\overline{\text{RD}}$ (Acknowledge) 22 TsIEI(RDA) 100 70 4 23 TdRD(DR) RD I to Vector Valid Delay 250 180 -TwRD1(IA)-Read Low Width (Interrupt Acknowledge) 390 250 24 INTACK 1 to RD 1 Hold Time 25 ThIA(RD) 30 20 IEI Hold Time to RD † 26 ThIEI(RD) 20 10 RD † to INT † Delay 27 TdRD(INT) 900 800 #### NOTES 28 **TdDCST** Interrupt Daisy Chain Settle Time for the lowest priority peripheral, and TdIEI(IEO) for each peripheral separating them in the chain. † Units in nanoseconds (ns) 250 350 Figure 43. Non-Z-BUS Interrupt Acknowledge Timing The parameter for the devices in any particular daisy chain must meet the following constraint. The delay from $\overline{\rm INTACK}$ . It to $\overline{\rm RD}$ . I must be greater than the sum of TdINA(IEO) for the highest priority peripheral, TsIEI(RD) Timings are preliminary and subject to change | AC C | AC Characteristics | | | MHz | 61 | MHz | | |------|--------------------|--------------------------------------------|-----|-----|-----|-----|---------| | No. | Symbol | Parameter | Min | Мах | Min | Max | Notes*† | | 29 | TdMW(INT) | Message Write to INT Delay | | | | | 5,6 | | 30 | TdDC(INT) | Data Direction Change to INT Delay | | | | | 5,7 | | 31 | TdPMW(INT) | Pattern Match (Write Case) to INT Delay | | | | | 5 | | 32- | -TdPMR(INT)- | —Pattern Match (Read Case) to INT Delay——— | r | | | | 5 | | 33 | TdSC(INT) | Status Compare to INT Delay | | | | | 5,7 | | 34 | TdER(INT) | Error to INT Delay | | | | | 5,7 | | 35 | TdEM(INT) | Empty to INT Delay | | | | | 5,7 | | 36 | TdFL(INT) | Full to INT Delay | | | | | 5,7 | | 37 | TdSO(INT) | State 0 to INT Delay | | | | | | #### NOTES: - 5. Delay number is valid for State 0 only.6. Write is from other side of FIO - 7. Write can be from either side, depending on programming of FIO - $^{\star}$ Timings are preliminary and subject to change. - † Units in nanoseconds (ns). Figure 44. Z-FIO Non-Z-BUS Interrupt Timing #### **AC Characteristics** | | | | 4 MHz | | 6 MHz | | | |-----|--------------|-----------------------------------------------------------------------------------------------|-----------|------|-------|-----------------|---------| | No. | Symbol | Parameter | Min | Max | Min | Мах | Notes*† | | 1 | TdRD(WT) | CE ↓ to WAIT Active | 200 170 | | | | | | 2 | TdRD1(WT) | $\overline{\text{RD}}$ l † or $\overline{\text{WR}}$ l † to $\overline{\text{WAIT}}$ Inactive | 1000 1000 | | | | | | 3 | TdACK(WT) | $\overline{\text{ACKIN}}$ to $\overline{\text{WAIT}}$ Inactive | 1000 1000 | | | | 1 | | 4- | —TdRD(REQ)—— | —RD ↓ or WR ↓ to REQ Inactive ————— | | 350 | | <del></del> 300 | | | 5 | TdRD1(REQ) | RDl f or WRl f to REQ Active | | 1000 | | 1000 | | | 6 | TdACK(REQ) | ACKIN I to REQ Active | | 1000 | | 1000 | | | 7 | TdDAC(RD) | DACK to RD or WR | 100 | | 80 | | | | 8- | -TSU(WR) | —Data Setup Time to WR———————— | 200 — | | | | | | 9 | Th(WR) | Data Hold Time to WR | 30 | | | 20 | | | 10 | TdDMA | RD to Valid Data | | 150 | | 100 | 2 | | 11 | TdDMA(DRH) | RD † to Data Not Valid | 0 | | 0 | | 2 | | 12 | TdDMA(DRZ) | RD ↑ to Data Bus Float | | 70 | | <b>4</b> 5 | 2 | #### NOTES. † Units in nanoseconds (ns) Figure 45. Non-Z-BUS Request/Wait Timing 2020-043 NOIES. 1. The delay is from $\overline{DAV}$ 1 for 3-Wire Input Handshake. The delay is from $\overline{DAC}$ 1 for 3-Wire Input Handshake. 2. Only when $\overline{DACK}$ is active. $<sup>^{\</sup>star}$ Timings are preliminary and subject to change. | AC Characteristics | | | | | | | | | | |--------------------|-----------|---------------------------------------------------------------------------------|-----|-----|-----|-------|---------|--|--| | | | | 4: | MHz | 61 | 6 MHz | | | | | No. | Symbol | Parameter | Min | Max | Min | Мах | Notes*† | | | | 1 | TdWR(RD) | Delay from WR ↑ to RD ↓ | 100 | | 70 | | | | | | 2 | TdRD(WR) | Delay from RD ↑ to WR ↓ | 100 | | 70 | | | | | | 3 | TwRD + WR | Width of $\overline{\text{RD}}$ and $\overline{\text{WR}}$ , both Low for Reset | 500 | | 350 | | | | | Figure 46. Non-Z-BUS Reset Timing | AC Characteristics | | | | | | | | | | | |--------------------|-----------|------------------------------|------------------|----------|------------|---------|--|--|--|--| | No. | Symbol | Parameter | 4 MHz<br>Min Max | 6<br>Min | MHz<br>Max | Notes*† | | | | | | 1 | TwCLR | Width of Clear to Reset FIFO | 700 | 700 | | | | | | | | 2 | TdOE(DO) | OE ↓ to Data Bus Driven | 0 | 0 | | | | | | | | 3 | TdOE(DRZ) | OE † to Data Bus Float | | | | | | | | | Figure 47. Port 2 Side Operation NOTES: \* Timings are preliminary and subject to change. † Units in nanoseconds (ns). NOTES: \* Timings are preliminary and subject to change. † Units in nanoseconds (ns). 1.0 1.0 | AC C | AC Characteristics | | | | | | | | | | | | |------|--------------------|------------------------------------------------|----------------|--------------|-----|-----|---------|--|--|--|--|--| | | | | 4 MHz | | 6 1 | MHz | | | | | | | | No. | Symbol | Parameter | Min | Max | Min | Max | Notes*† | | | | | | | 1 | TsDI(ACK) | Data Input to ACKIN ↓ to Setup Time | 50 | | 50 | | | | | | | | | 2 | TdACKf(RFD) | ACKIN ↓ to RFD ↓ Delay | 0 | 500 | 0 | 500 | | | | | | | | 3 | TdRFDr(ACK) | RFD ↑ to ACKIN ↓ Delay | 0 | | 0 | | | | | | | | | 4 | -TsDO(DAV) | -Data Out to DAV ↓ Setup Time- | <del></del> 25 | | 25 | | | | | | | | | 5 | TdDAVf(ACK) | DAV I to ACKIN I Delay | 0 | | 0 | | | | | | | | | 6 | ThDO(ACK) | Data Out to ACKIN Hold Time | 50 | | 50 | | | | | | | | | 7 | TdACK(DAV) | ACKIN ↓ to DAV † Delay | 0 | 500 | 0 | 500 | | | | | | | | 8 | -ThDI(RFD) | -Data Input to RFD Hold Time- | 0 | <del>/</del> | 0 | | | | | | | | | 9 | TdRFDf(ACK) | RFD ↓ to <del>ACKIN</del> † Delay | 0 | | 0 | | | | | | | | | 10 | TdACKr(RFD) | ACKIN † (DAV †) to RFD † Delay—Interlocked and | | | | | | | | | | | | | | 3-Wire Handshake | 0 | 400 | 0 | 400 | | | | | | | | 11 | TdDAVr(ACK) | DAV † to ACKIN † (RFD †) | 0 | | 0 | | | | | | | | | 12- | -TdACKr(DAV)- | -ĀCKĪN ↑ to DĀV ↓ | 0 | 800 | 0 | 800 | | | | | | | | 13 | TdACKf(Empty) | ACKIN ↓ to Empty | 0 | | 0 | | | | | | | | | 14 | TdACKf(Full) | ACKIN ↓ to Full | 0 | | 0 | | | | | | | | ### 15 ACKIN Cycle Time TcACK Figure 48. 2-Wire Handshake (Port 2 Side Only) Output Figure 49. 2-Wire Handshake (Port 2 Side Only) Input NOTES \* Timings are preliminary and subject to change † Units in nanoseconds (ns) | X. | $\sim$ | Ch | ~*~ | ~+~ | wi. | tice | |----|--------|-----|-----|-----|-----|------| | M | _ | ı.n | ara | CTE | TIC | TICE | | | | | 4 MHz | | 61 | | | |-----|---------------|-------------------------------------------|---------------|-----|---------------|-----|---------| | No. | Symbol | Parameter | Min | Мах | Min | Мах | Notes*† | | 1 | TsDI(DAV) | Data Input to <del>DAV</del> ↓ Setup Time | 50 | | 50 | | | | 2 | TdDAVIf(RFD) | DAV ↓ to RFD ↓ Delay | 0 | 500 | 0 | 500 | | | 3 | TdDAVf(DAC) | DAV ↓ to DAC ↑ Delay | 0 | 500 | 0 | 500 | | | 4 | -ThDI(DAC) | -Data In to DAC † Hold Time | 0 <del></del> | | 0 <del></del> | | | | 5 | TdDACIr(DAV) | DAC † to DAV † Delay | 0 | | 0 | | | | 6 | TdDAVIr(DAC) | DAV ↑ to DAC ↓ Delay | 0 | 500 | 0 | 500 | | | 7 | TdDAVIr(RFD) | DAV t to RFD t Delay | 0 | 500 | 0 | 500 | | | 8- | —TdRFDI(DAV)— | −RFD ↑ to DAV ↓ Delay −−−− | 0 | | o | | | | 9 | TsDO(DAC) | Data Out to <del>DAV</del> ↓ | | | | | | | 10 | TdDAVOf(RFD) | DAV ↓ to RFD ↓ Delay | 0 | | 0 | | | | 11 | TdDAVOf(DAC) | DAV ↓ to DAC ↑ Delay | 0 | | 0 | | | | 12- | -ThDO(DAC) | —Data Out to DAC † Hold Time — | | | | | | | 13 | TdDACOr(DAV) | DAC † to DAV † Delay | | 400 | | 400 | | | 14 | TdDAVOr(DAC | DAV ↑ to DAC ↓ Delay | 0 | | 0 | | | | 15 | TdDAVOr(RFD) | DAV † to RFD † Delay | 0 | | 0 | | | | 16 | TdRFDO(DAV) | RFD ↑ to DAV ↓ Delay | 0 | 800 | 0 | 800 | _ | Figure 50. 3-Wire Handshake Input Figure 51. 3-Wire Handshake Output NOTES Timings are preliminary and subject to change. Units in nanoseconds (ns) | Ordering<br>Information | Product<br>Number | Package/<br>Temp | Speed | Description | Product<br>Number | Package/<br>Temp | Speed | Description | |-------------------------|-------------------|------------------|---------|----------------|-------------------|------------------|---------|----------------| | | Z8038 | CE | 4.0 MHz | Z-FIO (40-pin) | Z8038A | CM | 6.0 MHz | Z-FIO (40-pin) | | | Z8038 | CM | 4.0 MHz | Same as above | Z8038A | CMB | 6.0 MHz | Same as above | | | Z8038 | CMB | 4.0 MHz | Same as above | Z8038A | CS | 6.0 MHz | Same as above | | | Z8038 | CS | 4.0 MHz | Same as above | Z8038A | DE | 6.0 MHz | Same as above | | | Z8038 | DE | 4.0 MHz | Same as above | Z8038A | DS | 6.0 MHz | Same as above | | | Z8038 | DS | 4.0 MHz | Same as above | Z8038A | PE | 6.0 MHz | Same as above | | | Z8038 | PE | 4.0 MHz | Same as above | Z8038A | PS | 6.0 MHz | Same as above | | | Z8038 | PS | 4.0 MHz | Same as above | | | | | NOTES. C = Ceramic, D = Cerdip, P = Plastic; E = -40 °C to +85 °C, M = 55 °C to +125 °C, MB = -55 °C to 125 °C with MIL-STD-883 with Class B processing, S = 0 °C to +70 °C # **Z8060 Z8000™FIFO Buffer Unit**and **Z-FIO Expander** # **Product Specification** June 1982 #### **Features** - Bidirectional, asynchronous data transfer capability - Large 128-bit-by-8-bit buffer memory - Two-wire, interlocked handshake protocol - Wire-ORing of empty and full outputs for sensing of multiple-unit buffers #### Julie 1502 - 3-state data outputs - Connects any number of FIFOs in series to form buffer of any desired length - Connects any number of FIFOs in parallel to form buffer of any desired width #### General Description The Z8060 First-In First-Out (FIFO) Buffer Unit consists of a 128-bit-by-8-bit memory, bidirectional data transfer and handshake logic. The structure of the FIFO unit is similar to that of other available buffer units. FIFO is a general-purpose unit; its handshake logic is compatible with that of other members of Zilog's Z8 and Z8000 Families. FIFOs can be cascaded end-to-end without limit to form a parallel 8-bit buffer of any desired length (in 128-byte increments). Any number of single- or multiple-unit FIFO serial buffers can be connected in parallel to form buffers of any desired width (in 8-bit increments). The FIFO buffer units are available as 28-pin packages. Figures 1 and 2 show the pin functions and pin assignments, respectively, of the FIFO device. A block diagram is shown in Figure 3. Figure 1. FIFO Pin Functions Figure 2. FIFO Pin Assignments 2123-001, 002 # General Description (Continued) Figure 3. Functional Block Diagram #### Pin Descriptions **ACKIN.** Acknowledge Input (input, active Low). This line signals the FIFO that output data has been received by peripherals or that input data is valid. CLEAR. Clear Buffer (input, active Low). When set to Low, this line causes all data to be cleared from the FIFO buffer. **D<sub>0</sub>-D<sub>7</sub>.** Data Bus (inputs/outputs, bidirectional). These bidirectional lines are used by the FIFO to receive and to transmit data. **DIR** $\overline{A}/B$ . Direction Input A/B (input, two control states). A High on this line signals that input data is to be received at Port B. A Low on this line signals that input data is to be received at Port A. **EMPTY.** Buffer Status (output, active High, open-drain). A High on this line indicates that the FIFO buffer is empty. **FULL.** Buffer Status (output, active High, open-drain). A High on this line indicates that the FIFO buffer is full. OEA, OEB. Output Enable A, Output Enable B (inputs, active Low). When Low, OEA enables the bus drivers for Port A; when High, OEA causes the bus drivers to float to a high-impedance level. Input OEB controls the bus drivers for Port B in the same manner as OEA controls those for Port A. RFD/DAV. Ready-for-Data/Data Available (outputs RFD, active High; DAV active Low). RFD, when High, signals to the peripherals involved that the FIFO is ready to receive data. DAV, when Low, signals to the peripherals involved that FIFO has data available to send. ### Functional Description Interlocked 2-Wire Handshake. In interlocked 2-wire handshake operation, the action of FIFO must be acknowledged by the other half of the handshake before the next action can occur. In an Output Handshake mode, the FIFO indicates that new data is available only after the external device has indicated that it is ready for the data. In an İnput Handshake mode, the FIFO does not indicate that it is ready for new data until the data source indi- cates that the previous byte of the data is no longer available, thereby acknowledging the acceptance of the last byte. This control feature allows the FIFO, with no external logic, to directly interface with the port of any CPU in the Z8 Family—a CIO, a UPC, an FIO, or another FIFO. The timing for the input and output handshake operations is shown in Figures 4 and 5, respectively. Figure 4. Two-Wire Interlocked Handshake Timing (input) Figure 5. Two-Wire Interlocked Handshake Timing (output) # Functional Description (Continued) Resetting or Clearing the FIFO. The $\overline{\text{CLEAR}}$ input is used to initialize and clear the FIFO. A Low level on this input clears all data from the FIFO, allows the EMPTY output to go High and forces both outputs RFD/ $\overline{\text{DAV}}_{A}$ and RFD/ $\overline{\text{DAV}}_{B}$ High. A High level on $\overline{\text{CLEAR}}$ allows the data to transfer through the FIFO. Bidirectional Transfer Control. The FIFO has bidirectional data transfer capability under control of the DIR $\overline{A}/B$ input. When DIR $\overline{A}/B$ is set Low, Port $\overline{A}$ becomes input handshake and Port B becomes output handshake; data transfers are then made from Port A to Port B. Setting DIR $\overline{A}/B$ High reverses the handshake assignments and the direction of transfer. This bidirectional control is illustrated in Table 1. | DIR Ā/B | Port A<br>Handshake | Port B<br>Handshake | Transier | |---------|---------------------|---------------------|----------| | 0 | Input | Output | A to B | | 1 | Output | Input | B to A | Table 1. Bidirectional Control Function Table The FIFO buffer must be empty before the direction of transfer is changed; otherwise, the results of the change will be unpredictable. If FIFO status is unknown when a transfer direc- tion change is to be made, the recommended procedure is: - (1) Force and hold CLEAR Low. - (2) Set DIR Ā/B to the level required for the desired direction. - (3) Force CLEAR High. Empty and Full Operation. The EMPTY and FULL output lines can be wire-ORed with the EMPTY and FULL lines of other FIFOs and FIOs. This capability enables the user to determine the empty/full status of a buffer consisting of multiple FIFOs, FIOs, or a combination of both. Table 2 shows the various states of EMPTY and FULL. | Number of<br>Bytes in FIFO | EMPTY | FULL | | | |----------------------------|-------|------|--|--| | 0 | High | Low | | | | 1-127 | Low | Low | | | | 128 | Low | High | | | Table 2. Signals EMPTY and FULL Operation Table **Interconnection Example.** Figure 6 illustrates a simplified block diagram showing the manner in which FIFOs can be interconnected to extend a FIO buffer. Figure 6. Typical Interconnection (Simplified Diagram) | Functional | Output Enable Operation. The FIFO provides | DIR Ā/B | $\overline{OE}_\mathtt{A}$ | $\overline{OE}_B$ | Function | | | |--------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------|-------------------|------------------------------------------------|--|--| | <b>Description</b> (Continued) | a separate Output Enable (OE) signal for each port of the buffer. An OE output is valid only when its port is in the Output Handshake | 0 | Х | 0 | Disable Port A Output<br>Enable Port B Output | | | | | mode. The control of this output function is shown in Table 3. Signal $\overline{OE}$ operates with | 0 | X | 1 | Disable Port A Output<br>Disable Port B Output | | | | | lines DIR $\overline{A}/B$ . A High on a valid $\overline{OE}$ line 3-states its port's data bus but does not affect | 1 | 0 | X | Enable Port A Output<br>Disable Port B Output | | | | ч., | the handshake operation. A Low level on a valid $\overline{OE}$ enables the data bus outputs if its | 1 | 1 | Х | Disable Port A Output<br>Disable Port B Output | | | | | port is in the Output Handshake mode. Note that the handshake operation is unaffected by | NOTE: X = Don't care. Table 3. Output Control Function Table | | | | | | | | the Output Enable pin. | | | | | | | | Äbsolute<br>Maximum<br>Ratings | Voltages on all inputs and outputs with respect to GND0.3 V to +7.0 V Operating Ambient Temperature As specified in Ordering Information Storage Temperature65° 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 not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability. | | | | | | | Standard<br>Test | The characteristics below apply for the following standard test conditions, unless | ■ $+4.75 \text{ V} \le \text{V}_{\text{CC}} \le +5.25 \text{ V}$ ■ GND = 0 V | | | | | | ### Conditions otherwise noted. All voltages are referenced to GND. Positive current flows into the referenced pin. Standard conditions are as follows: - T<sub>A</sub> as specified in Ordering Information. All ac parameters assume a load capacitance of 50 pF max. Figure 7. Standard Test Load Figure 8. Open-Drain Test Load | DC | Symbol | Parameter | Min | Max | Unit | Condition | |----------------------|-------------------|--------------------------------|------|-----------------------|---------|----------------------------------------------------------| | Character-<br>istics | $V_{IH}$ | Input High Voltage | 2.0 | V <sub>CC</sub> + 0.3 | V | | | | $V_{\mathrm{IH}}$ | Input Low Voltage | -0.3 | 0.8 | V | | | | $v_{oh}$ | Output High Voltage | 2.4 | | V | $I_{OH} = -250 \text{ A}$ | | | $v_{OL}$ | Output Low Voltage | | 0.4<br>0.5 | V<br>V | $I_{OL} = +2.0 \text{ mA}$<br>$I_{OL} = +3.2 \text{ mA}$ | | | ${ m I}_{ m IL}$ | Input Leakage | | ±10 | $\mu$ A | $0.4 \le V_{\rm IN} \le +2.4 \text{ V}$ | | | $I_{OL}$ | Output Leakage | | ±10 | μΑ | $0.4 \le V_{OUT} \le +2.4 \text{ V}$ | | | $I_{CC}$ | V <sub>CC</sub> Supply Current | | 200 | mA | | NOTE. $V_{CC} = +5 \text{ V } \pm 5\%$ unless otherwise specified over specified temperature range | Symbol Parameter | | Min | Min Max | | Test Condition | | | |------------------|---------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | C <sub>IN</sub> | Input Capacitance | | 10 | рF | Unmeasured pins | | | | $C_{OUT}$ | Output Capacitance | | 15 | рF | returned to ground | | | | $C_{I/O}$ | Bidirectional Capacitance | | 20 | рF | | | | | Input | | | | | | | | | tr | Any input rise time | | 100 | ns | | | | | tf | Any input fall time | | 100 | ns | | | | | | C <sub>IN</sub> C <sub>OUT</sub> C <sub>I/O</sub> Input | C <sub>IN</sub> Input Capacitance C <sub>OUT</sub> Output Capacitance C <sub>I/O</sub> Bidirectional Capacitance Input tr Any input rise time | $C_{IN}$ Input Capacitance $C_{OUT}$ Output Capacitance $C_{I/O}$ Bidirectional Capacitance Input tr Any input rise time | $C_{IN}$ Input Capacitance 10 $C_{OUT}$ Output Capacitance 15 $C_{I/O}$ Bidirectional Capacitance 20 Input tr Any input rise time 100 | $C_{IN}$ Input Capacitance 10 pF $C_{OUT}$ Output Capacitance 15 pF $C_{I/O}$ Bidirectional Capacitance 20 pF Input tr Any input rise time 100 ns | | | NOTE: f = 1 MHz over specified temperature range | Ordering<br>Information | Product<br>Number | Package/<br>Temp | Speed | Description | Product<br>Number | Package/<br>Temp | Speed | Description | |-------------------------|-------------------|------------------|---------|---------------|-------------------|------------------|---------|---------------| | | Z8060 | CE | 4.0 MHz | FIFO (28-pin) | Z8060 | DS | 4.0 MHz | FIFO (28-pin) | | | Z8060 | CS | 4.0 MHz | Same as above | Z8060 | PE | 4.0 MHz | Same as above | | | Z8060 | DE | 4.0 MHz | Same as above | Z8060 | PS | 4.0 MHz | Same as above | NOTES. C = Ceramic, D = Cerdip, P = Plastic, E = -40 °C to +85 °C, S = 0 °C to 70 °C 2-Wire Interlocked Handshake Timing ### INPUT TIMING ## **OUTPUT TIMING** ### ACKNOWLEDGE INPUT TO DATA AVAILABLE TIME (BUBBLE TIME) ## OUTPUT ENABLE AND CLEAR Figure 9. Timing Diagrams # **FIFO 2-Wire Handshake Timing.** Timing for 2-wire interlocked handshake operation is shown in Figure 9. The symbol, description and values for the numbered parameters (Figure 9) are given in AC Characteristics. | AC | No. | Symbol | Parameter | Min | Max | Units* | |----------------------|------------|--------------------|--------------------------------------------------------------------|-----------|-----|--------| | Character-<br>istics | 1 | TsDI(ACK) | Data Input to ACKIN ↓ to Setup Time | | | ns | | | 2 | TdACKf(RFD) | ACKIN ↓ to RFD ↓ Delay | 0 | | ns | | | 3 | TdRFDr(ACK) | RFD ↑ to ACKIN ↓ Delay | 0 | | ns | | | 4 | TsDO(DAV) | Data Out to DAV Setup Time | 25 | | ns | | | 5 <b>—</b> | - TdDAVf(ACK) | - DAV ↓ to ACKIN ↓ Delay ———————————————————————————————————— | 0 | | ns | | | 6 | ThDO(ACK) | Data Out to ACKIN † Hold Time | | | ns | | | 7 | TdACK(DAV) | ACKIN ↓ to DAV ↑ Delay | 0 | | ns | | | 8 | ThDI(RFD) | Data Input to RFD Hold Time | 0 | | ns | | | 9 | TdRFDf(ACK) | RFD↓to ACKIN↑ Delay | 0 | | ns | | | 10 — | - TdACKr(RFD) | - ACKIN † to RFD † Delay | 0 <u></u> | | ns | | | 11 | TdDAVr(ACK) | PAV t to ACKIN t | 0 | | ns | | | 12 | TdACKr(DAV) | ACKIN ↑ to DAV ↓ | 0 | | ns | | | 13 | TdACKINf(EMPTY) | (Input) ACKIN ↓ to EMPTY ↓ Delay (Output) ACKIN ↓ to EMPTY ↑ Delay | | | | | | 14 | TdACKINf(FULL) | (Input) ACKIN ↓ to FULL ↑ Delay (Output) ACKIN ↓ to FULL ↓ Delay | | | | | | 15 — | - ACKIN Clock Rate | (Input or Output) | 1.0 — | | MHz - | | | 16 | TdACKINf(DAVf) | (Bubble Time) | | | ns | | | 17 | TwCLR | Width of Clear to Reset FIFO | 700 | | ns | | | 18 | TdOE(DO) | OE ↓ to Data Bus Driven | 0 | | ns | | | 19 | TdOE(DRZ) | OE † to Data Bus Float | | | ns | NOTES. All timing references assume 2 0 V for a logic 1 and 0.8 V for a logic 0. Timings are preliminary and subject to change. ## Z8065 Z8000™Z-BEP Burst Error Processor # **Product Specification** ### June 1982 #### **Features** - Detects errors in serial data up to 585,442 bits in length - Implements correction of a detected error burst of up to 12 bits in length - Handles effective data rates of up to 20M bits per second - Provides four industry-standard polynomials for error detection - Designed for use in both microprocessor and microprogrammed disk-controlled systems - \_\_\_\_ - Provides three correction algorithms: □ Full-period clock-around method for con - formance to current practices Chinese remainder theorem, which reduces correction time by orders of - reduces correction time by orders of magnitude - □ Reciprocal polynomial, which allows correction with 48-bit code ### General Description The Z8065 Burst Error Processor (BEP) provides error detection and correction facilities for high-performance, high-density disk systems and any other system in which high-speed serial data transfers occur. For error detection, the BEP provides a selection of four standard polynomials, including the more popular 56-bit and 48-bit versions, to satisfy a broad range of applications. During write operations, the BEP generates check-bit words, which are appended to the record being written onto the disk. These check-bit words are then used in subsequent reads and, if necessary, in correction operations. Figure 1. Pin Functions Figure 2. Pin Assignments # General Description (Continued) When a stored record is read, the BEP computes the syndrome for data validation. This syndrome is then used to determine if an error burst is present in the retrieved data stream. If an error is detected, the BEP can be used to locate its actual bit pattern. The information obtained is then made available to the host system where it is used to correct the data read. Any of the three algorithms can be selected for this process. The BEP is fabricated using silicon-gate, N-MOS technology and is supplied in a 40-pin dual in-line package (DIP). Figures 1 and 2 illustrate the pin functions and pin assignments, respectively, of the Z8065. Z8065 operation requires a +5 V dc power supply and a single-phase clock. ### Pin Descriptions **AE.** Alignment Exception (output, active High). This output goes High when a misalignment condition occurs during an error-pattern search operation. **C<sub>0</sub>-C<sub>2</sub>.** Function Select (inputs, active High). These three lines carry the binary code used to select the BEP functions. The codes and the functions initiated by each are listed in Table 1. | C <sub>2</sub> | $C_1$ | C <sub>0</sub> | Function | |----------------|-------|----------------|----------------------------------------------------------| | L | L | L | Compute Check Bits | | L | L | Н | Write Check Bits | | L | Н | L | Read Normal | | L | Н | Н | Read High Speed | | Н | L | L | Load | | Н | L | Н | Reserved | | Н | Н | L | Correct Normal (Full Period<br>Clock Around) | | Н | Н | Н | Correct High Speed (Chinese<br>Remainder Theorem Method) | H = High, L = Low Table 1. Function Select Codes **CP.** Clock (input, active High). All BEP operations are timed by this external clock input. Any input changes must be made to the BEP when CP is High. Data is strobed into the BEP only during the Low-to-High transition of CP. BEP outputs are valid only after a subsequent Low-to-High transition occurs on CP. $\mathbf{D_0}$ - $\mathbf{D_7}$ . Data In (input, active High). These eight lines are used to enter data into the BEP. $D_0$ is the least-significant bit (LSB) position of the input; $D_7$ is the most-significant bit (MSB) position of the input. Data entry occurs on the Low-to-High transition of the input clock pulse. Any change on $D_0$ - $D_7$ must take place when the clock pulse (CP) input is High. **EP.** Error Pattern (output, active High). During an error correction process, EP is set High to indicate that the bit pattern of the detected error has been found. EP is set Low each time the BEP is initialized. EP is valid only during the performance of a correction function; it must be ignored at all other times. **ER.** Error (output, active High). ER indicates that the BEP has detected an error in the input data stream. If the register array contains a zero syndrome, ER is set Low to indicate that no error was detected. If the array contains a non-zero syndrome, ER is set High to indicate that an error was detected. The output is valid only after the BEP receives the last check byte during a normal read or a read high-speed function. The resulting syndrome is contained by the register array. ER is set Low each time the BEP is initialized. **LP<sub>0</sub>-LP<sub>3</sub>.** Located Error Pattern (outputs, 3-state). These four lines, together with $Q_0$ – $Q_7$ provide a 12-bit error pattern that is output when REP is High. $Q_7$ is the MSB of the pattern; LP<sub>0</sub> is the LSB of the pattern. A High level on any output line represents a logical 1; a Low level a logical 0. When no error pattern is available (REP is Low), output lines LP<sub>0</sub>–LP<sub>3</sub> and $Q_0$ – $Q_7$ are maintained in a high-impedance state. MR. Master Reset (input, active Low). This input controls the initialization of the BEP. Setting MR Low for a minimum period of 800 ns initialized the BEP. The BEP must be initialized prior to performing compute check bits, read normal, read high-speed, and load functions. **P<sub>0</sub>-P<sub>3</sub>.** Polynomial Shift Control (inputs, active High). During correction procedures using the Chinese remainder theorem, each syndrome obtained by the high-speed read function is shifted individually. The $P_0-P_3$ inputs provide this capability: $P_0$ enables the shifting of the first syndrome, $P_1$ shifts the second syndrome and so on. A High on an input allows the corresponding register to shift; a Low causes it to hold. These inputs are effective only during the correct high-speed function. Changes on these inputs occur only when the CP input is High. **PM2-PM4.** Pattern Match (outputs, active High). These lines are used during a Chinese remainder theorem error-correction operation to indicate error-pattern match conditions for each syndrome involved. When High, an output specifies that the corresponding syndrome register has achieved a match. **Q<sub>0</sub>-Q<sub>7</sub>.** Data Out (outputs, 3-state). These eight lines are active only during write check bit and error correction functions. At all other times, Q<sub>0</sub>-Q<sub>7</sub> are maintained at a high-impedance level. During the write check bit # Pin Descriptions (Continued) function, check bits are presented to these lines one byte at a time. $Q_0$ is the LSB and $Q_7$ is the MSB of the output. During the error-correction function, REP enables these lines to carry the detected error bit pattern. **REP.** Read Error Pattern (input, 3-state). REP when High, enables lines LP<sub>0</sub>-LP<sub>3</sub> and Q<sub>0</sub>-Q<sub>7</sub>. This error pattern information is valid only after a High is indicated on the EP output during correction operations. **S<sub>0</sub>-S<sub>1</sub>.** Polynomial Select (inputs, active High). These two pins carry the binary codes required to select which polynomial the BEP will implement. The select codes (logic levels) are given in Table 2. | s <sub>1</sub> s <sub>0</sub> | Polynomial | Number of<br>Check Bits | |-------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------| | L L | $ \begin{array}{l} (X^{22}+1)(X^{11}+X^7+X^6+X+1)(X^{12}+X^{11}+X^{10}+X^9+X^8+X^7+X^6+X^5+X^4+X^3+X^2+X+1) \\ (X^{11}+X^9+X^7+X^6+X^5+X+1) \end{array} $ | 56 | | L H | $(X^{21}+1)(X^{11}+X^2+1)$ | 32 | | H L | $(X^{23}+1)(X^{12}+X^{11}+X^{8}+X^{7}+X^{3}+X+1)$ | 35 | | нн | $(X^{13}+1)(X^{35}+X^{23}+X^{8}+X^{2}+1)$ | 48 | Table 2. Polynomial Select Codes #### Architecture The BEP consists of four major circuit groups: control logic, polynomial divide matrix, register array, and status logic. Figure 3 shows a block diagram of the BEP. $H = H_1 gh$ , L = Low **Control Logic.** The control logic circuits provide timing, reset, polynomial selection, and read error-pattern control inputs for the remaining BEP circuits. Basic timing is provided to the control logic by clock input CP. The control logic generates and distributes appropriate timing and control signals to the remaining BEP circuits. Enabling the Master Reset (MR) causes the control logic to initialize all device circuits. This operation is usually performed before the execution of a selected device function. Function select and polynomial select inputs are decoded by the control logic. The outputs of the decoder are then used to generate the control and timing signals needed to perform the encoded function or to select the encoded polynomial. The Read Error Pattern (REP) and Polynomial Shift Control signals enable the control logic to strobe valid error bit pattern outputs onto the register array output lines. During high-speed corrections, the polynomial shift inputs are used for register array, error burst-pattern bit-matching operations. **Polynomial Divide Matrix.** This matrix connects the register array circuits so that each data byte presented on lines $D_0$ – $D_7$ is suitably divided by the user-selected polynomial. The connections to be made are determined by Figure 3. Simplified Block Diagram # Architecture (Continued) gating the signals supplied by the control logic after decoding the select code on inputs $S_0$ and $S_1$ . **Register Array.** This array consists of 56 flipflop circuits used for: (1) check-bit computation during write operations, (2) syndrome computation during read operations, and (3) error pattern extraction during errorcorrection operations. The bit patterns required for array functions are provided by the polynomial divide matrix. The array and matrix circuits, together, simulate a serial, polynomial, feedback-shift register arrangement in an 8-bit parallel form. At the end of each write operation, the computed check-bit bytes are available on lines $Q_0-Q_7$ . On completion of a correction operation, the bit pattern of the detected error is available on lines $LP_0-LP_3$ and $Q_0-Q_7$ . Input REP determines when a valid error bit pattern is on the register output lines. **Status Logic.** These circuits monitor the register array to detect the conditions listed in Table 3 and to enable the generation of the corresponding control signals. #### Condition Detected Detected Result of Polynominal Division Location of an error bit pattern Alignment during H-S and normal correction Pattern matching during H-S correction #### Signal ER (error) High when error found; Low when no error. AE (alignment error) High when error pattern is incorrectly aligned. EP (error pattern) High when an error-bit pattern is detected. $PM_2$ , $PM_3$ , $PM_4$ (pattern match). Each signal goes High when its corresponding register matches the proper section of a located burst-bit pattern. Table 3. Status Logic, Detected Condition and Resulting Output ### Functional Description The BEP detects and corrects data errors using write, read, and correct operations. The BEP operates in conjunction with external logic: either a microprocessor or microprogrammed control circuitry. Master clock inputs, the selection of polynomials and functions, and the output of check bytes and error bit patterns are initiated and controlled by inputs from external circuits. External logic is also used to collect data, perform calculations, and carry out the actual modification of stored data during error-correction operations. The BEP contains code for four standard polynomials (sometimes referred to as Fire codes). This code forms the basis fo the unit's error detection and correction functions. The polynomial to be used is selected by a coded input from the host system\*. Table 2 lists the polynomial select codes, the equations implemented, and the number of check bits generated by each polynomial during a write operation. The same polynomial must be selected for the write, read, and correction operations performed for a given data stream. It is the responsibility of the host system to keep track of which polynomial is selected for use with each data stream. The BEP also contains the code required to implement each of seven functions that can be executed during data stream write, read, and correction operations. The function to be performed is selected by a coded input from the host system.\* The functions and their required input code are listed in Table 1. \*NOTE In the remainder of this specification, external circuitry and software is referred to as the host system. **Write Operation.** Before data is written onto a disk or similar storage device, the BEP must generate and add check-bit bytes to the data to be stored. These bytes are required for the detection and correction of errors that may occur during write and during subsequent read operations. Immediately before a write operation, the host system must output codes to the BEP to select the polynomial to be used and to initiate the compute check-bit function. The data stream to be written is entered, onthe-fly, into the BEP as it is written onto the disk. Data is presented to the BEP as a series of 8-bit bytes in parallel form. Check bits are generated by dividing each input byte by the selected polynomial using the rules of algebra in polynomial fields. The check bits are stored as they are generated. Check bits are generated in sets of 56, 48, 35, or 32 bits, depending on the selected polynomial. When the last input byte has been processed, the write check-bit function is initiated by the host system. During a check-bit write, the generated check bits are organized into 8-bit bytes (check-bit bytes), which are output byte by byte in 8-bit parallel form on lines $Q_0$ - $Q_7$ . The host system adds these check-bit bytes to the end of the newly written file. The polynomial selected for data write operations must also be used in subsequent reads of the written data. Therefore, in selecting a polynomial for a write operation, the user should consider the type of read and correction functions desired for future data retrieval operations. The relationships between the polynomials and the read and corrections functions are: - A read normal function must be followed by a correct normal function. All four polynomials can be used with this set of read/correction functions. - A read high-speed function must be followed by the Chinese remainder theorem correction function. All but the 48-bit polynomial can be used with this set of read/correction functions. Read Operations. When data is read from a disk, the BEP checks the retrieved data and check-bit bytes for read and write errors. If errors are detected, the host system initiates correction functions, retrieving from the BEP the information needed to locate and correct the erroneous data. Immediately before starting the read operation, the host system selects the desired polynomial and either a read normal or a read high-speed function. Data and associated check-bit bytes are then loaded, byte-by-byte, into the BEP as they are read from the disk. A divide operation results in one or more syndromes (depending on the polynomial used), which are stored in the register array. The binary values of these syndromes indicate whether or not an error was present in the scanned data stream. If an error was detected, ER is set High. When an error condition is indicated and correction is desired, the host system must initiate a correct normal, a 48-bit correct normal, or a correct high-speed function. The function selected depends on which polynomial and which read function were selected for the initial read operation. When executed, the selected correction function supplies the host system with the information needed to calculate the location of the error pattern in the data stream and to correct the erroneous data stream bits. Read Normal Function. When this function is selected, the polynomial matrix is configured to establish the selected polynomial in its expanded form. The input stream, data and check bit bytes, are divided byte by byte by the expanded polynomial. The results form a syndrome whose binary value is detected by the status logic. If the syndrome is nonzero, ER goes High, to indicate an error condition; if the syndrome is zero, ER remains Low, to indicate a no-error state. **Read High-Speed Function.** This function is selected when the correct high-speed function is used. All but the 48-bit polynomial can be used with this function. When selected, this function configures the polynomial matrix to simultaneously divide each byte of the input data/check-bit stream by all factors of the selected polynomial. The result of each factor division forms a separate syndrome. Thus, the number of syndromes developed depends upon the number of factors in the selected polynomial. The status logic monitors all syndromes and uses their combined binary values to determine if an error condition is present. If all syndromes are zero after the last byte of the input stream is read, a no-error state is indicated and ER remains Low. If any syndrome has a non-zero value, an error condition is indicated and ER is set High. 48-Bit Polynomial. Only read normal and correct normal functions can be used when this polynomial is selected. The read normal function for the 48-bit polynomial is performed in the same manner as for the other polynomials. The resulting syndrome, however, will be too long and cannot be used directly in subsequent correct normal functions; instead, the reciprocal of the syndrome must be established in the BEP before the correct normal function is selected. The host system initiates this operation by selecting the write check-bit function immediately after the syndrome is formed and error is indicated. Clock pulses are then applied to the BEP during the write bit function to strobe the syndrome onto lines $Q_0$ - $Q_7$ as six sequential 8-bit bytes. The host system must then reverse the order of the syndrome bits (that is, the original LSB becomes the new MSB and the original MSB becomes the new LSB) to form the reciprocal. The host system then reloads this new syndrome into the BEP by selecting the load function. **Load Function.** This function is used only during read normal and correct normal operations when the 48-bit polynomial is selected. The host system selects the load function to prepare the BEP to receive an externally-formed reciprocal syndrome and to control the loading of the syndrome bytes into the BEP. The load function causes the register array to be configured into an 8-bit wide, 7-bit deep shift register connected to lines $D_0-D_7$ . The host system then presents the six syndrome bytes on lines $D_0-D_7$ . Clock pulses are then generated to strobe the bytes into the Shift register one at a time. When all six bytes of the syndrome are loaded, the host system causes the input lines to be pulled Low, then generates a seventh clock pulse. The seventh clock pulse strobes these Lows into the Shift register as a zero dummy fill byte. On completion of the load operation, the BEP is ready for the correct normal function. # Correction Operations The detection of an error in a retrieved data stream causes the following corrective functions to be performed: - 1. The error burst containing the erroneous data bits is located by the BEP. - Using data supplied by the BEP, the host system calculates the exact position of the error burst in the retrieved data stream. - The bit pattern of the error burst is strobed out of the BEP and used by the host system to perform bit correction. Location of an Error Pattern. An error pattern is characterized by the appearance of a known number of consecutive 0s in specific registers of the register array. The exact number of 0s and their locations in the register array is unique to each polynomial. When a polynomial is selected for read and error-detect/correction operations, the pattern associated with that polynomial is loaded into the status logic. The status logic uses this pattern to identify an error burst during the error pattern location operations. When only one syndrome is developed during the read error-detection function, the error-bit pattern is located by repeatedly dividing the syndrome by the polynomial. Division is accomplished by the repeated application of clock pulses (CP), while ignoring the states of lines $D_0$ - $D_7$ . This operation results in a serial bit-by-bit reconstruction of the retrieved data stream. The generated data bits are shifted at a rate of one per clock cycle through the register array. The BEP status logic performs the actual error bit pattern detection as the data stream is reconstructed. The status logic monitors specific registers of the register array, and it detects a pattern of 0s that matches the zero error pattern unique to the selected polynomial, it sets EP High to indicate that an error burst was found. When more than one syndrome is developed during the read error-detection function, each syndrome is divided by its associated factor until a match condition is found for each. Each time a match is found, the status logic enables one of outputs $PM_2$ , $PM_3$ or $PM_4$ . When the total error bit pattern is found, the status logic outputs associated with the syndromes of a polynomial (2 or 4) are all enabled. The clock pulses required for each factor syndrome divide operation are supplied by lines $P_0$ – $P_3$ . A major factor in calculating the exact location of error-burst patterns in the retrieved data stream is the number of clock pulses used by the BEP to detect the error-burst pattern. The host system must record the total number of clock pulses generated from the start of BEP pattern-location operations to the enabling of output EP. If necessary, this total must include the clock pulses needed for alignment operations. Bit Alignment. During syndrome division, the register array is configured into a matrix representing an 8-bit, parallel mechanization of a serial, polynomial division scheme. Under certain conditions the error pattern bits developed do not line up automatically. When the status logic detects such a misalignment, AE is set High. When AE is High, the BEP switches internally into One-Bit Shift mode during which each input clock pulse shifts the data stream one cell through the register array. When alignment is achieved, the status logic sets AE Low and the BEP is switched out of the One-Bit Shift mode. The number of shift pulses needed to achieve alignment is an additional factor in calculating the position of the error-bit pattern. **Uncorrectable Errors.** If the total clock cycle time needed to locate the error burst pattern is greater than the natural period of the selected polynomial (Table 4), an uncorrectable error condition is indicated and the host system must abort the correction operation. | Polynomial | No. of<br>Check Bits | Period<br>(Bits) | Correctable<br>Burst Error<br>Length (Bits) | |-----------------------------------------------------------------------------------------------------------------------|----------------------|-------------------------|---------------------------------------------| | $X^{22} + 1)(X^{11} + X^7 + X^6 + X + 1)(X^{12} + X^{11} + X^{10} + + X + 1)(X^{11} + X^9 + X^7 + X^6 + X^5 + X + 1)$ | 56 | 585,442 | 11 | | $(X^{21} + 1)(X^{11} + X^{2} + 1)$ | 32 | 42,987 | 11 | | $(x^{23}+1)(x^{12}+x^{11}+x^8+x^7+x^3+x+1)$ | 35 | 94,185 | 12 | | $x^{13}+1$ )( $x^{35}+x^{23}+x^{8}+x^{2}+1$ ) | 48 | 13(2 <sup>35</sup> – 1) | 7 | Table 4. Polynomials, Checkbits, Natural Period, and Length of Error Burst Correction Operations (Continued) Correct Normal Function. This function must be preceded by a read normal function. With the exception of 48-bit polynomial operations, this function performs all operations needed to construct a serial form of the retrieved data stream and to locate the detected error burst. The operations performed are the same as those described previously for a single-syndrome situation. Computing Error Bit Pattern Locations. If no alignment exception state is indicated (AE is Low), the locations of the error-bit pattern within the data stream (except when the 35-bit polynomial is used) can be calculated by the formula: $$L = NK - 8R1$$ Where: L = The location (number) of the first bit in the error burst, counting from the last check bit in the scanned record. N =The natural period of the selected polynomial. K =The smallest integer needed to make this expression positive. R1 = The total number of clock pulses input by the BEP from the start of the find operation until EP goes High. If an alignment exception state is indicated (AE is High), the location of the error-bit pattern within the data stream (except when the 35-bit polynomial is used) can be calculated using the formula: $$L = NK - 8R1 - R2$$ Where: L,N,K, and R1 are the same as described above. R2 = The number of clock pulses input by the BEP between the time that AE goes High and EP goes High. If the 35-bit polynomial is selected, the quantity 5 must be added in the following manner to the formulas used to calculate the location of the error-bit pattern: $$L = NK - 8R1 + 5$$ and $L = NK - 8R1 - R2 + 5$ Correct Normal Function, 48-Bit Polynomial. The functions performed by the correct normal function when a 48-bit polynomial is selected are essentially the same as those described for the other polynomials. The major exception is that the location of the first bit in the error-bit pattern is calculated using the $$L = (8R1 + R2) - 48$$ Where: formula: L = The number of bit positions from the last check bit to the nearest error burst bit. R1 = If alignment is needed, R1 is the number of clock pulses from the start of the find operation until AE goes High. If no alignment is needed, R1 is the total number of clock pulses from the start of the find operation until EP goes High. R2 = Variable used only when an alignment is needed; it represents the number of clock pulses from the time AE goes High until EP goes High. Correct High Speed Function. This function uses a Chinese remainder theorem to locate a detected error-burst bit pattern. This theorem minimizes the number of clock pulses required for the location process, thus making it appreciably faster than the correct normal method. The correct high-speed function must be preceded by the read high-speed function. The multiple syndromes developed during the read operation are located in consecutive sets of flip-flops in the register array. The set of flip-flops containing syndromes is treated as an individual shift register. Each syndrome shift register is associated with the factor of the polynomial used to develop the syndrome. For example, the 56-bit polynomial has four factors (see Table 2), and when selected for read and correction operations it causes four corresponding syndromes to be developed, each housed in an individual shift register in the register array. # Correction Operations (Continued) The actual location of an error-bit pattern can be computed by the host system using the following elements: - The number of clock pulses required (per factor/syndrome register) to find the error pattern. - 2. The natural period of each factor of the selected polynomial. - 3. A predetermined constant per factor. The formulas used to calculate error-pattern locations for high-speed operations are described in Table 5. Table 6 lists the predetermined constants for each factor of the polynomials. Table 7 lists the natural period of each factor of each polynomial. ``` 56-Bit L = (NK) - (A1M1 + A2M2 + A3M3 + A4M4) 32-Bit L = (NK) - (A1M1 + A2M2) 35-Bit L = (NK) - (A1M1 + A2M2 + 5) ``` Table 5. Correct High-Speed, Error-Burst Location Formulas #### Legend: L = Beginning (first bit) of detected error burst counting from the last check bit in the processed record. K = Smallest integer required to make right side of equation positive. $A_1$ - $A_4$ = Predetermined constants for each factor of the selected polynomial. N = Natural period of selected polynomial. $M_1$ - $M_4$ = Number of clock pulses required to achieve a match in each factor/syndrome register. A detected error-bit pattern can be strobed from the BEP in 12-bit, parallel form by forcing REP High when EP goes High. The 12-bit output is then matched bit for bit with the corresponding bits in the stored data. The error-bit pattern is then XORed with the matching data stream bits to effect the required bit-by-bit correction. Figure 4 illustrates the format for strobing the error bit pattern (11 or 12 bits) out of the BEP in all but the 48-bit polynomial correction operation and shows how the pattern must be oriented to the data stream bits. Figure 5 illustrates the format for strobing the error-bit pattern (7 bits) out of the BEP in the 48-bit polynomial correction operation and shows how the pattern must be oriented to the data stream bits. Data Stream Correction Function. Each detected error pattern consists of 12 consecutive bits not all of which represent errors. If the data and check-bit stream scanned during the preceding read operation was stored in accessible memory, the error-bit pattern can be used directly to correct the data stream. | Poly- | Predetermined Constants | | | | | | | | | |--------|-------------------------|----------------|---------|-----------|--|--|--|--|--| | nomial | $\mathbf{A}_1$ | $\mathbf{A}_2$ | $A_3$ | $A_4$ | | | | | | | 56 Bit | 452,387 | 2,521,404 | 578,864 | 2,647,216 | | | | | | | 32 Bit | 311,144 | 32,760 | | | | | | | | | 35 Bit | 32,760 | 720,728 | | | | | | | | Table 6. Chinese Remainder Theorem Coefficients Correction Operations (Continued) Table 7. Natural Periods for Polynomials and Polynomial Factors | Polynomial | Period<br>Factor 1 | Period<br>Factor 2 | Period<br>Factor 3 | Period<br>Factor 4 | Composite<br>Period (n) | |------------|--------------------|--------------------|--------------------|--------------------|-------------------------| | 56 Bit | 22 | 13 | 89 | 23 | 585442 | | 32 Bit | 21 | 2047 | | | 42987 | | 35 Bit | 23 | 4095 | | | 94185 | Figure 4. Error Pattern Format for 56-Bit, 35-Bit, and 32-Bit Polynomials Figure 5. Error Pattern Format for 48-Bit Polynomial 2078-003 2078-004 289 ## Timing The overall timing requirements for BEP operations are illustrated in Figures 6 through 13. Individual timing parameters are identified numerically in each timing diagram and are described in the AC Characteristics section. Figure 6. Clock Waveform For All Functions Except Correct Normal Or Correct High-Speed ### AC Characteristics\* | No. | Symbol | Parameter | Min<br>(ns) | Max<br>(ns) | |-----|---------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|-----------------| | 1 | TwCPl | Clock Pulse (CP) Width (Low) | 180 | | | 2 | TcCP | Clock Pulse Cycle Time | 400 | | | 3 | TwCPh | Clock Pulse Width (High) | 180 | | | 4 | TwMR1 | MR Pulse Width (Low) | 800 | | | 5- | -TdMR(CP) | - MR ↑ to CP ↓ Time Delay—Recovery — | 250 | | | 6 | TsDI(CP) | DI (D <sub>0</sub> -D <sub>7</sub> ) to CP † Setup Time | 350 | | | 7 | ThCP(DI) | CP $\uparrow$ to DI (D <sub>0</sub> -D <sub>7</sub> ) Hold Time | 0 | | | 8 | TsC(CP) or | $C(C_0-C_2)$ or $S(S_0-S_1)$ to $CP \uparrow Setup Time$ | 400 | | | 9 | TsS(CP) ThCP(C) or ThCP(S) | CP † to $C(C_0-C_2)$ or $S(S_0-S_1)$ Hold Time | 0 | | | 0- | TsC(CP) or ——<br>TsS(CP) | - $C(C_0$ - $C_2)$ or $S(S_0$ - $S_1)$ to CP $\downarrow$ Setup Time ———————————————————————————————————— | 180 <del></del> | | | 1 | TdC(Q) or<br>TdS(Q) | $C(C_0-C_2)$ or $S(S_0-S_2)$ to $Q(Q_0-Q_7)$ Valid Time Delay | | 200 | | 2 | TdCP(Q) | CP † to $Q(Q_0-Q_7)$ Invalid Time Delay | 0 | | | 3 | TdCP(Q) | CP to $Q(Q_0-Q_7)$ Valid Time Delay (write) | | 200 | | 4 | TdC(Q) | $C(C_0-C_2)$ to $Q(Q_0-Q_7)$ Time Delay—3-state | | 100 | | 5 | - TdMR(ER) | - MR \ to ER \ Time Delay | | - 200 | | 6 | TdCP(ER) | CP † to ER † Valid Time Delay | | 200 | | 7 | TwCPCl | | 450 | 200 | | | | CP Pulse Width (Low) for Correct Functions | | | | 8 | TwCPCh | CP Pulse Width (High) for Correct Functions | 450 | | | 9 | TcCPC | CP Cycle Time for Correct Functions | 1000 | 000 | | 0— | - TdC(EP) or | - C(C <sub>0</sub> -C <sub>2</sub> ) to EP or to AE Valid Time Delay ———————————————————————————————————— | | <del></del> 250 | | l | TdC(AE) TdCP(EP) or | CP $\downarrow$ to EP, to AE or to PM(PM2-PM4) Valid Time Delay | | 400 | | 2 | TdCP(AE) | D/D D \ OD C The | 400 | | | 2 | TsP(CP) | P(P <sub>0</sub> -P <sub>3</sub> ) to CP \ Setup Time | 400 | 050 | | 3 | TdP <sub>0</sub> (EP) or<br>TdP <sub>0</sub> (AE) | P <sub>0</sub> † to EP or to AE Time Delay | | 250 | | 4 | TsC(CPC) or<br>TsS(CPC) | $C(C_0-C_2)$ or $S(S_0-S_1)$ to $CP \downarrow Setup$ Time for Correct Functions | 400 | | | 5 — | - TdP(PM) | -P <sub>1</sub> or P <sub>2</sub> or P <sub>3</sub> to Corresponding PM Output, Time Delay ———— | | <del></del> 250 | | 6 | TdCP(EP) or<br>TdCP(AE) or<br>TdCP(PM) | CP ↓ to EP, to AE, or to PM (PM <sub>2</sub> , PM <sub>3</sub> , PM <sub>4</sub> ) Invalid Time Delay | 0 | | | 7 | TdP <sub>0</sub> (EP) or<br>TdP <sub>0</sub> (AE) | $P_0 \downarrow$ to EP or to AE Invalid Time Delay | 0 | | | 8 | TwREPh | REP Pulse Width (High) | 250 | | | 9 | TdREP(Q) or | REP † to $Q(Q_0-Q_7)$ or to $LP(LP_0-LP_3)$ Time Delay | 200 | 150 | | | TdREP(LP) | | | | | | TdREP(LPT) | - REP 1 to Q(Q <sub>0</sub> -Q <sub>7</sub> ) or to LP(LP <sub>0</sub> -LP <sub>3</sub> ) Time Delay 3-state ——————————————————————————————————— | | — 100 | | 1 | TdP(PM) | $P(P_1-P_3)$ 1 to $PM(PM_2-PM_4)$ Invalid Time Delay | 0 | | | 2 | TdC(EP) or<br>TdC(AE) or<br>TdC(PM) | $C(C_0-C_2)$ to EP, or to AE, $PM(PM_2-PM_4)$ Invalid Time Delay | 0 | | <sup>\*</sup> All timings are preliminary and subject to change. AC Characteristics (Continued) Figure 7. Compute Check Bits or Load Function Notes: 1. REP input assumed low. 2. $Q_0-Q_7$ outputs will be high impedance if $C_0-C_2$ inputs do not specify write check bits function. Figure 8. Write Check Bits Function Note: ER output is a function of the contents in the register array flip-flops. Figure 9. Read Normal or Read High-Speed Function 2078-006 2078-007 2078-008 Figure 10. Clock Waveform for Correct Normal or Correct High-Speed Functions Note 1: Assumes AE or EP output becomes active without any clocking. Figure 11. Correct Normal Function Note 2: Assumes EP, AE becomes active without clocking. Note 3: Assumes corresponding PM output becomes active without clocking. Figure 12. Correct High-Speed Function Figure 13. Read Error Pattern Timing ## Absolute Maximum Ratings Voltages on all inputs and outputs with respect to GND . . . . . . . . . . -0.3 V to +7.0 V Operating Ambient Temperature..... See Ordering Information Storage Temperature.....-65° 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 characteristics below apply for the following standard test conditions, unless otherwise noted. All voltages are referenced to GND. Positive current flows into the referenced pin. Standard conditions are as follows: - $\blacksquare$ +4.75 V $\leq$ V<sub>CC</sub> $\leq$ +5.25 V - GND = 0 V - $\blacksquare 0^{\circ}\text{C} \leq T_{\text{A}} \leq +70^{\circ}\text{C}$ | DC | Symbol | Parameter | Min | Мах | Unit | Condition | |----------------------|-------------------|--------------------------------------|----------------------|-----------------------|---------|-----------------------------------------| | Character-<br>istics | 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_{\rm CL}$ | Clock Input Low Voltage | -0.3 | 0.45 | V | Driven by external clock generator | | | $V_{\mathrm{IH}}$ | Input High Voltage | 2.0 | $V_{CC} + 0.3$ | V | | | | $V_{\mathrm{IL}}$ | Input Low Voltage | -0.3 | 0.8 | V | | | | $V_{OH}$ | Output High Voltage | 2.4 | | V | $I_{OH} = -250 \text{ A}$ | | | $\mathtt{V}_{OL}$ | Output Low Voltage | | 0.4 | V | $I_{OL} = +2.0 \text{ mA}$ | | | $I_{\mathrm{IL}}$ | Input Leakage | | ±10 | $\mu$ A | $0.4 \le V_{\rm IN} \le +2.4 \text{ V}$ | | | $I_{OL}$ | Output Leakage | | ±10 | $\mu$ A | $0.4 \le V_{\rm IN} \le +2.4 \text{ V}$ | | | $I_{CC}$ | V <sub>CC</sub> Supply Current | | 300 | mA | | | Electrical | Symbol | Parameter | Min | Мах | Unit | Condition | | Character-<br>istics | $V_{\rm IL}$ | Input Low Voltage | -0.5 | +.8 | V | | | | $V_{\mathrm{IH}}$ | Input High Voltage | 2.0 | $v_{cc}$ | V | | | | $V_{OL}$ | Output Low Voltage | | 0.4 | V | $I_{OH} = 3.2 \text{ mA}$ | | | $V_{OH}$ | Output High Voltage | 2.4 | | V | $I_{OH} = 400 \mu A$ | | | $I_{OL}$ | Output Leakage Current | | 10 | $\mu$ A | $V_{OUT} = 0.4 V$ | | | $I_{LOH}$ | Output Leakage Current | | 10 | $\mu$ A | $V_{OUT} = V_{CC}$ | | | $C_{IN}$ | Input Capacitance | | 15 | рF | | | | $C_{I/O}$ | I/O Capacitance | | 25 | рF | | | | $I_{LL}$ | Input Leakage Current | | ±10 | $\mu$ A | | | | $I_{CC}$ | V <sub>CC</sub> Power Supply Current | | | | | NOTE: Typical values apply at $T_{\rm A}$ = 25°C and $V_{\rm CC}$ = 5.0 V. See table above for operating range. | Ordering<br>Information | Product<br>Number | Package/<br>Temp | Speed | Description | Product<br>Number | Package/<br>Temp | Speed | Description | |-------------------------|-------------------|------------------|---------|--------------------------------------|-------------------|------------------|---------|--------------------------------------| | | Z8065 | CE | 2.5 MHz | Burst Error<br>Processor<br>(40-pin) | Z8065 | PE | 2.5 MHz | Burst Error<br>Processor<br>(40-pin) | | | Z8065 | DS | 2.5 MHz | Same as above | Z8065 | PS | 2.5 MHz | Same as above | NOTES C = Ceramic, D = Cerdip, P = Plastic; E = -40 $^{\circ}C$ to +85 $^{\circ}C$ , S = 0 $^{\circ}C$ to 70 $^{\circ}C$ 00-2078-02 8085-0209 | , | | | | | | |---|--|--|--|--|--| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | ## Z8068 Z8000™Z-DCP Data Ciphering Processor ## Product Specification #### June 1982 #### Features - Encrypts and decrypts data using the National Bureau of Standards encryption algorithm. - Supports three standard ciphering modes: Electronic Code Book, Chain Block and Cipher Feedback. - Three separate registers for encryption, decryption, and master keys improve system - security and throughput by eliminating frequent reloading of keys. - Three separate programmable ports (master, slave, and key data) provide hardware separation of encrypted data, clear data, and keys. - Data rates greater than 1M bytes per second can be handled. - Key parity check. ### General Description The Z8068 Data Ciphering Processor (DCP) is an n-channel, silicon-gate LSI device, which contains the circuitry to encrypt and decrypt data using National Bureau of Standards encryption algorithms. It is designed to be used in a variety of environments, including dedicated controllers, communication concentrators, terminals, and peripheral task processors in general processor systems. The DCP provides a high throughput rate using Cipher Feedback, Electronic Code Book, or Cipher Block Chain operating modes. The provision of separate ports for key input, clear data, and enciphered data enhances security. The host system communicates with the DCP using commands entered in the master port or through auxiliary control lines. Once set up, data can flow through the DCP at high speeds because input, output and ciphering activities can be performed concurrently. External DMA control can easily be used to enhance throughput in some system configurations. The Z8068 DCP is designed to interface directly to Zilog's Z-BUS®. Device signal/pin functions are shown in Figure 1; actual pin number assignments are shown in Figure 2. SPO 2 39 9FA SPO 2 39 9FA SPO 3 38 9FA SPO 3 5 36 9FA AUX 3 6 35 AUX AUX 4 7 34 AUX S 7 34 AUX S 8 32 AUX S 7 36 SSS FAR 1 1 DCP 30 SSS FAR 1 1 DCP 30 SSS FAR 1 1 DCP 30 SSS FAR 1 1 4 27 MAW SCILL 1 1 4 27 MAW SCILL 1 1 4 27 MAW MP 1 17 24 MFA MP 1 17 24 MFA MP 2 18 22 MFA MP 2 19 22 MFA MP 3 19 22 MFA MP 3 19 22 MFA MP 3 19 22 MFA MP 3 19 22 MFA MP 3 19 22 MFA MP 3 19 MFA Figure 1. Pin Functions Figure 2. Pin Assignments 295 #### Pin Descriptions **AFLG.** Auxiliary Port Flag (output, active Low). This output signal indicates that the DCP is expecting key data to be entered on pins AUX<sub>0</sub>-AUX<sub>7</sub>. This can occur only when C/K is Low and a "Load Key Through AUX Port" command has been entered. AFLG remains active (Low) during the input of all eight bytes and will go inactive with the leading edge of the eighth strobe (ASTB). $\overline{\textbf{ASTB}}$ . Auxiliary Port Strobe (input, active Low). In Multiplexed Control mode (C/ $\overline{K}$ Low), the rising (trailing) edge of $\overline{\textbf{ASTB}}$ strobes the key data on pins $\overline{\textbf{AUX}}_0$ - $\overline{\textbf{AUX}}_0$ into the appropriate internal key register. This input is ignored unless $\overline{\textbf{AFLG}}$ and $\overline{\textbf{C/K}}$ are both Low. One byte of key data is entered on each $\overline{\textbf{ASTB}}$ with the most significant byte entered first. **AUX<sub>0</sub>-AUX<sub>7</sub>.** Auxiliary Port Bus (bidirectional, active High). When the DCP is operated in Multiplexed Control mode ( $C/\overline{K}$ Low), these eight lines form a key-byte input port, which can be used to enter the master and session keys. This port is the only path available for entering the master key. (Session keys can also be entered via the master port.) AUX<sub>0</sub> is the low-order bit and is considered to be the parity bit in key bytes. The most significant byte is entered first. When the DCP is operated in Direct Control mode ( $C/\overline{K}$ High), the auxiliary port's keyentry function is disabled and five of the eight lines become direct control/status lines for interfacing to high-speed microprogrammed controllers. In this case, $AUX_0$ , $AUX_1$ and $AUX_4$ have no function, and the other pins are defined as follows: **AUX<sub>2</sub>-BSY**. Busy (output, active Low). This status output gives a hardware indication that the ciphering algorithm is in operation. AUX<sub>2</sub>-BSY is driven by the BSY bit in the Status register such that when the BSY bit is 1 (active), AUX<sub>2</sub>-BSY is Low. **AUX<sub>3</sub>-\overline{\mathbf{CP}}.** Command Pending (output, active Low). This status output gives a hardware indication that the DCP is ready to accept the input of key bytes following a Low-to-High transition on AUX<sub>7</sub>-K/ $\overline{\mathbb{D}}$ . AUX<sub>3</sub>- $\overline{\mathbb{CP}}$ is driven by the CP bit in the Status register such that when the CP bit is 1 (active), AUX<sub>3</sub>- $\overline{\mathbb{CP}}$ is **AUX**<sub>5</sub>-**S/S**. Start/Stop (input, Low = Stop). When this pin goes Low (Stop), the DCP follows the normal Stop command sequence. When this pin goes High, a sequence equivalent to a Start Encryption or Start Decryption command is followed. When $AUX_5-S/\overline{S}$ goes High, the level on $AUX_6-E/\overline{D}$ selects either the start encryption or start decryption operation. **AUX<sub>6</sub>-E/\overline{D}.** Encrypt/Decrypt (input, Low = Decrypt). When $\overline{AUX_5}$ -S/ $\overline{S}$ goes High, it initiates a normal data ciphering operation whose input specifies whether the ciphering algorithm is to encrypt ( $E/\overline{D}$ High) or decrypt ( $E/\overline{D}$ Low). When $\overline{AUX_7}$ – $K/\overline{D}$ goes High, initiating the entry of key bytes, the level on $\overline{AUX_6}$ – $E/\overline{D}$ specifies whether the bytes are to be written into the E Key register ( $E/\overline{D}$ High) or the D key Register ( $E/\overline{D}$ Low). The $\overline{AUX_6}$ - $\overline{E/D}$ input is not latched internally and must be held constant whenever one or more of $\overline{AUX_5}$ - $\overline{S/S}$ , $\overline{AUX_7}$ - $\overline{K/D}$ , $\overline{AUX_2}$ - $\overline{BSY}$ , or $\overline{AUX_3}$ - $\overline{CP}$ are active. Failure to maintain the proper level on $\overline{AUX_6}$ - $\overline{E/D}$ during loading or ciphering operations results in scrambled data in the internal registers. **AUX<sub>7</sub>-K/D.** Key/Data (input, Low = Data). When this signal goes High, the DCP initiates a key-data input sequence as if a Load Clear E or D Key Through Master Port command had been entered. The level on $AUX_6-E/\overline{D}$ determines whether the subsequently entered clear-key bytes are written into the E key register (E/D High) or the D key register (E/D Low) $AUX_7$ – $K/\overline{D}$ and $AUX_5$ – $S/\overline{S}$ are mutually exclusive control lines; when one goes active (High), the other must remain inactive (Low) until the first returns to an inactive state. In addition, both lines must be inactive (Low) whenever a transition occurs on $C/\overline{K}$ (entering or exiting Direct Control mode). $\mathbf{C}/\overline{\mathbf{K}}$ . Control/Key Mode Control. (input, Low = Key). This input determines the operating characteristics of the DCP. A Low input on $\mathbb{C}/\overline{K}$ puts the DCP into the Multiplexed Control mode, enabling programmed access to internal registers through the master port and enabling input of keys through the auxiliary port. A High input on $\mathbb{C}/\overline{K}$ specifies operation in Direct Control mode. In this mode, several of the auxiliary port pins become direct control status signals which can be driven/sensed by high-speed controller logic, and access to internal registers through the master port is limited to the Input or Output register. CLK. Clock (input, TTL compatible). An external timing source is input via the CLK pin. The Master and Slave Port Chip Select and Data Strobe signals ( $\overline{MCS}$ , $\overline{MDS}$ , $\overline{SCS}$ , $\overline{SDS}$ ) must change synchronously with this clock input, as must Master Port Address Strobe $(\overline{\text{MAS}})$ in Multiplexed Control mode (C/ $\overline{\text{K}}$ Low), and also $\overline{AUX_7}$ - $\overline{K}/\overline{D}$ and $\overline{AUX_5}$ - $\overline{S}/\overline{S}$ in Direct Control mode ( $C/\overline{K}$ High). In addition, the Auxiliary, Master and Slave Port Flag outputs (AFLG, MFLG, and SFLG) change synchronously with the clock. When using the DCP with the Z8000 CPU in Multiplexed Control mode, the clock input must agree in frequency and phase with the processor clock; however, the DCP does not require the high voltage levels of the processor clock. # Pin Descriptions (Continued) MAS. Master Port Address Strobe (input, active Low). In Multiplexed Control mode $(C/\overline{K} \text{ Low})$ , an active (Low) signal on this pin indicates the presence of valid address and chip select information at the master port. This information is latched internally on the rising edge of Master Port Address Strobe ( $\overline{\text{MAS}}$ ). When $C/\overline{K}$ is High (Direct Control mode), MAS can be High or Low without affecting DCP operation, except that, regardless of the state of $C/\overline{K}$ , if both Master Port Address Strobe ( $\overline{\text{MAS}}$ ) and Data Strobe ( $\overline{\text{MDS}}$ ) are Low simultaneously, the DCP Mode register will be reset to ECB mode. The master port is assigned to clear data, the slave port is assigned to enable data, and all flags remain inactive. $\overline{\text{MCS}}$ . Master Port Chip Select (input, active High). This signal is used to select the master port. In Multiplexed Control mode (C/ $\overline{K}$ Low), the level on $\overline{\text{MCS}}$ is latched internally on the rising edge of Master Port Address Strobe ( $\overline{\text{MAS}}$ ). This latched level is retained as long as $\overline{\text{MAS}}$ is High; when $\overline{\text{MAS}}$ is Low, the latch becomes invisible and the internal signal follows the $\overline{\text{MCS}}$ input. In Direct Control mode (C/ $\overline{K}$ High), no latching of $\overline{\text{Master}}$ Port Chip Select occurs; the level on $\overline{\text{MCS}}$ is passed directly to the internal select circuitry, regardless of the state of Address Strobe ( $\overline{\text{MAS}}$ ). MDS. Master Port Data Strobe (input, active Low). When MDS is active and Master Port Chip Select (MCS) is valid, it indicates that valid data is present on MP0-MP7 during output. MDS and Master Port Address Strobe (MAS) are normally mutually exclusive; if both go Low simultaneously, the DCP is reset to ECB mode and all flags remain inactive. **MFLG.** Master Port Flag (output, active Low). This flag is used to indicate the need for a data transfer into or out of the master port during normal ciphering operation. Depending upon the control bits written to the Mode register, the master port is associated with either the Input register or the Output register. If data is to be transferred through the master port to the Input register, the MFLG reflects the contents of the Input register; after any start command is entered, MFLG goes active (Low) whenever the Input register is not full. MFLG is forced High by any command other than a start. Conversely, if the master port is associated with the Output register, MFLG reflects the contents of the Output register (except in single-port configuration). MFLG goes active (Low) whenever the Output register is not empty. In single-port configuration, MFLG reflects the contents of the Input register, while the Slave Port Flag (SFLG) is associated with the Output register. MP<sub>0</sub>-MP<sub>7</sub>. Master Port Bus (input/output, active High). These eight bidirectional lines are used to specify internal register addresses in Multiplexed Control mode (see $C/\overline{K}$ ) and to input and output data. The master port provides software access to the Status, Command and Mode registers as well as the Input and Output registers. The 3-state master port outputs are enabled only when the master port is selected by Master Port Chip Select (MCS) being Low, with Master Port Read/Write $(MR/\overline{W})$ High, and strobed by a Low on the Master Port Data Strobe ( $\overline{\text{MDS}}$ ). MP<sub>0</sub> is the low-order bit. Data and key information is entered into this port with most significant byte input first. $MR/\overline{W}$ . Master Port Read/Write (input, Low = Write). This signal indicates to the DCP whether the current master port operation is a read $(MR/\overline{W})$ is High) or a write $(MR/\overline{W})$ is Low), thereby indicating whether data is to be transferred from or to an internal register. $MR/\overline{W}$ is not latched internally and must be held stable while Master Port Data Strobe $(\overline{MDS})$ is Low. PAR. Parity (output, active Low). The DCP checks all key bytes for correct (odd) parity as they are entered through either the master port (Multiplexed or Direct Control mode) or the auxiliary port (Multiplexed Control mode only). If any key byte contains even parity, the PAR bit in the Status register is set to 1 and PAR goes Low. The least significant bit of key bytes is the parity. **SCS.** Slave Port Chip Select (input, active Low). This signal is logically combined with Slave Port Data Strobe (\$\overline{SDS}\$) to facilitate slave port data transfers in a bus environment. \$\overline{SCS}\$ is not latched internally and can be permanently tied to Low without impairing slave port operation. $\overline{\text{SDS}}$ . Slave Port Data Strobe (input, active Low). When both $\overline{\text{SDS}}$ and $\overline{\text{SCS}}$ are Low, it indicates to the DCP either that valid data is on the $SP_0$ – $SP_7$ lines for an input operation, or that data is to be driven onto the $SP_0$ – $SP_7$ lines for output. The direction of data flow is determined by the control bits in the Mode register. SFLG. Slave Port Flag (output, active Low). This output indicates the status of either the Input register or the Output register, depending on the control bits in the Mode register. In single-port configuration, SFLG goes active during normal processing whenever the Output register is not empty. In dual-port configuration, SFLG reflects the content of whichever register is associated with the slave port. If the input register is assigned to the slave port, SFLG goes active whenever the Input register is not full, once any of the start commands has been entered; SFLG is forced # Pin Descriptions (Continued) inactive if any other command is entered. If the slave port is assigned to the Output register, $\overline{SFLG}$ goes active whenever the Output register is not empty. In this case, $\overline{SFLG}$ goes inactive if any command is aborted. **SP<sub>0</sub>-SP<sub>7</sub>.** Slave Port Bus (bidirectional). The slave port provides a second data input/output interface to the DCP, allowing overlapped input, output, and ciphering operations. The 3-state slave port outputs are driven only when Slave Port Chip Select $(\overline{SCS})$ and Slave Port Data Strobe $(\overline{SDS})$ are both Low, $\overline{SFLG}$ is 0, and the internal port control configuration allows output to the slave port. $SP_0$ is the low order bit. The most significant byte of data blocks is entered or retrieved through this port first. # Functional Description The overall design of the DCP, as shown in Figure 3, is optimized to achieve high data throughput. Data bytes can be transferred through both the master and slave ports, and key bytes can be written through both the auxiliary and master ports. Three 8-bit buses (input, output and C bus) carry data and key bytes between the ports and the internal registers. Three 56-bit, write-only key registers are provided for the Master (M) Key, the Encryption (E) Key and the Decryption (D) Key. Parity checking is provided on incoming key bytes. Two 64-bit registers are provided for initializing vectors (IVE and IVD) that are required for chained (feedback) ciphering modes. Three 8-bit registers (Mode, Command and Status) are accessible through the master port. Algorithm Processing. The algorithm processing unit of the DCP (Figure 3) is designed to encrypt and decrypt data according to the National Bureau of Standards' Data Encryption Standard (DES), as specified in Federal Information Processing Standards Publication 46. The DES specifies a method for encrypting 64-bit blocks of clear data ("plain text") into corresponding 64-bit blocks of "cipher text." The DCP offers three ciphering methods, selected by the cipher type field of the Mode register: Electronic Code Book (ECB), Cipher Block Chain (CBC) and Cipher Feedback (CFB). These methods are implemented in accordance with Federal Information Processing Standards, Publication 46. Electronic Code Book (ECB) is a straightforward implementation of the DES: 64 bits of clear data in, 64 bits of cipher text out, with no cryptographic dependence between blocks. Cipher Block Chain (CBC) also operates on blocks of 64 bits, but it includes a feedback step which chains consecutive blocks so that repetitive data in the plain text (such as ASCII blanks) does not yield repetitive cipher text. CBC also provides an error extension characteristic which protects against fraudulent data insertions and deletions. Cipher Feedback (CFB) is an additive stream cipher method in which the DES algorithm generates a pseudorandom binary stream, which is then exclusive-0Red with the clear data to form the cipher text. The cipher text is then fed back to form a portion of the next DES input block. The DCP implements 8-bit cipher feedback, with data input, output, Figure 3. Z8068 Block Diagram 298 2080-003 and feedback paths of one byte wide. This method is useful for low speed, character-at-atime, serial communications. Multiple Key Registers. The DCP provides the necessary registers to implement a multiple-key or master-key system. In such an arrangement, a single master key, stored in the DCP M key register, is used to encrypt session keys for transmission to remote DES equipment and to decrypt session keys received from such equipment. The M Key register may be loaded (with plain text) only through the auxiliary port, using the Load Clear Master Key command. In addition to the M Key register, the DCP contains two session key registers: the E key register, used to encrypt clear text, and the D key register, used to decrypt cipher text. All three registers are loaded by writing commands such as Load Clear E Key, through master port, into the Command register, and then writing the eight bytes of key data to the port when the Command Pending bit in the Status register is 1. Operating Modes: Multiplexed Control vs. Direct Control. The DCP can be operated in either of two basic interfacing modes, determined by the logic level on the $C/\overline{K}$ input pin. In Multiplexed Control mode $(C/\overline{K}$ Low), the DCP is configured internally to allow a master CPU to address five of the internal control/status/data registers directly, thereby controlling the device via mode and command values written to these registers. Also, in this mode, the auxiliary port is enabled for keybyte input. If the logic level on $C/\overline{K}$ is brought High, the DCP enters Direct Control mode, and the auxiliary port pins are converted into direct hardware status or control signals capable of instructing the DCP to perform a functionally complete subset of its cipher processing at very high throughputs. This operating mode is particularly well suited for ciphering data for high-speed peripheral devices such as magnetic disk or tape. **Data Flow.** Bits $M_2$ and $M_3$ of the Mode register control the flow of data into and out of the DCP through the master and slave ports. Three basic configurations are provided: one single-port and two dual-port. **Single-Port Configuration.** The simplest configuration occurs when the Mode register con- figuration bits are set to master port only (Figure 4). In this operating configuration, the encrypt/decrypt bit ( $M_4$ ) controls the processing of data. Data to be encrypted or decrypted is written to the master port Input register address. To facilitate monitoring of the Input register status, the $\overline{\text{MFLG}}$ signal goes Low when the Input register is not full. Data is read by the master CPU through the master port Output register address. Pin $\overline{\text{SFLG}}$ goes Low when the Output register is not empty. $\overline{\text{MFLG}}$ is then redefined as a master input flag and $\overline{\text{SFLG}}$ is redefined as a master output flag. Figure 4. Single-Port Configuration, Multiplexed Control Figure 5a. Dual-Port Configuration, Multiplexed Control #### **Dual Port, Master Port Clear** Configuration. In the dual-port configurations, both the master and slave ports are used for data entry and removal (Figures 5a and 5b). In the master port clear configuration. clear text for encryption can be entered only through the master port, and clear text resulting from decryption can be read only through the master port. Cipher text can be handled only through the slave port. The actual direction of data flow is controlled either by the encrypt/decrypt bit $(M_4)$ in the Mode register or by the Start Encryption or Start Decryption commands. If encryption is specified, clear data will flow through the master port to the Input register, and cipher data will be available at the slave port when it is ready to be read from the Output register. For decryption, the process is reversed, with cipher data written to the Input register Figure 5b. Dual-Port Configuration, Direct Control through the master port. Slave port and clear text read from the Master port. In both dual-port configurations, the Master Port Flag ( $\overline{\text{MFLG}}$ ) and the Slave Port Flag ( $\overline{\text{SFLG}}$ ) are used to indicate the status of the data register associated with the master port and slave port, respectively. For example, during encryption in the master port clear configuration, $\overline{\text{MFLG}}$ goes Low (active) when the Input register is not full; $\overline{\text{SFLG}}$ goes Low (active) when the Output register is not empty. If cyphering operation changes direction, $\overline{\text{MFLG}}$ and $\overline{\text{SFLG}}$ switch their register association (see Table 1). #### **Mode Register Bits** | Encrypt/<br>Decrypt<br>Bit M4 | Por<br>Configu<br>Bit M3 | _ | Input<br>Register<br>Flag | Output<br>Register<br>Flag | |-------------------------------|--------------------------|---|---------------------------|----------------------------| | 0 | 0 | 0 | MFLG | SFLG | | 0 | 0 | 1 | SFLG | MFLG | | 0 | 1 | 0 | MFLG | SFLG | | 1 | 0 | 0 | SFLG | MFLG | | 1 | 0 | 1 | MFLG | SFLG | | 1 | 1 | 0 | MFLG | SFLG | Table 1. Association of Master Port Flag (MFLG) and Slave Port Flag (SFLG) with Input and Output Registers ### Dual Port, Slave Port Clear Configuration. This configuration is identical to the previously described dual-port, master port clear configuration except that the direction of ciphering is reversed. That is, all data flowing in or out of the master port is cipher text, and all data at the slave port is clear text. Master Port Read/Write Timing. The master port of the DCP is designed to operate directly with a multiplexed address/data bus such as the Zilog Z-BUS. Several features of the master port logic are: - The level on Master Port Chip Select (MCS) is latched internally on the rising (trailing) edge of Master Port Address Strobe (MAS). This action relieves external address decode circuitry of the responsibility for latching chip select at address time. - The levels on MP<sub>1</sub> and MP<sub>2</sub> are also latched internally on the rising edge of MAS and are subsequently decoded to enable reading and writing of the DCP's internal registers (Mode, Command, Status, Input and Output). This action also eliminates the need for external address latching and decoding. - Data transfers through the master port are controlled by the levels and transitions on Master Port Data Strobe (MDS) and Master Port Read/Write (MR/W). The former controls the timing and the latter controls the transfer direction. Data transfers disturb neither the chip-select nor address latches, so once the DCP and a particular register have been selected, any number of reads or writes of that register can be accomplished without intervening address cycles. This feature greatly speeds up the loading of keys and data, given the necessary transfer control external to the DCP. Loading Keys and Initializing Vector (IV) Registers. Because the key and Initializing Vector (IV) registers are not directly addressable through any of the DCP's ports, keys and vector data must be loaded (and in the case of vectors, read) via "command data sequences." Most of the commands recognized by the DCP are of this type. A load or read command is written to the Command register through the master port. The command processor responds by asserting the Command Pending output. The user then either writes eight bytes of key or vector data through the master or auxiliary port, as appropriate to the specific command, or reads eight bytes of vector data from the master port. In Direct Control mode, only the E Key and D Key registers can be loaded; the M Key and IV registers are inaccessible. Loading the E and D Key registers is accomplished by placing the proper state on the $AUX_6-E/\overline{D}$ input (High for E Key, Low for D Key) and then raising the $\overline{AUX_7}$ - $\overline{K/\overline{D}}$ input—indicating that key loading is required. The command processor attaches the proper key register to the master port and asserts the AUX3-CP (Command Pending) signal (active Low). The eight key bytes can then be written to the master port. In the Multiplexed Control mode, all key and vector registers can be written to and all but the Master (M) Key register can be loaded with encrypted, as well as clear, data. If the operation is a Load Encrypt command, the subsequent data written to the master or auxiliary port (as appropriate) is routed first to the Input register and decrypted before it is written into the specified key or Initializing Vector register. Parity Checking of Keys. Key bytes contain seven bits of key information and one parity bit. By DES designation, the low-order bit is the parity bit. The parity-check circuit is enabled whenever a byte is written to one of three key registers. The output of the paritycheck circuit is connected to PAR and the state of this signal is reflected in Status register bit PAR (S<sub>3</sub>). Status register bit PAR goes to 1 whenever a byte with even parity (an even number of 1s) is detected. In addition to the PAR bit, the Status register has a Latched Parity bit (LPAR, S<sub>4</sub>) that is set to 1 whenever the Status register PAR bit goes to 1. Once set, the LPAR bit is not cleared until a reset occurs or a new Load Key command is issued. When an encrypted key is entered, the parity-check logic operates only after the decrypted key is available. The encrypted data is not checked for parity. The PAR signal reflects the state of the decrypted bytes on a byte-to-byte basis as they are clocked through the parity-check logic on their way to the key register. Thus, the time during which $\overline{PAR}$ indicates the status of a byte of decrypted key data may be as short as four clock cycles. The LPAR bit in the Status register indicates if any erroneous bytes of key data were entered. #### Programming **Initialization.** The DCP can be reset in several ways: - By the "Software Reset" command. - By a hardware reset, which occurs whenever both MAS and MDS go Low simultaneously. - By writing to the Mode register. - By aborting any command. These sequences initiate the same internal operations, except that loading the Mode register or aborting any command does not subsequently reset the Mode register. Once a reset process starts, the DCP is unable to respond to further commands for approximately five clock cycles. If a power-up hardware reset is used, the leading edge of the reset signal should not occur until approximately l ms after $V_{\rm CC}$ has reached normal operating voltage. This delay time is needed for internal signals to stabilize. **Registers.** The registers in the DCP that can be addressed directly through the master port are shown with their addresses in Table 2. A brief description of these registers and those not directly accessible follows. | C/K | MP2 | MPl | MR/W | MCS | Register Addressed | |-----|-----|-----|------|-----|--------------------| | 0 | Х | 0 | 0 | 0 | Input Register | | Λ | Y | Λ | 1 | Λ | Output Register | | 0 | Х | 0 | 1 | 0 | Output Register | |---|---|---|---|---|----------------------| | 0 | 0 | 1 | 0 | 0 | Command Register | | 0 | 0 | 1 | 1 | 0 | Status Register | | 0 | 1 | 1 | Х | 0 | Mode Register | | Х | Х | Х | Х | 1 | No Register Accessed | | 1 | Х | Х | 0 | 0 | Input Register | | 1 | Х | Х | 1 | 0 | Output Register | Table 2. Master Port Register Addresses | Hex<br>Code | Command | |-------------|---------------------------------------------| | 90 | Load Clear M Key Through Auxiliary Port | | 91 | Load Clear E Key Through Auxiliary Port | | 92 | Load Clear D Key Through Auxiliary Port | | 11 | Load Clear E Key Through Master Port | | 12 | Load Clear D Key Through Master Port | | B1 | Load Encrypted E Key Through Auxiliary Port | | B2 | Load Encrypted D Key Through Auxiliary Port | | 31 | Load Encrypted E Key Through Master Port | | 32 | Load Encrypted D Key Through Master Port | | 85 | Load Clear IVE Through Master Port | | 84 | Load Clear IVD Through Master Port | | A5 | Load Encrypted IVE Through Master Port | | A4 | Load Encrypted IVD Through Master Port | | 8D | Read Clear IVE Through Master Port | | 8C | Read Clear IVD Through Master Port | | A9 | Read Encrypted IVE Through Master Port | | A8 | Read Encrypted IVD Through Master Port | | 39 | Encrypt With Master Key | | 41 | Start Encryption | | 40 | Start Decryption | | C0 | Start | | EO | Stop | Table 3. Command Codes in Multiplexed Control Mode Command Register. Data written to the 8-bit, write-only Command register through the master port is interpreted as an instruction. A detailed description of each command is given in the Commands section; the commands and their hexadecimal representations are summarized in Table 3. A subset of these commands can be entered implicitly in Direct Control mode ( $C/\overline{K}$ High)—even though the Command register cannot be addressed in that mode—by transitions on auxiliary lines $AUX_5-S/\overline{S}$ , $AUX_6-E/\overline{D}$ , and $AUX_7-K/\overline{D}$ . These implicit commands are summarized in Table 4. | C/K | $AUX_7-K/\overline{D}$ | Pins $AUX_6-E/\overline{D}$ | AUX5-S/S | Command Initiated | |-----|------------------------|-----------------------------|----------|--------------------------------------| | Н | L | L | 1 | Start Decryption | | H | L | H | t | Start Encryption | | H | L | X | 1 | Stop | | Н | t | L | L | Load D Key Clear through master port | | H | t | H | L | Load E Key Clear through master port | | H | 1 | X | L | End Load Key command | | H | H | X | H | Not allowed | | L | Data | Data | Data | AUX pins become Key-Byte inputs | 00 Software Reset Table 4. Implicit Command Sequences in Direct Control Mode Programming (Continued) Status Register. The bit assignments in the read-only Status register are shown in Figure 6. The PAR, AFLG, SFLG and MFLG bits indicate the status of the corresponding output pins, as do the busy and command pending bits when the DCP is in a Direct Control mode ( $C/\overline{K}$ High). In each case, the output signal will be active Low when the corresponding status bit is a 1. The parity bit indicates the parity of the most recently entered key byte. The LPAR bit indicates whether any key byte with even parity has been encountered since the last Reset or Load Key command. The Busy bit is 1 whenever the ciphering algorithm unit is actively encrypting or decrypting data, either as a response to a command such as Load Encrypted Key (in which case the Command Pending bit is 1) or in the ciphering of regular text (indicated by the Start/Stop bit being 1). If the ciphered data cannot be transferred to the Output register because that register still contains output from a previous ciphering cycle, the Busy bit remains 1 even after the ciphering is complete. Busy is 0 at all other times, even when ciphering is not possible because data has not been written to the Input register. The Command Pending bit is set to 1 by any command whose execution requires the transfer of data to or from a nonaddressable internal register, such as when writing key bytes to the E key register or reading bytes from the IVE register. Thus, the Command Pending bit is set following all commands ex- **Mode Register.** Bit assignments in this 5-bit read/write register are shown in Figure 7. The cipher type bits ( $M_1$ and $M_0$ ) indicate to the DCP which ciphering algorithm is to be used. On reset, the Cipher Type mode defaults to Electronic Code Book mode. Configuration bits ( $M_3$ and $M_2$ ) indicate which data ports are to be associated with the Input and Output registers and flags. When these bits are set to the single-port, masteronly configuration ( $M_3$ $M_2$ = 10), the slave port is disabled and no manipulation of Slave Port Chip Select ( $\overline{SCS}$ ) or Slave Data Strobe ( $\overline{SDS}$ ) can result in data movement through the slave port; all data transfers are accomplished through the master port, as previously described in the Functional Description. Both $\overline{MFLG}$ and $\overline{SFLG}$ are used in this configuration; $\overline{MFLG}$ gives the status of the Input register and $\overline{SFLG}$ gives the status of the Output register. When the configuration bits are set to one of the dual-port configurations ( $M_3 M_2 = 00$ or 01), both the master and slave ports are available for input and output. When $M_3$ , $M_2 = 01$ (the default configuration), the master port handles clear data while the slave port handles encrypted data. Configuration cept the three start commands, the Stop command and the Software Reset command. The Command Pending bit returns to 0 after all eight bytes have been transferred following Load Clear, Read Clear, or Read Encrypted commands; and after data has been transferred, decrypted, and loaded into the desired register following Load Encrypt commands. The Start/Stop bit is set to 1 when one of the start commands is entered and it is reset to 0 whenever a reset occurs or when a new command other than a Start is entered. Figure 6. Status Register Bit Assignments $M_3$ , $M_2 = 00$ reverses this assignment. Actual data direction at any particular moment is controlled by the Encrypt/Decrypt bit. The Encrypt/Decrypt bit $(M_4)$ instructs the DCP algorithm processor to encrypt or decrypt the data from the Input register using the ciphering method specified by the Cipher Type bits. The Encrypt/Decrypt bit also controls data flow within the DCP. For example, when the configuration bits are 0,1 (dual-port, master clear, slave encrypted) and the Encrypt/Decrypt bit is 1 (encrypt), clear data will flow into the DCP through the master port and encrypted data will flow out through the slave port. When the Encrypt/Decrypt bit is set to 0 (decrypt), data flow is reversed. Figure 7. Mode Register Bit Assignments #### Programming (Continued) Input Register. The 64-bit, write-only Input register is organized to appear to the user as eight bytes of pushdown storage. A status circuit monitors the number of bytes that have been stored. The register is considered empty when the data stored in it has been or is being processed; it is considered full when one byte of data has been entered in Cipher Feedback mode or when eight bytes of data have been entered in Electronic Code Book or Cipher Block Chain mode. If the user attempts to write data into the Input register when it is full, the Input register disregards the attempt; no data in the register is destroyed. **Output Register.** The 64-bit, read-only Output register is organized to appear to the user as eight bytes of pop-up storage. A status circuit detects the number of bytes stored in the Output register. The register is considered empty when all the data stored in it has been read by the master CPU and is considered full if it still contains one or more bytes of output data. If a user attempts to read data from the Output register when it is empty, the buffers driving the output bus remain in a 3-state condition. **M**, **E**, **D Key Registers**. The following multibyte key registers cannot be addressed directly, but are loaded in response to commands written to the Command register. There are three 64-bit, write-only key registers in the DCP: the Master (M) Key register, the Encrypt (E) key register, and the Decrypt (D) key register. The Master key register can be loaded only with clear data through the auxiliary port. The Encrypt and Decrypt Key registers can be loaded in any of four ways: (1) as clear data through the auxiliary port. (2) as clear data through the master port, (3) as encrypted data through the auxiliary port, or (4) as encrypted data through the master port. In the last two cases, the encrypted data is first routed to the Input register, decrypted using the M Key, and finally written to the target key register from the Output register. Initializing Vector Registers (IVE and IVD). Two 64-bit registers are provided to store feedback values for cipher feedback and chained block ciphering methods. One initializing vector register (IVE) is used during encryption, the other (IVD) is used during decryption. Both registers can be loaded with either clear or encrypted data through the master port (in the latter case, the data is decrypted before being loaded into the IV register), and both may be read out either clear or encrypted through the master port. #### Commands All operations of the DCP result from command inputs, which are entered in Multiplexed Control mode by writing a command byte to the Command register. Command inputs are entered in Direct Control mode by raising and lowering the logic levels on the $AUX_7-K/\overline{D}$ , $AUX_6-E/\overline{D}$ , and $AUX_5-S/\overline{S}$ pins. Table 3 shows all commands that can be given in Multiplexed Control mode. Table 4 shows a subset of the implicit commands that can be executed in the Direct Control mode. Load Clear M Key Through Auxiliary Port (90H). Load Clear E Key Through Auxiliary Port (91H). Load Clear D Key Through Auxiliary Port (92H). These commands may be used only for multiplexed operations; they override the data flow specifications set in the Mode register and cause the Master (M) Key, Encrypt (E) Key, or Decrypt (D) Key register to be loaded with eight bytes written to the auxiliary port. After the Load command is written to the Command register, the Auxiliary Port Flag ( $\overline{AFLG}$ ) goes active (Low) and the corresponding bit in the Status register (S2) becomes 1, indicating that the device is able to accept key bytes at the auxiliary port pins. Additionally, the Command Pending bit (S6) becomes 1 during the entire loading process. Each byte is written to its respective key register by placing an active Low signal on the Auxiliary Port Strobe ( $\overline{ASTB}$ ) once data has been set up on the auxiliary port pins. The actual write process occurs on the rising (trailing) edge of $\overline{ASTB}$ . (See Switching Characteristics section for exact setup, strobe width, and hold times.) The Auxiliary Port Flag (AFLG) goes inactive immediately after the eighth strobe goes active (Low). However, the Command Pending bit (S<sub>6</sub>) remains 1 for several more clock cycles, until the key loading process is completed. All key bytes are checked for correct (odd) parity as they are entered. ### Load Clear E Key Through Master Port (11H). Load Clear D Key Through Master Port (12H). These commands are available in both Multiplexed Control and Direct Control modes. They override the data flow specifications set in the Mode register and attach the master port inputs to the Encrypt (E) Key or Decrypt (D) Key register, as appropriate, until eight key bytes have been written. In Multiplexed Control mode, the command is initiated by writing the Load command to the Command register. In Direct Control mode, the command is initiated by raising the AUX $_7$ -K/ $\overline{D}$ control input while the AUX $_5$ -S/ $\overline{S}$ Commands (Continued) input is Low. In this latter case, the level on $AUX_6-E/\overline{D}$ determines which key register is written (High = E register). Once the command has been recognized, the Command Pending bit ( $S_6$ in the Status register) becomes 1. In Direct Control mode, $AUX_3-\overline{CP}$ goes active (Low), indicating that key entry may proceed. The host system then writes exactly eight bytes to the master port (at the Input register address in Multiplexed Control mode). When the key register has been loaded, the Command Pending bit returns to 0. In Direct Control mode, the AUX $_3$ -CP output goes inactive, indicating that the DCP can accept the next command. #### Load Encrypted E Key Through Auxiliary Port (B1H). Load Encrypted D Key Through Auxiliary Port (B2H). These commands are used in Multiplexed Control mode only. Their execution is similar to that of the Load Clear E (D) Key Through Auxiliary Port command, except that key bytes are first decrypted using the electronic code book algorithm and the Master (M) Key register. The key bytes are then loaded into the appropriate key register, after having passed through the parity-check logic. The Command Pending bit $(S_6)$ is 1 during the entire decrypt-and-load operation. In addition, the Busy bit $(S_5)$ is 1 during the actual decryption process. ### Load Encrypted E Key Through Master Port (31H). Load Encrypted D Key Through Master Port (32H). These commands are used in Multiplexed Control mode only. Their execution is similar in effect to that of the Load Clear E (D) Key Through Master Port command. The commands differ in that key bytes are initially decrypted using the electronic code book algorithm and the Master (M) Key register. Once decrypted, they are loaded byte-by-byte into the target key register, after having passed through the parity-check logic. The command pending bit $(S_6)$ is 1 during the entire decrypt-and-load operation. In addition, the busy bit $(S_5)$ is 1 during the actual decryption process. ### Load Clear IVE Register Through Master Port (85H) Load Clear IVD Register Through Master Port (84H) These commands are used in Multiplexed Control mode only. Their execution is virtually identical to that of the Load Clear E (or D) Key Through Master Port command. The commands differ in that the data written to the input register address is routed to either the Encryption Initializing Vector (IVE) or Decryption Initializing Vector (IVD) register instead of a key register. No parity checking occurs. The Command Pending bit $(S_6)$ is 1 during the entire loading process. ### Load Encrypted IVE Register Through Master Port (A5H). Load Encrypted IVD Register Through Master Port (A4H). These commands are analogous to the Load Encrypted E (or D) Key Through Master Port command. The data flow specifications set in the Mode register are overridden and the eight vector bytes are decrypted using the Decryption (D) Key register and the electronic code book algorithm. The resulting clear vector bytes are loaded into the target Initializing Vector register. No parity checking occurs. The Busy bit ( $S_5$ ) does not become 1 during the decryption process, but the Command Pending bit ( $S_6$ ) is 1 during the entire decryption-and-load operation. #### Read Clear IVE Register Through Master Port (8DH). Read Clear IVD Register Through Master Port (8CH). In the Multiplexed Control mode, these commands override the data flow specifications set in the Mode register and connect the appropriate Initializing Vector register to the master port at the Output register address. In this state, each IV register appears as eight bytes of FIFO storage. The first byte of data is available six clocks after loading the Command register. The Command Pending bit in the Status register remains a 1 until sometime after the eighth byte is read out. The host system is responsible for reading exactly eight bytes. #### Read Encrypted IVE Register Through Master Port (A9H). Read Encrypted IVD Register Through Master Port (A8H). In the Multiplexed Control mode only, these commands override the specifications set in the Mode register and encrypt the contents of the specified Initializing Vector register using the electronic code book algorithm and the Encrypt (E) key. The resulting cipher text is placed in the output register, where it can be read as eight bytes through the master port. During the actual encryption process, the Busy bit $(S_5)$ is 1. When the Busy bit becomes 0, the encrypted vector bytes are ready to be read out. The Command Pending bit (S<sub>6</sub>) is 1 during the entire encryption and output process; it becomes 0 when the eighth byte is read out. The host system is responsible for reading exactly eight bytes. #### Encrypt with Master (M) Key (39H). In the Multiplexed Control mode, this command overrides the data flow specifications set in the Mode register and causes the DCP to accept eight bytes from the master port, which are written to the Input register. When eight bytes have been received, the DCP encrypts ## Commands (Continued) the input using the Master (M) Key register. The encrypted data is loaded into the Output register, where it can be read out through the master port. The Command Pending bit (S<sub>6</sub>) and the Busy (S<sub>5</sub>) bit are used as status indicators in the three phases of this operation. The Command Pending bit becomes 1 as soon as the Input register can accept data. When exactly eight bytes have been entered, the Busy bit becomes and remains 1 until the encryption process is complete. When Busy becomes 0, the encrypted data is available to be read out. The Command Pending bit returns to 0 when the eighth byte has been read. ### Start Encryption (41H) Start Decryption (40H) Start (COH). The three start commands begin normal data ciphering by setting the Status register's Start/Stop bit (S<sub>7</sub>) to 1. The Start Encryption and Start Decryption commands explicitly specify the ciphering direction by forcing the Encrypt or Decrypt bit $(M_4)$ in the Mode register to 1 or 0, respectively. The Start command, however, uses the current state of the Encrypt/Decrypt bit, as specified in a previous Mode register load. When a start command has been entered, the port status flag ( $\overline{\text{MFLG}}$ or $\overline{\text{SFLG}}$ ) associated with the Input register becomes active (Low), indicating that data may be written to the Input register to begin ciphering. In Direct Control mode, the Start command is issued by raising the level on the $AUX_{5}-S/\overline{S}$ input (Table 4). The ciphering direction is specified by the level on $AUX_6-E/\overline{D}$ . If $\overline{AUX_6}$ - $\overline{E}/\overline{D}$ is High when $\overline{AUX_5}$ - $\overline{S}/\overline{S}$ goes High, the command is Start Encryption; if $AUX_6-E/\overline{D}$ is Low, it is Start Decryption. #### Stop (EOH). The Stop command clears the Start/Stop bit (S<sub>7</sub>) in the Status register. This action causes the input flag (MFLG or SFLG) to become inactive and inhibits the loading of any further input into the algorithm unit. If ciphering is in progress [Busy bit (S<sub>5</sub>) is 1 or $\overline{AUX_2}$ - $\overline{BSY}$ is active], it is allowed to finish, and any data in the Output register remains accessible. In Direct Control mode, the Stop command is implied when the signal level on the $AUX_5-S/\overline{S}$ input goes from High to Low (Table 4). #### Software Reset (00). This command has the same effect as a hardware reset ( $\overline{MAS}$ and $\overline{MDS}$ Low): it forces the DCP back to its default configuration, and all processing flags go into Inactive mode. The default configuration includes setting the Mode register to Electronic Code Book ciphering mode and establishes a dual-port configuration with master port clear and slave port encrypted. # Timing The control and/or data signals and the Requirements timing requirements for clock/reset, Direct Control mode, Multiplexed Control mode (master port), master (slave) port read/write, and auxiliary port key entry functions are illustrated in Figures 8 through 12. The ac switching characteristics of the signals involved in the above functions are described in the AC Characteristics. The specific timing periods described are identified by numerics (1 through 48), which are referenced in both the timing diagrams and in the AC Characteristics. A two-to-seven character symbol is listed in AC Characteristics for each period described. The symbol specifies the signal(s) involved, the state of each signal, and optionally, the port associated with a signal. Symbols are encoded as follows: General Form: Ta Ab (Cb) ### Where: - (1) T is a constant. - (2) a represents any one of the following symbols: ### Symbol Meaning - Clock С - d Delay - Fall Time h Hold Time Rise Time r Setup Time s Width (3) A,C represent any of the following signal names: #### Symbol Signal Name Ā Address Strobe В BSY, Busy С Clock D\* Data In or the address at the master port. Ε $E/\overline{D}$ , Enable/Disable F\* Flag (MFLG, SFLG, or (AFLG) G\* Data Strobe (MDS, SDS, or ASTB) K $K/\overline{D}$ , Key/Data M C/K, Control/Key Mode Ν S/S, Start/Stop Ρ PAR, Parity 0\* Data Out (master or slave port) CP, Clock Pulse S\* Chip Select (master or slave port) W MR/W, Master Port read/write # Timing Requirements (Continued) (4) b represents any one of the following signal state descriptors (symbol). For example: D1 specifies data in at Master Port; F2 specifies Slave Port flag-SFLG. Symbol State Indicated h High l Low v Valid x Invalid z High Impedance \*These signal names may be modified by the following optional numeric port identifiers: 1 Master Port 2 Slave Port 2 Slave Port 3 AUX (Key) Port Figure 8. Clock and Reset 60 | AC | Number | Symbol | Parameter | Min | Max | Notes*† | |-------------------------|-----------------------------------------|----------------|-----------------------------------------------------------------------------|----------|-----------------|---------| | Switching<br>Character- | *************************************** | | Clock | | **** | | | stics | 1 | TwCh | Clock Width (High) | 105 | | | | 131103 | 2 | TwCl | Clock Width (Low) | 105 | | | | | 3 | TcC | Clock Cycle Time | 250 | | | | | | | Reset | | | | | | 4 | - TdGll(Glh) - | <ul> <li>— MDS+MAS Low to MDS+MAS High —<br/>(Reset Pulse Width)</li> </ul> | — TC — | | | | | 5 | TdC(G1h) | Clock High to MDS∗MAS High | 0 | 50 | | | | | • | Direct Control Mode | | | | | | 6 | TsN1(Mh) | $S/\overline{S}$ Low to $C/\overline{K}$ High (Setup) | 2TC | | | | | 7 | - TsK1(Mh) | <ul> <li>K/D Low to C/K</li></ul> | — 2TC — | | | | | 8 | TdMh(Nh) | $C/\overline{K}$ High to $S/\overline{S}$ high | 4TC | | | | | 9 | TdMh(Kh) | $C/\overline{K}$ High to $K/\overline{D}$ High | 4TC | | | | | 10 | TsEv(Kh) | $E/\overline{D}$ Valid to $K/\overline{D}$ High (Setup) | 2TC | | | | | 11 | - TdKh(R1) | — K/D̄ High to CP̄ Low ————— | | 200 | | | | 12 | ThK1(Ex) | $K/\overline{D}$ Low to $E/\overline{D}$ Invalid (Hold) | TC | | | | | 13 | TdCl(Nh) | Clock Low to S/S Valid | 20 | 80 | | | | 14 | TsEv(Hn) | $E/\overline{D}$ Valid to $S/\overline{S}$ High (Setup) | 2TC | | | | | 15 | -TdNh(F11) | — S/S High to MFLG (SFLG) Low ——— | | 230 | | | | | | (Port Input Flag) | | | | | | 16 | TdCh(F11) | Clock High to MFLG (SFLG) Low (Port Input Flag) | | 230 | 1 | | | 17 | TdCh(B1) | Clock High to BSY Low | | 300 | | | | 18 —— | -TdCl(Bh) | — Block Low to BSY High —————— | | <del> 220</del> | | | | 19 | TdCh(F11) | Clock High to MFLG (SFLG) Low (Port Output Flag) | | 230 | | | | 20 | TdNl(Flh) | S/S Low to MFLG (SFLG) High (Port Input Flag) | | 230 | 2 | | | | | Multiplexed Control Mode – Master I | Port | | | | | 21 | TwAl | MAS Width (Low) | 80 | | | | | 22 | TdWv(Ah) | MR/W Valid to MAS High | 40 | | | | | 23 | TsSll(Ah) | $\overline{\text{MCS}}$ Low to $\overline{\text{MAS}}$ High (Setup) | 0 | | | | | 24 | -ThAh(Slh) | — MAS High to MCS High (Hold)———— | <u> </u> | | | | | 25 | TsDlv(Ah) | Address-In Valid to $\overline{\text{MAS}}$ High (Address Setup Time) | 55 | | | | | | | | | | | <sup>\*</sup> Notes referenced at end of AC Characteristics table. ThAh(Dlx) 26 306 MAS High to Address-In Invalid (Address Hold Time) | AC | Number | Symbol | Parameter | Min | Max | Notes*† | |--------------------|--------|----------------|---------------------------------------------------------------------------------------------------------------------|----------|----------------|---------------| | witching | | | Master (Slave) Port Read/Write | | | | | haracter-<br>stics | 27 | TdSll(Gll) | MCS (SCS) Low to MDS (SDS) Low | 70 | | | | Continued) | 28 | ThGlh(Slh) | MDS (SDS) High to MCS (SCS) High | 0 | | 3 | | Commuca | 20 | inGin(Sin) | (Select Hold Time) | U | | 3 | | | 29 | TsWv(Gll) | $MR/\overline{W}$ Valid to $\overline{MDS}$ Low (Setup) | 70 | | | | | 30 | - ThGlh(Hwx)- | $\overline{\text{MDS}}$ High to MR/ $\overline{\text{W}}$ Invalid (Hold) —— | 0 | | | | | 31 | TwGll(Glh) | $\overline{\text{MDS}}$ ( $\overline{\text{SDS}}$ ) Low to $\overline{\text{MDS}}$ ( $\overline{\text{SDS}}$ ) High | | | | | | | | Width—Write Data Read | 125 | | | | | | | Width—Status Register Read | 155 | | | | | 32 | - TdCl(Glh) | — Clock Low to $\overline{\text{MDS}}$ ( $\overline{\text{SDS}}$ ) High ——— | 20 | <del> 70</del> | | | | 33 | TdG1h(HGII) | $\overline{\text{MDS}}$ ( $\overline{\text{SDS}}$ ) High to $\overline{\text{MDS}}$ ( $\overline{\text{SDS}}$ ) Low | 125 | | | | | | , , | (Data Strobe Recovery Time) | | | | | | 34 | TsDlr(Hlh) | Write-Data Valid to $\overline{\text{MDS}}$ ( $\overline{\text{SDS}}$ ) High | | | | | | | , , | Setup Time—Key Load | 200 | | | | | | | —— Setup Time—Data Write ———— | <u> </u> | | | | | | | Setup Time—Command/Mode | 100 | | | | | | | Register Write | | | | | | 35 | ThGlh(Dlx) | MDS (SDS) High to Write-Data | 40 | | | | | | | Invalid (Hold Time—All Writes) | | | | | | 36 | – TdGll(Qlv) — | | | | | | | | | Read Access Time—Status Register | | 155 | | | | | | Read Access Time—Data | | 120 | | | | 37 | ThGlh(Qlx) | MDS (SDS) High to Read-Data Invalid | 5 | 80 | | | | | | (Read Hold Time) | | | | | | 38 | — TdGll(Flh) — | $\longrightarrow$ MDS (SDS) Low to MFLG (SFLG) $\longrightarrow$ | | 125 | <del> 4</del> | | | | | High (Last Strobe) | | | | | | 39 | TdG11(Rh) | $\overline{ ext{MDS}}$ High to $\overline{ ext{CP}}$ High | | TC + 280 | | | | | | (Last Strobe, Key Load) | | | | | | 40 | ThG1(HNÌ) | $\overline{\text{MDS}}$ ( $\overline{\text{SDS}}$ ) High to S/ $\overline{\overline{\text{S}}}$ Low | 3TC | | | | | | | (Hold Time After Last Input Strobe) | | | | | | 41 | TdG1(HPv) | $\overline{ ext{MDS}}$ High to $\overline{ ext{PAR}}$ Valid (Key Write) | | 200 | | | | | (111 1) | rana (no) vino) | | 200 | | <sup>\*</sup> Notes referenced at end of AC Characteristics table Figure 9. Control and Status Signals (Direct Control Mode) | AC<br>Switching | Number | Symbol | Parameter | Min | Max | Notes*† | |-----------------|--------|------------|-----------------------------------------------------|-----|-----|---------| | Character- | | | Auxiliary Port Key Entry | | | | | istics | 42 | TwG3 | ASTB Low to ASTB High (Width) | 160 | | | | (Continued) | 43 | TdCl(G3h) | Clock Low to ASTB High | 20 | 70 | | | | 44 | TdG3h(G31) | ASTB High to Next ASTB Low<br>(Recovery Time) | 125 | | | | | 45 | TsD3v(G3h) | Write-Data Valid to ASTB High<br>(Data Setup Time) | 200 | | | | | 46 | ThG3h(D3x) | ASTB High to Write-Data Invalid<br>(Data Hold Time) | 40 | | | | | 47 | TdG3h(Pr) | ASTB High to PAR Valid | | 200 | | | | 48 | TdG31(F3h) | ASTB Low to AFLG High (Last Strobe) | | 230 | | #### NOTES: - All transition times are assumed to be ≤ 20 ns - All units in nanoseconds (ns). All timings are - preliminary and subject to change. Parameter TaCh(F1I) applies to all input blocks except the first (when S/S first goes High). - When S/S goes mactive (Low) in Direct Control mode, the flag associated with the input port turns off. - 3. Direct Control mode only. - 4. In Cipher Feedback mode, the port flag (MFLG or $\overline{SFLG}$ ) goes mactive following the leading edge of the first data strobe ( $\overline{MDS}$ or $\overline{SDS}$ ); in all other modes and operations, the flags go inactive on the eighth data strobe. Figure 10. Master Port, Multiplexed Control Mode Read/Write Timing AC Switching Characteristics (Continued) Figure 11. Master (Slave) Port Read/Write Figure 12. Auxiliary Port Key Entry 2080-012, 013 | Ordering<br>Information | | Package/<br>Temp. | Speed | Description | Product<br>Number | Package/<br>Temp. | Speed | Description | |-------------------------|-------|-------------------|---------|---------------|-------------------|-------------------|---------|---------------| | | Z8068 | CE | 4.0 MHz | DCP (40-pin) | Z8068 | PE | 4.0 MHz | DCP (40-pin) | | | Z8068 | DE | 4.0 MHz | Same as above | Z8068 | PS | 4.0 MHz | Same as above | | | Z8068 | DS | 4.0 MHz | Same as above | | | | | NOTES: C = Ceramic, D = Cerdip, P = Plastic; E = -40°C to E = +85°C, S = 0°C to 70°C. 310 00-2080-02 # Z8070 Floating-Point Software Emulation Package ## Product Brief #### June 1982 #### **Features** - Provides high-quality, floating-point arithmetic capability. - Executes the same instruction set and supports the same architecture as Zilog's Z8070 Arithmetic Processing Unit (APU). The same application software can use this emulation package or the Z8070 APU without modification. - June 1982 - Provides routines for the conversion of binary integer and Binary Coded Decimal (BCD) to and from floating-point formats. - Conforms to the proposed IEEE Standard P754 Draft 9.0 for binary floating-point arithmetic. #### General Description The Floating-Point Software Emulator Package provides floating-point arithmetic capability for any of Zilog's Z8000 series CPUs. Floating-point instructions are coded using the Extended Processing Architecture opcodes of the Z8000. When the CPU encounters an EPU instruction and the Floating-Point Emulator is used, a CPU Extended Instruction trap occurs and a link is made to the emulation package. Conversely, when a Z8070 APU is used, no trap occurs and the instructions are directly executed by the APU. Floating-point arithmetic operations are performed according to the requirements of the proposed IEEE Standard P754 Draft 9.0. This standard provides for: - Single (32-bit), Double (64-bit), and Extended (80-bit) precision floating-point number formats - Addition, subtraction, multiplication, division, square-root, remainder and compare operations - Conversions between different floating-point formats - Conversions between binary integers and floating-point numbers - Non-numbers (NaNs) and infinity arithmetic - Floating-point exceptions and their handling. #### Instruction Set The floating-point instruction set consists of the following instructions: Primary Arithmetic Operations - Addition - Subtraction - Multiplication - Division - Square root - Remainder step Load And Store Operations - Floating point - BCD integer - Binary integer (either rounded or truncated) ### Instruction Set (Continued) **-** C - Compare and Examine Operations - Compare - Compare and raise exception if unordered - Compare and transfer status to the CPU's Flag and Control Word (FCW) - Compare, transfer status to FCW, and raise exception if unordered - Compare with zero and transfer to FCW - Compare with zero, transfer to FCW and raise exception if unordered #### Secondary Arithmetic Operation - Load absolute value - Clear - Round to floating integer - Negate - Truncate to integer ## Control Operation - Floating-point load and store control - Transfer selected floating-point flags to FCW - Clear floating-point flags - Clear floating-point trap enables - Set floating-point flags - Set floating-point modes - Set floating-point trap enables ## Data Types The Floating-Point Emulator Software supports the following data types: ## Z8090 Z8000™Z-UPC Universal Peripheral Controller # **Product Specification** #### June 1982 #### **Features** - Complete slave microcomputer, for distributed processing Z-BUS use. - 2K bytes of on-chip ROM. - 256-byte register file, accessible by both the master CPU and Z-UPC, using a fail-safe message-passing protocol. - Three programmable I/O ports, two with optional 2-Wire Handshake. - Z8 architecture and instruction set. - Six levels of priority interrupts from eight sources: six external sources and two internal sources. - Two programmable 8-bit counter/timers each with a 6-bit prescaler. Counter/Timer T0 is driven by an internal source, and Counter/Timer T1 can be driven by internal or external sources. Both counter/timers are independent of program execution. ### General Description The Z8090 Universal Peripheral Controller (Z-UPC) is an intelligent peripheral controller for distributed processing applications (Figure 3). The Z-UPC unburdens the host processor by assuming tasks traditionally done by the host (or by added hardware), such as performing arithmetic, translating or formatting data, and controlling I/O devices. Based on the Z8 microcomputer architecture and instruction set, the Z-UPC contains 2K bytes of internal program ROM, a 256-byte register file, three 8-bit I/O ports, and two counter/timers. The Z-UPC offers fast execution time; an effective use of memory; and sophisticated interrupt, I/O, and bit manipulation. Using a powerful and extensive instruction set Figure 1. Pin Functions Figure 2. Pin Assignments General Description (Continued) combined with an efficient internal addressing scheme, the Z-UPC speeds program execution and efficiently packs program code into the on-chip ROM. An important feature of the Z-UPC is an internal register file containing I/O port and control registers accessed both by the Z-UPC program and by its associated master CPU. The architecture results in both byte and programming efficiency, because Z-UPC instructions can operate directly on I/O data without moving it to and from an accumulator. Such a structure allows the user to allocate as many general-purpose registers as the application requires for data buffers between the CPU and peripheral devices. All general-purpose registers can be used as address pointers, index registers, data buffers, or stack space. The register file is logically divided into 16 groups, each consisting of 16 working registers. A Register Pointer is used in conjunction with short format instructions, resulting in tight, fast code and easy task switching. Communication between the master CPU and the register file takes place via one group of 19 interface registers addressed directly by both the master CPU and the Z-UPC, or via a block transfer mechanism. Access by the master CPU is controlled by the Z-UPC to allow independence between the master CPU and Z-UPC software. The Z-UPC has 24 pins that can be dedicated to I/O functions. Grouped logically into three 8-line ports, they can be programmed in many combinations of input or output lines, with or without handshake, and with push-pull or open-drain outputs. Ports 1 and 2 are bit-programmable; Port 3 has four fixed inputs and four outputs. To relieve software from coping with realtime counting and timing problems, the Z-UPC has two 8-bit hardware counter/timers, each with a fixed divide-by-four, and a 6-bit programmable prescaler. Various counting modes may be selected. In addition to the 40-pin standard configuration, the Z-UPC is available in four special configurations: - A 64-pin RAM development version with external interface for up to 4K bytes of RAM and 36 bytes of internal ROM permitting down-loading from the master CPU. - A Protopack RAM version with a socket for up to 2K bytes of RAM, with 36 bytes of internal ROM permitting down-loading from the master CPU. - A 64-pin ROM development version with external interface for up to 4K bytes of ROM and no internal ROM. - A Protopack ROM version with a socket for 2K bytes of ROM and no internal ROM. This range of versions and configurations makes the Z-UPC compatible with most system peripheral device control considerations. Figure 3. Functional Block Diagram # Pin Description **AD<sub>0</sub>-AD<sub>7</sub>.** Z-Bus Address/Data Lines (bidirectional). These multiplexed address and data lines are used to transfer information between the master CPU and the slave Z-UPC. $\overline{AS}$ . Address Strobe (input, active Low). The rising edge of $\overline{AS}$ initiates the beginning of a transaction and indicates that the Address, Status, $R/\overline{W}$ , and $\overline{CS}$ signals must be valid. **PCLK.** Clock (input). TTL-compatible clock input, 4 MHz maximum. This signal does not need to be related to the master CPU clock. **CS.** Chip Select (input, active Low). A Low on this line during the rising edge of $\overline{AS}$ enables the Z-UPC to accept address or data information from the bus during a master CPU write cycle or to transmit data to the bus during a read cycle. $\overline{\text{DS}}$ . Data Strobe (input, active Low). $\overline{\text{DS}}$ provides timing for data movement to the bus master. A simultaneous Low on $\overline{\text{AS}}$ and $\overline{\text{DS}}$ resets the Z-UPC. It is held in reset as long as $\overline{\text{DS}}$ is Low. # P1<sub>0</sub>-P1<sub>7</sub>, P2<sub>0</sub>-P2<sub>7</sub>, P3<sub>0</sub>-P3<sub>7</sub>. I/O Port Lines (inputs/outputs, TTL-compatible). These 24 lines are divided into three 8-bit I/O ports and may be configured in the following ways under program control: **Pl<sub>0</sub>-Pl<sub>7</sub>.** Port 1 (input/output—as output it can be push-pull or open-drain). Bit-programmable Parallel I/O. **P2**<sub>0</sub>-**P2**<sub>7</sub>. *Port 2* (input/output—as output, it can be push-pull or open-drain). Bit-programmable Parallel I/O. **P3**<sub>0</sub>-**P3**<sub>7</sub>. *Port 3* (four inputs, four outputs). Parallel I/O, handshake control, timer I/O, or interrupt control. $\mathbf{R}/\overline{\mathbf{W}}$ . Read/Write (input). This status signal indicates that the master CPU is executing a Read cycle if High, and a Write cycle if Low. **WAIT.** Wait (output, active Low, open-drain). When the CPU accesses the Z-UPC register file, this signal requests the master CPU to wait until the Z-UPC can complete its part of the transaction. # Functional Description Address Space. On the 40-pin Z-UPC, all address space is committed to on-chip memory. There are 2048 bytes of mask-programmed ROM and 256 bytes of register file. I/O is memory-mapped to three registers in the register file. Only the Protopack and 64-pin versions of the Z-UPC can access external program memory. See the section entitled "Special Configurations" for complete descriptions of the Protopack and 64-pin versions. Program Memory. Figure 4 is a map of the 2K on-chip program ROM. Even though the architecture allows addresses from 0 to 4K, behavior of the device above program address 2047 (7FFH) is not defined. The first 12 bytes of program memory are reserved for the Z-UPC interrupt vectors. For the Protopack and 64-pin versions, the address space is extended to 4096 bytes. In the RAM versions, addresses 0CH through 2FH are reserved for on-chip ROM. Register File. This 256-byte file includes three I/O port registers (1-3H), 234 general-purpose registers (6-EEH), and 19 control, status and special I/O registers (0H, 4H, 5H, and F0-FFH). The functions and mnemonics assigned to these register address locations are shown in Figure 5. Of the 256 Z-UPC registers, 19 can be directly accessed by the master CPU; the others are accessed indirectly via the block transfer mechanism. Figure 4. Program Memory Map | LOCATION | | IDENTIFIER<br>(UPC Side) | |------------|---------------------------------|--------------------------| | FFH | STACK POINTER | SP | | FEH | MASTER CPU INTERRUPT CONTROL | MIC | | FDH | REGISTER POINTER | RP | | FCH | PROGRAM CONTROL FLAGS | FLAGS | | FBH | UPC INTERRUPT MASK REGISTER | IMR | | FAH | UPC INTERRUPT REQUEST REGISTER | IRQ | | F9H | UPC INTERRUPT PRIORITY REGISTER | IPR | | F8H | PORT 1 MODE | P1M | | F7H | PORT 3 MODE | P3M | | F6H | PORT 2 MODE | P2M | | F5H | T <sub>0</sub> PRESCALER | PRE0 | | F4H | TIMER/COUNTER 0 | T <sub>0</sub> | | F3H | T <sub>1</sub> PRESCALER | PRE1 | | F2H | TIMER/COUNTER 1 | T <sub>1</sub> | | F1H | TIMER MODE | TMR | | FOH | MASTER CPU INTERRUPT VECTOR REG | MIV | | EFH | GENERAL-PURPOSE REGISTERS | | | 6H | | i | | 5H | DATA INDIRECTION REGISTER | DIND | | 4H | LIMIT COUNT REGISTER | LC | | 3 <b>H</b> | PORT 3 | P3 | | 2H | PORT 2 | P2 | | 1H | PORT 1 | P1 | | ОН | DATA TRANSFER CONTROL REGISTER | DTC | Figure 5. Register File Organization The I/O port and control registers are included in the register file without differentiation. This allows any Z-UPC instruction to process I/O or control information, thereby eliminating the need for special I/O and control instructions. All general-purpose registers can function as accumulators, address pointers, or index registers. In instruction execution, the registers are read when they are defined as sources and written when defined as destinations. Z-UPC instructions may access registers directly or indirectly using an 8-bit address mode or a 4-bit address mode and a Register Pointer. For the 4-bit addressing mode, the file is divided into 16 working register groups, each occupying 16 contiguous locations (Figure 6). The Register Pointer (RP) addresses the starting point of the active working-register group, and the 4-bit register designator supplied by the instruction specifies the register within the group. Any instruction altering the contents of the register file can also alter the Register Pointer. The Z-UPC instruction set also has a special Set Register Pointer (SRP) instruction for initializing or altering the pointer contents. Stacks. An 8-bit Stack Pointer (SP), register R255, is used for addressing the stack, residing within the 234 general-purpose registers, address location 6H through EFH. PUSH and POP instructions can save and restore any register in the register file on the stack. During CALL instructions, the Program Counter is automatically saved on the stack. During Z-UPC interrupt cycles, the Program Counter and the Flag register are automatically saved on the stack. The RET and IRET instructions pop the saved values of the Program Counter and Flag register. Figure 6. Register Pointer Mechanism Ports. The Z-UPC has 24 lines dedicated to input and output. These are grouped into three ports of eight lines each and can be configured under software control as inputs, outputs, or special control signals. They can be programmed to provide Parallel I/O with or without handshake and timing signals. All outputs can have active pullups and pulldowns, compatible with TTL loads. In addition, they may be configured as open-drain outputs. Port 1. Individual bits of Port 1 can be configured as input or output by programming Port 1 Mode register (P1M) F8H. This port is accessed by the Z-UPC program as general register 1H. It is written by specifying address 1H as the destination of any instruction used to store data in the output register. The port is read by specifying address 1H as the source of an instruction. Port 1 may be placed under handshake control by programming Port 3 Mode register (P3M) F7H. This configures Port 3 pins P3 $_3$ and P3 $_4$ as handshake control lines DAV1 and RDY1 for input handshake, or RDY1 and DAV1 for output handshake, as determined by the direction (input or output) assigned to bit 7 of Port 1. The Port 3 Mode register also has a bit that programs Port 1 for open-drain output. Port 2. Individual bits of Port 2 can be configured as inputs or outputs by programming Port 2 Mode register (P2M) F6H. This port is accessed by the Z-UPC program as general register 2H, and its functions and methods of programming are the same as those of Port 1. Port 3 pins P31 and P36 are the handshake lines DAV2 and RDY2, with the direction (input or output) determined by the state of bit 7 of the port. The Port 3 Mode register also has a bit used to program Port 2 for open-drain output. | Function | Line | Direction | Signal | |----------------------------------------------|--------------------------------------------------------------------------|------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Handshake | P3 <sub>1</sub><br>P3 <sub>3</sub><br>P3 <sub>4</sub><br>P3 <sub>6</sub> | In<br>In<br>Out<br>Out | $\begin{array}{c} \overline{\text{DAV}}_2/\text{RDY}_2 \\ \overline{\text{DAV}}_1/\overline{\text{RDY}}_1 \\ \text{RDY}_1/\overline{\text{DAV}}_1 \\ \text{RDY}_2/\overline{\text{DAV}}_2 \end{array}$ | | Z-UPC Interrupt<br>Request*<br>Counter/Timer | P3 <sub>0</sub> P3 <sub>1</sub> P3 <sub>3</sub> | In<br>In<br>In | IRQ <sub>3</sub><br>IRQ <sub>2</sub><br>IRQ <sub>1</sub> | | Counter/Timer | P3 <sub>1</sub><br>P3 <sub>6</sub> | In<br>Out | $ extstyle{T_{ extstyle{IN}}}{ extstyle{T_{ extstyle{OUT}}}}$ | | Master CPU | P3 <sub>5</sub><br>P3 <sub>2</sub><br>P3 <sub>0</sub><br>P3 <sub>7</sub> | Out<br>In<br>In<br>Out | INT<br>INTACK<br>IEI<br>IEO | | Test Mode | P3 <sub>5</sub> | Out | ĀS | \*P3<sub>0</sub>, P3<sub>1</sub>, and P3<sub>3</sub> can always be used as UPC interrupt request inputs, regardless of the configuration programmed. Table 1. Port 3 Control Functions Port 3. This port can be configured as I/O or control lines by programming the Port 3 Mode register. Port 3 is accessed as general register 3H. The directions of the eight data lines are fixed. Four lines, P3<sub>0</sub> through P3<sub>3</sub>, are inputs, and the other four, P3<sub>4</sub> through P3<sub>7</sub>, are outputs. The control functions performed by Port 3 are listed in Table 1. **Counter/Timers.** The Z-UPC contains two 8-bit programmable counter/timers, each driven by an internal 6-bit programmable prescaler. The Tl prescaler can be driven by internal or external clock sources. The TO prescaler is driven by an internal clock source. Both counter/timers operate independently of the processor instruction sequence to relieve the program from time-critical operations like event counting or elapsed-time calculation. TO Prescaler register (PREO) F5H and T1 Prescaler register (PRE1) F3H can be programmed to divide the input frequency of the source being counted by any number from 1 to 64. A Counter register (F2H or F4H) is loaded with a number from 1 to 256. The corresponding counter is decremented from this number each time the prescaler reaches end-of-count. When the count is complete, the counter issues a timer interrupt request; IRQ4 for T0 or IRQ5 for T1. Loading either counter with a number (n) results in the interruption of the Z-UPC at the nth count. The counters can be started, stopped, restarted to continue, or restarted from the initial value. They can be programmed to stop upon reaching end-of-count (Single-Pass mode) or to automatically reload the initial value and continue counting (Modulo-n Continuous mode). The counters and prescalers can be read at any time without disturbing their values or changing their counts. The clock sources for both timers can be defined as any one of the following: - Z-UPC internal clock (4 MHz maximum) divided by four. - External clock input to Counter/Timer Tl via P3<sub>1</sub> (1 MHz maximum). - Retriggerable trigger input for the Z-UPC internal clock divided by four. - Nonretriggerable trigger input for the Z-UPC internal clock divided by four. - External gate input for the Z-UPC internal clock divided by four. **Interrupts.** The Z-UPC allows six interrupts from eight different sources as follows: - Port 3 lines P3<sub>0</sub>, P3<sub>2</sub>, and P3<sub>3</sub>. - The master CPU(3). - The two counter/timers. These interrupts can be masked and globally enabled or disabled using Interrupt Mask Register (IMR) FBH. Interrupt Priority Register (IPR) F9H specifies the order of their priority. All Z-UPC interrupts are vectored. Table 2 lists the Z-UPC's interrupt sources, their types, and their vector locations in program ROM. Interrupt Request IRO<sub>0</sub> is dedicated to master CPU communications. Interrupt Requests IRQ1, IRQ2, and IRQ3 are generated on the falling transitions of external inputs P3<sub>3</sub>, P3<sub>1</sub>, and P3<sub>0</sub>. Interrupt Requests IRQ4 and IRQ5 are generated upon the timeout of the Z-UPC's two counter/timers. When an interrupt request is granted, the Z-UPC enters an interrupt machine cycle. This cycle disables all subsequent interrupts, saves the Program Counter and status flags, and branches to the program memory vector location reserved for that interrupt. This memory location and the next byte contain the address of the interrupt service routine for that particular interrupt reauest. The Z-UPC also supports polled systems. To accommodate a polled structure, any or all of the interrupt inputs can be masked and the Interrupt Request register polled to determine which of the interrupt requests needs service. Following any hardware reset operation, an EI instruction must be executed to enable the setting of any interrupt request bit in the IRQ register. Interrupts must be disabled prior to changing the content of either the IPR (F9H) or the IMR (FBH). DI is the only instruction that should be used to globally disable interrupts. | Name | Source | Vector<br>L'ocation | Comments | |------------------|--------------------------------------------------------|---------------------|----------------------------------------------| | IRQ <sub>0</sub> | EOM, XERR, LERR | 0,1 | Internal (R0 Bits 0, 1, 2) | | $IRQ_1$ | $\overline{\mathtt{DAV}}_1$ , $\mathtt{IRQ}_1$ | 2,3 | External (P3 <sub>3</sub> ) ↓ Edge Triggered | | $IRQ_2$ | $\overline{\text{DAV}}_2$ , IRQ $_2$ , T $_{ ext{IN}}$ | 4,5 | External (P3 <sub>1</sub> ) ↓ Edge Triggered | | $IRQ_3$ | IRQ3, IEI | 6,7 | External (P3 <sub>0</sub> ) ↓ Edge Triggered | | $IRQ_4$ | TO | 8,9 | Internal | | IRQ5 | T1 | 10,11 | Internal | Table 2. Interrupt Types, Sources, and Vector Locations Master CPU Register File Access. There are two ways in which the master CPU can access the Z-UPC register file: direct access and block access. Direct Access. Three Z-UPC registers—the Data Transfer Control (0H), the Master Interrupt Vector (F0H), and the Master Interrupt Control (FEH)—are mapped directly into the master CPU address space. The master CPU accesses these registers via the addresses shown in Table 3. The master CPU also has direct access to 16 registers known as the DSC (Data, Status, Command) registers. The DSC Registers are numbered 0 through F (DSC0-DSCF). These registers can be any 16 contiguous register file registers beginning on a 16-byte boundary. The base address of the DSC register group is designated by the IRP (I/O Register Pointer), which is bits $D_4$ - $D_7$ of the Data Transfer Control register (0H). Figure 7 shows how the register address is made up of the 4-bit IRP field, concatenated with the low order 4-bits of the address from the master CPU. Block Access. The master CPU may transmit or receive blocks of data via address xxx10101 (xx10101x shifted). When the master CPU accesses this address, the Z-UPC register pointed to by the Data Indirection register is Figure 7. DCS Register Addressing Scheme read or written. The Data Indirection register is incremented, and the Limit Count register is decremented, for example, when the master CPU issues a read or write to address xxx10101 while the Data Indirection register contains the value 33H. The operation causes register 33H to be read or written and the Data Indirection register to be incremented to 34H. The Limit Count register (04H) is decremented and is used to control the number of bytes to be transferred by master CPU block accesses. If the master CPU attempts a read or write to the Z-UPC after the Limit Count register reaches 0, the access is not completed, the LERR bit (D<sub>1</sub>) of the Data Transfer Control register is set (indicating a limit error), and the LERR error causes an IRQ $_0$ interrupt request. The IRP field of the Data Transfer Control register, the Data Indirection register, and the Limit Count register are not directly accessible to the master CPU and therefore must be set by the Z-UPC. This allows the Z-UPC to protect itself from master CPU errors and frees the master CPU from tracking the Z-UPC's internal data layout. | Z-UPC | Address<br>Hex | Identifier | No-Shift<br>Address | Shift<br>Address | |--------------|----------------|------------|---------------------|------------------| | 0 | 0H | DTC | xxx11000 | xx11000x | | 5 | 5H | DIND | | | | <b>@</b> 5** | @5H** | | xxx10101 | xx10101x | | 240 | FOH | VIM | xxx10000 | xx10000x | | 254 | FEH | MIC | xxx11110 | xxllll0x | | *n | | DSC0 | 00000xxx | x00000x | | n+1 | | DSCl | xxx00001 | xx00001x | | n+2 | | DSC2 | xxx00010 | xx00010x | | n+3 | | DSC3 | xxx00011 | xx00011x | | n+4 | | DSC4 | xxx00100 | xx00100x | | ,n + 5 | | DSC5 | xxx00101 | xx00101x | | n+6 | | DSC6 | xxx00110 | xx00110x | | n+7 | | DSC7 | xxx00111 | xx00111x | | n+8 | | DSC8 | xxx01000 | xx01000x | | n+9 | | DSC9 | xxx01001 | xx01001x | | n+10 | | DSCA | xxx01010 | xx01010x | | n+ll | | DSCB | xxx01011 | xx01011x | | n + 12 | | DSCC | xxx01100 | xx01100x | | n+13 | | DSCD | xxx01101 | xx01101x | | n + 14 | | DSCE | xxx01110 | xx01110x | | n+15 | | DSCF | xxx01111 | xx01111x | r = don't care Table 3. Master CPU/Z-UPC Register Map <sup>\*</sup>n is the value in the IRP x 16 <sup>\*\*</sup>Master CPU accesses the register address in Register 5 # Special Configurations There are two Protopack and two 64-pin versions of the Z-UPC. These versions are identical to the 40-pin Z-UPC with the following exceptions: - Internal ROM is totally omitted from the 64-pin development and ROM Protopack versions. - All but 36 bytes of internal ROM are omitted from the 64-pin RAM and Protopack RAM versions - The memory address and data lines are buffered and brought out to external pins or to the socket on the Protopack. - Control lines for the external memory are also provided. The 64-pin version of the Z-UPC allows the user to prototype the system in hardware with an actual Z-UPC device and to develop the code intended to be mask-programmed into the on-chip ROM of the 40-pin Z-UPC for the production system. The 64-pin or Protopack RAM/ROM versions of the Z-UPC are extremely versatile parts. Memory space can be extended to 4K bytes on the 64-pin version by using external RAM/ROM for all but 36 bytes of the Z-UPC's memory space. This memory can then be down-loaded from the master CPU using a bootstrap program stored in the 36 bytes (C-2F). Figure 8 is a memory map for the 64-pin RAM version. Figure 8. Z-UPC RAM Version Memory Map **64-Pin and Protopack Pin Functions.** Forty of the pins on the 64-pin and Protopack versions have functions identical to those of the 40-pin version. The remaining 24 pins have additional functions described below. (Figures 9 through 11 show the 64-pin and Protopack versions' pin functions and pin assignments.) **A<sub>0</sub>-A<sub>11</sub>.** Program Memory Address Lines (output). These lines are identical in all 64-pin and RAM versions in the Protopack. They are used to address 4K bytes of external Z-UPC memory. **D<sub>0</sub>-D<sub>7</sub>.** Program Data (input). Data is read in from the external memory on these lines. The RAM version also writes external memory through this bus. **IACK.** Interrupt Acknowledge (output, active High). This signal is active whenever an internal Z-UPC interrupt cycle is in process. Figure 9. Z8091/Z8092 Z-UPC Pin Functions # Special Configurations (Continued) MAS. Memory Address Strobe (output, active Low). This address strobe is pulsed once for each memory fetch to interface with quasistatic RAM. MDS. Memory Data Strobe (output, active Low). This signal is Low during an instruction fetch or memory write. versions only). This signal is High when the Z-UPC is fetching an instruction and Low when it is loading external memory. MR/W. Memory Read/Write (output RAM) **SYNC.** Instruction Sync (output, active Low). This signal is Low during the clock cycle just preceding an opcode fetch. \*SOCKET FOR 2716 EPROM (2K × 8) OR RAM Figure 10. Z8091/Z8092 Z-UPC Pin Assignments Figure 11. Z8093/Z8094 Protopack Pin Assignments # Addressing Modes The following notation is used to describe the addressing modes and instruction operations as shown in the instruction summary. R Register or working-register address Working-register address only IR Indirect-register or indirect working-register address Īr Indirect working-register address only RR Register pair or working-register pair address IRR Indirect register pair or indirect working-register pair address Indirect working-register pair only Irr X Indexed address DA Direct address RA Relative address IM Immediate # **Symbols** dst Destination location or contents Source location or contents STC CC Condition code (see list) Indirect address prefix @ SP Stack Pointer (control register FFH) PC Program Counter FLAGS Flag register (control register FCH) RP Register Pointer (control register FDH) IMR Interrupt Mask register (control register FBH) Assignment of a value is indicated by the symbol "←". For example, dst ← dst + src indicates that the source data is added to the destination data and the result is stored in the destination location. The notation "addr(n)" is used to refer to bit "n" of a given location. For example, dst (7) refers to bit 7 of the destination operand. 2017-007, 008 | Flags | | ontrol Register FCH contains the following six | Affected flags are indicated by: | | | | | | |-------|--------------------|------------------------------------------------|----------------------------------|---------------------------------------|--|--|--|--| | | flags | 3: | 0 | Cleared to zero | | | | | | | С | Carry flag | 1 | Set to one | | | | | | | <b>Z</b> Zero flag | | * | Set or cleared according to operation | | | | | | | S | Sign flag | _ | Unaffected | | | | | | | V | Overflow flag | X | Undefined | | | | | | | D | Decimal-adjust flag | | | | | | | | Condition | Value | Mnemonic | Meaning | Flags Set | |-----------|-------|----------|--------------------------------|-------------------------| | Codes | 1000 | | Always true | | | | 0111 | С | Carry | C = 1 | | | 1111 | NC | No carry | C = 0 | | | 0110 | Z | Zero | Z = 1 | | | 1110 | NZ | Not zero | Z = 0 | | | 1101 | PL | Plus | S = 0 | | | 0101 | MI | Minus | S = 1 | | | 0100 | OV | Overflow | V = 1 | | | 1100 | NOV | No overflow | V = 0 | | | 0110 | EQ | Equal | Z = 1 | | | 1110 | NE | Not equal | Z = 0 | | | 1001 | GE | Greater than or equal | (S XOR V) = 0 | | | 0001 | LT | Less than | (S XOR V) = 1 | | | 1010 | GT | Greater than | [Z OR (S XOR V)] = 0 | | | 0010 | LE | Less than or equal | [Z OR (S XOR V)] = 1 | | | 1111 | UGE | Unsigned greater than or equal | C = 0 | | | 0111 | ULT | Unsigned less than | C = 1 | | | 1011 | UGT | Unsigned greater than | (C = 0 AND Z = 0) = 1 | | | 0011 | ULE | Unsigned less than or equal | (C OR Z) = 1 | | | 0000 | | Never true | _ | н Half-carry flag # One-Byte Instructions Two-Byte Instructions Three-Byte Instructions | Maj | þ | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | A | В | С | D | E | F | |--------------------|-------|---------------------------------------|---------------------------------------|---------------------------------------------------------|--------------------------------------------------------|--------------------------------------------------------|---------------------------------------------------------|--------------------------------------------|---------------------------------------------------------|-----------------------------------------------------|-----------------------------------------------------|---------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------|--------------------------------|-------------------------|--------------------| | | 0 | 6, 5<br><b>DEC</b><br>R <sub>1</sub> | 6, 5<br><b>DEC</b><br>IR <sub>1</sub> | 6, 5<br><b>ADD</b><br>11, 12 | 6, 5<br><b>ADD</b><br>r <sub>1</sub> , Ir <sub>2</sub> | 10, 5<br><b>ADD</b><br>R <sub>2</sub> , R <sub>1</sub> | 10, 5<br><b>ADD</b><br>IR <sub>2</sub> , R <sub>1</sub> | 10, 5<br><b>ADD</b><br>R <sub>1</sub> , IM | 10, 5<br><b>ADD</b><br>IR <sub>1</sub> , IM | 6,5<br><b>LD</b><br>r <sub>1</sub> , R <sub>2</sub> | 6,5<br><b>LD</b><br>r <sub>2</sub> , R <sub>1</sub> | 12/10,5<br><b>DJNZ</b><br>r <sub>1</sub> , RA | 12/10,0<br><b>JR</b><br>cc, RA | 6,5<br><b>LD</b><br>r <sub>1</sub> , IM | 12/10,0<br><b>JP</b><br>cc, DA | 6,5<br><b>INC</b><br>r1 | | | | 1 | 6,5<br><b>RLC</b><br>R <sub>1</sub> | 6, 5<br><b>RLC</b><br>IR <sub>1</sub> | 6, 5<br><b>ADC</b><br>r <sub>1</sub> , r <sub>2</sub> | 6, 5<br><b>ADC</b><br>r <sub>1</sub> , Ir <sub>2</sub> | 10, 5<br><b>ADC</b><br>R <sub>2</sub> , R <sub>1</sub> | 10, 5<br><b>ADC</b><br>IR <sub>2</sub> , R <sub>1</sub> | 10, 5<br><b>ADC</b><br>R <sub>1</sub> , IM | 10,5<br><b>ADC</b><br>IR <sub>1</sub> , IM | | | | | | | | | | | 2 | 6, 5<br>INC<br>R <sub>1</sub> | 6, 5<br><b>INC</b><br>IR <sub>1</sub> | 6, 5<br><b>SUB</b><br>11, 12 | 6, 5<br><b>SUB</b><br>r1, Ir2 | 10, 5<br><b>SUB</b><br>R <sub>2</sub> , R <sub>1</sub> | 10, 5<br><b>SUB</b><br>IR <sub>2</sub> , R <sub>1</sub> | 10, 5<br><b>SUB</b><br>R <sub>1</sub> , IM | 10,5<br><b>SUB</b><br>IR <sub>1</sub> , IM | | | | | | | | | | | 3 | 8,0<br>JP<br>IRR <sub>1</sub> | 6, 1<br><b>SRP</b><br>IM | 6, 5<br><b>SBC</b><br>r <sub>1</sub> , r <sub>2</sub> | 6, 5<br>SBC<br>r <sub>1</sub> , Ir <sub>2</sub> | 10,5<br><b>SBC</b><br>R <sub>2</sub> , R <sub>1</sub> | 10, 5<br><b>SBC</b><br>IR <sub>2</sub> , R <sub>1</sub> | 10, 5<br><b>SBC</b><br>R <sub>1</sub> , IM | 10, 5<br><b>SBC</b><br>IR <sub>1</sub> , IM | | | | | | | | | | | 4 | 8,5<br><b>DA</b><br>R <sub>1</sub> | 8,5<br><b>DA</b><br>IR <sub>1</sub> | 6, 5<br>OR<br>r1, r2 | 6, 5<br>OR<br>r <sub>1</sub> , Ir <sub>2</sub> | 10,5<br><b>OR</b><br>R <sub>2</sub> , R <sub>1</sub> | 10, 5<br><b>OR</b><br>IR <sub>2</sub> , R <sub>1</sub> | 10,5<br><b>OR</b><br>R <sub>1</sub> ,IM | 10, 5<br><b>OR</b><br>IR <sub>1</sub> , IM | | | | | | | | | | | 5 | 10, 5<br><b>POP</b><br>R <sub>1</sub> | 10,5<br><b>POP</b><br>IR <sub>1</sub> | 6, 5<br><b>AND</b><br>r <sub>1</sub> , r <sub>2</sub> | 6, 5<br><b>AND</b><br>r <sub>1</sub> , Ir <sub>2</sub> | 10,5<br><b>AND</b><br>R <sub>2</sub> , R <sub>1</sub> | 10, 5<br><b>AND</b><br>IR <sub>2</sub> , R <sub>1</sub> | 10,5<br><b>AND</b><br>R <sub>1</sub> ,IM | 10,5<br>AND<br>IR <sub>1</sub> , IM | | | | | | | | | | Нех) | 6 | 6,5<br><b>COM</b><br>R <sub>1</sub> | 6,5<br><b>COM</b><br>IR <sub>1</sub> | 6, 5<br><b>TCM</b><br>r <sub>1</sub> , r <sub>2</sub> | 6, 5<br><b>TCM</b><br>r <sub>1</sub> , Ir <sub>2</sub> | 10,5<br>TCM<br>R <sub>2</sub> , R <sub>1</sub> | 10,5<br><b>TCM</b><br>IR <sub>2</sub> , R <sub>1</sub> | 10,5<br><b>TCM</b><br>R <sub>1</sub> ,IM | 10,5<br><b>TCM</b><br>IR <sub>1</sub> ,IM | | | | | | | | | | Upper Nibble (Hex) | 7 | 10/12, 1<br>PUSH<br>R <sub>2</sub> | 12/14, 1<br>PUSH<br>IR <sub>2</sub> | 6,5<br><b>TM</b><br>r <sub>1</sub> , r <sub>2</sub> | 6, 5<br><b>TM</b><br>r <sub>1</sub> , Ir <sub>2</sub> | 10, 5<br><b>TM</b><br>R <sub>2</sub> , R <sub>1</sub> | 10,5<br><b>TM</b><br>IR <sub>2</sub> ,R <sub>1</sub> | 10,5<br><b>TM</b><br>R <sub>1</sub> ,IM | 10, 5<br><b>TM</b><br>IR 1, IM | | | | | | | | | | Upper | 8 | 10,5<br>DECW<br>RR <sub>1</sub> | 10,5<br>DECW<br>IR <sub>1</sub> | 12,0<br><b>LDE</b><br>r <sub>1</sub> ,Irr <sub>2</sub> | 18,0<br>LDEI<br>Ir1,Irr2 | | | | | | | | | | | | 6, 1<br><b>DI</b> | | | 9 | 6,5<br><b>RL</b><br>R <sub>1</sub> | 6,5<br><b>RL</b><br>IR <sub>1</sub> | 12,0<br><b>LDE</b><br>r <sub>2</sub> , Irr <sub>1</sub> | 18,0<br>LDEI<br>Ir2,Irr1 | | | | | | | | | | | | 6, 1<br><b>EI</b> | | | A | 10,5<br>INCW<br>RR <sub>1</sub> | 10,5<br>INCW<br>IR <sub>1</sub> | 6,5<br><b>CP</b><br>r <sub>1</sub> , r <sub>2</sub> | 6,5<br><b>CP</b><br>r1, Ir2 | 10,5<br><b>CP</b><br>R <sub>2</sub> ,R <sub>1</sub> | 10,5<br><b>CP</b><br>IR <sub>2</sub> ,R <sub>1</sub> | 10,5<br><b>CP</b><br>R <sub>1</sub> , IM | 10,5<br><b>CP</b><br>IR <sub>1</sub> ,IM | | | | | | | | 14,0<br>RET | | | В | 6,5<br><b>CLR</b><br>R <sub>1</sub> | 6,5<br>CLR<br>IR <sub>1</sub> | 6, 5<br><b>XOR</b><br>r <sub>1</sub> , r <sub>2</sub> | 6,5<br><b>XOR</b><br>r1, Ir2 | 10, 5<br><b>XOR</b><br>R <sub>2</sub> , R <sub>1</sub> | 10, 5<br><b>XOR</b><br>IR <sub>2</sub> , R <sub>1</sub> | 10,5<br><b>XOR</b><br>R <sub>1</sub> , IM | 10,5<br><b>XOR</b><br>IR <sub>1</sub> ,IM | | | | A COMPANY OF THE PROPERTY T | | | | 16,0<br>IRET | | | С | 6,5<br>RRC<br>R <sub>1</sub> | 6,5<br>RRC<br>IR <sub>1</sub> | 12,0<br><b>LDC</b><br>r <sub>1</sub> , Irr <sub>2</sub> | 18,0<br>LDCI<br>Ir1,Irr2 | | | | 10,5<br><b>LD</b><br>r <sub>1</sub> , x, R <sub>2</sub> | | | | | | | | 6,5<br><b>RCF</b> | | | D | 6,5<br><b>SRA</b><br>R <sub>1</sub> | 6,5<br><b>SRA</b><br>IR <sub>1</sub> | 12,0<br><b>LDC</b><br>r <sub>2</sub> , Irr <sub>1</sub> | 18,0<br>LDCI<br>Ir2, Irr1 | 20,0<br>CALL*<br>IRR1 | | 20, 0<br>CALL<br>DA | 10,5<br><b>LD</b><br>12, x, R <sub>1</sub> | | | | | | | | 6, 5<br><b>SCF</b> | | | E | 6,5<br><b>RR</b><br>R <sub>1</sub> | 6,5<br><b>RR</b><br>IR <sub>1</sub> | | 6,5<br><b>LD</b><br>r <sub>1</sub> ,Ir <sub>2</sub> | 10, 5<br><b>LD</b><br>R <sub>2</sub> , R <sub>1</sub> | 10,5<br><b>LD</b><br>IR <sub>2</sub> ,R <sub>1</sub> | 10,5<br><b>LD</b><br>R <sub>1</sub> ,IM | 10,5<br><b>LD</b><br>IR <sub>1</sub> , IM | | | | | | | | 6,5<br><b>CCF</b> | | | F | 8,5<br><b>SWAP</b><br>R <sub>1</sub> | 8,5<br>SWAP<br>IR <sub>1</sub> | | 6, 5<br><b>LD</b><br>Ir1, r2 | | 10,5<br><b>LD</b><br>R <sub>2</sub> , IR <sub>1</sub> | | | \ \ | | \ | <b>\</b> | <b>\</b> | | <b>\</b> | 6, 0<br><b>NOP</b> | | | s per | <u> </u> | 2 | 2 | | | | | | | | | | | 3 | _ | 1 | | | | | | | Lower<br>Opcod<br>Nibble | e | | | | | | | | | | | | | | | | | cution<br>Cycles | <b>4</b> | | eline<br>cles | | | | | Legend:<br>R = 8-Bit | | | | | | | | | | Upper<br>Opcode -<br>Nibble | <b>→</b> A | 10, 5<br><b>CP</b><br>R <sub>2</sub> , R <sub>1</sub> | 1 | nemonic | Į | | | | r = 4-Bit<br>R <sub>1</sub> or r <sub>1</sub> =<br>R <sub>2</sub> or r <sub>2</sub> = | = Dst Add | | | | | | | | | | | <del>/</del> | * | | | | | | Sequen | :e: | | C 1 C | <b>.</b> | | First Operand Second Operand Opcode, First Operand, Second Operand Note: The blank areas are not defined. $<sup>{}^{\</sup>star}2\text{-byte}$ instruction, fetch cycle appears as a 3-byte instruction | Instruction | Instruction | Addr | Mode | Opcode | Flags Affected | | | | | | |-------------|------------------------------------------------------------------------------------------------------|------------------------|------------------------|----------------------------|----------------|---|---|---|---|---| | Summary | and Operation | dst | src | Byte<br>(Hex) | _ | ÷ | | _ | D | - | | | ADC dst,src<br>dst - dst + src + C | | te l) | 10 | * | * | * | * | 0 | * | | | ADD dst,src<br>dst - dst + src | (No | te l) | 0□ | * | * | * | * | 0 | * | | | AND dst,src<br>dst dst AND src | (No | te 1) | 5□ | _ | * | * | 0 | _ | - | | | CALL dst<br>SP - SP - 2<br>@SP - PC; PC - c | DA<br>IRR<br>dst | | D6<br>D4 | - | - | _ | - | - | - | | | CCF<br>C - NOT C | | | EF | * | - | _ | - | - | - | | | CLR dst<br>dst - 0 | R<br>IR | | B0<br>B1 | - | - | - | - | - | - | | | COM dst<br>dst - NOT dst | R<br>IR | | 60<br>61 | _ | * | * | 0 | - | - | | | CP dst,src<br>dst - src | (No | te l) | A | * | * | * | * | - | - | | | <b>DA</b> dst<br>dst - DA dst | R<br>IR | | 40<br>41 | * | * | * | Х | _ | - | | | DEC dst<br>dst dst - 1 | R<br>IR | | 00<br>01 | - | * | * | * | _ | _ | | | <b>DECW</b> dst dst ← dst - 1 | RR<br>IR | | 80<br>81 | _ | * | * | * | _ | _ | | | <b>DI</b> IMR (7) + 0 | | | 8F | _ | | _ | _ | | _ | | | DINZ r,dst<br>$r \leftarrow r - 1$<br>if $r \neq 0$<br>PC $\leftarrow$ PC + dst<br>Range: +127, -128 | RA | | rA<br>r=0-F | - | _ | _ | _ | _ | _ | | | EI IMR (7) - 1 | | | 9F | _ | _ | _ | _ | _ | _ | | | INC dst<br>dst ← dst + l | r | | rE<br>r=0-F | - | * | * | * | _ | - | | | | R<br>IR | | 20<br>21 | | | | | | | | | INCW dst<br>dst dst + 1 | RR<br>IR | | A0<br>A1 | - | * | * | * | _ | - | | | IRET<br>FLAGS ← @ SP; SP<br>PC ← @ SP; SP ← S | | | BF<br>) ← l | * | * | * | * | * | * | | | IP cc,dst if cc is true PC - dst | DA<br>IRR | | cD<br>c=0-F<br>30 | | | _ | _ | | _ | | | JR cc,dst<br>if cc is true,<br>PC - PC + dst<br>Range: +127,-128 | RA | | cB<br>c=0-F | | | - | - | | - | | | LD dst,src<br>dst - src | r<br>r<br>R | Im<br>R<br>r | rC<br>r8<br>r9<br>r=0-F | | - | | - | | - | | | | r<br>X<br>r<br>Ir<br>R | X<br>r<br>Ir<br>r<br>R | C7<br>D7<br>E3<br>F3<br>E4 | | | | | | | | | | R<br>R<br>IR<br>IR | IR<br>Im<br>Im<br>R | E5<br>E6<br>E7<br>F5 | | | | | | | | | LDC dst,src<br>dst - src | r<br>Irr | Irr<br>r | C2<br>D2 | | | - | - | - | - | | | I DOI 1 | | | C2 | _ | _ | | | | _ | | Instruction | Āddr | Mode | Opcode<br>Byte | Fl | αg | s A | ffe | ct | ed | |----------------------------------------------------------|----------------|-----------|----------------|----|----|-----|-----|----|----| | and Operation | dst | STC | (Hex) | С | Z | S | ٧ | D | H | | LDE dst,src<br>dst - src | r<br>Irr | Irr<br>r | 82<br>92 | - | - | - | - | - | - | | <b>LDEI</b> dst,src<br>dst ← src<br>r ← r + 1; rr ← rr + | Ir<br>Irr<br>1 | Irr<br>Ir | 83<br>93 | _ | _ | - | _ | - | - | | NOP | | | FF | _ | _ | _ | - | - | _ | | OR dst,src<br>dst dst OR src | (Not | e 1) | 4□ | - | * | * | 0 | - | _ | | <b>POP</b> dst<br>dst ← @ SP<br>SP ← SP + 1 | R<br>IR | | 50<br>51 | - | - | - | - | - | - | | PUSH src<br>SP - SP - 1; @ SP - | - src | R<br>IR | 70<br>71 | - | - | - | - | - | - | | <b>RCF</b><br>C - 0 | | | CF | 0 | - | - | - | - | - | | RET<br>PC - @ SP; SP - S | P + 2 | | AF | - | - | - | - | - | _ | | RL dst | ] R<br>IR | | 90<br>91 | * | * | * | * | - | - | | RLC dst | ] R<br>IR | | 10<br>11 | * | * | * | * | - | - | | RR dst | ] R<br>IR | | E0<br>E1 | * | * | * | * | - | - | | RRC dst | R<br>IR | | C0<br>C1 | * | * | * | * | - | _ | | SBC dst,src<br>dst - dst - src - C | (Note | el) | 3□ | * | * | * | * | 1 | * | | <b>SCF</b><br>C - 1 | | | DF | 1 | - | - | - | - | - | | SRA dst | □ R<br>IR | | D0<br>D1 | * | * | * | 0 | _ | _ | | SRP src<br>RP ← src | | Im | 31 | _ | - | - | _ | - | - | | SUB dst,src<br>dst — dst – src | (Note | e 1) | 2□ | * | * | * | * | 1 | * | | SWAP dst , 4/3 o | I R<br>IR | | FO<br>F1 | Х | * | * | Х | - | - | | TCM dst,src<br>(NOT dst) AND src | (Note | e l) | 6□ | _ | * | * | 0 | - | - | | TM dst, src<br>dst AND src | (Note | e l) | 7□ | - | * | * | 0 | - | - | | <b>XOR</b> dst,src<br>dst ← dst XOR src | (Note | e l) | В□ | _ | * | * | 0 | - | _ | # Note 1 These instructions have an identical set of addressing modes, which are encoded for brevity. The first opcode nibble is found in the instruction set table above. The second nibble is expressed symbolically by a $\square$ in this table, and its value is found in the following table to the left of the applicable addressing mode pair. For example, to determine the opcode of an ADC For example, to determine the opcode of an ADC instruction using the addressing modes r (destination) and Ir (source) is 13. | Addr | Mode | Lower | | |------|------|---------------|--| | dst | src | Opcode Nibble | | | r | r | 2 | | | r | Ir | 3 | | | R | R | 4 | | | R | IR | 5 | | | R | IM | 6 | | | IR | IM | 7 | | LDCI dst,src $r \leftarrow r + 1$ ; $rr \leftarrow rr + 1$ dst ← src C3 D3 Ir Irr Irr # Registers # R248 P1M Port 1 Mode Register Z-UPC register address (Hex): F8 # R246 P2M Port 2 Mode Register Z-UPC register address (Hex): F6 # R247 P3M Port 3 Mode Register Z-UPC register address (Hex): F7 Figure 12. Port Mode Registers # R251 IMR Interrupt Mask Register Z-UPC register address (Hex): FB # R250 IRQ Interrupt Request Register Z-UPC register address (Hex): FA # R249 IPR Interrupt Priority Register Z-UPC register address (Hex): F9 (Write Only) Figure 13. Interrupt Control Registers ### R254 MIC # Master CPU Interrupt Control Register Z-UPC register address (Hex): FE # R240 MIV Master CPU Interrupt Vector Register Z-UPC register address (Hex): F0 Figure 14. Master CPU Interrupt Registers INDIRECTION ADDRESS ### Registers R252 FLAGS **R253 RP** (Continued) Flag Register Register Pointer Z-UPC register address (Hex): FC Z-UPC register address (Hex): FD D<sub>7</sub> D<sub>6</sub> D<sub>5</sub> D<sub>4</sub> D<sub>3</sub> D<sub>2</sub> D<sub>12</sub> D<sub>0</sub> D7 D6 D5 D4 D3 D2 D1 D0 - HEED ELAG E1 REGISTER POINTER DON'T CARE USER FLAG F2 (r4-r7) HALF-CARRY FLAG DECIMAL ADJUST FLAG **R255 SP** OVERFLOW FLAG Stack Pointer SIGN FLAG Z-UPC register address (Hex): FF ZERO FLAG CARRY FLAG D<sub>7</sub> D<sub>6</sub> D<sub>5</sub> D<sub>4</sub> D<sub>3</sub> D<sub>2</sub> D<sub>1</sub> D<sub>0</sub> STACK POINTER Figure 15. Z-UPC Control Registers R0 DTC R4 LC **Data Transfer Control Register** Limit Count Register Z-UPC register address (Hex): 00 Z-UPC register address (Hex): 04 D<sub>7</sub> D<sub>6</sub> D<sub>5</sub> D<sub>4</sub> D<sub>3</sub> D<sub>2</sub> D<sub>1</sub> D<sub>0</sub> D<sub>7</sub> D<sub>6</sub> D<sub>5</sub> D<sub>4</sub> D<sub>3</sub> D<sub>2</sub> D<sub>1</sub> D<sub>0</sub> LIMIT COUNT VALUE (EOM) 0 (RANGE 0-255 DECIMAL 00-FF HEX) END OF MESSAGE (LERR) NO LIMIT ERROR LIMIT ERROR **R5 DIND** (XERR) NO TRANSFER ERROR TRANSFER ERROR Data Indirection Register (EDX) DISABLE DATA TRANSFER ENABLE DATA TRANSFER Z-UPC register address (Hex): 05 (IRP) D<sub>7</sub> D<sub>6</sub> D<sub>5</sub> D<sub>4</sub> D<sub>3</sub> D<sub>2</sub> D<sub>1</sub> D<sub>0</sub> 1 I/O REGISTER POINTER Figure 16. Master CPU-Z-UPC Data Transfer Registers Figure 17. Z-UPC Counter/Timer Registers 2017-012, 013, 014 | Control Register | D <sub>7</sub> | D <sub>6</sub> | D <sub>5</sub> | D <sub>4</sub> | D <sub>3</sub> | D <sub>2</sub> | Dı | D <sub>0</sub> | Comments | |-------------------------------------------------------------|----------------|----------------|----------------|----------------|----------------|----------------|----|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 00 <sub>H</sub><br>Data Transfer Control Register | Х | Х | Х | Х | 0 | 0 | 0 | 0 | Disable data transfer from master CPU | | 04 <sub>H</sub><br>Limit Count Register | | | | Not De | fined | | | | | | 05 <sub>H</sub><br>lata Indirection Register | | | | Not De | fined | | | | | | F0 <sub>H</sub><br>nterrupt Vector Register | | | | Not De | fined | | | | | | Fl <sub>H</sub><br>Timer Mode | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Stops T0 and T1 | | F2 <sub>H</sub><br>T0 Register | | | | Not De | fined | | | | | | F3 <sub>H</sub><br>T0 Prescaler | Х | Х | Х | Х | Х | Х | 0 | 0 | Single-Pass mode | | F4 <sub>H</sub><br>T1 Register | | | | Not De | fined | | | | | | F5 <sub>H</sub><br>T1 Prescaler | Х | Х | Х | Х | Х | Х | 0 | 0 | Single-Pass mode<br>External clock source | | F6 <sub>H</sub><br>Port 2 Mode | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | Port 2 lines defined as inputs | | F7 <sub>H</sub><br>Port 3 Mode | 0 | 0 | 0 | 0 | Х | 1 | 0 | 0 | Port 1, 2 open drain;<br>P3 <sub>5</sub> = INT; P3 <sub>0</sub> , P3 <sub>1</sub> , P3 <sub>2</sub><br>P3 <sub>3</sub> defined as input; P3 <sub>4</sub> ,<br>P3 <sub>6</sub> , P3 <sub>7</sub> defined as outpu | | F8 <sub>H</sub><br>Port 1 Mode | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | Port 1 lines defined as inputs | | F9 <sub>H</sub><br>Interrupt Priority | | | | Not De | fined | | | | | | FA <sub>H</sub><br>Interrupt Request | Х | Х | 0 | 0 | 0 | 0 | 0 | 0 | Reset Interrupt Request | | FB <sub>H</sub><br>Interrupt Mask | 0 | Х | Х | Х | Х | Х | Х | Х | Interrupts disabled | | FC <sub>H</sub><br>Flag Register | | | | Not De | fined | | | | | | FD <sub>H</sub><br>Register Pointer | | | | Not De | fined | | | | | | FE <sub>H</sub><br>Master CPU Interrupt<br>Control Register | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Master CPU interrupt dis-<br>abled; wait enable when<br>write; lower chain enable | | FF <sub>H</sub><br>Stack Pointer | | | | Not De | fined | | | | | NOTE: X means not defined. Table 4. Control Register Reset Conditions Registers (Continued) | Absolute<br>Maximum<br>Ratings | Voltages on all pins (except with respect to GND | 22. | Stresses greate<br>mum Ratings may<br>This is a stress ra | |--------------------------------|--------------------------------------------------|---------------------|-----------------------------------------------------------| | | Operating Ambient TemperatureSee O | rdering Information | condition above t<br>of these specifica | | | Storage Temperature | -65°C to +150°C | maximum rating | er than those listed under Absolute Maxiay cause permanent damage to the device. ating only; operation of the device at any those indicated in the operational sections ations is not implied. Exposure to absolute conditions for extended periods may affect device reliability. # Standard Test Conditions The characteristics below apply for the following standard test conditions, unless otherwise noted. All voltages are referenced to GND. Positive current flows into the reference pin. Standard conditions are as follows: $\blacksquare$ +4.75 V $\leq$ V<sub>CC</sub> $\leq$ +5.25 V $$\blacksquare$$ $V_{SS} = GND = 0 V$ $$\blacksquare$$ 0°C $\leq$ T<sub>A</sub> $\leq$ +70°C <sup>\*</sup>See Ordering Information section for package temperature range and product number. Figure 18. Test Load 1 Figure 19. Test Load 2 | DC<br>Charac-<br>teristics | Sym | bol Parameter | Min | Max | Unit | Condition | Notes | |----------------------------|----------------------------|--------------------------------|------|----------|------|----------------------------------------|-------| | | $v_{ch}$ | Clock Input High Voltage | 2.4 | $V_{CC}$ | V | | | | | $\mathtt{V}_{\mathtt{CL}}$ | Clock Input Low Voltage | -0.3 | 0.8 | V | | | | | $V_{IH}$ | Input High Voltage | 2.0 | $V_{CC}$ | V | | | | | $V_{\mathrm{IL}}$ | Input Low Voltage | -0.3 | 0.8 | V | | | | | $V_{OH}$ | Output High Voltage | 2.4 | | V | $I_{OH} = -250 \mu\text{A}$ | 1 | | | $v_{ol}$ | Output Low Voltage | | 0.4 | V | $I_{OL} = +2.0 \text{ mA}$ | 1 | | | ${ m I}_{ m IL}$ | Input Leakage | -10 | 10 | μΑ | $0 \le V_{\rm IN} \le +5.25 \text{ V}$ | | | | $I_{OL}$ | Output Leakage | -10 | 10 | μΑ | $0 \le V_{\rm IN} \le +5.25 \text{ V}$ | | | | $I_{CC}^{\star}$ | V <sub>CC</sub> Supply Current | | 180 | mA | | | <sup>1</sup> For A<sub>0</sub>-A<sub>11</sub> and D<sub>0</sub>-D<sub>7</sub>, $\overline{\text{MDS}}$ , $\overline{\text{SYNC}}$ , $\overline{\text{MAS}}$ , and $MR/\overline{W}/IACK$ on the 64-pin versions $I_{OH}=100~\mu\text{A}$ and $I_{OL}=1~0~\text{mA}$ <sup>\*</sup>For Protopack versions $I_{\mbox{CC}}$ = 180 $\mu\mbox{A}$ plus the current for the memory IC used Master CPU Interface Timing Interrupt Acknowledge Timing 328 2017-015, 016 | | | 4 MHz | | | 61 | | | |-----|-------------|---------------------------------------------------------------------------|----------------|------|------------------|----------|---------------------------| | No. | Symbol | Parameter | Min | Мах | Min | Мах | Notes*† | | l | TrC | Clock Rise Time | | 20 | | 15 | | | 2 | TwCh | Clock High Width | 105 | 1855 | 70 | 1855 | | | 3 | TfC | Clock Fall Time | | 20 | | 10 | | | 4 | TwCl | Clock Low Width | 105 | 1855 | 70 | 1855 | | | 5- | -TpC | Clock Period | - 250 | 2000 | 165 <del>-</del> | — 2000 — | | | 6 | TsCS(AS) | $\overline{\text{CS}}$ to $\overline{\text{AS}}$ † Setup Time | 0 | | 0 | | 1 | | 7 | ThCS(AS) | $\overline{\text{CS}}$ to $\overline{\text{AS}}$ † Hold Time | 60 | | 40 | | 1 | | 8 | TsĀ(ĀS) | Address to $\overline{\rm AS}$ † Setup Time | 30 | | 10 | | 1 | | 9 | ThA(AS) | Address to <del>AS</del> ↑ Hold T∎me | 50 | | 30 | | 1 | | 10- | TwAS | — AS Low Width ———— | <del></del> 70 | | 50 | | | | 11 | TdDS(DR) | $\overline{\rm DS}$ ↑ to Read Data Not Valid | 0 | | 0 | | | | 12 | TdDS(DRz) | DS † to Read Data Float Delay | | 70 | | 45 | 2 | | 13 | TdAS(DS) | $\overline{\mathrm{AS}}$ ↑ to $\overline{\mathrm{DS}}$ ↓ Delay | 60 | 2095 | 40 | 2095 | | | 14 | TdDS(AS) | $\overline{\mathrm{DS}}$ ↑ to $\overline{\mathrm{AS}}$ ↓ Delay | 50 | | 35 | | | | 15- | -ThDW(DS) | — Write Data to <del>DS</del> ↑ Hold Time——— | <del></del> 30 | | 20 — | | <del></del> 1 <del></del> | | 16 | TdDS(DR) | $\overline{\rm DS}$ ↓ to Read Data Valid Delay | | | | | 3 | | 17 | TdAz(DS) | Address Float to $\overline{\text{DS}}$ Delay | 0 | | 0 | | | | 18 | TwDS | DS Low Width | 390 | | 250 | | | | 19 | TsRWR(DS) | $R/\overline{W}$ (Read) to $\overline{DS} \downarrow Setup Time$ | 100 | | 80 | | | | 20- | TsRWW(DS)— | — R/W̄ (Write) to D̄S ↓ Setup Time ——— | <del> 0</del> | | 0 <del>-</del> | | | | 21 | TsDW(DSf) | Write Data to <del>DS</del> ↓ Setup Time | 30 | | 20 | | | | 22 | TdAS(W) | AS ↑ to WAIT ↓ Valid Delay | | 195 | | 160 | | | 23 | ThRW(DS) | $R/\overline{W}$ to $\overline{DS}$ † Hold Time | 60 | | 40 | | | | 24 | TsDR(W) | Read Data Valid to WAIT † | 0 | | 0 | | | | 25 | TsIA(AS) | INTACK to AS ↑ Setup Time | 0 | | 0 | | | | 26 | ThIA(AS) | INTACK to AS † Hold Time | 250 | | 250 | | | | 27 | TdAS(DSA) | ĀS↑ to DS↓ (/Acknowledge) Delay | 940 | | 200 | | | | 28 | TdDSA(DR) | DS ↓ (Acknowledge) to Read Data Valid Delay | | 360 | | 180 | | | 29 | TwDSA | <del>DS</del> ↓ (Acknowledge) Low Width | 475 | | 250 | | | | 30- | TdAS(IEO) | — $\overline{\rm AS}$ † to IEO Delay ———————————————————————————————————— | | 290 | | 250 | | | 31 | TdIEIf(IEO) | IEI to IEO Delay | | 120 | | 100 | | | 32 | TsIEI(DSA) | IEI to DS ↓ (Acknowledge) Setup Time | 150 | | 120 | | | | 33 | TdDS(INT) | <del>DS</del> ↓ to <del>INT</del> Delay | | 500 | | 500 | | 100 # NOTES 34 ThIEI(DS) IEI to DS † Hold Time 100 Parameter does not apply to Interrupt Acknowledge transactions The maximum value for TdAS(DS) does not apply to Interrupt Acknowledge transactions This parameter is dependent on the state of UPC at the time of master CPU access <sup>\*</sup> Timings are preliminary and subject change † Units in nanoseconds (ns) Units in nanoseconds (ns) The jiming characteristics given reference 2 0 V as High and 0 8 V as Low. All output ac parameters use test load 1 # Handshake Timing Input Handshake Output Handshake # Reset Timing # RAM Version Program Memory Timing 330 2017-017, 018, 019 | No. Symbol Parcemeter Min Max Min Max Notes*† 1 TsDI(DA) Data In Hold Time 0 0 0 0 1 0 0 0 1 0 0 0 1 0 1 0 1 1 1 1 1 1 1 1 1 1 1 1 1 2 1 1 1 2 1 1 1 2 1 1 1 2 2 1 1 1 2 2 3 1 2 1 1 1 2 2 1 1 1 2 2 1 1 2 3 1 2 2 1 2 1 2 1 2 1 2 1 2 1 2 1 2 1 2 1 2 1 2 1 2 3 1 | | | | 4 1 | MHz | 61 | /IHz | | |------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|---------------|----------------------------------------------------------------------------------|-----|-------------|----------------|------|--------------| | 2 ThDA(DI) | No. | Symbol | Parameter | Min | Max | Min | Мах | Notes*† | | TwDA | 1 | TsDI(DA) | Data In Setup Time | 0 | | 0 | | | | TdDAL(RY) Data Available Low To Ready 20 175 20 175 1,2 | 2 | ThDA(DI) | Data In Hold Time | 230 | | 230 | | | | Delay Time | 3 | TwDA | Data Available Width | 175 | | 175 | | 1,2 | | Delay Time | 4 | TdDAL(RY) | | | 175 | | 175 | | | Delay Time TdRY(DA) Ready To Data Available Delay Time 0 205 0 205 2 | 5 | TdDAH(RY) | | 0 | 150 | 0 | 150 | | | 1 TdRDQ(WR) Delay from DS 1 to AS 1 for No Reset 40 35 2 TdWRQ(RD) Delay from AS 1 to DS 1 for No Reset 50 35 3 TwRES Minmum Width of AS and DS both Low for Reset 250 250 4 1 TwMAS Memory Address Strobe Width 60 55 5 2 TdA(MAS) Address Valid to Memory Address 30 30 30 5 3 TdMR/W(MAS) Memory Read/Write to Memory Address 30 30 5 3 TdMR/W(MAS) Memory Bead/Write to Memory Address 60 60 60 4 TdMDS(A) Memory Data Strobe 1 to Address 60 60 60 5—TDMDS(MR/W)—Memory Data Strobe 1 to Memory—Read/Write Not Valid Delay 80 75 75 6 Tw(MDS) Memory Data Strobe Width (Write Case) 160 110 6 7 TdDO(MDS) Data Out Valid to Memory Data Strobe I to Data Out Change Delay 30 30 5 8 TdMDS(DO) Memory Data Strobe Vidth (Read Ca | 6 | TdDO(DA) | | 50 | | 50 | | 2 | | 2 TdWRQ(RD) Delay from \overline{AS} \tau \text{ to \overline{DS} \tau for No Reset} 50 35 35 35 35 35 35 35 | 7 | TdRY(DA) | Ready To Data Available Delay Time | 0 | 205 | 0 | 205 | 2 | | TwRES | 1 | TdRDQ(WR) | Delay from $\overline{\rm DS}$ † to $\overline{\rm AS}$ † for No Reset | 40 | | 35 | | | | TwMAS | 2 | TdWRQ(RD) | Delay from $\overline{\mathrm{AS}}$ † to $\overline{\mathrm{DS}}$ ↓ for No Reset | 50 | | 35 | | | | 2 TdA(MAS) Address Valid to Memory Address Strobe † Delay 30 30 5 3 TdMR/W(MAS) Memory Read/Write to Memory Address Strobe † Delay 30 30 30 5 4 TdMDS(A) Memory Data Strobe † to Address Change Delay 60 60 60 60 60 5—TDMDS(MR/W)—Memory Data Strobe † to Memory Memory Data Strobe † to Memory Data Strobe Width (Write Case) 160 110 6 6 7 TdDO(MDS) 30 30 5 5 5 5 7 TdDO(MDS) Data Out Valid to Memory Data Strobe † Delay 30 30 30 5 5 5 6 7 TdMDS(DO) Memory Data Strobe † to Data Out Data Out Data Out Data Out Change Delay 30 30 30 5 5 5 6 6 10 10 6 6 10 10 10 6 10 10 10 6 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 10 | 3 | Twres | | 250 | | 250 | | 4 | | Strobe Delay 3 TdMR/W(MAS) Memory Read/Write to Memory Address 30 30 5 | 1 | TwMAS | Memory Address Strobe Width | 60 | | 55 | | 5 | | Strobe Delay TdMDS(A) Memory Data Strobe to Address 60 60 Change Delay 5 TDMDS(MR/W) Memory Data Strobe to Memory 80 75 Read/Write Not Valid Delay 6 Tw(MDS) Memory Data Strobe Width (Write Case) 160 110 6 6 7 TdDO(MDS) Data Out Valid to Memory Data Strobe Delay 30 30 5 | 2 | TdA(MAS) | | 30 | | 30 | | 5 | | Change Delay 5—TDMDS(MR/W)—Memory Data Strobe † to Memory———————————————————————————————————— | 3 | TdMR/W(MAS) | | 30 | | 30 | | 5 | | Read/Write Not Valid Delay 6 Tw(MDS) Memory Data Strobe Width (Write Case) 160 110 6 6 7 TdDO(MDS) Data Out Valid to Memory Data Strobe Delay 30 30 5 8 TdMDS(DO) Memory Data Strobe to Data Out 30 30 5 5 Change Delay 9 Tw(MDS) Memory Data Strobe to Data In Valid Delay 230 230 6 10 TdMDS(DI) Memory Data Strobe to Data In Valid Delay 160 130 7 7 11 TdMAS(DI) Memory Address Strobe to Data In Valid Delay 180 220 7 7 12 ThMDS(DI) Memory Data Strobe to Data In Hold Time 0 0 0 13 TwSY Instruction Sync Out Width 160 100 14 TdSY(MDS) Instruction Sync Out to Memory Data 200 160 Strobe Delay 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 160 1 | 4 | TdMDS(A) | | 60 | | 60 | | | | 7 TdDO(MDS) Data Out Valid to Memory Data Strobe Delay 30 30 5 8 TdMDS(DO) Memory Data Strobe to Data Out Change Delay 30 30 5 9 Tw(MDS) Memory Data Strobe Width (Read Case) 230 230 6 10—TdMDS(DI) Memory Data Strobe to Data In Valid Delay 160 130 7— 11 TdMAS(DI) Memory Address Strobe to Data In Valid Delay 180 220 7 12 ThMDS(DI) Memory Data Strobe to Data In Hold Time 0 0 0 13 TwSY Instruction Sync Out Width 160 100 14 TdSY(MDS) Instruction Sync Out to Memory Data 200 160 | 5— | -TDMDS(MR/W)- | | 80 | | ———75 <b>—</b> | | | | 8 TdMDS(DO) Memory Data Strobe † to Data Out 30 30 5 Change Delay 9 Tw(MDS) Memory Data Strobe Width (Read Case) 230 230 6 10—TdMDS(DI) — Memory Data Strobe ‡ to Data In Valid Delay 160 130 7— 11 TdMAS(DI) Memory Address Strobe † to Data In Valid Delay 180 220 7 Valid Delay 12 ThMDS(DI) Memory Data Strobe † to Data In Hold Time 0 0 13 TwSY Instruction Sync Out Width 160 100 14 TdSY(MDS) Instruction Sync Out to Memory Data 200 160 Strobe Delay | 6 | Tw(MDS) | Memory Data Strobe Width (Write Case) | 160 | | 110 | | 6 | | Change Delay 9 Tw(MDS) Memory Data Strobe Width (Read Case) 230 230 6 10—TdMDS(DI) — Memory Data Strobe I to Data In Valid Delay — 160 130 7— 11 TdMAS(DI) Memory Address Strobe I to Data In 180 220 7 Valid Delay 12 ThMDS(DI) Memory Data Strobe I to Data In Hold Time 0 0 13 TwSY Instruction Sync Out Width 160 100 14 TdSY(MDS) Instruction Sync Out to Memory Data 200 160 Strobe Delay | 7 | TdDO(MDS) | Data Out Valid to Memory Data Strobe Delay | 30 | | 30 | | 5 | | 10—TdMDS(DI) — Memory Data Strobe I to Data In Valid Delay — 160—130—7— 11 TdMAS(DI) Memory Address Strobe I to Data In 180 220 7 Valid Delay 12 ThMDS(DI) Memory Data Strobe I to Data In Hold Time 0 0 13 TwSY Instruction Sync Out Width 160 100 14 TdSY(MDS) Instruction Sync Out to Memory Data 200 160 Strobe Delay | 8 | TdMDS(DO) | | 30 | | 30 | | 5 | | 11 TdMAS(DI) Memory Address Strobe 1 to Data In Valid Delay 12 ThMDS(DI) Memory Data Strobe 1 to Data In Hold Time 0 0 13 TwSY Instruction Sync Out Width 160 100 14 TdSY(MDS) Instruction Sync Out to Memory Data 200 160 Strobe Delay | 9 | Tw(MDS) | Memory Data Strobe Width (Read Case) | 230 | | 230 | | 6 | | Valid Delay 12 ThMDS(DI) Memory Data Strobe † to Data In Hold Time 0 0 13 TwSY Instruction Sync Out Width 160 100 14 TdSY(MDS) Instruction Sync Out to Memory Data 200 160 Strobe Delay | 10- | —TdMDS(DI) —— | —Memory Data Strobe↓to Data In Valıd Delay —— | | <u></u> 160 | | 130 | <del>7</del> | | 13 TwSY Instruction Sync Out Width 160 100 14 TdSY(MDS) Instruction Sync Out to Memory Data 200 160 Strobe Delay | 11 | TdMAS(DI) | | | 180 | | 220 | 7 | | 14 TdSY(MDS) Instruction Sync Out to Memory Data 200 160 Strobe Delay | 12 | ThMDS(DI) | Memory Data Strobe † to Data In Hold Time | 0 | | 0 | | | | Strobe Delay | 13 | TwSY | Instruction Sync Out Width | 160 | | 100 | | | | 15 TwI Interrupt Request via Port 3 Input Width 100 100 | 14 | TdSY(MDS) | | 200 | | 160 | | | | | 15 | TwI | Interrupt Request via Port 3 Input Width | 100 | | 100 | | | # NOTES: - Input Handshake - Test Load 1 - Output Handshake - Internal reset signal is 1/2 to 2 clock delays from external reset condition. - Delay times are specified for an input clock frequency of 4 MHz. When operating at a lower frequency, the increase in input clock period must be added to the specified delay time. - Data strobe width is specified for an input clock frequency of 4 MHz. When operating at a lower frequency, the increase in - three input clock periods must be added to the specified width. Data strobe width varies according to the instruction being executed - Address strobe and data strobe to data in valid delay times represent memory system access times and are given for a 4 MHz input frequency - \* Timings are preliminary and subject to change. All timing references assume 2.0 V for a logic "1" and 0.8 V for a logic "0". † Units in nanoseconds (ns) - All output ac parameters use test load 2 | Ordering<br>Information | Product<br>Number | Package/<br>Temp | Speed | Description | Product<br>Number | Package/<br>Temp | Speed | Description | |-------------------------|-------------------|------------------|---------|------------------------------------------------------------------------------|-------------------|------------------|---------|------------------------------------------------------------------------| | | Z8090 | PS | 8.0 MHz | Z8000 Z-UPC<br>Universal<br>Peripheral<br>Controller (40-pin) | Z8092 | QS | 8.0 MHz | Z8000 Z-UPC<br>(Quip)<br>External<br>RAM-based | | | Z8090 | DE | 8.0 MHz | Same as above | | | | Program<br>Memory (64-pin) | | | Z8090 | DS | 8.0 MHz | Same as above | Z8093 | RS | 8.0 MHz | Z8000 Z-UPC<br>(Protopack)<br>2716 EPROM<br>Program Memory<br>(40-pin) | | | Z8090 | CS | 8.0 MHz | Same as above | | | | | | | Z8090 | PE | 8.0 MHz | Same as above | | | | | | | Z8090 | CE | 8.0 MHz | Same as above | | | | | | | Z8091 | QS | 8.0 MHz | Z8000 Z-UPC<br>(Quip)<br>External<br>ROM-based<br>Program<br>Memory (64-pin) | Z8094 | RS | 8.0 MHz | Z8000 Z-UPC<br>(Protopack)<br>RAM Program<br>Memory<br>(40-pin) | NOTES· C = Ceramic, D = Cerdip, P = Plastic, Q = Quip, E = -40°C to +85°C, S = 0°C to +70°C. # Universal Peripherals Zilog | | | - | |--|---|---| | | | | | | | | | | | | | | | | | | | | | | · | | | | | | | | | | | | | | # **Universal Peripherals** # Two Versions Extend Range of Applications June 1982 Zilog's Universal Peripheral Components Family is more than a group of simple I/O circuits—they are intelligent, fully programmable devices capable of performing complicated tasks independently. Their capabilities unburden the master CPU, reduce bus traffic, increase system throughput, and greatly simplify overall system hardware design requirements. The peripheral components, where needed, are produced in two versions to increase their range of application. One version. identified by the number Z80xx, is capable of interfacing with Zılog's multiplexed Z-BUS only or with both the Z-BUS and conventional multiplexed buses. The second version, identified by the number Z85xx, is capable of interfacing with conventional non-multiplexed buses. Many of these Z85xx peripherals will function with and add capability to non-Zilog CPUs. Contact your local Zilog sales office, local distributor or representative for additional information and detailed specifications. This section of the data book includes only product specifications or product briefs on the Z85xx series of components. For the specifications or briefs on the Z80xx components refer to the Z8000 peripherals section. All of the peripheral components are extensively programmable to permit each to be tailored to its own application(s). All Z-BUS peripherals share common interrupt and bus-request structures; they can also be operated in either a priority-interrupt or polled environment. Counting, timing, and parallel I/O transfer problems are easily solved using the Z8036/Z8536 CIO Counter/Timer and I/O Unit. This component has three 16-bit counter/timers, three I/O ports, and can double as a programmable priority-interrupt controller. Data communications problems are neatly handled by the Z8030/Z8530 SCC Serial Communications Controller. This device is a serial, dual-channel, multi-protocol controller which supports all popular communications formats. The SCC supports virtually all serial data transfer applications. Interface problems with the interconnection of major components within an asynchronous, parallel processor system can be solved using the Z8038 Z-FIO FIFO I/O Interface Unit. This general-purpose interface unit provides expandable, bidirectional buffering between asynchronous CPUs in a parallel processing network, or between a CPU and peripheral circuits and/or devices. The Z-FIO can be used with systems having either multiplexed or non-multiplexed buses. General-purpose control and data manipulation problems are easily handled by the Z8034/Z8534 UPC Universal Peripheral Controller. The UPC is a complete microcomputer designed for offline applications. This microcomputer executes the same friendly, capable instruction set as Zilog's Z8 microcomputer; it has three I/O ports, six levels of priority-interrupt, and 2K bytes of memory on chip. The UPC is intended for applications that require an intelli- gent peripheral controller which can assume many of the tasks normally required of the master CPU. Two new universal peripherals have been added to the ever expanding line of Zilog peripherals. They are the Z8581 Clock Generator and Controller (CGC) and the Z8531 ASCC Asynchronous Serial Communications Controller. The Z8581 Clock Generator and Controller (CGC) is a versatile addition to Zilog's family of universal microprocessor components. The selective clock-stretching capabilities and variety of timing outputs of this device allow it to meet the timing design requirements of various microprocessors easily, including those of LSI and VLSI peripherals. The outputs of the Z8581 CGC directly drive the Z80 and Z8000 microprocessor clock inputs. The oscillator input frequency reference sources can be either crystals or TTL compatible oscillators. To complement the Z8530/Z8030 SCC Serial Communications Controller Zilog has introduced an asynchronous version designated the Z8531 ASCC. It features two independent 0 to 1M bit/second, full-duplex channels each with a seperate crystal oscillator, baud rate generator and digital phaselocked loop for clock recovery. The Z8581 ASCC has programmable NRZ, NRZI, or FM data encoding. The LSI and VLSI components now available can meet the design needs of today, while Zilog continues to design state-of-the-art devices for the needs of tomorrow. | 1 | | | | |---|--|--|--| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | • | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | # Z8530 SCC Serial Communications Controller # Product Specification June 1982 ### Features - Two independent, 0 to 1M bit/second, full-duplex channels, each with a separate crystal oscillator, baud rate generator, and Digital Phase-Locked Loop for clock recovery. - Multi-protocol operation under program control; programmable for NRZ, NRZI, or FM data encoding. - Asynchronous mode with five to eight bits and one, one and one-half, or two stop bits per character; programmable clock factor; break detection and generation; parity, overrun, and framing error detection. - Synchronous mode with internal or external character synchronization on one or two synchronous characters and CRC generation and checking with CRC-16 or CRC-CCITT preset to either 1s or 0s. - SDLC/HDLC mode with comprehensive frame-level control, automatic zero insertion and deletion, I-field residue handling, abort generation and detection, CRC generation and checking, and SDLC Loop mode operation. - Local Loopback and Auto Echo modes. # General Description The Z8530 SCC Serial Communications Controller is a dual-channel, multi-protocol data communications peripheral designed for use with conventional non-multiplexed buses. The SCC functions as a serial-to-parallel, parallel-to-serial converter/controller. The SCC can be software-configured to satisfy a wide variety of serial communications applications. The device contains a variety of new, sophisticated internal functions including on-chip baud rate generators, Digital Phase-Locked Loops, and crystal oscillators that dramatically reduce the need for external logic. Figure 1. Pin Functions Figure 2. Pin Assignments 2023-001, 002 # General Description (Continued) The SCC handles asynchronous formats, Synchronous byte-oriented protocols such as IBM Bisync, and Synchronous bit-oriented protocols such as HDLC and IBM SDLC. This versatile device supports virtually any serial data transfer application (cassette, diskette, tape drives, etc.). The device can generate and check CRC codes in any Synchronous mode and can be programmed to check data integrity in various modes. The SCC also has facilities for modem controls in both channels. In applications where these controls are not needed, the modem controls can be used for general-purpose I/O. The Z-Bus daisy-chain interrupt hierarchy is also supported—as is standard for Zilog peripheral components. The Z8530 SCC is packaged in a 40-pin ceramic DIP and uses a single +5 V power supply. # Pin Description The following section describes the pin functions of the SCC. Figures 1 and 2 detail the respective pin functions and pin assignments. **A/B.** Channel A/Channel B Select (input). This signal selects the channel in which the read or write operation occurs. **CE.** Chip Enable (input, active Low). This signal selects the SCC for a read or write operation. CTSA, CTSB. Clear To Send (inputs, active Low). If these pins are programmed as Auto Enables, a Low on the inputs enables the respective transmitters. If not programmed as Auto Enables, they may be used as general-purpose inputs. Both inputs are Schmitt-trigger buffered to accommodate slow rise-time inputs. The SCC detects pulses on these inputs and can interrupt the CPU on both logic level transitions. **D/C.** Data/Control Select (input). This signal defines the type of information transferred to or from the SCC. A High means data is transferred; a Low indicates a command. **DCDA.** DCDB. Data Carrier Detect (inputs, active Low). These pins function as receiver enables if they are programmed for Auto Enables; otherwise they may be used as general-purpose input pins. Both pins are Schmitt-trigger buffered to accomodate slow rise-time signals. The SCC detects pulses on these pins and can interrupt the CPU on both logic level transitions. **D<sub>0</sub>-D<sub>7</sub>.** Data Bus (bidirectional, 3-state). These lines carry data and commands to and from the SCC. **DTR/REQA, DTR/REQB.** Data Terminal Ready/Request (outputs, active Low). These outputs follow the state programmed into the DTR bit. They can also be used as general-purpose outputs or as Request lines for a DMA controller. **IEI.** Interrupt Enable In (input, active High). IEI is used with IEO to form an interrupt daisy chain when there is more than one interrupt-driven device. A High IEI indicates that no other higher priority device has an interrupt under service or is requesting an interrupt. **IEO.** Interrupt Enable Out (output, active High). IEO is High only if IEI is High and the CPU is not servicing an SCC interrupt or the SCC is not requesting an interrupt (Interrupt Acknowledge cycle only). IEO is connected to the next lower priority device's IEI input and thus inhibits interrupts from lower priority devices. **INT.** Interrupt Request (output, open-drain, active Low). This signal is activated when the SCC requests an interrupt. INTACK. Interrupt Acknowledge (input, active Low). This signal indicates an active Interrupt Acknowledge cycle. During this cycle, the SCC interrupt daisy chain settles. When RD becomes active, the SCC places an interrupt vector on the data bus (if IEI is High). INTACK is latched by the rising edge of PCLK. **PCLK.** Clock (input). This is the master SCC clock used to synchronize internal signals PCLK is a TTL level signal. **RD.** Read (input, active Low). This signal indicates a read operation and when the SCC is selected, enables the SCC's bus drivers. During the Interrupt Acknowledge cycle, this signal gates the interrupt vector onto the bus if the SCC is the highest priority device requesting an interrupt. **RxDA**, **RxDB**. Receive Data (inputs, active High). These input signals receive serial data at standard TTL levels. RTxCA. RTxCB. Receive/Transmit Clocks (inputs, active Low). These pins can be programmed in several different modes of operation. In each channel, RTxC may supply the receive clock, the transmit clock, the clock for the baud rate generator, or the clock for the Digital Phase-Locked Loop. These pins can also be programmed for use with the respective SYNC pins as a crystal oscillator. The receive clock may be 1, 16, 32, or 64 times the data rate in Asynchronous modes. RTSA, RTSB. Request To Send (outputs, active Low). When the Request To Send (RTS) bit in Write Register 5 (Figure 11) is set, the RTS signal goes Low. When the RTS bit is reset in the Asynchronous mode and Auto # Pin Description (Continued) Enable is on, the signal goes High after the transmitter is empty. In Synchronous mode or in Asynchronous mode with Auto Enable off, the RTS pin strictly follows the state of the RTS bit. Both pins can be used as general-purpose outputs. **SYNCA. SYNCB.** *Synchronization* (inputs or outputs, active Low). These pins can act either as inputs, outputs, or part of the crystal oscillator circuit. In the Asynchronous Receive mode (crystal oscillator option not selected), these pins are inputs similar to $\overline{\text{CTS}}$ and $\overline{\text{DCD}}$ . In this mode, transitions on these lines affect the state of the Synchronous/Hunt status bits in Read Register 0 (Figure 10) but have no other function. In External Synchronization mode with the crystal oscillator not selected, these lines also act as inputs. In this mode, SYNC must be driven Low two receive clock cycles after the last bit in the synchronous character is received. Character assembly begins on the rising edge of the receive clock immediately preceding the activation of SYNC. In the Internal Synchronization mode (Monosync and Bisync) with the crystal oscillator not selected, these pins act as outputs and are active only during the part of the receive clock cycle in which synchronous characters are recognized. The synchronous condition is not latched, so these outputs are active each time a synchronization pattern is recognized (regardless of character boundaries). In SDLC mode, these pins act as outputs and are valid on receipt of a flag. **TxDA**, **TxDB**. *Transmit Data* (outputs, active High). These output signals transmit serial data at standard TTL levels. TRXCA. TRXCB. Transmit/Receive Clocks (inputs or outputs, active Low). These pins can be programmed in several different modes of operation. TRxC may supply the receive clock or the transmit clock in the input mode or supply the output of the Digital Phase-Locked Loop, the crystal oscillator, the baud rate generator, or the transmit clock in the output mode. $\overline{\mathbf{WR}}$ . Write (input, active Low). When the SCC is selected, this signal indicates a write operation. The coincidence of $\overline{\mathrm{RD}}$ and $\overline{\mathrm{WR}}$ is interpreted as a reset. W/REQA, W/REQB. Wait/Request (outputs, open-drain when programmed for a Wait function, driven High or Low when programmed for a Request function). These dual-purpose outputs may be programmed as Request lines for a DMA controller or as Wait lines to synchronize the CPU to the SCC data rate. The reset state is Wait. # Functional Description The functional capabilities of the SCC can be described from two different points of view: as a data communications device, it transmits and receives data in a wide variety of data communications protocols; as a microprocessor peripheral, the SCC offers valuable features such as vectored interrupts, polling, and simple handshake capability. **Data Communications Capabilities.** The SCC provides two independent full-duplex channels programmable for use in any common Asynchronous or Synchronous datacommunication protocol. Figure 3 and the following description briefly detail these protocols. Asynchronous Modes. Transmission and reception can be accomplished independently on each channel with five to eight bits per character, plus optional even or odd parity. The transmitters can supply one, one-and-ahalf, or two stop bits per character and can provide a break output at any time. The receiver break-detection logic interrupts the CPU both at the start and at the end of a received break. Reception is protected from spikes by a transient spike-rejection Figure 3. Some SCC Protocols 2042-108 mechanism that checks the signal one-half a bit time after a Low level is detected on the receive data input (RxDA or RxDB in Figure 1). If the Low does not persist (as in the case of a transient), the character assembly process does not start. Framing errors and overrun errors are detected and buffered together with the partial character on which they occur. Vectored interrupts allow fast servicing or error conditions using dedicated routines. Furthermore, a built-in checking process avoids the interpretation of a framing error as a new start bit: a framing error results in the addition of one-half a bit time to the point at which the search for the next start bit begins. The SCC does not require symmetric transmit and receive clock signals—a feature allowing use of the wide variety of clock sources. The transmitter and receiver can handle data at a rate of 1, 1/16, 1/32, or 1/64 of the clock rate supplied to the receive and transmit clock inputs. In Asynchronous modes, the SYNC pin may be programmed as an input used for functions such as monitoring a ring indicator. Synchronous Modes. The SCC supports both byte-oriented and bit-oriented synchronous communication. Synchronous byte-oriented protocols can be handled in several modes, allowing character synchronization with a 6-bit or 8-bit synchronous character (Monosync), any 12-bit synchronization pattern (Bisync), or with an external synchronous signal. Leading sync characters can be removed without interrupting the CPU. Five- or 7-bit synchronous characters are detected with 8- or 16-bit patterns in the SCC by overlapping the larger pattern across multiple incoming synchronous characters as shown in Figure 4. CRC checking for Synchronous byteoriented modes is delayed by one character time so that the CPU may disable CRC checking on specific characters. This permits the implementation of protocols such as IBM Bisync. Both CRC-16 ( $X^{16} + X^{15} + X^2 + 1$ ) and CCITT ( $X^{16} + X^{12} + X^5 + 1$ ) error checking polynomials are supported. Either polynomial may be selected in all Synchronous modes. Users may preset the CRC generator and checker to all 1s or all 0s. The SCC also provides a feature that automatically transmits CRC data when no other data is available for transmission. This allows for high speed transmissions under DMA control, with no need for CPU intervention at the end of a message. When there is no data or CRC to send in Synchronous modes, the transmitter inserts 6-, 8-, or 16-bit synchronous characters, regardless of the programmed character length. The SCC supports Synchronous bit-oriented protocols, such as SDLC and HDLC, by performing automatic flag sending, zero insertion, and CRC generation. A special command can be used to abort a frame in transmission. At the end of a message, the SCC automatically transmits the CRC and trailing flag when the transmitter underruns. The transmitter may also be programmed to send an idle line consisting of continuous flag characters or a steady marking condition. If a transmit underrun occurs in the middle of a message, an external/status interrupt warns the CPU of this status change so that an abort may be issued. The SCC may also be programmed to send an abort itself in case of an underrun, relieving the CPU of this task. One to eight bits per character can be sent, allowing reception of a message with no prior information about the character structure in the information field of a frame. The receiver automatically acquires synchronization on the leading flag of a frame in SDLC or HDLC and provides a synchronization signal on the SYNC pin (an interrupt can also be programmed). The receiver can be programmed to search for frames addressed by a single byte (or four bits within a byte) of a user-selected address or to a global broadcast address. In this mode, frames not matching either the user-selected or broadcast address are ignored. The number of address bytes can be extended under software control. For receiving data, an interrupt on the first received character, or an interrupt on every character, or on special condition only (endof-frame) can be selected. The receiver automatically deletes all 0s inserted by the transmitter during character assembly. CRC is also calculated and is automatically checked to validate frame transmission. At the end of transmission, the status of a received frame is available in the status registers. In SDLC mode, the SCC must be programmed to use the SDLC CRC polynomial, but the generator and checker may be preset to all 1s or all 0s. Figure 4. Detecting 5- or 7-Bit Synchronous Characters The CRC is inverted before transmission and the receiver checks against the bit pattern 0001110100001111. NRZ, NRZI or FM coding may be used in any $l\,x$ mode. The parity options available in Asynchronous modes are available in Synchronous modes. The SCC can be conveniently used under DMA control to provide high speed reception or transmission. In reception, for example, the SCC can interrupt the CPU when the first character of a message is received. The CPU then enables the DMA to transfer the message to memory. The SCC then issues an end-of-frame interrupt and the CPU can check the status of the received message. Thus, the CPU is freed for other service while the message is being received. The CPU may also enable the DMA first and have the SCC interrupt only on end-of-frame. This procedure allows all data to be transferred via the DMA. **SDLC Loop Mode.** The SCC supports SDLC Loop mode in addition to normal SDLC. In an SDLC Loop, there is a primary controller station that manages the message traffic flow on the loop and any number of secondary stations. In SDLC Loop mode, the SCC performs the functions of a secondary station while an SCC operating in regular SDLC mode can act as a controller (Figure 5). A secondary station in an SDLC Loop is always listening to the messages being sent around the loop, and in fact must pass these messages to the rest of the loop by retransmitting them with a one-bit-time delay. The secondary station can place its own message on the loop only at specific times. The controller signals that secondary stations may transmit messages by sending a special character, called an EOP (End Of Poll), around the loop. The EOP character is the bit pattern 11111110. Because of zero insertion during messages, this bit pattern is unique and easily recognized. When a secondary station has a message to transmit and recognizes an EOP on the line, it SECONDARY #1 SECONDARY #2 SECONDARY #3 Figure 5. An SDLC Loop changes the last binary 1 of the EOP to a 0 before transmission. This has the effect of turning the EOP into a flag sequence. The secondary station now places its message on the loop and terminates the message with an EOP. Any secondary stations further down the loop with messages to transmit can then append their messages to the message of the first secondary station by the same process. Any secondary stations without messages to send merely echo the incoming messages and are prohibited from placing messages on the loop (except upon recognizing an EOP). SDLC Loop mode is a programmable option in the SCC. NRZ, NRZI, and FM coding may all be used in SDLC Loop mode. Baud Rate Generator. Each channel in the SCC contains a programmable baud rate generator. Each generator consists of two 8-bit time constant registers that form a 16-bit time constant, a 16-bit down counter, and a flip-flop on the output producing a square wave. On startup, the flip-flop on the output is set in a High state, the value in the time constant register is loaded into the counter, and the counter starts counting down. The output of the baud rate generator toggles upon reaching 0, the value in the time constant register is loaded into the counter, and the process is repeated. The time constant may be changed at any time, but the new value does not take effect until the next load of the counter. The output of the baud rate generator may be used as either the transmit clock, the receive clock, or both. It can also drive the Digital Phase-Locked Loop (see next section). If the receive clock or transmit clock is not programmed to come from the TRxC pin, the output of the baud rate generator may be echoed out via the TRxC pin. The following formula relates the time constant to the baud rate (the baud rate is in bits/second and the BR clock period is in seconds): baud rate = $\frac{1}{2 \text{ (time constant + 2)} \times \text{ (BR clock period)}}$ Digital Phase-Locked Loop. The SCC contains a Digital Phase-Locked-Loop (DPLL) to recover clock information from a data stream with NRZI or FM encoding. The DPLL is driven by a clock that is nominally 32 (NRZI) or 16 (FM) times the data rate. The DPLL uses this clock, along with the data stream, to construct a clock for the data. This clock may then be used as the SCC receive clock, the transmit clock, or both. For NRZI encoding, the DPLL counts the 32x clock to create nominal bit times. As the 32x clock is counted, the DPLL is searching the incoming data stream for edges (either 1 to 0 or 0 to 1). Whenever an edge is detected, the DPLL makes a count adjustment (during the next counting cycle), producing a terminal count closer to the center of the bit cell. For FM encoding, the DPLL still counts from 0 to 31, but with a cycle corresponding to two bit times. When the DPLL is locked, the clock edges in the data stream should occur between counts 15 and 16 and between counts 31 and 0. The DPLL looks for edges only during a time centered on the 15 to 16 counting transition. The 32x clock for the DPLL can be programmed to come from either the $\overline{RTxC}$ input or the output of the baud rate generator. The DPLL output may be programmed to be echoed out of the SCC via the $\overline{TRxC}$ pin (if this pin is not being used as an input). Data Encoding. The SCC may be programmed to encode and decode the serial data in four different ways (Figure 6). In NRZ encoding, a l is represented by a High level and a 0 is represented by a Low level. In NRZI encoding, a l is represented by no change in level and a 0 is represented by a change in level. In FM1 (more properly, bi-phase mark), a transition occurs at the beginning of every bit cell. A l is represented by an additional transition at the center of the bit cell and a 0 is represented by no additional transition at the center of the bit cell. In FMO (bi-phase space). a transition occurs at the beginning of every bit cell. A 0 is represented by an additional transition at the center of the bit cell, and a l is represented by no additional transition at the center of the bit cell. In addition to these four methods, the SCC can be used to decode Manchester (bi-phase level) data by using the DPLL in the FM mode and programming the receiver for NRZ data. Manchester encoding always produces a transition at the center of the bit cell. If the transition is 0 to 1, the bit is a 0. If the transition is 1 to 0, the bit is a 1. Auto Echo and Local Loopback. The SCC is capable of automatically echoing everything it receives. This feature is useful mainly in Asynchronous modes, but works in Synchronous and SDLC modes as well. In Auto Echo mode, TxD is RxD. Auto Echo mode can be used with NRZI or FM encoding with no additional delay, because the data stream is not decoded before retransmission. In Auto Echo mode, the $\overline{CTS}$ input is ignored as a transmitter enable (although transitions on this input can still cause interrupts if programmed to do so). In this mode, the transmitter is actually bypassed and the programmer is responsible for disabling transmitter interrupts and WAIT/REQUEST on transmit. The SCC is also capable of local loopback. In this mode TxD is RxD, just as in Auto Echo mode. However, in Local Loopback mode, the internal transmit data is tied to the internal receive data and RxD is ignored (except to be echoed out via TxD). The CTS and DCD inputs are also ignored as transmit and receive enables. However, transitions on these inputs can still cause interrupts. Local Loopback works in Asynchronous, Synchronous and SDLC modes with NRZ, NRZI or FM coding of the data stream. I/O Interface Capabilities. The SCC offers the choice of Polling, Interrupt (vectored or nonvectored), and Block Transfer modes to transfer data, status, and control information to and from the CPU. The Block Transfer mode can be implemented under CPU or DMA control. **Polling.** All interrupts are disabled. Three status registers in the SCC are automatically updated whenever any function is performed. For example, end-of-frame in SDLC mode sets a bit in one of these status registers. The idea behind polling is for the CPU to periodically read a status register until the register contents indicate the need for data to be transferred. Only one register needs to be Figure 6. Data Encoding Methods 342 2016-002 read; depending on its contents, the CPU either writes data, reads data, or continues. Two bits in the register indicate the need for data transfer. An alternative is a poll of the Interrupt Pending register to determine the source of an interrupt. The status for both channels resides in one register. Interrupts. When an SCC responds to an Interrupt Acknowledge signal (INTACK) from the CPU, an interrupt vector may be placed on the data bus. This vector is written in WR2 and may be read in RR2A or RR2B (Figures 10 and 11). To speed interrupt response time, the SCC can modify three bits in this vector to indicate status. If the vector is read in Channel A, status is never included; if it is read in Channel B, status is always included. Each of the six sources of interrupts in the SCC (Transmit, Receive, and External/Status interrupts in both channels) has three bits associated with the interrupt source: Interrupt Pending (IP), Interrupt Under Service (IUS), and Interrupt Enable (IE). Operation of the IE bit is straightforward. If the IE bit is set for a given interrupt source, then that source can given interrupts. The exception is when the MIE (Master Interrupt Enable) bit in WR9 is reset and no interrupts may be requested. The IE bits are write only. The other two bits are related to the interrupt priority chain (Figure 7). As a microprocessor peripheral, the SCC may request an interrupt only when no higher priority device is requesting one, e.g., when IEI is High. If the device in question requests an interrupt, it pulls down INT. The CPU then responds with INTACK, and the interrupting device places the vector on the data bus. In the SCC, the IP bit signals a need for interrupt servicing. When an IP bit is 1 and the IEI input is High, the $\overline{\text{INT}}$ output is pulled Low, requesting an interrupt. In the SCC, if the IE bit is not set by enabling interrupts, then the IP for that source can never be set. The IP bits are readable in RR3A. The IUS bits signal that an interrupt request is being serviced. If an IUS is set, all interrupt sources of lower priority in the SCC and external to the SCC are prevented from requesting interrupts. The internal interrupt sources are inhibited by the state of the internal daisy chain, while lower priority devices are inhibited by the IEO output of the SCC being pulled Low and propagated to subsequent peripherals. An IUS bit is set during an Interrupt Acknowledge cycle if there are no higher priority devices requesting interrupts. There are three types of interrupts: Transmit, Receive, and External/Status. Each interrupt type is enabled under program control with Channel A having higher priority than Channel B, and with Receiver, Transmit, and External/Status interrupts prioritized in that order within each channel. When the Transmit interrupt is enabled, the CPU is interrupted when the transmit buffer becomes empty. (This implies that the transmitter must have had a data character written into it so that it can become empty.) When enabled, the receiver can interrupt the CPU in one of three ways: - Interrupt on First Receive Character or Special Receive Condition. - Interrupt on All Receive Characters or Special Receive Condition. - Interrupt on Special Receive Condition Only. Interrupt on First Character or Special Condition and Interrupt on Special Condition Only are typically used with the Block Transfer mode. A Special Receive Condition is one of the following: receiver overrun, framing error in Asynchronous mode, end-of-frame in SDLC mode and, optionally, a parity error. The Special Receive Condition interrupt is different from an ordinary receive character available interrupt only in the status placed in the vector during the Interrupt Acknowledge cycle. In Interrupt on First Receive Character, an interrupt can occur from Special Receive Conditions any time after the first receive character interrupt. The main function of the External/Status interrupt is to monitor the signal transitions of the $\overline{\text{CTS}}$ , $\overline{\text{DCD}}$ , and $\overline{\text{SYNC}}$ pins; however, an Figure 7. Interrupt Schedule External/Status interrupt is also caused by a Transmit Underrun condition, or a zero count in the baud rate generator, or by the detection of a Break (Asynchronous mode), Abort (SDLC mode) or EOP (SDLC Loop mode) sequence in the data stream. The interrupt caused by the Abort or EOP has a special feature allowing the SCC to interrupt when the Abort or EOP sequence is detected or terminated. This feature facilitates the proper termination of the current message, correct initialization of the next message, and the accurate timing of the Abort condition in external logic in SDLC mode. In SDLC Loop mode, this feature allows secondary stations to recognize the wishes of the primary station to regain control of the loop during a poll sequence. CPU/DMA Block Transfer. The SCC provides a Block Transfer mode to accommodate CPU block transfer functions and DMA controllers. The Block Transfer mode uses the WAIT/REQUEST output in conjunction with the Wait/Request bits in WR1. The WAIT/REQUEST output can be defined under software control as a WAIT line in the CPU Block Transfer mode or as a REQUEST line in the DMA Block Transfer mode. To a DMA controller, the SCC REQUEST output indicates that the SCC is ready to transfer data to or from memory. To the CPU, the WAIT line indicates that the SCC is not ready to transfer data, thereby requesting that the CPU extend the I/O cycle. The DTR/REQUEST line allows full-duplex operation under DMA control. ### Architecture The SCC internal structure includes two full-duplex channels, two baud rate generators, internal control and interrupt logic, and a bus interface to a nonmultiplexed bus. Associated with each channel are a number of read and write registers for mode control and status information, as well as logic necessary to interface to modems or other external devices (Figure 8). The logic for both channels provides formats, synchronization, and validation for data transferred to and from the channel interface. The modem control inputs are monitored by the control logic under program control. All of the modem control signals are general-purpose in nature and can optionally be used for functions other than modem control. The register set for each channel includes ten control (write) registers, two synccharacter (write) registers, and four status (read) registers. In addition, each baud rate generator has two (read/write) registers for holding the time constant that determines the baud rate. Finally, associated with the interrupt logic is a write register for the interrupt vector accessible through either channel, a Figure 8. Block Diagram of SCC Architecture # Architecture (Continued) write only Master Interrupt Control register and three read registers: one containing the vector with status infomation (Channel B only), one containing the vector without status (Channel A only), and one containing the Interrupt Pending bits (Channel A only). The registers for each channel are designated as follows: WR0-WR15 — Write Registers 0 through 15. RR0-RR3, RR10, RR12, RR13, RR15 — Read Registers 0 through 3, 10, 12, 13, 15. Table 1 lists the functions assigned to each read or write register. The SCC contains only one WR2 and WR9, but they can be accessed by either channel. All other registers are paired (one for each channel). Data Path. The transmit and receive data path illustrated in Figure 9 is identical for both channels. The receiver has three 8-bit buffer registers in an FIFO arrangement, in addition to the 8-bit receive shift register. This scheme creates additional time for the CPU to service an interrupt at the beginning of a block of high speed data. Incoming data is routed through one of several paths (data or CRC) depending on the selected mode (the character length in Asynchronous modes also determines the data path). The transmitter has an 8-bit Transmit Data buffer register loaded from the internal data bus and a 20-bit Transmit Shift register that can be loaded either from the synchronous character registers or from the Transmit Data register. Depending on the operational mode, outgoing data is routed through one of four main paths before it is transmitted from the Transmit Data output (TxD) # Read Register Functions | RR0 | Transmit/Receive buffer status and External status | |------|-----------------------------------------------------------------------------------------| | RR1 | Special Receive Condition status | | RR2 | Modified interrupt vector (Channel B only) Unmodified interrupt vector (Channel A only) | | RR3 | Interrupt Pending bits (Channel A only) | | RR8 | Receive buffer | | RR10 | Miscellaneous status | | RR12 | Lower byte of baud rate generator time constant | | RR13 | Upper byte of baud rate generator time constant | | RR15 | External/Status interrupt information | ### Write Register Functions | WR0 | CRC initialize, initialization commands for the various modes, Register Pointers | |------|----------------------------------------------------------------------------------| | WR1 | Transmit/Receive interrupt and data transfer mode definition | | WR2 | Interrupt vector (accessed through either channel) | | WR3 | Receive parameters and control | | WR4 | Transmit/Receive miscellaneous parameters and modes | | WR5 | Transmit parameters and controls | | WR6 | Sync characters or SDLC address field | | WR7 | Sync character or SDLC flag | | WR8 | Transmit buffer | | WR9 | Master interrupt control and reset (accessed through either channel) | | WR10 | Miscellaneous transmitter/receiver control bits | Clock mode control Miscellaneous control bits External/Status interrupt control WRII WR12 WR13 WR14 WR15 Table 1. Read and Write Register Functions Lower byte of baud rate generator time constant Upper byte of baud rate generator time constant # Programming The SCC contains 13 write registers in each channel that are programmed by the system separately to configure the functional personality of the channels. In the SCC, register addressing is direct for the data registers only, which are selected by a High on the $D/\overline{C}$ pin. In all other cases (with the exception of WR0 and RR0), programming the write registers requires two write operations and reading the read registers requires both a write and a read operation. The first write is to WR0 and contains three bits that point to the selected register. The second write is the actual control word for the selected register, and if the second operation is read, the selected read register is accessed. All of the registers in the SCC, including the data registers, may be accessed in this fashion. The pointer bits are automatically cleared after the read or write operation so that WRO (or RRO) is addressed again. The system program first issues a series of commands to initialize the basic mode of operation. This is followed by other commands to qualify conditions within the selected mode. For example, the Asynchronous mode, character length, clock rate, number of stop bits, even or odd parity might be set first. Then the interrupt mode would be set, and finally, receiver or transmitter enable. # (Continued) Programming Read Registers. The SCC contains eight read registers (actually nine, counting the receive buffer (RR8) in each channel). Four of these may be read to obtain status information (RRO, RR1, RR10, and RR15). Two registers (RR12 and RR13) may be read to learn the baud rate generator time constant. RR2 contains either the unmodified interrupt vector (Channel A) or the vector modified by status information # Read Register 0 # Read Register 1 # Read Register 2 # Read Register 3 (Channel B). RR3 contains the Interrupt Pending (IP) bits (Channel A). Figure 10 shows the formats for each read register. The status bits of RRO and RR1 are carefully grouped to simplify status monitoring; e.g., when the interrupt vector indicates a Special Receive Condition interrupt, all the appropriate error bits can be read from a single register (RR1). # Read Register 10 # Read Register 12 # Read Register 13 # Read Register 15 Figure 10. Read Register Bit Functions 2016-005 (Continued) Programming Write Registers. The SCC contains 13 write registers (14 counting WR8, the transmit buffer) in each channel. These write registers are programmed separately to configure the functional "personality" of the channels. In addition, there are two registers (WR2 and WR9) shared by the two channels that may be accessed through either of them. WR2 contains the interrupt vector for both channels, while WR9 contains the interrupt control bits. Figure 11 shows the format of each write register. # Write Register 0 \*WITH POINT HIGH COMMAND # Write Register 1 # Write Register 2 # Write Register 3 # Write Register 4 # Write Register 5 # Write Register 6 Figure 11. Write Register Bit Functions 2016-006 2023-010 MONOSYNC, 8 BITS MONOSYNC, 6 BITS BISYNC, 16 BITS BISYNC, 12 BITS (ADDRESS RANGE) # Write Register 7 ### Write Register 9 # Write Register 10 # Write Register 11 # Write Register 12 # Write Register 13 # Write Register 14 # Write Register 15 Figure 11. Write Register Bit Functions (Continued) #### Timing The SCC generates internal control signals from $\overline{WR}$ and $\overline{RD}$ that are related to PCLK. Since PCLK has no phase relationship with $\overline{WR}$ and $\overline{RD}$ , the circuitry generating these internal control signals must provide time for metastable conditions to disappear. This gives rise to a recovery time related to PCLK. The recovery time applies only between bus transactions involving the SCC. The recovery time required for proper operation is specified from the rising edge of $\overline{WR}$ or $\overline{RD}$ in the first trans- action involving the SCC to the falling edge of $\overline{WR}$ or $\overline{RD}$ in the second transaction involving the SCC. This time must be at least 6 PCLK cycles plus 200 ns. **Read Cycle Timing.** Figure 12 illustrates Read cycle timing. Addresses on $\overline{A/B}$ and $\overline{D/C}$ and the status on $\overline{INTACK}$ must remain stable throughout the cycle. If $\overline{CE}$ falls after $\overline{RD}$ falls or if it rises before $\overline{RD}$ rises, the effective $\overline{RD}$ is shortened. Figure 12. Read Cycle Timing **Write Cycle Timing.** Figure 13 illustrates Write cycle timing. Addresses on $A/\overline{B}$ and $D/\overline{C}$ and the status on $\overline{INTACK}$ must remain stable throughout the cycle. If $\overline{CE}$ falls after $\overline{WR}$ falls or if it rises before $\overline{WR}$ rises, the effective $\overline{WR}$ is shortened. Figure 13. Write Cycle Timing Interrupt Acknowledge Cycle Timing. Figure 14 illustrates Interrupt Acknowledge cycle timing. Between the time $\overline{\text{INTACK}}$ goes Low and the falling edge of $\overline{\text{RD}}$ , the internal and external IEI/IEO daisy chains settle. If there is an interrupt pending in the SCC and IEI is High when $\overline{\text{RD}}$ falls, the Acknowledge cycle is intended for the SCC. In this case, the SCC may be programmed to respond to $\overline{\text{RD}}$ Low by placing its interrupt vector on D<sub>0</sub>-D<sub>7</sub> and it then sets the appropriate Interrupt-Under-Service latch internally. Figure 14. Interrupt Acknowledge Cycle Timing | Absolute<br>Maximum<br>Ratings | Voltages on all inputs and outputs with respect to GND0.3 V to +7.0 V Operating Ambient TemperatureAs Specified in Ordering Information Storage Temperature65°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 characteristics below apply for the following standard test conditions, unless otherwise noted. All voltages are referenced to GND. Positive current flows into the referenced pin. Standard conditions are as follows: $\blacksquare$ +4.75 V $\leq$ V $_{\rm CC}$ $\leq$ +5.25 V - GND = 0 V - T<sub>A</sub> as specified in Ordering Information All ac parameters assume a load capacitance of 50 pF max. Figure 15. Standard Test Load Figure 16. Open-Drain Test Load | DC | Symbol | Parameter | Min | Мах | Unit | Condition | |----------------------|-------------------|--------------------------------|------|-----------------------|------|-----------------------------| | Charac-<br>teristics | $V_{\mathrm{IH}}$ | Input High Voltage | 2.0 | V <sub>CC</sub> + 0.3 | V | | | | $V_{\rm IL}$ | Input Low Voltage | -0.3 | 0.8 | V | | | | $V_{OH}$ | Output High Voltage | 2.4 | | V | $I_{OH} = -250 \mu\text{A}$ | | | $v_{OL}$ | Output Low Voltage | | 0.4 | V | $I_{OL} = +2.0 \text{ mA}$ | | | I <sub>II.</sub> | Input Leakage | | ±10.0 | μΑ | $0.4 \le V_{IN} \le +2.4V$ | | | $I_{OL}$ | Output Leakage | | ±10.0 | μA | $0.4 \le V_{OUT} \le +2.4V$ | | | $I_{CC}$ | V <sub>CC</sub> Supply Current | | 250 | mA | 30. | V<sub>CC</sub> = 5 V ± 5% unless otherwise specified, over specified temperature range | Capacitance | Symbol | Parameter | Min | Мах | Unit | Test Condition | |-------------|---------------------------------------------------------|----------------------------------------------------------------------|-----|----------------|----------------|---------------------------------------| | | C <sub>IN</sub><br>C <sub>OUT</sub><br>C <sub>I/O</sub> | Input Capacitance<br>Output Capacitance<br>Bidirectional Capacitance | | 10<br>15<br>20 | pF<br>pF<br>pF | Unmeasured Pins<br>Returned to Ground | f = 1 MHz, over specified temperature range ### Read and Write Timing | | | | 4 | MHz | 6 1 | MHz | | |------|---------------|-------------------------------------------|------------------|------|-----------------|------------|---------------| | No. | Symbol | Parameter | Min | Max | Min | Max | Notes*† | | 1 | TwPC1 | PCLK Low Width | 105 | 2000 | 70 | 1000 | | | 2 | TwPCh | PCLK High Width | 105 | 2000 | 70 | 1000 | | | 3 | TfPC | PCLK Fall Time | | 20 | | 10 | | | 4 | TrPC | PCLK Rise Time | | 20 | | 15 | | | 5 — | — TcPC ——— | PCLK Cycle Time | <del> 250</del> | 4000 | 165 | 2000 | | | 6 | TsA(WR) | Address to WR Setup Time | 80 | | 80 | | | | 7 | ThA(WR) | Address to $\overline{ m WR}$ † Hold Time | 0 | | 0 | | | | 8 | TsA(RD) | Address to RD ↓ Setup Time | 80 | | 80 | | | | 9 | ThA(RD) | Address to RD † Hold Time | 0 | | 0 | | | | 10 | — TsIA(PC) —— | — INTACK to PCLK † Setup Time ———— | <del></del> 0 | | <del></del> 0 | ** | | | 11 | TsIAi(WR) | INTACK to WR ↓ Setup Time | 200 | | 160 | | 1 | | 12 | ThIA(WR) | INTACK to WR † Hold Time | 0 | | 0 | | | | 13 | TsIAi(RD) | INTACK to RD ↓ Setup Time | 200 | | 160 | | 1 | | 14 | ThIA(RD) | INTACK to RD † Hold Time | 0 | | 0 | | | | 15 - | — ThIA(PC)—— | | 100 <del>-</del> | | <del></del> 100 | | | | 16 | TsCE1(WR) | CE Low to WR ↓ Setup Time | 0 | | 0 | | | | 17 | ThCE(WR) | CE to WR † Hold Time | 0 | | 0 | | | | 18 | TsCEh(WR) | CE High to WR ↓ Setup Time | 100 | | 70 | | | | 19 | TsCE1(RD) | CE Low to RD Setup Time | 0 | | 0 | | 1 | | 20 — | — ThCE(RD) —— | — CE to RD † Hold Time — | 0 – | | 0 – | | 1 <del></del> | | 21 | TsCEh(RD) | CE High to RD ↓ Setup Time | 100 | | 70 | | 1 | | 22 | TwRD1 | RD Low Width | 390 | | 250 | | 1 | | 23 | TdRD(DRA) | RD ↓ to Read Data Active Delay | 0 | | 0 | | | | 24 | TdRDr(DR) | RD † to Read Data Not Valid Delay | 0 | | 0 | | | | 25 | TdRDf(DR) | RD I to Read Data Valid Delay | | 250 | | 180 | | | 26 | TdRD(DRz) | RD † to Read Data Float Delay | | 70 | | <b>4</b> 5 | 2 | 2023-006 352 <sup>1.</sup> Parameter does not apply to Interrupt Acknowledge <sup>2.</sup> Float delay is defined as the time required for a $\pm 0.5$ V change in the output with a maximum dc load and minimum ac load. <sup>\*</sup> Timings are preliminary and subject to change. † Units in nanoseconds (ns). | | | | 4 | MHz | 6 1 | MHz | | |------|--------------------------------|--------------------------------------------------|-------|-----------|-------|--------|---------------| | No. | Symbol | Parameter | Min | Max | Min | Max | Notes*† | | 27 | TdA(DR) | Address Required Valid to Read Data Valid Delay | | 590 | | 420 | | | 28 | TwWRl | WR Low Width | 390 | | 250 | | | | 29 | TsDW(WR) | Write Data to WR ↓ Setup Time | 0 | | 0 | | | | 30 | ThDW(WR) | Write Data to WR † Hold Time | 0 | | 0 | | | | 31 — | – TdWR(W) ––– | — WR ↓ to Wait Valid Delay —————— | | 240 | | 200 | <del> 4</del> | | 32 | TdRD(W) | RD ↓ to Wait Valid Delay | | 240 | | 200 | 4 | | 33 | TdWRf(REQ) | WR ↓ to W/REQ Not Valid Delay | | 240 | | 200 | | | 34 | TdRDf(REQ) | RD ↓ to W/REQ Not Valid Delay | | 240 | | 200 | | | 35 | TdWRr(REQ) | WR t to DTR/REQ Not Valid Delay | | 5TcPC | | 5TcPC | | | | | • | | + 300 | | + 250 | | | 36 — | <ul><li>TdRDr(REQ) —</li></ul> | — RD ↑ to DTR/REQ Not Valid Delay ———— | | - 5TcPC - | | -5TcPC | | | | | • | | +300 | | + 250 | | | 37 | TdPC(INT) | PCLK ↓ to INT Valid Delay | | 500 | | 500 | 4 | | 38 | TdIAi(RD) | INTACK to RD (Acknowledge) Delay | 250 | | 250 | | 5 | | 39 | TwRDA | RD (Acknowledge) Width | 285 | | 250 | | | | 40 — | – TdRDA(DR) —— | — RD ↓ (Acknowledge) to Read Data Valid Delay —— | | 190 | | 180 | | | 41 | TsIEI(RDA) | IEI to RD ↓ (Acknowledge) Setup Time | 120 | | 100 | | | | 42 | ThIEI(RDA) | IEI to RD † (Acknowledge) Hold Time | 0 | | 0 | | | | 43 | TdIEI(IEO) | IEI to IEO Delay Time | | 120 | | 100 | | | 44 | TdPC(IEO) | PCLK † to IEO Delay | | 250 | | 250 | | | 45 — | – TdRDA(INT) — | — RD ↓ to INT Inactive Delay ————— | | 500 | | 500 | 4 | | 46 | TdRD(WRQ) | RD ↑ to WR ↓ Delay for No Reset | 30 | | 15 | | | | 47 | TdWRQ(RD) | WR ↑ to RD ↓ Delay for No Reset | 30 | | 30 | | | | 48 | Twres | WR and RD Coincident Low for Reset | 250 | | 250 | | | | 49 | Trc | Valid Access Recovery Time | 6TcPC | | 6TcPC | | | | | | - | + 200 | | +130 | | 3 | #### NOTES: 2023-007, 008, 009 <sup>3</sup> Parameter applies only between transactions involving the SCC. 4 Open-drain output, measured with open-drain test load 5 Parameter is system dependent. For any SCC in the daisy chain, TdIAi(RD) must be greater than the sum of TdPC(IEO) for the highest priority device in the daisy chain, TsIEI(RDA) for the SCC, and TdIEIf(IEO) for each device separating them in the daisy chain. <sup>\*</sup> Timings are preliminary and subject to change. <sup>†</sup> Units in nanoseconds (ns). | No. | Symbol | Parameter | 4:<br>Min | MHz<br>Max | 6 I<br>Min | MHz<br>Max | Notes*† | |------|-----------------|--------------------------------------------------|-----------------|------------|-----------------|------------|---------| | | TdPC(REO) | PCLK ↓ to W/REQ Valid Delay | | 250 | | 250 | | | 2 | TdPC(W) | PCLK ↓ to Wait Inactive Delay | | 350 | | 350 | | | 3 | TsRXC(PC) | RxC † to PCLK † Setup Time (PCLK ÷ 4 case only) | 80 | TwPCl | 70 | TwPCl | 1,4 | | 4 | TsRXD(RXCr) | RxD to RxC † Setup Time (X1 Mode) | 0 | | 0 | | 1 | | 5— | - ThRXD(RXCr) - | - RxD to RxC † Hold Time (X1 Mode) | <del></del> 150 | | 150 | | ı | | 6 | TsRXD(RXCf) | RxD to RxC ↓ Setup Time (X1 Mode) | 0 | | 0 | | 1,5 | | 7 | ThRXD(RXCf) | $RxD$ to $\overline{RxC}$ Hold Time (X1 Mode) | 150 | | 150 | | 1,5 | | 8 | TsSY(RXC) | SYNC to RxC Setup Time | -200 | | -200 | | 1 | | 9 | ThSY(RXC) | SYNC to RxC † Hold Time | 3TcPC<br>+ 200 | | 3TcPC<br>+ 200 | | 1 | | 10 — | - TsTXC(PC) | - TxC ↓ to PCLK ↑ Setup Time - | 0 - | | 0 - | | 2,4 | | 11 | TdTXCf(TXD) | TxC ↓ to TxD Delay (X1 Mode) | | 300 | | 230 | 2 | | 12 | TdTXCr(TXD) | $\overline{\text{TxC}}$ † to TxD Delay (X1 Mode) | | 300 | | 230 | 2,5 | | 13 | TdTXD(TRX) | TxD to TRxC Delay (Send Clock Echo) | | 200 | | 200 | | | 14 | TwRTXh | RTxC High Width | 180 | | 180 | | | | 15— | - TwRTX1 | - RTxC Low Width - | <u> </u> | | <del></del> 180 | | | | 16 | TcRTX | RTxC Cycle Time | 400 | | 400 | | | | 17 | TcRTXX | Crystal Oscillator Period | 250 | 1000 | 250 | 1000 | 3 | | 18 | TwTRXh | TRxC High Width | 180 | | 180 | | | | 19 | TwTRX1 | TRxC Low Width | 180 | | 180 | | | | 20 — | - TcTRX | TRxC Cycle Time | <del></del> 400 | | <del></del> | | | | 21 | TwEXT | DCD or CTS Pulse Width | 200 | | 200 | | | | 22 | TwSY | SYNC Pulse Width | 200 | | 200 | | | $<sup>\</sup>frac{\text{NOTES}}{1 \quad \overline{\text{RxC}}} \text{ is } \overline{\text{RTxC}} \text{ or } \overline{\text{TRxC}}, \text{ whichever is supplying the receive}$ $<sup>\</sup>frac{\text{clock}}{\text{TxC}}$ is $\overline{\text{TRxC}}$ or $\overline{\text{RTxC}}$ , whichever is supplying the transmit clock 3 Both RTxC and SYNC have 30 pF capacitors to ground connected to them <sup>4</sup> Parameter applies only if the data rate is one-fourth the PCLK rate. In all other cases, no phase relationship between RxC and PCLK or TxC and PCLK is required. 5 Parameter applies only to FM encoding/decoding. 5 Timings are preliminary and subject to change. 5 Units in nanoseconds (ns). ## System Timing | | | | 4 | MHz | 61 | MHz | , | |-----|---------------|------------------------------------------|-----|-----|---------------|---------|---------| | No. | Symbol | Parameter | Min | Max | Min | Max | Notes*† | | 1 | TdRXC(REQ) | RxC † to W/REQ Valid Delay | 8 | 12 | 8 | 12 | 2 | | 2 | TdRXC(W) | RxC † to Wait Inactive Delay | 8 | 12 | 8 | 12 | 1,2 | | 3 | TdRXC(SY) | RxC † to SYNC Valid Delay | 4 | 7 | 4 | 7 | 2 | | 4 | TdRXC(INT) | RxC ↑ to INT Valid Delay | 10 | 16 | 10 | 16 | 1,2 | | 5 — | —Tdtxc(req) — | —TxC ↓ to W/REQ Valid Delay ————— | 5 — | 8 | <del> 5</del> | —— 8 —— | 3 | | 6 | TdTXC(W) | TxC ↓ to Wait Inactive Delay | 5 | 8 | 5 | 8 | 1,3 | | 7 | TdTXC(DRQ) | TxC ↓ to DTR/REQ Valid Delay | 4 | 7 | 4 | 7 | 3 | | 8 | TdTXC(INT) | TxC ↓ to INT Valid Delay | 6 | 10 | 6 | 10 | 1,3 | | 9 | TdSY(INT) | SYNC Transition to INT Valid Delay | 2 | 6 | 2 | 6 | 1 | | 10 | TdEXT(INT) | DCD or CTS Transition to INT Valid Delay | 2 | 6 | 2 | 6 | 1 | #### NOTES <sup>1</sup> Open-drain output, measured with open-drain test load RXC is RTxC or TRxC, whichever is supplying the receive clock TxC is TRxC or RTxC, whichever is supplying the transmit clock. $<sup>^{\</sup>star}$ Timings are preliminary and subject to change $\uparrow$ Units equal to TcPC | Ordering<br>Information | Product<br>Number | Package/<br>Temp | Speed | Description | Product<br>Number | Package/<br>Temp | Speed | Description | |-------------------------|-------------------|------------------|---------|---------------|-------------------|------------------|---------|---------------| | | Z8530 | CE | 4.0 MHz | SCC (40-pin) | Z8530A | CE | 6.0 MHz | SCC (40-pin) | | | Z8530 | CM | 4.0 MHz | Same as above | Z8530A | CM | 6.0 MHz | Same as above | | | Z8530 | CMB | 4.0 MHz | Same as above | Z8530A | CMB | 6.0 MHz | Same as above | | | Z8530 | CS | 4.0 MHz | Same as above | Z8530A | CS | 6.0 MHz | Same as above | | | Z8530 | DE | 4.0 MHz | Same as above | Z8530A | DE | 6.0 MHz | Same as above | | | Z8530 | DS | 4.0 MHz | Same as above | Z8530A | DS | 6.0 MHz | Same as above | | | Z8530 | PE | 4.0 MHz | Same as above | Z8530A | PE | 6.0 MHz | Same as above | | | Z8530 | PS | 4.0 MHz | Same as above | Z8530A | PS | 6.0 MHz | Same as above | NOTES. C = Ceramic, D = Cerdip, P = Plastic, E = -40 °C to +85 °C, M = -55 °C to 125 °C, MB = -55 °C to 125 °C with MIL-STD-883 with Class B processing, S = 0 °C to +70 °C | | ` | | | |--|---|--|--| | | | | | | | | | | | | | | | ### **Z8531 ASCC Asynchronous Serial Communications Controller** ### **Product Specification** #### **Features** - Two independent, 0 to 1M bit/second, fullduplex channels, each with a separate crystal oscillator, baud rate generator, and Digital Phase-Locked Loop for clock - Programmable for NRZ, NRZI, or FM data encodina. - June 1982 - Asynchronous communications with five to eight bits per character and one, one and one-half, or two stop bits per character; programmable clock factor; break detection and generation; parity, overrun, and framing error detection. - Local Loopback and Auto Echo modes. ### General Description The Z8531 ASCC Asynchronous Serial Communications Controller is a dual-channel. multi-protocol data communications peripheral designed for use with conventional nonmultiplexed buses. The ASCC functions as a serial-to-parallel, parallel-to-serial converter/controller. The device contains a variety of new, sophisticated internal functions including on-chip baud rate generators. Digital Phase-Locked Loops, and crystal oscillators that dramatically reduce the need for external loaic. The ASCC also has facilities for modem controls in both channels. In applications where these controls are not needed, the modem controls can be used for general-purpose I/O. The Z-BUS daisy-chain interrupt hierarchy is also supported—as is standard for Zilog peripheral components. The Z8531 ASCC is packaged in a 40-pin ceramic DIP and uses a single +5 V power Figure 2. Pin Assignments 2244-001, 002 #### Pin Description The following section describes the pin functions of the ASCC. Figures 1 and 2 detail the respective pin functions and pin assignments. **A/B**. Channel A/Channel B Select (input). This signal selects the channel in which the read or write operation occurs. **CE.** Chip Enable (input, active Low). This signal selects the ASCC for a read or write operation. CTSA. CTSB. Clear To Send (inputs, active Low). If these pins are programmed as Auto Enables, a Low on the inputs enables the respective transmitters. If not programmed as Auto Enables, they may be used as general-purpose inputs. Both inputs are Schmitt-trigger buffered to accommodate slow rise-time inputs. The ASCC detects pulses on these inputs and can interrupt the CPU on both logic level transitions. **D/C.** Data/Control Select (input). This signal defines the type of information transferred to or from the ASCC. A High means data is transferred; a Low indicates a command. DCDA. DCDB. Data Carrier Detect (inputs, active Low). These pins function as receiver enables if they are programmed for Auto Enables; otherwise they may be used as general-purpose input pins. Both pins are Schmitt-trigger buffered to accomodate slow rise-time signals. The ASCC detects pulses on these pins and can interrupt the CPU on both logic level transitions. **D<sub>0</sub>-D<sub>7</sub>.** Data Bus (bidirectional, 3-state). These lines carry data and commands to and from the ASCC. DTR/REQA, DTR/REQB. Data Terminal Ready/Request (outputs, active Low). These outputs follow the state programmed into the DTR bit. They can also be used as general-purpose outputs or as Request lines for a DMA controller. **IEI.** Interrupt Enable In (input, active High). IEI is used with IEO to form an interrupt daisy chain when there is more than one interrupt-driven device. A High IEI indicates that no other higher priority device has an interrupt under service or is requesting an interrupt. **IEO.** Interrupt Enable Out (output, active High). IEO is High only if IEI is High and the CPU is not servicing an ASCC interrupt or the ASCC is not requesting an interrupt (Interrupt Acknowledge cycle only). IEO is connected to the next lower priority device's IEI input and thus inhibits interrupts from lower priority devices. **INT.** Interrupt Request (output, open-drain, active Low). This signal is activated when the ASCC requests an interrupt. INTACK. Interrupt Acknowledge (input, active Low). This signal indicates an active Interrupt Acknowledge cycle. During this cycle, the ASCC interrupt daisy chain settles. When RD becomes active, the ASCC places an interrupt vector on the data bus (if IEI is High). INTACK is latched by the rising edge of PCLK. **PCLK.** Clock (input). This is the master ASCC clock used to synchronize internal signals; PCLK is a TTL level signal. **RD.** Read (input, active Low). This signal indicates a read operation and when the ASCC is selected, enables the ASCC's bus drivers. During the Interrupt Acknowledge cycle, this signal gates the interrupt vector onto the bus if the ASCC is the highest priority device requesting an interrupt. **RxDA. RxDB.** Receive Data (inputs, active High). These input signals receive serial data at standard TTL levels. RIA, RIB. Ring Indicator (inputs, active Low). These pins can act either as inputs, or part of the crystal oscillator circuit. In normal mode (crystal oscillator option not selected), these pins are inputs similar to CTS and DCD. In this mode, transitions on these lines affect the state of the Ring Indicator status bits in Read Register 0 (Figure 8) but have no other function. RTxCA, RTxCB. Receive/Transmit Clocks (inputs, active Low). These pins can be programmed in several different modes of operation. In each channel, RTxC may supply the receive clock, the transmit clock, the clock for the baud rate generator, or the clock for the Digital Phase-Locked Loop. These pins can also be programmed for use with the respective RI pins as a crystal oscillator. The receive clock may be 1, 16, 32, or 64 times the data rate in Asynchronous modes. RTSA. RTSB. Request To Send (outputs, active Low). When the Request To Send (RTS) bit in Write Register 5 (Figure 9) is set, the RTS signal goes Low. When the RTS bit is reset in the Asynchronous mode and Auto Enable is on, the signal goes High after the transmitter is empty. With Auto Enable off, the RTS pin strictly follows the state of the RTS bit. Both pins can be used as general-purpose outputs. **TxDB.** Transmit Data (outputs, active High). These output signals transmit serial data at standard TTL levels. $\overline{\text{TRxCA}}$ , $\overline{\text{TRxCB}}$ . Transmit/Receive Clocks (inputs or outputs, active Low). These pins can be programmed in several different modes of operation. $\overline{\text{TRxC}}$ may supply the receive clock or the transmit clock in the input mode or sup- Pin Description (Continued) ply the output of the Digital Phase-Locked Loop, the crystal oscillator, the baud rate generator, or the transmit clock in the output mode. $\overline{\mathbf{WR}}$ . Write (input, active Low). When the ASCC is selected, this signal indicates a write operation. The coincidence of $\overline{\mathrm{RD}}$ and $\overline{\mathrm{WR}}$ is interpreted as a reset. W/REQA. W/REQB. Wait/Request (outputs, open-drain when programmed for a Wait function, driven High or Low when programmed for a Request function). These dual-purpose outputs may be programmed as Request lines for a DMA controller or as Wait lines to synchronize the CPU to the ASCC data rate. The reset state is Wait. ### Functional Description The functional capabilities of the ASCC can be described from two different points of view: as a data communications device, it transmits and receives data in a wide variety of data communications protocols; as a microprocessor peripheral, the ASCC offers valuable features such as vectored interrupts, polling, and simple handshake capability. **Data Communications Capabilities.** The ASCC provides two independent full-duplex channels programmable for use in any common Asynchronous datacommunication protocol. Figure 3 and the following description briefly detail this protocol. Asynchronous Modes. Transmission and reception can be accomplished independently on each channel with five to eight bits per character, plus optional even or odd parity. The transmitters can supply one, one-and-ahalf, or two stop bits per character and can provide a break output at any time. The receiver break-detection logic interrupts the CPU both at the start and at the end of a received break. Reception is protected from spikes by a transient spike-rejection mechanism that checks the signal one-half a bit time after a Low level is detected on the receive data input (RxDA or RxDB in Figure 1). If the Low does not persist (as in the case of a transient), the character assembly process does not start. Framing errors and overrun errors are detected and buffered together with the partial character on which they occur. Vectored interrupts allow fast servicing of error conditions using dedicated routines. Furthermore, a built-in checking process avoids the interpretation of a framing error as a new start bit: a framing error results in the addition of one-half a bit time to the point at which the search for the next start bit begins. The ASCC does not require symmetric transmit and receive clock signals—a feature allowing use of the wide variety of clock sources. The transmitter and receiver can handle data at a rate of 1, 1/16, 1/32, or 1/64 of the clock rate supplied to the receive and transmit clock inputs. Baud Rate Generator. Each channel in the ASCC contains a programmable baud rate generator. Each generator consists of two 8-bit time constant registers that form a 16-bit time constant, a 16-bit down counter, and a flip-flop on the output producing a square wave. On startup, the flip-flop on the output is set in a High state, the value in the time constant register is loaded into the counter, and the counter starts counting down. The output of the baud rate generator toggles upon reaching 0, the value in the time constant register is loaded into the counter, and the process is repeated. The time constant may be changed at any time, but the new value does not take effect until the next load of the counter. The output of the baud rate generator may be used as either the transmit clock, the receive clock, or both. It can also drive the Digital Phase-Locked Loop (see next section). If the receive clock or transmit clock is not programmed to come from the TRxC pin, the output of the baud rate generator may be echoed out via the TRxC pin. The following formula relates the time constant to the baud rate (the baud rate is in bits/second and the BR clock period is in seconds): baud rate = $$\frac{1}{2 \text{ (time constant + 2)} \times \text{ (BR clock period)}}$$ Digital Phase-Locked Loop. The ASCC contains a Digital Phase-Locked-Loop (DPLL) to recover clock information from a data stream with NRZI or FM encoding. The DPLL is driven by a clock that is nominally 32 (NRZI) or 16 (FM) times the data rate. The DPLL uses this clock, along with the data stream, to construct a clock for the data. This clock may then be used as the ASCC receive clock, the transmit clock, or both. Figure 3. ASCC Protocol For NRZI encoding, the DPLL counts the 32x clock to create nominal bit times. As the 32x clock is counted, the DPLL is searching the incoming data stream for edges (either 1 to 0 or 0 to 1). Whenever an edge is detected, the DPLL makes a count adjustment (during the next counting cycle), producing a terminal count closer to the center of the bit cell. For FM encoding, the DPLL still counts from 0 to 31, but with a cycle corresponding to two bit times. When the DPLL is locked, the clock edges in the data stream should occur between counts 15 and 16 and between counts 31 and 0. The DPLL locks for edges only during a time centered on the 15 to 16 counting transition. The 32x clock for the DPLL can be programmed to come from either the $\overline{RTxC}$ input or the output of the baud rate generator. The DPLL output may be programmed to be echoed out of the ASCC via the $\overline{TRxC}$ pin (if this pin is not being used as an input). Data Encoding. The ASCC may be programmed to encode and decode the serial data ın four different ways (Figure 4). In NRZ encoding, a l is represented by a High level and a 0 is represented by a Low level. In NRZI encoding, a l is represented by no change in level and a 0 is represented by a change in level. In FM1 (more properly, bi-phase mark), a transition occurs at the beginning of every bit cell. A l is represented by an additional transition at the center of the bit cell and a 0 is represented by no additional transition at the center of the bit cell. In FMO (bi-phase space), a transition occurs at the beginning of every bit cell. A 0 is represented by an additional transition at the center of the bit cell, and a l is represented by no additional transition at the center of the bit cell. In addition to these four methods, the ASCC can be used to decode Manchester (bi-phase level) data by using the DPLL in the FM mode and programming the receiver for NRZ data. Manchester encoding always produces a transition at the center of the bit cell. If the transition is 0 to 1, the bit is a 0. If the transition is 1 to 0, the bit is a 1. Auto Echo and Local Loopback. The ASCC is capable of automatically echoing everything it receives. In Auto Echo mode, RxD is connected to TxD internally. Auto Echo mode can be used with NRZI or FM encoding with no additional delay, because the data stream is not decoded before retransmission. In Auto Echo mode, the CTS input is ignored as a transmitter enable (although transitions on this input can still cause interrupts if programmed to do so). In this mode, the transmitter is actually bypassed and the programmer is responsible for disabling transmitter interrupts and WAIT/REQUEST on transmit. In this mode TxD is connected to RxD internally, just as in Auto Echo mode. However, in Local Loopback mode, the internal transmit data is tied to the internal receive data and RxD is ignored (except to be echoed out via TxD). The CTS and DCD inputs are also ignored as transmit and receive enables. However, transitions on these inputs can still cause interrupts. Local Loopback works with NRZ, NRZI or FM coding of the data stream. The ASCC is also capable of local loopback. I/O Interface Capabilities. The ASCC offers the choice of Polling, Interrupt (vectored or nonvectored), and Block Transfer modes to transfer data, status, and control information to and from the CPU. The Block Transfer mode can be implemented under CPU or DMA control. Polling. All interrupts are disabled. Three status registers in the ASCC are automatically updated whenever any function is performed. The idea behind polling is for the CPU to periodically read a status register until the register contents indicate the need for data to be transferred. Only one register needs to be read; depending on its contents, the CPU either writes data, reads data, or continues. Two bits in the register indicate the need for Figure 4. Data Encoding Methods data transfer. An alternative is a poll of the Interrupt Pending register to determine the source of an interrupt. The status for both channels resides in one register. Interrupts. When an ASCC responds to an Interrupt Acknowledge signal (INTACK) from the CPU, an interrupt vector may be placed on the data bus. This vector is written in WR2 and may be read in RR2A or RR2B (Figures 8 and 9). To speed interrupt response time, the ASCC can modify three bits in this vector to indicate status. If the vector is read in Channel A, status is never included; if it is read in Channel B, status is always included. Each of the six sources of interrupts in the ASCC (Transmit, Receive, and External/Status interrupts in both channels) has three bits associated with the interrupt source: Interrupt Pending (IP), Interrupt Under Service (IUS), and Interrupt Enable (IE). Operation of the IE bit is straightforward. If the IE bit is set for a given interrupt source, then that source can request interrupts. The exception is when the MIE (Master Interrupt Enable) bit in WR9 is reset and no interrupts may be requested. The IE bits are write only. The other two bits are related to the interrupt priority chain (Figure 5). As a microprocessor peripheral, the ASCC may request an interrupt only when no higher priority device is requesting one, e.g., when IEI is High. If the device in question requests an interrupt, it pulls down INT. The CPU then responds with INTACK, and the interrupting device places the vector on the data bus. In the ASCC, the IP bit signals a need for interrupt servicing. When an IP bit is 1 and the IEI input is High, the INT output is pulled Low, requesting an interrupt. In the ASCC, if the IE bit is not set by enabling interrupts, then the IP for that source can never be set. The IP bits are readable in RR3A. The IUS bits signal that an interrupt request is being serviced. If an IUS is set, all interrupt sources of lower priority in the ASCC and external to the ASCC are prevented from requesting interrupts. The internal interrupt sources are inhibited by the state of the internal daisy chain, while lower priority devices are inhibited by the IEO output of the ASCC being pulled Low and propagated to subsequent peripherals. An IUS bit is set during an Interrupt Acknowledge cycle if there are no higher priority devices requesting interrupts. There are three types of interrupts: Transmit, Receive, and External/Status. Each interrupt type is enabled under program control with Channel A having higher priority than Channel B, and with Receiver, Transmit, and External/Status interrupts prioritized in that order within each channel. When the Transmit interrupt is enabled, the CPU is interrupted when the transmit buffer becomes empty. (This implies that the transmitter must have had a data character written into it so that it can become empty.) When enabled, the receiver can interrupt the CPU in one of three ways: - Interrupt on First Receive Character or Special Receive Condition. - Interrupt on All Receive Characters or Special Receive Condition. - Interrupt on Special Receive Condition Only. Interrupt on First Character or Special Condition and Interrupt on Special Condition Only are typically used with the Block Transfer mode. A Special Receive Condition is a receiver overrun, and, optionally, a parity error. The Special Receive Condition interrupt is different from an ordinary receive character available interrupt only in the status placed in the vector during the Interrupt Acknowledge cycle. In Interrupt on First Receive Character, an interrupt can occur from Special Receive Conditions any time after the first receive character interrupt. The main function of the External/Status interrupt is to monitor the signal transitions of the $\overline{CTS}$ , $\overline{DCD}$ , and $\overline{RI}$ pins; however, an External/Status interrupt is also caused by a Transmit Underrun condition, or a zero count in the baud rate generator, or by the detection of a Break. Figure 5. Interrupt Schedule 2016-003 CPU/DMA Block Transfer. The ASCC provides a Block Transfer mode to accommodate CPU block transfer functions and DMA controllers. The Block Transfer mode uses the WAIT/ REQUEST output in conjunction with the Wait/Request bits in WR1. The WAIT/ REQUEST output can be defined under software control as a WAIT line in the CPU Block Transfer mode or as a REQUEST line in the #### DMA Block Transfer mode. To a DMA controller, the ASCC $\overline{\text{REQUEST}}$ output indicates that the ASCC is ready to transfer data to or from memory. To the CPU, the $\overline{\text{WAIT}}$ line indicates that the ASCC is not ready to transfer data, thereby requesting that the CPU extend the I/O cycle. The $\overline{\text{DTR}}/\overline{\text{REQUEST}}$ line allows full-duplex operation under DMA control. #### Architecture The ASCC internal structure includes two full-duplex channels, two baud rate generators, internal control and interrupt logic, and a bus interface to a nonmultiplexed bus. Associated with each channel are a number of read and write registers for mode control and status information, as well as logic necessary to interface to modems or other external devices (Figure 6). The logic for both channels provides formats, synchronization, and validation for data transferred to and from the channel interface. The modem control inputs are monitored by the control logic under program control. All of the modem control signals are generalpurpose in nature and can optionally be used for functions other than modem control. The register set for each channel includes ten control (write) registers, and four status (read) registers. In addition, each baud rate generator has two (read/write) registers for holding the time constant that determines the Figure 6. Block Diagram of ASCC Architecture 364 2244-003 **Z8231 Y2CC** ### Architecture (Continued) baud rate. Finally, associated with the interrupt logic is a write register for the interrupt vector accessible through either channel, a write only Master Interrupt Control register and three read registers: one containing the vector with status infomation (Channel B only), one containing the vector without status (Channel A only), and one containing the Interrupt Pending bits (Channel A only). The registers for each channel are designated as follows: WR0-WR15 — Write Registers 0-5, 8-15. RR0-RR3, RR10, RR12, RR13, RR15 — Read Registers 0 through 3, 10, 12, 13, 15. Table 1 lists the functions assigned to each read or write register. The ASCC contains only one WR2 and WR9, but they can be accessed by either channel. All other registers are paired (one for each channel). **Data Path.** The transmit and receive data path illustrated in Figure 7 is identical for both channels. The receiver has three 8-bit buffer registers in an FIFO arrangement, in addition to the 8-bit receive shift register. This scheme creates additional time for the CPU to service an interrupt at the beginning of a block of high speed data. Incoming data is routed through one of several paths depending on the selected mode (the character length also determines the data path). The transmitter has an 8-bit Transmit Data buffer register loaded from the internal data bus and an 11-bit Transmit Shift register that can be loaded from the Transmit Data register. #### Read Register Functions Transmit/Receive buffer status and External status RR0 RR13 RR15 WR11 WR12 WR15 | RR1 | Special Receive Condition status | |------|-----------------------------------------------------------------------------------------| | RR2 | Modified interrupt vector (Channel B only) Unmodified interrupt vector (Channel A only) | | RR3 | Interrupt Pending bits (Channel A only) | | RR8 | Receive buffer | | RR10 | Miscellaneous status | | RR12 | Lower byte of baud rate generator time constant | #### Write Parietes Functions External/Status interrupt information Upper byte of baud rate generator time constant | | Write Register Functions | |------|-----------------------------------------------------------------------------------| | WR0 | CRC initialize, initialization commands for the various modes, Register Pointers. | | WR1 | Transmit/Receive interrupt and data transfer mode definition | | WR2 | Interrupt vector (accessed through either channel | | WR3 | Receive parameters and control | | WR4 | Transmit/Receive miscellaneous parameters and modes | | WR5 | Transmit parameters and controls | | WR8 | Transmit buffer | | WR9 | Master interrupt control and reset (accessed through either channel) | | WR10 | Miscellaneous transmitter/receiver control bits | WR13 Upper byte of baud rate generator time constant WR14 Miscellaneous control bits External/Status interrupt control Lower byte of baud rate generator time constant Clock mode control Table 1. Read and Write Register Functions #### Programming The ASCC contains 11 write registers in each channel that are programmed by the system separately to configure the functional personality of the channels. In the ASCC, register addressing is direct for the data registers only, which are selected by a High on the $D/\overline{C}$ pin. In all other cases (with the exception of WR0 and RR0), programming the write registers requires two write operations and reading the read registers requires both a write and a read operation. The first write is to WR0 and contains three bits that point to the selected register. The second write is the actual control word for the selected register, and if the second operation is read, the selected read register is accessed. All of the registers in the ASCC, including the data registers, may be accessed in this fashion. The pointer bits are automatically cleared after the read or write operation so that WRO (or RRO) is addressed again. The system program first issues a series of commands to initialize the basic mode of operation. For example, the character length, clock rate, number of stop bits, even or odd parity might be set first. Then the interrupt mode would be set, and finally, receiver or transmitter enable. ### Programming (Continued) Read Registers. The ASCC contains eight read registers (actually nine, counting the receive buffer (RR8) in each channel). Four of these may be read to obtain status information (RR0, RR1, RR10, and RR15). Two registers (RR12 and RR13) may be read to learn the baud rate generator time constant. RR2 contains either the unmodified interrupt vector (Channel A) or the vector modified by status information (Channel B). RR3 contains the #### Read Register 0 #### Read Register 1 #### Read Register 2 #### Read Register 3 Interrupt Pending (IP) bits (Channel A). Figure 8 shows the formats for each read register. The status bits of RRO and RR1 are carefully grouped to simplify status monitoring; e.g., when the interrupt vector indicates a Special Receive Condition interrupt, all the appropriate error bits can be read from a single register (RR1). #### Read Register 10 #### Read Register 12 #### Read Register 13 #### Read Register 15 Figure 8. Read Register Bit Functions 2244 005 ### (Continued) Programming Write Registers. The ASCC contains 11 write registers (12 counting WR8, the transmit buffer) in each channel. These write registers are programmed separately to configure the functional "personality" of the channels. In addition, there are two registers (WR2 and #### Write Register 0 \*WITH POINT HIGH COMMAND #### Write Register 1 #### Write Register 2 WR9) shared by the two channels that may be accessed through either of them. WR2 contains the interrupt vector for both channels, while WR9 contains the interrupt control bits. Figure 9 shows the format of each write reaister. #### Write Register 3 #### Write Register 4 #### Write Register 5 Figure 9. Write Register Bit Functions #### Programming Write Register 9 (Continued) #### Write Register 10 #### Write Register 11 #### Write Register 12 #### Write Register 13 ### Write Register 14 #### Write Register 15 Figure 9. Write Register Bit Functions (Continued) 2244 006 #### Timing The ASCC generates internal control signals from $\overline{WR}$ and $\overline{RD}$ that are related to PCLK. Since PLCK has no phase relationship with $\overline{WR}$ and $\overline{RD}$ , the circuitry generating these internal control signals must provide time for metastable conditions to disappear. This gives rise to a recovery time related to PCLK. The recovery time applies only between bus transactions involving the ASCC. The recovery time required for proper operation is specified from the rising edge of $\overline{WR}$ or $\overline{RD}$ in the first transaction involving the ASCC to the falling edge of $\overline{\text{WR}}$ or $\overline{\text{RD}}$ in the second transaction involving the ASCC. This time must be at least 6 PLCK cycles plus 200 ns. **Read Cycle Timing.** Figure 10 illustrates read cycle timing, Addresses on $A/\overline{B}$ and $D/\overline{C}$ and the status on $\overline{INTACK}$ must remain stable throughout the cycle. If $\overline{CE}$ falls after $\overline{RD}$ falls, or rises before $\overline{RD}$ rises, the effective $\overline{RD}$ is shortened. Figure 10. Read Cycle Timing **Write Cycle Timing.** Figure 11 illustrates write cycle timing. Addresses on $A/\overline{B}$ and $D/\overline{C}$ and the status on $\overline{1NTACK}$ must remain stable throughout the cycle. If $\overline{CE}$ falls after $\overline{WR}$ falls or rises before $\overline{WR}$ rises, the effective $\overline{WR}$ is shortened. Figure 11. Write Cycle Timing Interrupt Acknowledge Cycle Timing. Figure 12 illustrates interrupt acknowledge cycle timing. Between the time $\overline{\text{INTACK}}$ goes low and the falling edge of $\overline{\text{RD}}$ , the internal and external IEI/IEO daisy chains settle. If there is an interrupt pending the ASCC and IEI is High when $\overline{RD}$ falls, the acknowledge cycle was intended for the ASCC. In this case, the ASCC may be programmed to respond to $\overline{RD}$ Low by placing its interrupt vector on $D_0-D_7$ and sets the appropriate Interrupt-Under-Service latch internally. Figure 12. Interrupt Acknowledge Cycle Timing 370 2023-003, 004, 005 | Absolute<br>Maximum | Voltages on all inputs and outputs<br>with respect to GND0.3 V to +7.0 V | |---------------------|--------------------------------------------------------------------------| | Ratings | Operating Ambient Temperature | | | Storage Temperature65°C to +150°C | | G. 1 1 | T 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | 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 following standard test conditions, unless otherwise noted. All voltages are referenced to GND. Positive current flows into the referenced pin. Standard conditions are as follows: - $\blacksquare$ +4.75 V $\leq$ V $_{\rm CC}$ $\leq$ +5.25 V - GND = 0 V - TA as specified in Ordering Information All ac parameters assume a load capacitance of 50 pF max. Figure 13. Standard Test Load Figure 14. Open-Drain Test Load | DC | Symbol | Parameter | Min | Max | Unit | Condition | |----------------------|----------------------------|----------------------------|------|----------------|---------|--------------------------------| | Charac-<br>teristics | $V_{IH}$ | Input High Voltage | 2.0 | $V_{CC} + 0.3$ | v | | | | ${ m v}_{_{ m IL}}$ | Input Low Voltage | -0.3 | 0.8 | V | | | | $v_{_{\mathrm{OH}}}$ | Output High Voltage | 2.4 | | V | $I_{OH} = -250 \mu A$ | | | $v_{ol}$ | Output Low Voltage | • | 0.4 | V | $I_{OL} = +2.0 \text{ mA}$ | | | $\mathbf{I}_{\mathtt{IL}}$ | Input Leakage | | ±10.0 | $\mu$ A | $0.4 \le V_{\rm IN} \le +2.4V$ | | | $I_{OL}$ | Output Leakage | | ±10.0 | $\mu$ A | $0.4 \le V_{OUT} \le +2.4V$ | | | $I_{CC}$ | $ m V_{CC}$ Supply Current | | 250 | mA | | $V_{\rm CC}$ = 5 V $\pm$ 5% unless otherwise specified, over specified temperature range. | Capacitance | Symbol | Parameter | Min | Max | Unit | Test Condition | |-------------|-----------|---------------------------|-----|-----|------|--------------------| | | $C_{IN}$ | Input Capacitance | | 10 | рF | Unmeasured Pins | | | $C_{OUT}$ | Output Capacitance | | 15 | рF | Returned to Ground | | | $C_{I/O}$ | Bidirectional Capacitance | | 20 | рF | | f = 1 MHz, over specified temperature range ### Read and Write Timing | | | | 4 | MHz | 6 MHz | | | |-----|--------------|---------------------------------------|-----------------------------|------------------------------|-----------------------------|-------------|---------| | No. | Symbol | Parameter | Min | Max | Min | Max | Notes*† | | 1 | TwPC1 | PCLK Low Width | 105 | 2000 | 70 | 1000 | | | 2 | TwPCh | PCLK High Width | 105 | 2000 | 70 | 1000 | | | 3 | TfPC | PCLK Fall Time | | 20 | | 10 | | | 4 | TrPC | PCLK Rise Time | | 20 | | 15 | | | 5- | TcPC | — PCLK Cycle Time | <del></del> | <del></del> 4000 <del></del> | <del></del> 165 - | <del></del> | | | 6 | TsA(WR) | Address to WR ↓ Setup Time | 80 | | 80 | | | | 7 | ThA(WR) | Address to WR † Hold Time | 0 | | 0 | | | | 8 | TsA(RD) | Address to RD ↓ Setup Time | 80 | | 80 | | | | 9 | ThA(RD) | Address to RD 1 Hold Time | 0 | | 0 | | | | 10- | TsIA(PC) | - INTACK to PCLK Setup Time | 0 | | 0 - | | | | 11 | TsIAi(WR) | INTACK to WR ↓ Setup Time | 200 | | 200 | | 1 | | 12 | ThIA(WR) | INTACK to WR † Hold Time | 0 | | 0 | | | | 13 | $TsIA_1(RD)$ | INTACK to RD ↓ Setup Time | 200 | | 200 | | 1 | | 14 | ThIA(RD) | INTACK to RD † Hold Time | 0 | | 0 | | | | 15- | —ThIA(PC) —— | - INTACK to PCLK † Hold Time | <del>1</del> 00 <del></del> | | <del></del> 100 <del></del> | | | | 16 | TsCEl(WR) | CE Low to WR ↓ Setup Time | 0 | | 0 | | | | 17 | ThCE(WR) | CE to WR † Hold Time | 0 | | 0 | | | | 18 | TsCEh(WR) | CE High to WR ↓ Setup Time | 100 | | 70 | | | | 19 | TsCEl(RD) | CE Low to RD Setup Time | 0 | | 0 | | 1 | | 20 | ThCE(RD) | CE to RD † Hold Time | 0 | | 0 | | 1 | | 21- | —TsCEh(RD)— | — CE High to RD ↓ Setup Time | 100- | | <del></del> 70 | | 1 | | 22 | TwRDl | RD Low Width | 390 | | 250 | | 1 | | 23 | TdRD(DRA) | <u>RD</u> ↓ to Read Data Active Delay | 0 | | 0 | | | | 24 | TdRDr(DR) | RD 1 to Read Data Not Valid Delay | 0 | | 0 | | | | 25 | TdRDf(DR) | RD ↓ to Read Data Valıd Delay | | 250 | | 180 | | | 26 | TdRD(DRz) | RD † to Read Data Float Delay | | 70 | | 45 | 2 | | | | | | | | | | NOTES: <sup>1</sup> Parameter does not apply to Interrupt Acknowledge transactions Float delay is defined as the time required for a ±0.5 V change in the output with a maximum dc load and minimum ac load Timings are preliminary and subject to change Units in nanoseconds (ns) | | | | 4 | MHz | 6 1 | | | |-------------|------------------------|----------------------------------------------------------------|-------|---------------------|-------|-----------------------------|--------------| | No. | Symbol | Parameter | Min | Max | Min | Max | Notes*† | | 27 | TdA(DR) | Address Required Valid to Read Data Valid Delay | | 590 | | 420 | | | 28 | TwWRl | WR Low Width | 390 | | 250 | | | | 29 | TsDW(WR) | Write Data to WR ↓ Setup Time | 0 | | 0 | | | | 30 | ThDW(WR) | Write Data to WR † Hold Time | 0 | | 0 | | | | 31 - | <del>-</del> TdWR(W) | —WR ↓ to Wait Valid Delay ———————————————————————————————————— | | <del> 240</del> | | <u> </u> | ——— 4 —— | | 32 | TdRD(W) | RD ↓ to Wa <u>ıt Valıd</u> Delay | | 240 | | 200 | 4 | | 33 | TdWRf(REQ) | <u>WR ↓ to W/REQ</u> Not Valid Delay | | 240 | | 200 | | | 34 | TdRDf(REQ) | RD ↓ to W/REQ Not Valid Delay | | 240 | | 200 | | | 35 | TdWRr(REQ) | WR ↑ to DTR/REQ Not Valid Delay | | 5TcPC | | 5TcPC | | | | | | | + 300 | | + 250 | | | 36 <b>–</b> | −TdRDr(REQ)−− | RD to DTR/REQ Not Valid Delay | | –5TcPC <del>–</del> | | –5TcPC <del>–</del> | | | | | | | + 300 | | + 250 | | | 37 | TdPC(INT) | PCLK ↓ to INT Valid Delay | | 500 | | 500 | 4 | | 38 | TdIA1(RD) | INTACK to RD (Acknowledge) Delay | | | | | 5 | | 39 | TwRDA | RD (Acknowledge) Width | 285 | | 250 | | | | 40 — | −TdRDA(DR) <del></del> | —RD↓(Acknowledge) to Read Data Valid Delay—— | | <del></del> 190 | | <del></del> 180 <del></del> | | | 41 | TsIEI(RDA) | IEI to RD ↓ (Acknowledge) Setup Time | 120 | | 100 | | | | 42 | ThIEI(RDA) | IEI to RD † (Acknowledge) Hold Time | 0 | | 0 | | | | 43 | TdIEI(IEO) | IEI to IEO Delay Time | | 120 | | 100 | | | 44 | TdPC(IEO) | PCLK † to IEO Delay | | 250 | | 250 | | | 45 <b>–</b> | —Tdrda(Int) — | — <u>RD</u> ↓ to <u>INT</u> Inactive Delay | | <del></del> 500 | | 500 | <del>4</del> | | 46 | TdRD(WRQ) | <u>RD</u> ↑ to <u>WR</u> ↓ Delay for No Reset | 30 | | 15 | | | | 47 | TdWRQ(RD) | <u>WR</u> ↑ to <u>RD</u> ↓ Delay for No Reset | 30 | | 30 | | | | 48 | Twres | WR and RD Coincident Low for Reset | 250 | | 250 | | | | 49 | Trc | Valıd Access Recovery Tıme | 6TcPC | | 6TcPC | | | | | | | + 200 | | +130 | | 3 | #### NOTES for the highest priority device in the daisy chain, TsIEI(RDA) for the ASCC, and TdIEIf(IEO) for each device separating them in the daisy chain 2023-007, 008, 009 <sup>3.</sup> Parameter applies only between transactions involving the ASCC <sup>4</sup> Open-drain output, measured with open-drain test load 5 Parameter is system dependent. For any ASCC in the daisy chain, TdIAi(RD) must be greater than the sum of TdPC(IEO) <sup>\*</sup> Timings are preliminary and subject to change <sup>†</sup> Units in nanoseconds (ns) | | | | 4 | 4 MHz | | 6 MHz | | |------|-----------------|----------------------------------------------------------|-------|------------------------------|-----------------------------|------------------------------|---------| | No. | Symbol | Parameter | Min | Max | Min | Max | Notes*† | | 1 | TdPC(REQ) | PCLK ↓ to W/REQ Valid Delay | | 250 | | 250 | | | 2 | TdPC(W) | PCLK ↓ to Wait Inactive Delay | | 350 | | 350 | | | 3 | TsRXC(PC) | RxC † to PCLK † Setup Time | 50 | | 50 | | 1,4 | | 4 | TsRXD(RXCr) | RxD to RxC † Setup Time (X1 Mode) | 0 | | 0 | | 1 | | 5 – | – ThRXD(RXCr) – | - RxD to RxC † Hold Time (X1 Mode) | 150 - | | 150 <b>-</b> - | | —— 1 — | | 6 | TsRXD(RXCf) | RxD to RxC ↓ Setup Time (X1 Mode) | 0 | | 0 | | 1,5 | | 7 | ThRXD(RXCf) | $RxD$ to $\overline{RxC} \downarrow Hold Time (X1 Mode)$ | 150 | | 150 | | 1,5 | | 8 | TsTXC(PC) | TxC ↓ to PCLK ↑ Setup Time | 0 | | 0 | | 2,4 | | 9 | TdTXCf(TXD) | TxC ↓ to TxD Delay (X1 Mode) | | 300 | | 300 | 2 | | 10 - | – TdTXCr(TXD) – | — TxC † to TxD Delay (X1 Mode) ————— | | 300 | | <del></del> 300 | 2,5 | | 11 | TdTXD(TRX) | TxD to TRxC Delay (Send Clock Echo) | | | | | | | 12 | TwRTXh | RTxC High Width | 180 | | 180 | | | | 13 | TwRTX1 | RTxC Low Width | 180 | | 180 | | | | 14 | TcRTX | RTxC Cycle Time | 400 | | 400 | | | | 15 - | TcRTXX —— | — Crystal Oscillator Period ————— | 250 - | <del></del> 1000 <del></del> | <del></del> 250 <del></del> | <del></del> 1000 <del></del> | — 3 — | | 16 | TwTRXh | TRxC High Width | 180 | | 180 | | | | 17 | TwTRX1 | TRxC Low Width | 180 | | 180 | | | | 18 | TcTRX | TRxC Cycle Time | 400 | | 400 | | | | 19 | TwEXT | DCD or CTS or RI Pulse Width | 200 | | 200 | | | NOTES. 1 RXC is RTxC or TRxC, whichever is supplying the receive clock 2 TXC is TRxC or RTxC, whichever is supplying the transmit clock 3. Both RTxC and RI have 30 pF capacitors to ground connected to them Parameter applies only if the data rate is one-fourth the PCLK rate. In all other cases, no phase relationship between RxC and PCLK or TxC and PCLK is required Parameter applies only to FM encoding/decoding Timings are preliminary and subject to change. <sup>†</sup> Units in nanoseconds (ns) ## System RTxC, TRxC RECEIVE Timing W/REQ REQUEST W/REQ WAIT 2 INT RTxC, TRxC W/REQ REQUEST W/REQ DTR/REQ REQUEST INT | | | | 4 MHz | | 6 MHz | | | | |-----|----------------|-----------------------------------------------------------------------------------|--------------|---------------|-------|---------------|-------------------|--| | No. | Symbol | Parameter | Min | Max | Min | Max | Notes*† | | | 1 | TdRXC(REQ) | $\overline{ ext{RxC}}$ † to $\overline{ ext{W}}/\overline{ ext{REQ}}$ Valid Delay | 8 | 12 | 8 | 12 | 2 | | | 2 | TdRXC(W) | RxC † to Wait Inactive Delay | 8 | 12 | 8 | 12 | 1,2 | | | 3 | TdRXC(INT) | RxC † to INT Valid Delay | 10 | 16 | 10 | 16 | 1,2 | | | 4 - | — TdTXC(REQ) — | — TxC ↓ to W/REQ Valid Delay ———————————————————————————————————— | <del>5</del> | <del></del> 8 | 5 | <del></del> 8 | —— 3 <del>—</del> | | | 5 | TdTXC(W) | TxC ↓ to Wait Inactive Delay | 5 | 8 | 5 | 8 | 1,3 | | | 6 | TdTXC(DRQ) | TxC ↓ to DTR/REQ Valid Delay | 4 | 7 | 4 | 7 | 3 | | | 7 | TdTXC(INT) | TxC ↓ to INT Valid Delay | 6 | 10 | 6 | 10 | 1,3 | | | 8 | TdEXT(INT) | DCD or CTS Transition to INT Valid Delay | 2 | 6 | 2 | 6 | 1 | | #### NOTES CTS, DCD, RI INT NOIES 1. Open-drain output, measured with open-drain test load 2. RXC is RTxC or TRxC, whichever is supplying the receive clock. 3. TxC is TRxC or RTxC, whichever is supplying the transmit clock. $<sup>^{\</sup>star}$ Timings are preliminary and subject to change. † Units equal to TcPC | Ordering<br>Information | Product<br>Number | Package/<br>Temp | Speed | Description | Product<br>Number | Package/<br>Temp | Speed | Description | |-------------------------|-------------------|------------------|---------|---------------|-------------------|------------------|---------|---------------| | | Z8531 | CE | 4.0 MHz | ASCC (40-pin) | Z8531 <b>A</b> | CE | 6.0 MHz | ASCC (40-pin) | | | Z8531 | CM | 4.0 MHz | Same as above | Z8531 <b>A</b> | CM | 6.0 MHz | Same as above | | | Z8531 | CMB | 4.0 MHz | Same as above | Z8531A | CMB | 6.0 MHz | Same as above | | | Z8531 | CS | 4.0 MHz | Same as above | Z8531 <b>A</b> | CS | 6.0 MHz | Same as above | | | Z8531 | DE | 4.0 MHz | Same as above | Z8531 <b>A</b> | DE | 6.0 MHz | Same as above | | | Z8531 | DS | 4.0 MHz | Same as above | Z8531 <b>A</b> | DS | 6.0 MHz | Same as above | | | Z8531 | PE | 4.0 MHz | Same as above | Z8531 <b>A</b> | PE | 6.0 MHz | Same as above | | | Z8531 | PS | 4.0 MHz | Same as above | Z8531A | PS | 6.0 MHz | Same as above | NOTES C = Ceramic, D = Cerdip, P = Plastic, CM = $-55^{\circ}$ C to $+125^{\circ}$ C, E = $-40^{\circ}$ C to $+85^{\circ}$ C, M = $-55^{\circ}$ C to $125^{\circ}$ C, MB = $-55^{\circ}$ C to $+125^{\circ}$ C with MIL-STD-883 Class B processing, S = $0^{\circ}$ C to $+70^{\circ}$ C | , | | | |---|--|--| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | ### Z8536 CIO Counter/Timer and Parallel I/O Unit # **Product Specification** June 1982 #### **Features** - Two independent 8-bit, double-buffered, bidirectional I/O ports plus a 4-bit special-purpose I/O port. I/O ports feature programmable polarity, programmable direction (Bit mode), "pulse catchers," and programmable opendrain outputs. - Four handshake modes, including 3-Wire (like the IEEE-488). - REQUEST/WAIT signal for high-speed data transfer. - Flexible pattern-recognition logic, programmable as a 16-vector interrupt controller. - Three independent 16-bit counter/timers with up to four external access lines per counter/timer (count input, output, gate, and trigger), and three output duty cycles (pulsed, one-shot, and square-wave), programmable as retriggerable or nonretriggerable. - Easy to use since all registers are read/write. #### General Description The Z8536 CIO Counter/Timer and Parallel I/O element is a general-purpose peripheral circuit, satisfying most counter/timer and parallel I/O needs encountered in system designs. This versatile device contains three I/O ports and three counter/timers. Many programmable options tailor its configuration to specific applications. The use of the device is simplified by making all internal registers (command, status, and data) readable and (except for status bits) writable. In addition, each register is given its own unique internal address, so that any register can be accessed in two operations. All data registers can be directly accessed in a single operation. The CIO is easily interfaced to all popular microprocessors. Figure 1. Pin Functions Figure 2. Pin Assignments #### Pin Description **A<sub>0</sub>-A<sub>1</sub>.** Address Lines (input). These two lines are used to select the register involved in the CPU transaction: Port A's Data register, Port B's Data register, Port C's Data register, or a control register. **CE.** Chip Enable (input, active Low). A Low level on this input enables the CIO to be read from or written to. **D<sub>0</sub>-D<sub>7</sub>.** Data Bus (bidirectional 3-state). These eight data lines are used for transfers between the CPU and the CIO. **IEI.** Interrupt Enable In (input, active High). IEI is used with IEO to form an interrupt daisy chain when there is more than one interrupt-driven device. A High IEI indicates that no other higher priority device has an interrupt under service or is requesting an interrupt. **IEO.** Interrupt Enable Out (output, active High). IEO is High only if IEI is High and the CPU is not servicing an interrupt from the requesting CIO or is not requesting an interrupt (Interrupt Acknowledge cycle only). IEO is connected to the next lower priority device's IEI input and thus inhibits interrupts from lower priority devices. **INT.** Interrupt Request (output, open-drain, active Low). This signal is pulled Low when the CIO requests an interrupt. INTACK. Interrupt Acknowledge (input, active Low). This input indicates to the CIO that an Interrupt Acknowledge cycle is in progress. INTACK must be synchronized to PCLK, and it must be stable throughout the Interrupt Acknowledge cycle. **PA<sub>0</sub>-PA<sub>7</sub>.** Port A I/O lines (bidirectional, 3-state, or open-drain). These eight I/O lines transfer information between the CIO's Port A and external devices. **PB<sub>0</sub>-PB<sub>7</sub>.** Port B I/O lines (bidirectional, 3-state, or open-drain). These eight I/O lines transfer information between the CIO's Port B and external devices. May also be used to provide external access to Counter/Timers 1 and 2. **PC<sub>0</sub>-PC<sub>3</sub>.** Port C I/O lines (bidirectional, 3-state, or open-drain). These four I/O lines are used to provide handshake, WAIT, and REQUEST lines for Ports A and B or to provide external access to Counter/Timer 3 or access to the CIO's Port C. **PCLK.** Peripheral Clock (input, TTL-compatible). This is the clock used by the internal control logic and the counter/timers in timer mode. It does not have to be the CPU clock. **RD\*.** Read (input, active Low). This signal indicates that a CPU is reading from the CIO. During an Interrupt Acknowledge cycle, this signal gates the interrupt vector onto the data bus if the CIO is the highest priority device requesting an interrupt. **WR\*.** Write (input, active Low). This signal indicates a CPU write to the CIO. \*When $\overline{RD}$ and $\overline{WR}$ are detected Low at the same time (normally an illegal condition), the CIO is reset. #### Architecture The CIO Counter/Timer and Parallel I/O element (Figure 3) consists of a CPU interface, three I/O ports (two general-purpose 8-bit ports and one special-purpose 4-bit port), Figure 3. CIO Block Diagram Figure 4. Ports A and B Block Diagram three 16-bit counter/timers, an interruptcontrol logic block, and the internal-control logic block. An extensive number of programmable options allow the user to tailor the configuration to best suit the specific application. The two general-purpose 8-bit I/O ports (Figure 4) are identical, except that Port B can be specified to provide external access to Counter/Timers 1 and 2. Either port can be programmed to be a handshake-driven, double-buffered port (input, output, or bidirectional) or a control-type port with the direction of each bit individually programmable. Each port includes pattern-recognition logic, allowing interrupt generation when a specific pattern is detected. The pattern-recognition logic can be programmed so the port functions like a priority-interrupt controller. Ports A and B can also be linked to form a 16-bit I/O port. To control these capabilities, both ports contain 12 registers. Three of these registers, the Input, Output, and Buffer registers, comprise the data path registers. Two registers, the Mode Specification and Handshake Specification registers, are used to define the mode of the port and to specify which handshake, if any, is to be used. The reference pattern for the pattern-recognition logic is defined via three registers: the Pattern Polarity, Pattern Transition, and Pattern Mask registers. The detailed characteristics of each bit path (for example, the direction of data flow or whether a path is inverting or noninverting) are programmed using the Data Path Polarity, Data Direction, and Special I/O Control registers. The primary control and status bits are grouped in a single register, the Command and Status register, so that after the port is initially configured, only this register must be accessed frequently. To facilitate initialization, the port logic is designed so that registers associated with an unrequired capability are ignored and do not have to be programmed. The function of the special-purpose 4-bit port, Port C (Figure 5), depends upon the roles of Ports A and B. Port C provides the required handshake lines. Any bits of Port C not used as handshake lines can be used as I/O lines or to provide external access for the third counter/timer. Since Port C's function is defined primarily by Ports A and B, only three registers (besides the Data Input and Output registers) are needed. These registers specify the details of each bit path: the Data Path Polarity, Data Direction, and Special I/O Control registers. ## Architecture (Continued) Figure 5. Port C Block Diagram The three counter/timers (Figure 6) are all identical. Each is comprised of a 16-bit down-counter, a 16-bit Time Constant register (which holds the value loaded into the down-counter), a 16-bit Current Count register (used to read the contents of the down-counter), and two 8-bit registers for control and status (the Mode Specification and the Command and Status registers). The capabilities of the counter/timer are numerous. Up to four port I/O lines can be dedicated as external access lines for each counter/timer: counter input, gate input, trigger input, and counter/timer output. Three different counter/timer output duty cycles are available: pulse, one-shot, or square-wave. The operation of the counter/timer can be programmed as either retriggerable or nonretriggerable. With these and other options, most counter/timer applications are covered. There are five registers (Master Interrupt Control register, three Interrupt Vector registers, and the Current Vector register) associated with the interrupt logic. In addition, the ports' Command and Status registers and the counter/timers' Command and Status registers include bits associated with the interrupt logic. Each of these registers contains three bits for interrupt control and status: Interrupt Pending (IP), Interrupt Under Service (IUS), and Interrupt Enable (IE). Architecture (Continued) Figure 6. Counter/Timer Block Diagram ## Functional Description The following describes the functions of the ports, pattern-recognition logic, counter/timers, and interrupt logic. I/O Port Operations. Of the CIO's three I/O ports, two (Ports A and B) are generalpurpose, and the third (Port C) is a specialpurpose 4-bit port. Ports A and B can be configured as input, output, or bidirectional ports with handshake. (Four different handshakes are available.) They can also be linked to form a single 16-bit port. If they are not used as ports with handshake, they provide 16 input or output bits with the data direction programmable on a bit-by-bit basis. Port B also provides access for Counter/Timers 1 and 2. In all configurations, Ports A and B can be programmed to recognize specific data patterns and to generate interrupts when the pattern is encountered. The four bits of Port C provide the handshake lines for Ports A and B when required. A REQUEST/WAIT line can also be provided so that CIO transfers can be synchronized with DMAs or CPUs. Any Port C bits not used for handshake or REQUEST/WAIT can be used as input or output bits (individually data-direction programmable) or external access lines for Counter/Timer 3. Port C does not contain any pattern-recognition logic. It is, however, capable of bit-addressable writes. With this feature, any combination of bits can be set and/or cleared while the other bits remain undisturbed without first reading the register. Bit Port Operations. In bit port operations, the port's Data Direction register specifies the direction of data flow for each bit. A l specifies an input bit, and a 0 specifies an output bit. If bits are used as I/O bits for a counter/timer, they should be set as input or output, as required. The Data Path Polarity register provides the capability of inverting the data path. A 1 specifies inverting, and a 0 specifies non-inverting. All discussions of the port operations assume that the path is noninverting. The value returned when reading an input bit reflects the state of the input just prior to the read. A 1's catcher can be inserted into the input data path by programming a 1 to the corresponding bit position of the port's Special I/O Control register. When a 1 is detected at the 1's catcher input, its output is set to 1 until it is cleared. The 1's catcher is cleared by writing a 0 to the bit. In all other cases, attempted writes to input bits are ignored. When Ports A and B include output bits, reading the Data register returns the value being output. Reads of Port C return the state of the pin. Outputs can be specified as opendrain by writing a 1 to the corresponding bit of the port's Special I/O Control register. Port C has the additional feature of bit-addressable writes. When writing to Port C, the four most significant bits are used as a write protect mask for the least significant bits (0-4, 1-5, 2-6, and 3-7). If the write protect bit is written with a 1, the state of the corresponding output bit is not changed. Ports with Handshake Operation. Ports A and B can be specified as 8-bit input, output, or bidirectional ports with handshake. The CIO provides four different handshakes for its ports: Interlocked, Strobed, Pulsed, and 3-Wire. When specified as a port with handshake, the transfer of data into and out of the port and interrupt generation is under control of the handshake logic. Port C provides the handshake lines as shown in Table 1. Any Port C lines not used for handshake can be used as simple I/O lines or as access lines for Counter/Timer 3. When Ports A and B are configured as ports with handshake, they are double-buffered. This allows for more relaxed interrupt service routine response time. A second byte can be input to or output from the port before the interrupt for the first byte is serviced. Normally, the Interrupt Pending (IP) bit is set and an interrupt is generated when data is shifted into the Input register (input port) or out of the Output register (output port). For input and output ports, the IP is automatically cleared when the data is read or written. In bidirectional ports, IP is cleared only by command. When the Interrupt on Two Bytes (ITB) control bit is set to 1, interrupts are generated only when two bytes of data are available to be read or written. This allows a minimum of 16 bits of information to be transferred on each interrupt. With ITB set, the IP is not automatically cleared until the second byte of data is read or written. When the Single Buffer (SB) bit is set to 1, the port acts as if it is only single-buffered. This is useful if the handshake line must be stopped on a byte-by-byte basis. Ports A and B can be linked to form a 16-bit port by programming a 1 in the Port Link Control (PLC) bit. In this mode, only Port A's Handshake Specification and Command and Status registers are used. Port B must be specified as a bit port. When linked, only Port A has pattern-match capability. Port B's pattern-match capability must be disabled. Also, when the ports are linked, Port B's Data register must be read or written before Port A's. When a port is specified as a port with handshake, the type of port it is (input, output, or bidirectional) determines the direction of data flow. The data direction for the bidirectional port is determined by a bit in Port C (Table 1). In all cases, the contents of the Data Direction register are ignored. The contents of the Special I/O Control register apply only to output bits (3-state or open-drain). Inputs may not have I's catchers: therefore, those bits in the Special I/O Control register are ignored. Port C lines used for handshake should be programmed as inputs. The handshake specification overrides Port C's Data Direction register for bits that must be outputs. The contents of Port C's Data Path Polarity register still apply. Interlocked Handshake. In the Interlocked Handshake mode, the action of the CIO must be acknowledged by the external device before the next action can take place. Figure 7 shows timing for Interlocked Handshake. An output port does not indicate that new data is available until the external device indicates it is ready for the data. Similarly, an input port does not indicate that it is ready for new data until the data source indicates that the previous byte of the data is no longer available, thereby acknowledging the input port's acceptance of the last byte. This allows the CIO to interface directly to the port of a Z8 microcomputer, a UPC, an FIO, an FIFO, or to another CIO port with no external logic. A 4-bit deskew timer can be inserted in the Data Available ( $\overline{DAV}$ ) output for output ports. As data is transferred to the Buffer register, the deskew timer is triggered. After the number of PCLK cycles specified by the deskew timer time constant plus one, $\overline{DAV}$ is allowed to go Low. The deskew timer therefore guarantees that the output data is valid for a specified minimum amount of time before $\overline{DAV}$ | Port A/B Configuration | PC <sub>3</sub> | PC <sub>2</sub> | PC <sub>1</sub> | PC <sub>0</sub> | |---------------------------------------------------------------------------------|----------------------------|-----------------|----------------------------|-----------------| | Ports A and B: Bit Ports | Bit I/O | Bit I/O | Bit I/O | Bit I/O | | Port A: Input or Output Port<br>(Interlocked, Strobed, or Pulsed<br>Handshake)* | RFD or DAV | ACKIN | REQUEST/WAIT<br>or Bit I/O | Bit I/O | | Port B: Input or Output Port<br>(Interlocked, Strobed, or Pulsed<br>Handshake)* | REQUEST/WAIT<br>or Bit I/O | Bit I/O | RFD or DAV | ACKIN | | Port A or B: Input Port (3-Wire Handshake) | RFD (Output) | DAV (Input) | REQUEST/WAIT or Bit I/O | DAC (Output) | | Port A or B: Output Port (3-Wire Handshake) | DAV (Output) | DAC (Input) | REQUEST/WAIT<br>or Bit I/O | RFD (Input) | | Port A or B: Bidirectional Port<br>(Interlocked or Strobed Handshake) | RFD or DAV | ACKIN | REQUEST/WAIT<br>or Bit I/O | IN/OUT | <sup>\*</sup>Both Ports A and B can be specified input or output with Interlocked, Strobed, or Pulsed Handshake at the same time if neither uses REOUEST/WAIT. Table 1. Port C Bit Utilization goes Low. Deskew timers are available for output ports independent of the type of handshake employed. Strobed Handshake. In the Strobed Handshake mode, data is "strobed" into or out of the port by the external logic. The falling edge of the Acknowledge Input (ĀCKIN) strobes data into or out of the port. Figure 7 shows timing for the Strobed Handshake. In contrast to the Interlocked handshake, the signal indicating the port is ready for another data transfer operates independently of the ĀCKIN input. It is up to the external logic to ensure that data overflows or underflows do not occur. 3-Wire Handshake. The 3-Wire Handshake is designed for the situation in which one output port is communicating with many input ports simultaneously. It is essentially the same as the Interlocked Handshake, except that two signals are used to indicate if an input port is ready for new data or if it has accepted the present data. In the 3-Wire Handshake (Figure 8), the rising edge of one status line indicates that the port is ready for data, and the rising edge of another status line indicates that the data has been accepted. With the 3-Wire Handshake, the output lines of many input ports can be bussed together with open-drain drivers; the output port knows when all the ports have accepted the data and are ready. This is the same handshake as is used on the IEEE-488 bus. Because this handshake requires three lines, only one port (either A or B) can be a 3-Wire Handshake port at a time. The 3-Wire Handshake is not available in the bidirectional mode. Because the port's direction can be changed under software control, however, bidirectional IEEE-488-type transfers can be performed. Pulsed Handshake. The Pulsed Handshake (Figure 9) is designed to interface to mechanical-type devices that require data to be held for long periods of time and need relatively wide pulses to gate the data into or out of the device. The logic is the same as the Interlocked Handshake mode, except that an internal counter/timer is linked to the handshake logic. If the port is specified in the input mode, the timer is inserted in the ACKIN path. The external ACKIN input triggers the timer and its output is used as the Interlocked Handshake's normal acknowledge input. If the port is an output port, the timer is placed in the Data Available (DAV) output path. The timer is triggered when the normal Interlocked Handshake DAV output goes Low and the timer output is used as the actual DAV output. The counter/timer maintains all of its normal capabilities. This handshake is not available to bidirectional ports. INPUT HANDSHAKE Figure 7. Interlocked and Strobed Handshakes Figure 8. 3-Wire Handshake 2014-005, 006 # Functional Description (Continued) REOUEST/WAIT Line Operation. Port C can be programmed to provide a status signal output in addition to the normal handshake lines for either Port A or B when used as a port with handshake. The additional signal is either a REQUEST or WAIT signal. The REQUEST signal indicates when a port is ready to perform a data transfer via the CPU interface. It is intended for use with a DMA-type device. The WAIT signal provides synchronization for transfers with a CPU. Three bits in the Port Handshake Specification register provide controls for the REQUEST/WAIT logic. Because the extra Port C line is used, only one port can be specified as a port with a handshake and a REQUEST/WAIT line. The other port must be a bit port. Operation of the REQUEST line is modified by the state of the port's Interrupt on Two Bytes (ITB) control bit. When ITB is 0, the REQUEST line goes active as soon as the CIO is ready for a data transfer. If ITB is 1, REQUEST does not go active until two bytes can be transferred. REQUEST stays active as long as a byte is available to be read or written. The SPECIAL REQUEST function is reserved for use with bidirectional ports only. In this case, the REQUEST line indicates the status of the register not being used in the data path at that time. If the $IN/\overline{OUT}$ line is High, the REQUEST line is High when the Output register is empty. If $IN/\overline{OUT}$ is Low, the REQUEST line is High when the Input register is full. Pattern-Recognition Logic Operation. Both Ports A and B can be programmed to generate interrupts when a specific pattern is recognized at the port. The pattern-recognition logic is independent of the port application, thereby allowing the port to recognize patterns in all of its configurations. The pattern can be independently specified for each bit as 1, 0, rising edge, falling edge, or any transition. Individual bits may be masked off. A patternmatch is defined as the simultaneous satisfaction of all nonmasked bit specifications in the AND mode or the satisfaction of any nonmasked bit specifications in either of the OR or OR-Priority Encoded Vector modes. OUTPUT PORT TRIGGER COUNTER OUTPUT C/T 3 TRIGGER COUNTER OUTPUT OUTPUT OUTPUT OUTPUT OUTPUT OUTPUT C/T 3 Figure 9. Pulsed Handshake The pattern specified in the Pattern Definition register assumes that the data path is programmed to be noninverting. If an input bit in the data path is programmed to be inverting, the pattern detected is the opposite of the one specified. Output bits used in the patternmatch logic are internally sampled before the invert/noninvert logic. Bit Port Pattern-Recognition Operations. During bit port operations, pattern-recognition may be performed on all bits, including those used as I/O for the counter/timers. The input to the pattern-recognition logic follows the value at the pins (through the invert/noninvert logic) in all cases except for simple inputs with I's catchers. In this case, the output of the I's catcher is used. When operating in the AND or OR mode, it is the transition from a nomatch to a match state that causes the interrupt. In the "OR" mode, if a second match occurs before the first match goes away, it does not cause an interrupt. Since a match condition only lasts a short time when edges are specified, care must be taken to avoid losing a match condition. Bit ports specified in the OR-Priority Encoded Vector mode generate interrupts as long as any match state exists. A transition from a no-match to a match state is not required. The pattern-recognition logic of bit ports operates in two basic modes: transparent and latched. When the Latch on Pattern Match (LPM) bit is set to 0 (Transparent mode), the interrupt indicates that a specified pattern has occurred, but a read of the Data register does not necessarily indicate the state of the port at the time the interrupt was generated. In the Latched mode (LPM = 1), the state of all the port inputs at the time the interrupt was generated is latched in the input register and held until IP is cleared. In all cases, the PMF indicates the state of the port at the time it is read. If a match occurs while IP is already set, an error condition exists. If the Interrupt On Error bit (IOE) is 0, the match is ignored. However, if IOE is 1 after the first IP is cleared, it is automatically set to 1 along with the Interrupt Error (ERR) flag. Matches occurring while ERR is set are ignored. ERR is cleared when the corresponding IP is cleared. When a pattern-match is present in the OR-Priority Encoded Vector mode, IP is set to 1. The IP cannot be cleared until a match is no longer present. If the interrupt vector is allowed to include status, the vector returned during Interrupt Acknowledge indicates the highest priority bit matching its specification at the time of the Acknowledge cycle. Bit 7 is the highest priority and bit 0 is the lowest. The bit initially causing the interrupt may not be the one indicated by the vector if a higher priority bit matches before the Acknowledge. Once the # Functional Description (Continued) Acknowledge cycle is initiated, the vector is frozen until the corresponding IP is cleared. Where inputs that cause interrupts might change before the interrupt is serviced, the l's catcher can be used to hold the value. Because a no-match to match transition is not required, the source of the interrupt must be cleared before IP is cleared or else a second interrupt is generated. No error detection is performed in this mode, and the Interrupt On Error bit should be set to 0. Ports with Handshake Pattern-Recognition Operation. In this mode, the handshake logic normally controls the setting of IP and, therefore, the generation of interrupt requests. The pattern-match logic controls the Pattern-Match Flag (PMF). The data is compared with the match pattern when it is shifted from the Buffer register to the Input register (input port) or when it is shifted from the Output register to the Buffer register (output port). The pattern match logic can override the handshake logic in certain situations. If the port is programmed to interrupt when two bytes of data are available to be read or written, but the first byte matches the specified pattern, the pattern-recognition logic sets IP and generates an interrupt. While PMF is set, IP cannot be cleared by reading or writing the data registers. IP must be cleared by command. The input register is not emptied while IP is set, nor is the output register filled until IP is cleared. If the Interrupt on Match Only (IMO) bit is set, IP is set only when the data matches the pattern. This is useful in DMA-type application when interrupts are required only after a block of data is transferred. Counter/Timer Operation. The three independent 16-bit counter/timers consist of a presettable 16-bit down counter, a 16-bit Time Constant register, a 16-bit Current Counter register, an 8-bit Mode Specification register, an 8-bit Command and Status register, and the associated control logic that links these registers. | Function | C/T <sub>1</sub> | C/T <sub>2</sub> | C/T <sub>3</sub> | | |----------------------|------------------|------------------|------------------|--| | Counter/Timer Output | PB 4 | PB 0 | PC 0 | | | Counter Input | PB 5 | PB 1 | PC 1 | | | Trigger Input | PB 6 | PB 2 | PC 2 | | | Gate Input | PB 7 | PB 3 | PC 3 | | Table 2. Counter/Timer External Access The flexibility of the counter/timers is enhanced by the provision of up to four lines per counter/timer (counter input, gate input, trigger input, and counter/timer output) for direct external control and status. Counter/Timer 1's external I/O lines are provided by the four most significant bits of Port B. Counter/Timer 2's are provided by the four least significant bits of Port B. Counter/Timer 3's external I/O lines are provided by the four bits of Port C. The utilization of these lines (Table 2) is programmable on a bit-by-bit basis via the Counter/Timer Mode Specification registers. When external counter/timer I/O lines are to be used, the associated port lines must be vacant and programmed in the proper data direction. Lines used for counter/timer I/O have the same characteristics as simple input lines. They can be specified as inverting or noninverting; they can be read and used with the pattern-recognition logic. They can also include the l's catcher input. Counter/Timers 1 and 2 can be linked internally in three different ways. Counter/Timer 1's output (inverted) can be used as Counter/Timer 2's trigger, gate, or counter input. When linked, the counter/timers have the same capabilities as when used separately. The only restriction is that when Counter/Timer 1 drives Counter/Timer 2's count input, Counter/Timer 2 must be programmed with its external count input disabled. There are three duty cycles available for the timer/counter output: pulse, one-shot, and square-wave. Figure 10 shows the counter/timer waveforms. When the Pulse mode Figure 10. Counter/Timer Waveforms # Functional Description (Continued) is specified, the output goes High for one clock cycle, beginning when the down-counter leaves the count of 1. In the One-Shot mode, the output goes High when the counter/timer is triggered and goes Low when the downcounter reaches 0. When the square-wave output duty cycle is specified, the counter/timer goes through two full sequences for each cycle. The initial trigger causes the downcounter to be loaded and the normal countdown sequence to begin. If a 1 count is detected on the down-counter's clocking edge, the output goes High and the time constant value is reloaded. On the clocking edge, when both the down-counter and the output are l's, the output is pulled back Low. The Continuous/Single Cycle (C/SC) bit in the Mode Specification register controls operation of the down-counter when it reaches terminal count. If C/SC is 0 when a terminal count is reached, the countdown sequence stops. If the C/SC bit is 1 each time the countdown counter reaches 1, the next cycle causes the time constant value to be reloaded. The time constant value may be changed by the CPU, and on reload, the new time constant value is loaded. Counter/timer operations require loading the time constant value in the Time Constant register and initiating the countdown sequence by loading the down-counter with the time constant value. The Time Constant register is accessed as two 8-bit registers. The registers are readable as well as writable, and the access order is irrelevant. A 0 in the Time Constant register specifies a time constant of 65,536. The down-counter is loaded in one of three ways: by writing a 1 to the Trigger Command Bit (TCB) of the Command and Status register, on the rising edge of the external trigger input, or, for Counter/Timer 2 only, on the rising edge of Counter/Timer I's internal output if the counters are linked via the trigger input. The TCB is write-only, and read always returns 0. Once the down-counter is loaded, the countdown sequence continues toward terminal count as long as all the counter/timers' hardware and software gate inputs are High. If any of the gate inputs goes Low (0), the countdown halts. It resumes when all gate inputs are 1 again. The reaction to triggers occurring during a countdown sequence is determined by the state of the Retrigger Enable Bit (REB) in the Mode Specification register. If REB is 0, retriggers are ignored and the countdown continues normally. If REB is 1, each trigger causes the down-counter to be reloaded and the countdown sequence starts over again. If the output is programmed in the Square-Wave mode, retrigger causes the sequence to start over from the initial load of the time constant. The rate at which the down-counter counts is determined by the mode of the counter/timer. In the Timer mode (the External Count Enable [ECE] bit is 0), the down-counter is clocked internally by a signal that is half the frequency of the PCLK input to the chip. In the Counter mode (ECE is 1), the down-counter is decremented on the rising edge of the counter/timer's counter input. Each time the counter reaches terminal count, its Interrupt Pending (IP) bit is set to 1, and if interrupts are enabled (IE = 1), an interrupt is generated. If a terminal count occurs while IP is already set, an internal error flag is set. As soon as IP is cleared, it is forced to 1 along with the Interrupt Error (ERR) flag. Errors that occur after the internal flag is set are ignored. The state of the down-counter can be determined in two ways: by reading the contents of the down-counter via the Current Count register or by testing the Count In Progress (CIP) status bit in the Command and Status register. The CIP status bit is set when the down-counter is loaded; it is reset when the down-counter reaches 0. The Current Count register is a 16-bit register, accessible as two 8-bit registers, which mirrors the contents of the down-counter. This register can be read anytime. However, reading the register is asynchronous to the counter's counting, and the value returned is valid only if the counter is stopped. The down-counter can be reliably read "on the fly" by the first writing of a 1 to the Read Counter Control (RCC) bit in the counter/timer's Command and Status register. This freezes the value in the Current Count register until a read of the least significant byte is performed. Interrupt Logic Operation. The CIO has five potential sources of interrupts: the three counter/timers and Ports A and B. The priorities of these sources are fixed in the following order: Counter/Timer 3, Port A, Counter/Timer 2, Port B, and Counter/Timer 1. Since the counter/timers all have equal capabilities and Ports A and B have equal capabilities, there is no adverse impact from the relative priorities. The CIO interrupt priority, relative to other components within the system, is determined by an interrupt daisy chain. Two pins, Interrupt Enable In (IEI) and Interrupt Enable Out (IEO), provide the input and output necessary to implement the daisy chain. When IEI is pulled Low by a higher priority device, the CIO cannot request an interrupt of the CPU. The following discussion assumes that the IEI line is High. Each source of interrupt in the CIO contains three bits for the control and status of the interrupt logic: an Interrupt Pending (IP) status bit, an Interrupt Under Service (IUS) # Functional Description (Continued) status bit, and an Interrupt Enable (IE) control bit. IP is set when an event requiring CPU intervention occurs. The setting of IP results in forcing the Interrupt ( $\overline{\text{INT}}$ ) output Low, if the associated IE is 1. The IUS status bit is set as a result of the Interrupt Acknowledge cycle by the CPU and is set only if its IP is of highest priority at the time the Interrupt Acknowledge commences. It can also be set directly by the CPU. Its primary function is to control the interrupt daisy chain. When set, it disables lower priority sources in the daisy chain, so that lower priority interrupt sources do not request servicing while higher priority devices are being serviced. The IE bit provides the CPU with a means of masking off individual sources of interrupts. When IE is set to 1, interrupt is generated normally. When IE is set to 0, the IP bit is set when an event occurs that would normally require service; however, the $\overline{\text{INT}}$ output is not forced Low. The Master Interrupt Enable (MIE) bit allows all sources of interrupts within the CIO to be disabled without having to individually set each IE to 0. If MIE is set to 0, all IPs are masked off and no interrupt can be requested or acknowledged. The Disable Lower Chain (DLC) bit is included to allow the CPU to modify the system daisy chain. When the DLC bit is set to 1, the CIO's IEO is forced Low, independent of the state of the CIO or its IEI input, and all lower priority devices' interrupts are disabled. As part of the Interrupt Acknowledge cycle. the CIO is capable of responding with an 8-bit interrupt vector that specifies the source of the interrupt. The CIO contains three vector registers: one for Port A, one for Port B, and one shared by the three counter/timers. The vector output is inhibited by setting the No Vector (NV) control bit to 1. The vector output can be modified to include status information to pinpoint more precisely the cause of interrupt. Whether the vector includes status or not is controlled by a Vector Includes Status (VIS) control bit. Each base vector has its own VIS bit and is controlled independently. When MIE = 1, reading the base vector register always includes status, independent of the state of the VIS bit. In this way, all the information obtained by the vector, including status, can be obtained with one additional instruction when VIS is set to 0. When MIE = 0, reading the vector register returns the unmodified base vector so that it can be verified. Another register, the Current Vector register, allows use of the CIO in a polled environment. When read, the data returned is the same as the interrupt vector that would be output in an acknowledge, based on the highest priority IP set. If no unmasked IPs are set, the value FFH is returned. The Current Vector register is read-only. #### Programming The data registers within the CIO are directly accessed by address lines $A_0$ and $A_1$ (Table 3). All other internal registers are accessed by the following two-step sequence, with the address lines specifying a control operation. First, write the address of the target register to an internal 6-bit Pointer Register; then read from or write to the target register. The Data registers can also be accessed by this method. An internal state machine determines if accesses with $A_0$ and $A_1$ equalling 1 are to the Pointer Register or to an internal control register (Figure 11). Following any control read operation, the state machine is in State 0 (the next control access is to the Pointer Register). This can be used to force the state machine into a known state. Control reads in State 0 return the contents of the last register | A <sub>1</sub> | A <sub>0</sub> | Register | |----------------|----------------|------------------------| | 0 | 0 | Port C's Data Register | | 0 | 1 | Port B's Data Register | | 1 | 0 | Port A's Data Register | | 1 | 1 | Control Registers | continuously without writing to the Pointer. While the CIO is in State 1 (next control access is to the register pointed to), many internal operations are suspended—no IPs are set and internal status is frozen. Therefore, to minimize interrupt latency and to allow continuous status updates, the CIO should not be left in State 1. pointed to. Therefore, a register can be read The CIO is reset by forcing $\overline{\text{RD}}$ and $\overline{\text{WR}}$ Low simultaneously (normally an illegal condition) or by writing a 1 to the Reset bit. Reset disables all functions except a read from or write to the Reset bit; writes to all other bits are ignored, and all reads return $01_H$ . In this state, all control bits are forced to 0 and may be programmed only after clearing the Reset bit (by writing a 0 to it). NOTE: State changes occur only when $A_0 = A_1 = 1$ . No other accesses have effect. Table 3. Register Selection Figure 11. State Machine Operation #### Registers #### Master Interrupt Control Register Address: 000000 (Read/Write) #### Master Configuration Control Register Address: 000001 (Read/Write) Figure 12. Master Control Registers Addresses: 100000 Port A 101000 Port B (Read/Write) Addresses: 100001 Port A 101001 Port B (Read/Write) #### Port Command and Status Registers Addresses: 001000 Port A 001001 Port B (Read/Partial Write) Figure 13. Port Specifications Registers #### Data Path Polarity Registers **Data Direction Registers** Addresses: 100010 Port A Addresses: 100011 Port A 101010 Port B 101011 Port B 000101 Port C (4 LSBs only) 000110 Port C (4 LSBs only) (Read/Write) (Read/Write) D<sub>7</sub> D<sub>6</sub> D<sub>5</sub> D<sub>4</sub> D<sub>3</sub> D<sub>2</sub> D<sub>1</sub> D<sub>0</sub> D<sub>7</sub> D<sub>6</sub> D<sub>5</sub> D<sub>4</sub> D<sub>3</sub> D<sub>2</sub> D<sub>1</sub> D<sub>0</sub> DATA DIRECTION (DD) 0 = OUTPUT BIT 1 = INPUT BIT DATA PATH POLARITY (DPP) 0 = NON-INVERTING 1 = INVERTING Special I/O Control Registers Addresses: 100100 Port A 101100 Port B 000111 Port C (4 LSBs only) (Read/Write) D<sub>7</sub> D<sub>6</sub> D<sub>5</sub> D<sub>4</sub> D<sub>3</sub> D<sub>2</sub> D<sub>1</sub> D<sub>0</sub> SPECIAL INPUT/OUTPUT (SIO) 0 = NORMAL INPUT OR OUTPUT 1 = OUTPUT WITH OPEN DRAIN OR INPUT WITH 1'S CATCHER Figure 14. Bit Path Definition Registers **Port Data Registers** Port C Data Register Addresses: 001101 Port A\* Address: 001111\* 001110 Port B\* (Read/Write) (Read/Write) D<sub>7</sub> D<sub>6</sub> D<sub>5</sub> D<sub>4</sub> D<sub>3</sub> D<sub>2</sub> D<sub>1</sub> D<sub>0</sub> D<sub>7</sub> D<sub>6</sub> D<sub>5</sub> D<sub>4</sub> D<sub>3</sub> D<sub>2</sub> D<sub>1</sub> D<sub>0</sub> 4 MSBs \*These registers can be 0 = WRITING OF CORRESPONDING LSB ENABLED addressed directly. (READ RETURNS 1) Figure 15. Port Data Registers Pattern Polarity Registers (PP) D<sub>7</sub> D<sub>6</sub> D<sub>5</sub> D<sub>4</sub> D<sub>3</sub> D<sub>2</sub> D<sub>1</sub> D<sub>0</sub> Addresses: 100101 Port A 101101 Port B (Read/Write) Pattern Transition Registers (PT) PM PT PP X 0 1 X 1 0 0 1 1 1 1 0 1 1 1 Addresses: 100110 Port A D<sub>7</sub> D<sub>6</sub> D<sub>5</sub> D<sub>4</sub> D<sub>3</sub> D<sub>2</sub> D<sub>1</sub> D<sub>0</sub> PATTERN SPECIFICATION 101110 Port B (Read/Write) ONE TO ZERO TRANSITION (4) ZERO-TO-ONE TRANSITION (7) Pattern Mask Registers (PM) Registers (Continued) Figure 16. Pattern Definition Registers D<sub>7</sub> D<sub>6</sub> D<sub>5</sub> D<sub>4</sub> D<sub>3</sub> D<sub>2</sub> D<sub>1</sub> D<sub>0</sub> 2014-011, 012, 013 Addresses: 100111 Port A (Read/Write) 101111 Port B Figure 17. Counter/Timer Registers Registers (Continued) Registers Interrupt Vector Register Addresses: 000010 Port A (Continued) 000011 Port B 000100 Counter/Timers (Read/Write) INTERRUPT VECTOR PORT VECTOR STATUS PRIORITY ENCODED VECTOR MODE: D<sub>3</sub> D<sub>2</sub> D<sub>1</sub> NUMBER OF HIGHEST PRIORITY BIT WITH A MATCH ALL OTHER MODES D<sub>3</sub> D<sub>2</sub> D<sub>1</sub> ORE IRF PMF NORMAL 0 0 0 ERROR COUNTER/TIMER STATUS **Current Vector Register** Address: 011111 (Read only) D<sub>7</sub> D<sub>6</sub> D<sub>5</sub> D<sub>4</sub> D<sub>3</sub> D<sub>2</sub> D<sub>1</sub> D<sub>0</sub> INTERRUPT VECTOR BASED ON HIGHEST PRIORITY UNMASKED IP. IF NO INTERRUPT PENDING ALL 1'8 OUTPUT | | | Figure 18. Inter | rupt Vector Reg | risters | |---------------------|-------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Register<br>Address | Address | Main Control Registers<br>Register Name | Address | Port A Specification Registers Register Name | | Summary | 000000<br>000001<br>000010<br>000011<br>000100<br>000101<br>000110<br>000111 | Master Interrupt Control Master Configuration Control Port A's Interrupt Vector Port B's Interrupt Vector Counter/Timer's Interrupt Vector Port C's Data Path Polarity Port C's Data Direction Port C's Special I/O Control | 100000<br>100001<br>100010<br>100011<br>100100<br>100101<br>100110 | Port A's Mode Specification Port A's Handshake Specification Port A's Data Path Polarity Port A's Data Direction Port A's Special I/O Control Port A's Pattern Polarity Port A's Pattern Transition Port A's Pattern Mask | | | | Most Often Accessed Registers | | Port B Specification Registers | | | Address<br>001000<br>001001<br>001010<br>001011<br>001100<br>001101<br>001110 | Register Name Port A's Command and Status Port B's Command and Status Counter/Timer 1's Command and Status Counter/Timer 2's Command and Status Counter/Timer 3's Command and Status Port A's Data (can be accessed directly) Port B's Data (can be accessed directly) Port C's Data (can be accessed directly) | Address 101000 101001 101010 101011 101100 101101 | Register Name Port B's Mode Specification Port B's Handshake Specification Port B's Data Path Polarity Port B's Data Direction Port B's Special I/O Control Port B's Pattern Polarity Port B's Pattern Transition Port B's Pattern Mask | | | | Counter/Timer Related Registers | | | | | Address 010000 010001 010010 010011 010100 010111 011000 011011 | Register Name Counter/Timer 1's Current Count-MSBs Counter/Timer 1's Current Count-LSBs Counter/Timer 2's Current Count-MSBs Counter/Timer 2's Current Count-MSBs Counter/Timer 3's Current Count-MSBs Counter/Timer 3's Current Count-LSBs Counter/Timer 1's Time Constant-MSBs Counter/Timer 1's Time Constant-MSBs Counter/Timer 2's Time Constant-MSBs Counter/Timer 2's Time Constant-MSBs Counter/Timer 3's Time Constant-MSBs Counter/Timer 3's Time Constant-LSBs Counter/Timer 3's Time Constant-LSBs Counter/Timer 3's Time Constant-LSBs Counter/Timer 1's Mode Specification Counter/Timer 2's Mode Specification Counter/Timer 3's Mode Specification Counter/Timer 3's Mode Specification Counter/Timer 3's Mode Specification Counter/Timer 3's Mode Specification Counter/Vector | | | 2014-015 #### Timing **Read Cycle.** At the beginning of a read cycle, the CPU places an address on the address bus. Bits $A_0$ and $A_1$ specify a CIO register; the remaining address bits and status information are combined and decoded to generate a Chip Enable $(\overline{CE})$ signal that selects the CIO. When Read $(\overline{RD})$ goes Low, data from the specified register is gated onto the data bus. **Write Cycle.** At the beginning of a write cycle, the CPU places an address on the data bus. Bits $A_0$ and $A_1$ specify a CIO register; the remaining address bits and status information are combined and decoded to generate a Chip Enable ( $\overline{\text{CE}}$ ) signal that selects the CIO. When $\overline{\text{WR}}$ goes Low, data placed on the bus by the CPU is strobed into the specified CIO register. Figure 19. Read Cycle Timing Figure 20. Write Cycle Timing Interrupt Acknowledge. The CIO pulls its Interrupt Request (INT) line Low, requesting interrupt service from the CPU, if an Interrupt Pending (IP) bit is set and interrupts are enabled. The CPU responds with an Interrupt Acknowledge cycle. When Interrupt Acknowledge (INTACK) goes true and the IP is set, the CIO forces Interrupt Enable Out (IEO) Low, disabling all lower priority devices in the interrupt daisy chain. If the CIO is the highest priority device requesting service (IEI is High), it places its interrupt vector on the data bus and sets the Interrupt Under Service (IUS) bit when Read $(\overline{\text{RD}})$ goes Low. Figure 21. Interrupt Acknowledge Timing 394 2021-003, 004, 005 | Absolute Voltages on all inputs and outputs with respect to GND0.3 V to +7.0 V Operating Ambient Temperature | Stresses greater than those listed under Absolute Maximum Ratings may cause permanent damage to the device. This is a stress rating only; operation of the device at any condition above those indicated in the operational sections of these specifications is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability. | |--------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| |--------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| #### Standard Test Conditions The characteristics below apply for the following standard test conditions, unless otherwise noted. All voltages are referenced to GND. Positive current flows into the referenced pin. Standard conditions are as follows: - $+4.75 \text{ V} \le \text{V}_{CC} \le +5.25 \text{ V}$ - $\blacksquare$ GND = 0 V - T<sub>A</sub> as specified in Ordering Information All ac parameters assume a load capacitance of 50 pF max. Figure 22. Standard Test Load Figure 23. Open-Drain Test Load | DC<br>Charac- | Symbol | Parameter | Min | Мах | Unit | Condition | |---------------|----------|---------------------------------|------|-----------------------|---------|--------------------------------------| | teristics | $v_{ih}$ | Input High Voltage | 2.0 | V <sub>CC</sub> + 0.3 | V | | | | $V_{IL}$ | Input Low Voltage | -0.3 | 0.8 | V | | | | $v_{OH}$ | Output High Voltage | 2.4 | | V | $I_{OH} = -250 \mu A$ | | | $V_{OL}$ | Output Low Voltage | | 0.4 | V | $I_{OL} = +2.0 \text{ mA}$ | | | | | | 0.5 | V | $I_{OL} = +3.2 \text{ mA}$ | | | $I_{IL}$ | Input Leakage | | ±10.0 | $\mu$ A | $0.4 \le V_{IN} \le +2.4 \text{ V}$ | | | $I_{OL}$ | Output Leakage | | ± 10.0 | $\mu$ A | $0.4 \le V_{OUT} \le +2.4 \text{ V}$ | | | $I_{CC}$ | ${ m V}_{ m CC}$ Supply Current | | 200 | mA | -<br>- | $V_{CC}$ = 5 V $\pm$ 5% unless otherwise specified, over specified temperature range. | Capacitance | C <sub>IN</sub> Input Capacitance 10 p | | Unit | Test Condition | | |-------------|----------------------------------------|---------------------------|------|----------------|--------------------| | | $C_{IN}$ | Input Capacitance | 10 | рF | Unmeasured Pins | | | $C_{OUT}$ | Output Capacitance | 15 | рF | Returned to Ground | | | $C_{I/O}$ | Bidirectional Capacitance | 20 | рF | | f = 1 MHz, over specified temperature range. | No. | Symbol | Parameter | 4 l<br>Min | MHz<br>Max | 6 l<br>Min | MHz<br>Max | Notes*† | |------|-----------------|---------------------------------------------------------------------------|------------|------------|----------------|------------|---------------| | | TcPC | PCLK Cycle time | 250 | 4000 | 165 | 4000 | | | 2 | TwPCh | PCLK Width (High) | 105 | 2000 | 70 | 2000 | | | 3 | TwPCl | PCLK Width (Low) | 105 | 2000 | 70 | 2000 | | | 4 | TrPC | PCLK Rise Time | | 20 | | 10 | | | 5 — | — TfPC ——— | — PCLK Fall Time | | 20 | | 15 | | | 6 | TsIA(PC) | INTACK to PCLK † Setup Time | 100 | | 100 | | | | 7 | ThIA(PC) | INTACK to PCLK † Hold Time | 0 | | 0 | | | | 8 | TsIA(RD) | INTACK to RD ↓ Setup Time | 200 | | 200 | | | | 9 | ThIA(RD) | INTACK to RD † Hold Time | 0 | | 0 | | | | | — TsIA(WR) —— | — INTACK to WR ↓ Setup Time ———————————————————————————————————— | 200 - | | 200 | | | | 11 | ThIA(WR) | INTACK to WR † Hold Time | 0 | | 0 | | | | 12 | TsA(RD) | Address to RD ↓ Setup Time | 80 | | 80 | | | | 13 | ThA(RD) | Address to RD † Hold Time | 0 | | 0 | | | | 14 | TsA(WR) | Address to WR ↓ Setup Time | 80 | | 80 | | | | | - ThA(WR) | — Address to WR † Hold Time | 0 - | | 0 _ | | | | 16 | TsCEl(RD) | CE Low to RD ↓ Setup Time | 0 | | 0 | | 1 | | 17 | TsCEh(RD) | CE High to RD ↓ Setup Time | 100 | | 70 | | 1 | | 18 | ThCE(RD) | CE to RD † Hold Time | 0 | | 0 | | 1 | | 19 | TsCEl(WR) | CE Low to WR ↓ Setup Time | 0 | | 0 | | _ | | 20 - | | — CE High to WR Setup Time — | 100 - | | <del></del> 70 | | | | 21 | ThCE(WR) | CE to WR † Hold Time | 0 | | 0 | | | | 22 | TwRDl | RD Low Width | 390 | | 250 | | 1 | | 23 | TdRD(DRA) | RD I to Read Data Active Delay | 0 | | 0 | | | | 24 | TdRDf(DR) | RD I to Read Data Valid Delay | | 255 | | 180 | | | 25 - | - TdRDr(DR) | - RD † to Read Data Not Valid Delay | 0 - | | 0 - | | | | 26 | TdRD(DRz) | RD † to Read Data Float Delay | - | 70 | _ | 45 | 2 | | 27 | TwWRl | WR Low Width | 390 | | 250 | | _ | | 28 | TsDW(WR) | Write Data to WR ↓ Setup Time | 0 | | 0 | | | | 29 | ThDW(WR) | Write Data to WR † Hold Time | 0 | | 0 | | | | 30 | Trc | Valid Access Recovery Time | 1000* | | 650 | | 3 | | | | valid Heddeld Heddevery Time | | | | | | | 31 | TdPM(INT) | Pattern Match to INT Delay (Bit Port) | | 2 | | 2 | 6 | | 32 | TdACK(INT) | ACKIN to INT Delay (Port with Handshake) | | 10 | | 10 | 4,6 | | 33 | TdCI(INT) | Counter Input to INT Delay (Counter Mode) | | 2 | | 2 | 6 | | 34 | TdPC(INT) | PCLK to INT Delay (Timer Mode) | | 3 | | 3 | 6 | | 35 | TsIA(RDA) | ĪNTĀCK TO RD ↓ (Acknowledge) Setup Time | 350 | | 250 | | 5 | | 36 | TwRDA | RD (Acknowledge Width) | 350 | | 250 | | Ü | | 37 | TdRDA(DR) | RD \ (Acknowledge) to Read Data Valid Delay | 000 | 250 | 200 | 180 | | | 38 | TdIA(IEO) | INTACK to IEO Delay | | 350 | | 250 | 5 | | 39 – | – TdIE(IEO) ––– | — IEI to IEO Delay | | — 150 — | | ——100 — | 5 <del></del> | | 40 | TsIEI(RDA) | IEI to RD + (Acknowledge) Setup Time | 100 | 100 | 70 | 100 | 5 | | 41 | ThIEI(RDA) | IEI to RD + (Acknowledge) Setup Time IEI to RD + (Acknowledge) Hold Time | 100 | | 70 | | J | | 42 | TdRDA(INT) | RD \ (Acknowledge) to INT \ Delay | 100 | 600 | 10 | 600 | | | 74 | TOTIDA(IIII) | IID • (Acknowledge) to INT Delay | | 000 | | 000 | | #### NOTES. must meet the following constraint: The delay from $\overline{INTACK}$ i to $\overline{RD}$ i must be greater than the sum of TdIA(IEO) for the highest priority peripheral, TsIEI(RDA) for the lowest priority peripheral, and TdIEI(IEO) for each peripheral separating them in the chain Parameter does not apply to Interrupt Acknowledge transactions. <sup>2.</sup> Float delay is measured to the time when the output has changed 0.5 V with minimum ac load and maximum dc load <sup>3</sup> Trc is lµS or TcPC, whichever is longer The delay is from DAV | for 3-Wire Input Handshake. The delay is from DAC | for 3-Wire Output Handshake. <sup>5.</sup> The parameters for the devices in any particular daisy chain <sup>6.</sup> Units equal to TcPC + ns. <sup>\*</sup>Timings are preliminary and subject to change <sup>†</sup>Units in nanoseconds, except as noted. | No. | Symbol | Parameter | 4<br>Min | MHz<br>Max | 6 l<br>Min | MHz<br>Max | Notes*† | |------|----------------|---------------------------------------------------------------------------------------------------|----------|------------|------------|------------|---------| | | | | | | | | | | 1 | TsDI(ACK) | Data Input to ACKIN Setup Time | 0 | | 0 | | | | 2 | ThDI(ACK) | Data Input to ACKIN Hold Time—<br>Strobed Handshake | | | | | | | 3 | TdACKf(RFD) | ACKIN ↓ to RFD ↓ Delay | 0 | | 0 | | | | 4 | TwACK1 | ACKIN Low Width—Strobed Handshake | | | | | | | 5 — | - TwACKh | - ACKIN High Width—Strobed Handshake ———— | | | | | | | 6 | TdRFDr(ACK) | RFD ↑ to ACKIN ↓ Delay | 0 | | 0 | | | | 7 | TsDO(DAV) | Data Out to DAV ↓ Setup Time | 25 | | 20 | | 1 | | 8 | TdDAVf(ACK) | DAV ↓ to ACKIN ↓ Delay | 0 | | 0 | | | | 9 | ThDO(ACK) | Data Out to ĀCKĪN ↓ Hold Time | 2 | | 2 | | 2 | | 10 — | - TdACK(DAV) - | - ĀCKĪN↓ to DĀV↑ Delay ———————————————————————————————————— | <u> </u> | | 2 | | 2 | | 11 | THDI(RFD) | Data Input to RFD Hold Time—Interlocked<br>Handshake | | | | | | | 12 | TdRFDf(ACK) | RFD to ACKIN Delay Interlocked Handshake | 0 | | 0 | | | | 13 | TdACKr(RFD) | $\overline{ACKIN}$ † ( $\overline{DAV}$ †) to RFD † Delay—Interlocked and 3-Wire Handwshake | 0 | | 0 | | | | 14 | TdDAVr(ACK) | $\overline{\text{DAV} t}$ to $\overline{\text{ACKIN}} t$ (RFD t)—Interlocked and 3-Wire Handshake | 0 | | 0 | | | | 15 — | - TdACK(DAV)— | - ĀCKĪN † (RFD †) to DĀV ↓ Delay—Interlocked and - 3-Wire Handshake | 0 | | 0 | | | | 16 | TdDAVIf(DAC) | DAV ↓ to DAC ↑ Delay—Input 3-Wire Handshake | 0 | | 0 | | | | 17 | ThDI(DAC) | Data Input to DAC † Hold Time—3-Wire Handshake | 0 | | 0 | | | | 18 | TdDACOr(DAV) | DAC † to DAV † Delay—Input 3-Wire Handshake | 0 | | 0 | | | | 19 | TdDAVIr(DAC) | DAV ↑ to DAC ↓ Delay—Input 3-Wire Handshake | 0 | | 0 | | | | 20 — | - TdDAVOf(DAC) | DAV ↓ to DAC ↑ Delay—Output 3-Wire Handshake | — 0 — | | o | | | | 21 | ThDO(DAC) | Data Output to DAC † Hold Time—3-Wire<br>Handshake | 2 | | 2 | | 2 | | 22 | TdDACIr(DAV) | DAC † to DAV † Delay—Output 3-Wire Handshake | 2 | | 2 | | 2 | | 23 | TdDAVOr(DAC) | $\overline{\mathrm{DAV}}$ † to DAC Delay—Output 3-Wire Handshake | 0 | | 0 | | | NOTES: 1. This time can be extended through the use of deskew timers. 2. Units equal to TcPC. <sup>\*</sup> Timings are preliminary and subject to change. All timing references assume 2.0 V for a logic "1" and 0.8 V for a logic "0" † Units in nanoseconds (ns), except as noted. Counter/ Timer Timing | | | | 4 | MHz | 6 1 | MHz | | |------|--------------------------|---------------------------------------------------------------------------------|-----|-----|-----|-----|---------| | No. | Symbol | Parameter | Min | Мах | Min | Мах | Notes*† | | 1 | TcCI | Counter Input Cycle Time | 500 | | 330 | | | | 2 | TCIh | Counter Input High Width | 230 | | 150 | | | | 3 | TWCI1 | Counter Input Low Width | 230 | | 150 | | | | 4 | TfCI | Counter Input Fall Time | | 20 | | 15 | | | 5 — | – TrCI ——— | — Counter Input Rise Time ———— | | 20 | | 15 | | | 6 | TsTI(PC) | Trigger Input to PCLK ↓ Setup Time (Timer Mode) | | | | | 1 | | 7 | TsTI(CI) | Trigger Input to Counter Input ↓ Setup Time<br>(Counter Mode) | | | | | 1 | | 8 | TwTI | Trigger Input Pulse Width (High or Low) | | | | | | | 9 | TsGI(PC) | Gate Input to PCLK ↓ Setup Time (Timer Mode) | | | | | 1 | | 10 — | – TsGI(CI) <del>––</del> | — Gate Input to Counter Input Setup Time ———————————————————————————————————— | | | | | 1 | | 11 | ThGI(PC) | Gate Input to PCLK ↓ Hold Time (Timer Mode) | | | | | 1 | | 12 | ThGI(CI) | Gate Input to Counter Input Hold Time (Counter Mode) | | | | | 1 | | 13 | TdPC(CO) | PCLK to Counter Output Delay (Timer Mode) | | | | | | | 14 | TdCI(CO) | Counter Input to Counter Output Delay<br>(Counter Mode) | | | | | | 2021-009 400 NOTES. 1. These parameters must be met to guarantee trigger or gate are valid for the next counter/timer cycle. <sup>\*</sup> Timings are preliminary and subject to change. All timing references assume 2.0 V for a logic "1" and 0.8 V for a logic "0" † Units in nanoseconds (ns). #### REQUEST/ WAIT Timing | | | | 4 1 | MHz | 6 1 | ИHz | | |-----|-----------------|-------------------------|-----|-----|-----|-----|---------| | No. | Symbol | Parameter | Min | Max | Min | Мах | Notes*† | | 1 | TdRD(REQ) | RD ↓ to REQ ↓ Delay | | | | | | | 2 | TdRD(WAIT) | RD ↓ to WAIT ↓ Delay | | | | | | | 3 | TdWR(REQ) | WR ↓ to WAIT ↓ Delay | | | | | | | 4 | TdWR(WAIT) | WR ↓ to WAIT ↓ Delay | | | | | | | 5— | – TdPC(REQ) ––– | -PCLK ↓ to REQ ↑ Delay | | | | | | | 6 | TdPC(WAIT) | PCLK ↓ to WAIT ↑ Delay | | | | | | | 7 | TdACK(REQ) | ACKIN ↓ to REQ ↑ Delay | | | | | 1,2 | | 8 | TdACK(WAIT) | ACKIN ↓ to WAIT ↑ Delay | | | | | 1,2 | #### NOTES: - 1. The delay is from DAC 1 for 3-Wire Input Handshake. The delay is from DAC 1 for 3-Wire Output Handshake. 2. Units equal to TcPC + ns. - \* Timings are preliminary and subject to change. All timing references assume 2.0 V for a logic "1" and 0.8 V for a logic "0". † Units in nanoseconds (ns), except as noted #### Reset Timing | | | | 4 1 | MHz | 61 | MHz | | |-----|----------|---------------------------------------------------------------------------------------|-----|-----|-----|-----|---------| | No. | Symbol | Parameter | Min | Max | Min | Max | Notes*† | | 1 | TdRD(WR) | Delay from $\overline{RD}$ † to $\overline{WR}$ ↓ for No Reset | 50 | | 50 | | | | 2, | TdWR(RD) | Delay from WR ↑ to RD ↓ for No Reset | 50 | | 50 | | | | 3 | TwRES | Minimum Width of $\overline{\text{RD}}$ and $\overline{\text{WR}}$ both Low for Reset | 250 | | 250 | | | $<sup>^{\</sup>bullet}$ Timings are preliminary and subject to change. All timing references assume 2.0 V for a logic "1" and 0.8 V for a logic "0". <sup>†</sup> Unites in nanoseconds (ns). #### Miscellaneous Port Timing | | | | 4 | MHz | 6 1 | MHz | | |-----|--------|-----------------------------------------------------|------|-----|-----|-----|---------| | No. | Symbol | Parameter | Min | Max | Min | Мах | Notes*† | | 1 | TrI | Any Input Rise Time | | 100 | | 100 | | | 2 | TfI | Any Input Fall Time | | 100 | | 100 | | | 3 | Twl's | l's Catcher High Width | 250 | | 170 | | 1 | | 4 | TwPM | Pattern Match Input Valid (Bit Port) | 750 | | 500 | | | | 5 | TsPMD | Data Latched on Pattern Match Setup Time (Bit Port) | 0 | | 0 | | | | 6 | ThPMD | Data Latched on Pattern Match Hold Time (Bit Port) | 1000 | | 650 | | | #### NOTES: <sup>\*</sup> Timings are preliminary and subject to change. All timing references assume 2.0 V for a logic "1" and 0.8 V for a logig "0". † Units in nanoseconds (ns). | Ordering<br>Information | Product<br>Number | Package/<br>Temp | Speed | Description | Product<br>Number | Package/<br>Temp | Speed | Description | |-------------------------|-------------------|------------------|---------|---------------|-------------------|------------------|---------|---------------| | | Z8536 | CE | 4.0 MHz | CIO (40-pin) | Z8536A | CE | 6.0 MHz | CIO (40-pin) | | | Z8536 | CM | 4.0 MHz | Same as above | Z8536A | CM | 6.0 MHz | Same as above | | | Z8536 | CMB | 4.0 MHz | Same as above | Z8536A | CMB | 6.0 MHz | Same as above | | | Z8536 | CS | 4.0 MHz | Same as above | Z8536A | CS | 6.0 MHz | Same as above | | | Z8536 | DE | 4.0 MHz | Same as above | Z8536A | DE | 6.0 MHz | Same as above | | | Z8536 | DS | 4.0 MHz | Same as above | Z8536A | DS | 6.0 MHz | Same as above | | | Z8536 | PE | 4.0 MHz | Same as above | Z8536A | PE | 6.0 MHz | Same as above | | | Z8536 | PS | 4.0 MHz | Same as above | Z8536 <b>A</b> | PS | 6.0 MHz | Same as above | NOTES: C = Ceramic, D = Cerdip, P = Plastic, $E = -40\,^{\circ}C$ to $+85\,^{\circ}C$ , $M = -55\,^{\circ}C$ to $125\,^{\circ}C$ , $MB = -55\,^{\circ}C$ to $125\,^{\circ}C$ with MIL-STD-883 with Class B processing, $S = 0\,^{\circ}C$ to $+70\,^{\circ}C$ . **2014-028** 00-2021-02 <sup>1</sup> If the input is programmed inverting, a Low-going pulse of the same width will be detected. ## **Z8581 Clock Generator** and Controller ### Product Brief #### June 1982 #### Features - Two independent 20 MHz oscillators. - Clock output drivers meet the high capacitance clock input requirements of NMOS microprocessors. - Outputs directly drive the Z80 and Z8000 microprocessor clock inputs. - Oscillator input frequency reference source can be either crystals or TTL-compatible oscillators. - System Clock oscillator - □ Provides a TTL-compatible timebase signal at source frequency. - □ Provides an NMOS-compatible clock signal at a programmable percentage of the source frequency. - Provides ability to stretch High or Low phase of clock signal under external control. - General-Purpose Clock oscillator - □ Provides an NMOS clock signal at half source frequency. - System Reset output - □ Reset output is synchronized with System Clock output. - □ Power up reset period is maintained for a minimum of 30 ms. - □ External input initiates system reset. - 18-pin slimline package used; single +5 V dc power required. #### Introduction The Z8581 Clock Generator and Controller is a versatile addition to Zilog's family of Universal microprocessor components. The selective clock-stretching capabilities and variety of timing outputs produced by this device allow it to easily meet the timing design requirements of systems with microprocessors and LSI peripherals. The clock output drivers of the Z8581 also meet the non-TTL voltage requirements for driving NMOS clock inputs with no additional external discrete transistors. In general, the Z8581 provides an elegant, single-chip solution to the design of system clocks for microprocessor-based products. #### General Description The Z8581 is produced in an 18-pin package (see Figure 1 for pin functions and Figure 2 for pin assignments); it contains two separate oscillators, cycle stretching logic, and reset synchronization and delay logic. Figure 1. Pin Functions Figure 2. Pin Assignments 2248-001, 002 General Description (Continued) The Z8581 oscillators are referenced as the System Clock oscillator and the General-Purpose Clock oscillator. Both oscillators are driven by external crystals or other frequency sources. System Clock Oscillator. The timing outputs provided by this oscillator consist of a Time Base output (OSC), at the frequency of the reference source, and a stretchable System Clock output (ZCLK), at a frequency determined by the stretch control inputs. An onchip TTL driver at OSC and an NMOS driver at ZCLK eliminate the need for external buffers or drivers. The NMOS drivers can drive 200 pF loads to within 0.2 volts of $V_{\rm CC}$ and sink 8 mA. Output rise and fall times are 10 ns. ZCLK can be stretched under program or hardwired control by selectively adding periods equivalent to a full OSC cycle to either the High or Low portion of a clock cycle. One, two, or three periods can be added to double, triple, or quadruple the duration of the selected ZCLK half-cycle. Adding periods to ZCLK is a function of the ADDI and ADD2 inputs. These active Low inputs are sampled prior to the rising edge of signal OSC; their sampled status represents the number of periods to be added to ZCLK. Two additional control inputs, $\overline{\text{INH}}$ and $\overline{\text{STRH}}$ , affect the stretch function. Input $\overline{\text{INH}}$ , when asserted, inhibits the function of $\overline{\text{ADDI}}$ and $\overline{\text{ADD2}}$ . Input $\overline{\text{STRH}}$ stretches the ZCLK output for as long as it is asserted (Low); it overrides all other stretch control inputs. Table 1 summarizes the functions performed by the stretch control inputs. | STRH | ĪNĦ | ADDI | ADD2 | Periods Added | |------|-----|------|------|---------------| | 0 | Х | Х | Х | Unlimited | | 1 | 0 | Х | X | 0 | | 1 | 1 | 0 | 0 | 3 | | 1 | 1 | 0 | 1 | 2 | | 1 | 1 | 1 | 0 | 1 | | 1 | 1 | 1 | 1 | 0 | Notes X = Don't Care, 1 = High, 0 = Low Table 1. Stretch Control Functions The clock stretch capability allows systems to run at the nominal high speed of ZCLK, except during cycles that require more time than usual to complete a transaction. For example, extended access time may be required in accessing certain areas of memory, in accessing I/O devices or in other CPU/Peripheral transactions. Figures 3 and 4 illustrate, respectively, the circuit configuration and timing required to stretch the Z8000 address strobe ( $\overline{\rm AS}$ ) and data strobe ( $\overline{\rm DS}$ ) to allow more time for address functions and to enable the CPU to operate with memories that have a relatively long access time. In addition, the ZCLK stretch control logic can be hardwired to meet various duty cycle requirements. For example, a simple hardwired connection can cause every other ZCLK cycle to be stretched to produce a ZCLK output with a 33% duty cycle. The System Clock oscillator also provides a system reset output (\$\overline{RTSO}\$) that is synchronized with ZCLK. This output is controlled by a system reset input (\$\overline{RSTI}\$) during normal system reset operations and by delay circuitry in the System Clock oscillator during power up operations. During a normal system reset operation a Low on \$\overline{RSTI}\$ causes \$\overline{RSTO}\$ to be asserted (set Low) on the next rising edge of \$ZCLK\$. Output \$\overline{RSTO}\$ is held Low for a period of 16 \$ZCLK\$ clock cycles (the required reset time for both the Z80 and Z8000 CPU system reset functions). During a power up operation, \$\overline{RSTO}\$ is asserted for a minimum of 30 ms after Figure 3. Configuration for Stretching Z8000 Address (AS) and Data (DS) Strobes 404 2248-003 # General Description (Continued) power is turned on (the time required for both the Z80 and Z8000 power up functions). The System Clock oscillator also contains a 2-bit ZCLK counter. This counter, when initialized by the assertion of $\overline{STRT}$ , counts the next four rising edges of the ZCLK output. The current count is presented on outputs C0 and C1. This counter and its outputs enable the user to determine the occurrence (rising edge) of each of four clocks after a specific event ( $\overline{STRT}$ is asserted). This facility can, for example, be used to determine when a delay is to be inserted into a CPU machine cycle when $\overline{STRT}$ is triggered by either an $\overline{M1}$ (Z80) or an $\overline{AS}$ (Z8000) input signal. General-Purpose Oscillator. This oscillator provides a fixed frequency General-Purpose Clock output (TCLK) at half its source frequency. This output is useful for system timing functions such as controlling a baud rate generator. Output TCLK can also be used as the frequency reference source for the System Clock oscillator. Figure 4. Timing Diagram, Stretching Z8000 AS and DS 00-2248-01 2248-004 405 ### Z8590 UPC Universal Peripheral Controller ### Product Specification June 1982 #### Features - Complete slave microcomputer, for distributed processing use. - Unmatched power of Z8 architecture and instruction set. - Three programmable I/O ports, two with optional 2-Wire Handshake. - Six levels of priority interrupts from eight sources: six from external sources and two from internal sources. - Two programmable 8-bit counter/timers each with a 6-bit prescaler. Counter/Timer T0 is driven by an internal source, and Counter/Timer T1 can be driven by internal or external sources. Both counter/timers are independent of program execution. - 256-byte register file, accessible by both the master CPU and UPC, as allocated in the UPC program. - 2K bytes of on-chip ROM for efficiency and versatility. #### General Description The Z8590 Universal Peripheral Controller (UPC) is an intelligent peripheral controller for distributed processing applications (Figure 3). The UPC unburdens the host processor by assuming tasks traditionally done by the host (or by added hardware), such as performing arithmetic, translating or formatting data, and controlling I/O devices. Based on the Z8 microcomputer architecture and instruction set, the UPC contains 2K bytes of internal program ROM, a 256-byte register file, three 8-bit I/O ports, and two counter/timers. The UPC offers fast execution time, an effective use of memory, and sophisticated interrupt, I/O, and bit manipulation. Using a powerful and extensive instruction set Figure 1. Pin Functions Figure 2. Pin Assignments General Description (Continued) combined with an efficient internal addressing scheme, the UPC speeds program execution and efficiently packs program code into the on-chip ROM. An important feature of the UPC is an internal register file containing I/O port and control registers accessed both by the UPC program and indirectly by its associated master CPU. This architecture results in both byte and programming efficiency, because UPC instructions can operate directly on I/O data without moving it to and from an accumulator. Such a structure allows the user to allocate as many general purpose registers as the application requires for data buffers between the CPU and peripheral devices. All general-purpose registers can be used as address pointers, index registers, data buffers, or stack space. The register file is logically divided into 16 groups, each consisting of 16 working registers. A Register Pointer is used in conjunction with short format instructions, resulting in tight, fast code and easy task switching. Communication between the master CPU and the register file takes place via one group of 19 interface registers addressed directly by both the master CPU and the UPC, or via a block transfer mechanism. Access by the master CPU is controlled by the UPC to allow independence between the master CPU and UPC software. The UPC has 24 pins that can be dedicated to I/O functions. Grouped logically into three 8-line ports, they can be programmed in many combinations of input or output lines, with or without handshake, and with push-pull or open-drain outputs. Ports 1 and 2 are bit-programmable; Port 3 has four fixed inputs and four outputs. To relieve software from coping with realtime counting and timing problems, the UPC has two 8-bit hardware counter/timers, each with a fixed divide-by-four, and a 6-bit programmable prescaler. Various counting modes may be selected. In addition to the 40-pin standard configuration, the UPC is available in four special configurations: - A 64-pin RAM development version with external interface for up to 4K bytes of RAM and 36 bytes of internal ROM permitting down-loading from the master CPU. - A Protopack RAM version with a socket for up to 2K bytes of RAM, with 36 bytes of internal ROM permitting down-loading from the master CPU. - A 64-pin ROM development version with external interface for up to 4K bytes of ROM and no internal ROM. - A Protopack ROM version with a socket for 2K bytes of ROM and no internal ROM. This range of versions and configurations makes the UPC compatible with most system peripheral device control considerations. Figure 3. Functional Block Diagram #### Pin Description **Ā/D.** Address/Data (input). A Low on this pin defines information on the data bus as an address. A High defines the information as data. CS. Chip Select (input, active Low). A Low enables the UPC to accept address or data information from the master CPU during a write cycle or to transmit data to the master CPU during a read cycle. This line is usually generated from higher bits of the address lines **DB<sub>0</sub>-DB<sub>7</sub>.** Data Bus (bidirectional). This bus is used to transfer address and data information between the master CPU and the UPC. Pl<sub>0</sub>-Pl<sub>7</sub>, P2<sub>0</sub>-P2<sub>7</sub>, P3<sub>0</sub>-P3<sub>7</sub>. I/O Port Lines (bidirectional, TTL compatible). These 24 lines are divided into three 8-bit I/O ports and may be configured in the following ways under program control: **Pl<sub>0</sub>-Pl<sub>7</sub>.** Port 1 (input/output—as output it can be push-pull or open-drain). Bit-programmable Parallel I/O. P20-P27. Port 2 (input/output—as output, it can be push-pull or open-drain). Bit-programmable Parallel I/O. **P30-P37.** Port 3 (four inputs, four outputs). Parallel I/O, handshake control, timer I/O, or interrupt control. **PCLK.** Clock (input). TTL-compatible clock input, 4 MHz maximum. This signal does not need to be related to the master CPU clock. $\overline{\textbf{RD}}$ . Read (input, active Low). A Low enables the master CPU to read information from the UPC. Raising the voltage on this pin above $V_{DD}$ will force the UPC into test mode. **WAIT.** Wait (output, active Low, open-drain). When the CPU accesses the UPC register file, this signal requests the master CPU to wait until the UPC can complete its part of the transaction. $\overline{\mathbf{WR}}$ . Write (input, active Low). A Low on this pin enables the master CPU to write information to the UPC. A simultaneous Low on $\overline{\mathrm{RD}}$ and $\overline{\mathrm{WR}}$ resets the UPC. It is held in reset as long as $\overline{\mathrm{WR}}$ is Low. ## Functional Description Address Space. On the 40-pin UPC, all address space is committed to on-chip memory. There are 2048 bytes of mask-programmed ROM and 256 bytes of register file. I/O is memory-mapped to three registers in the register file. Only the Protopack and 64-pin versions of the UPC can access external program memory. See the section entitled "Special Configurations" for complete descriptions of the Protopack and 64-pin versions. Program Memory. Figure 4 is a map of the 2K on-chip program ROM. Even though the architecture allows addresses from 0 to 4K, behavior of the device above program address 2047 (7FFH) is not defined. The first 12 bytes of program memory are reserved for the UPC interrupt vectors. For the Protopack and 64-pin versions, the address space is extended to 4096 bytes. In the RAM versions, addresses 0CH Figure 4. Program Memory Map through 2FH are reserved for on-chip ROM. Register File. This 256-byte file includes three I/O port registers (1-3H), 234 general-purpose registers (6-EEH), and 19 control, status and special I/O registers (0H, 4H, 5H, and F0-FFH). The functions and mnemonics assigned to these register address locations are shown in Figure 5. Of the 256 UPC registers, 19 can be directly accessed by the master CPU; the others are accessed indirectly via the block transfer mechanism. Figure 5. Register File Organization Functional Description (Continued) The I/O port and control registers are included in the register file without differentiation. This allows any UPC instruction to process I/O or control information, thereby eliminating the need for special I/O and control instructions. All general-purpose registers can function as accumulators, address pointers, or index registers. In instruction execution, the registers are read when they are defined as sources and written when defined as destinations. UPC instructions may access registers directly or indirectly using an 8-bit address mode or a 4-bit address mode and a Register Pointer. For the 4-bit addressing mode, the file is divided into 16 working register groups, each occupying 16 contiguous locations (Figure 6). The Register Pointer (RP) addresses the starting point of the active working-register group, and the 4-bit register designator supplied by the instruction specifies the register within the group. Any instruction altering the contents of the register file can also alter the Register Pointer. The UPC instruction set has a special Set Register Pointer (SRP) instruction for initializing or altering the pointer contents. Stacks. An 8-bit Stack Pointer (SP), register R255, is used for addressing the stack, residing within the 234 general-purpose registers, address location 6H through EFH. PUSH and POP instructions can save and restore any register in the register file on the stack. During CALL instructions, the Program Counter is automatically saved on the stack. During UPC interrupt cycles, the Program Counter and the Flag register are automatically saved on the stack. The RET and IRET instructions pop the saved values of the Program Counter and Flag register. Figure 6. Register Pointer Mechanism **Ports.** The UPC has 24 lines dedicated to input and output. These are grouped into three ports of eight lines each and can be configured under software control as inputs, outputs, or special control signals. They can be programmed to provide Parallel I/O with or without handshake and timing signals. All outputs can have active pullups and pulldowns, compatible with TTL loads. In addition, they may be configured as open-drain outputs. Port 1. Individual bits of Port 1 can be configured as input or output by programming Port 1 Mode register (P1M) F8H. This port is accessed by the UPC program as general register 1H. It is written by specifying address 1H as the destination of any instruction used to store data in the output register. The port is read by specifying address 1H as the source of an instruction. Port 1 may be placed under handshake control by programming Port 3 Mode register (P3M) F7H. This configures Port 3 pins P33 and P34 as handshake control lines $\overline{\rm DAV}_1$ and RDY1 for input handshake, or RDY1 and $\overline{\rm DAV}_1$ for output handshake, as determined by the direction (input or output) assigned to bit 7 of Port 1. The Port 3 Mode register also has a bit that programs Port 1 for open-drain output. Port 2. Individual bits of Port 2 can be configured as inputs or outputs by programming Port 2 Mode register (P2M) F6H. This port is accessed by the UPC program as general register 2H, and its functions and methods of programming are the same as those of Port 1. Port 3 pins P31 and P36 are the handshake lines $\overline{DAV_2}$ and RDY2, with the direction (input or output) determined by the state of bit 7 of the port. The Port 3 Mode register also has a bit used to program Port 2 for open-drain output. | Function | Line | Direction | Signal | |------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------|------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Handshake { | P3 <sub>1</sub><br>P3 <sub>3</sub><br>P3 <sub>4</sub><br>P3 <sub>6</sub> | In<br>In<br>Out<br>Out | $\begin{array}{c} \overline{\text{DAV}}_2/\text{RDY}_2 \\ \overline{\text{DAV}}_1/\text{RDY}_1 \\ \text{RDY}_1/\overline{\text{DAV}}_1 \\ \text{RDY}_2/\overline{\text{DAV}}_2 \end{array}$ | | $\begin{array}{c} \text{UPC Interrupt} \\ \text{Request*} \end{array} \left\{ \begin{array}{c} \\ \end{array} \right.$ | P3 <sub>0</sub> | In | IRQ <sub>3</sub> | | | P3 <sub>1</sub> | In | IRQ <sub>2</sub> | | | P3 <sub>3</sub> | In | IRQ <sub>1</sub> | | Counter/Timer { | P3 <sub>1</sub> | In | T <sub>7N</sub> | | | P3 <sub>6</sub> | Out | T <sub>OUT</sub> | | $ ext{Master CPU} \; \left\{ ight. ight. \; \left. ight. ight. ight. \; \left. ight. ig$ | P3 <sub>5</sub> | Out | INT | | | P3 <sub>2</sub> | In | INTACK | | | P3 <sub>0</sub> | In | IEI | | | P3 <sub>7</sub> | Out | IEO | | Test Mode | P3 <sub>5</sub> | Out | Ā/D | <sup>\*</sup>P3<sub>0</sub>, P3<sub>1</sub>, and P3<sub>3</sub> can always be used as UPC interrupt request inputs, regardless of the configuration programmed. Table 1. Port 3 Control Functions 410 2017-003 # Functional Description (Continued) Port 3. This port can be configured as I/O or control lines by programming the Port 3 Mode register. Port 3 is accessed as general register 3H. The directions of the eight data lines are fixed. Four lines, P30 through P33, are inputs, and the other four, P34 through P37, are outputs. The control functions performed by Port 3 are listed in Table 1. **Counter/Timers.** The UPC contains two 8-bit programmable counter/timers, each driven by an internal 6-bit programmable prescaler. The T1 prescaler can be driven by internal or external clock sources. The TO prescaler is driven by an internal clock source. Both counter/timers operate independently of the processor instruction sequence to relieve the program from time-critical operations like event counting or elapsed-time calculation. TO Prescaler register (PREO) F5H and T1 Prescaler register (PRE1) F3H can be programmed to divide the input frequency of the source being counted by any number from 1 to 64. A counter register (F2H or F4H) is loaded with a number from 1 to 256. The corresponding counter is decremented from this number each time the prescaler reaches end-of-count. When the count is complete, the counter issues a timer interrupt request; IRQ4 for T0 or IRQ5 for T1. Loading either counter with a number (n) results in the interruption of the UPC at the nth count. The counters can be started, stopped, restarted to continue, or restarted from the initial value. They can be programmed to stop upon reaching end-of-count (Single-Pass mode) or to automatically reload the initial value and continue counting (Modulo-n Continuous mode). The counters and prescalers can be read at any time without disturbing their values or changing their counts. The clock sources for both timers can be defined as any one of the following: - UPC internal clock (4 MHz maximum) divided by four. - External clock input to Counter/Timer Tl via P3<sub>1</sub> (1 MHz maximum). - Retriggerable trigger input for the UPC internal clock divided by four. - Nonretriggerable trigger input for the UPC internal clock divided by four. - External gate input for the UPC internal clock divided by four. **Interrupts.** The UPC allows six interrupts from eight different sources as follows: - Port 3 lines P3<sub>0</sub>, P3<sub>2</sub>, and P3<sub>3</sub>. - The master CPU(3). - The two counter/timers. These interrupts can be masked and globally enabled or disabled using Interrupt Mask Register (IMR) FBH. Interrupt Priority Register (IPR) F9H specifies the order of their priority. All UPC interrupts are vectored. Table 2 lists the UPC's interrupt sources, their types, and their vector locations in program ROM. Interrupt Request IRQ6 is dedicated to master CPU communications. Interrupt Requests IRQ1, IRQ2, and IRQ3 are generated on the falling transitions of external inputs P33, P31, and P30. Interrupt Requests IRQ4 and IRQ5 are generated upon the timeout of the UPC's two counter/timers. When an interrupt request is granted, the UPC enters an interrupt machine cycle. This cycle disables all subsequent interrupts, saves the Program Counter and Status Flags, and branches to the program memory vector location reserved for that interrupt. This memory location and the next byte contain the 16-bit address of the interrupt service routine for that particular interrupt request. The UPC also supports polled systems. To accommodate a polled structure, any or all of the interrupt inputs can be masked and the Interrupt Request register polled to determine which of the interrupt reguests needs service. Following any hardware reset operation, an EI instruction must be executed to enable the setting of any interrupt request bit in the IRQ register. Interrupts must be disabled prior to changing the content of either the IPR (F9H) or the IMR (FBH). DI is the only instruction that should be used to globally disable interrupts. | Name | Source | Vector<br>Location | Comments | |------------------|-------------------------------------------------------------|--------------------|----------------------------------------------| | IRQ <sub>0</sub> | EOM, XERR, LERR | 0,1 | Internal (RO Bits 0, 1, 2) | | $IRQ_1$ | $\overline{\mathtt{DAV}}_1$ , $\mathtt{IRQ}_1$ | 2,3 | External (P3 <sub>3</sub> ) ↓ Edge Triggered | | $IRQ_2$ | $\overline{\mathtt{DAV}}_2$ , IRQ $_2$ , T $_{\mathrm{IN}}$ | 4,5 | External (P3 <sub>1</sub> ) Edge Triggered | | $IRQ_3$ | IRQ3, IEI | 6,7 | External (P3 <sub>0</sub> ) Edge Triggered | | $IRQ_4$ | TO | 8,9 | Internal | | IRQ5 | Tl | 10,11 | Internal | Table 2. Interrupt Types, Sources, and Vector Locations Functional Description (Continued) Master CPU Register File Access. There are two ways in which the master CPU can access the UPC register file: direct access and block access. Direct Access. Three UPC registers—the Data Transfer Control (0H), the Master Interrupt Vector (F0H), and the Master Interrupt Control (FEH)—are mapped directly into the master CPU address space. The master CPU accesses these registers via the addresses shown in Table 3. The master CPU also has direct access to 16 registers known as the DSC (Data, Status, Command) registers. The DSC registers are numbered 0 through F (DSC0-DSCF). These registers can be any 16 contiguous register file registers beginning on a 16-byte boundary. The base address of the DSC register group is designated by the IRP (I/O Register Pointer), which is bits D<sub>4</sub>-D<sub>7</sub> of the Data Transfer Control register (0H). Figure 7 shows how the register address is made up of the 4-bit IRP field, concatenated with the low order 4-bits of the address from the master CPU. Block Access. The master CPU may transmit or receive blocks of data via address xxx10101. When the master CPU accesses this address, the UPC register pointed to by the Data Indirection register is read or written. The Data Indirection register is incremented, and the Limit Count register is decremented, for example, when the master CPU issues a read or write to address xxx10101 while the Data Figure 7. DSC Register Addressing Scheme Indirection register contains the value 33H. The operation causes register 33H to be read or written and the Data Indirection register to be incremented to 34H. This scheme is well suited to Block I/O Instructions and allows the master CPU to efficiently read or write a block of data to or from the UPC. The Limit Count register (04H) is decremented and is used to control the number of bytes to be transferred by master CPU block accesses. If the master CPU attempts a read or write to the UPC after the Limit Count register reaches 0, the access is not completed, the LERR bit (D<sub>1</sub>) of the Data Transfer Control register is set (indicating a limit error), and the LERR error causes an IRQ0 interrupt request. The IRP field of the Data Transfer Control register, the Data Indirection register, and the Limit Count register are not directly accessible to the master CPU and therefore must be set by the UPC. This allows the UPC to protect itself from master CPU errors and frees the master CPU from tracking the UPC's internal data layout. | UPC A | ddress | | | |--------------|--------|------------|----------| | Decimal | Hex | Identifier | Address | | 0 | OH | DTC | xxx11000 | | 5 | 5H | DIND | | | <b>@</b> 5** | @5H** | | xxx10101 | | 240 | FOH | MIV | xxx10000 | | 254 | FEH | MIC | xxx11110 | | *n | | DSC0 | xxx00000 | | n+1 | | DSC1 | xxx00001 | | n+2 | | DSC2 | xxx00010 | | n+3 | | DSC3 | xxx00011 | | n+4 | | DSC4 | xxx00100 | | n+5 | | DSC5 | xxx00101 | | n+6 | | DSC6 | xxx00110 | | n+7 | | DSC7 | xxx00111 | | n+8 | | DSC8 | xxx01000 | | n+9 | | DSC9 | xxx01001 | | n + 10 | | DSCA | xxx01010 | | n+ll | | DSCB | xxx01011 | | n+12 | | DSCC | xxx01100 | | n + 13 | | DSCD | xxx01101 | | n + 14 | | DSCE | xxx01110 | | n + 15 | | DSCF | xxx01111 | x = don't care Table 3. Master CPU/UPC Register Map <sup>\*</sup>n is the value in the IRP x 16 <sup>\*\*</sup>Master CPU accesses the register address in Register 5. #### Special Configurations There are two Protopack and two 64-pin versions of the UPC. These versions are identical to the 40-pin UPC with the following exceptions: - Internal ROM is totally omitted from the 64-pin development and ROM Protopack versions. - All but 36 bytes of internal ROM are omitted from the 64-pin RAM and Protopack RAM versions. - The memory address and data lines are buffered and brought out to external pins or to the socket on the Protopack. - Control lines for the external memory are also provided. The 64-pin version of the UPC allows the user to prototype the system in hardware with an actual UPC device and to develop the code intended to be mask programmed into the on-chip ROM of the 40-pin UPC for the production system. The 64-pin or Protopack RAM versions of the UPC are extremely versatile parts. Memory space can be extended to 4K bytes on the 64-pin version by using external RAM/ROM for all but 36 bytes of the UPC's memory space. This memory can then be down-loaded from the master CPU using a bootstrap program stored in the 36 bytes (C-2F). Figure 8 is a memory map for the 64-pin RAM version. Figure 8. UPC RAM Version Memory Map **64-Pin and Protopack Pin Functions.** Forty of the pins on the 64-pin and Protopack versions have functions identical to those of the 40-pin version. The remaining 24 pins have additional functions described below. (Figures 9 through 11 show the 64-pin and Protopack versions' pin functions and pin assignments.) **A<sub>0</sub>-A<sub>11</sub>.** Program Memory Address Lines (output). These lines are identical in all 64-pin and RAM versions in the Protopack. They are used to address 4K bytes of external UPC memory. **D<sub>0</sub>-D<sub>7</sub>.** Program Data (input). Data is read in from the external memory on these lines. The RAM version also writes external memory through this bus. **IACK.** Interrupt Acknowledge (output, active High). This signal is active whenever an internal UPC interrupt cycle is in process. Figure 9. Z8591/Z8592 UPC Pin Functions 2017 005, 006 #### Special Configurations (Continued) MAS. Memory Address Strobe (output, active Low). This address strobe is pulsed once for each memory fetch to interface with quasistatic RAM. MDS. Memory Data Strobe (output, active Low). This signal is Low during an instruction fetch or memory write. P3₁ [ 64 h+5 V P36 63 PCLK P27 62 P37/IEO P2e □ 61 P3<sub>0</sub>/IEI P2s 60 P35/INT P24 [ 59 P32/INTACK P23 58 RD 57 □ WR 56 □ Ā/D P22 [ P21 [ 55 CS 54 WAIT P20 10 P3<sub>3</sub> 11 P34 🖂 12 53 DB7 P17 52 DB<sub>6</sub> 13 P16 🗌 51 DB5 78501 P15 15 50 DB4 Z8592 P14 [ 49 DB<sub>3</sub> 16 P13 [ 48 GND 17 P12 ⊟ DВ₂ 18 47 P11 19 46 DB1 P10 [ 20 45 DB<sub>0</sub> 44 SYNC D7 21 D6 [ 22 43 MAS 42 MDS D<sub>5</sub> 23 41 MR/W/IACK D4 [ 24 25 40 D<sub>0</sub> A<sub>0</sub> 26 39 🔲 D<sub>1</sub> 27 38 A<sub>2</sub> [ 28 37 🗖 D<sub>3</sub> A3 [ A<sub>4</sub> 29 36 A11 35 A10 A<sub>5</sub> 31 34 🛮 A9 A<sub>6</sub> [ MR/W. Memory Read/Write (output RAM versions only). This signal is High when the UPC is fetching an instruction and Low when it is loading external memory. **SYNC.** Instruction Sync (output, active Low). This signal is Low during the clock cycle just preceding an opcode fetch. \*SOCKET FOR 2716 EPROM (2K × 8) OR RAM Figure 10. Z8591/Z8592 UPC Pin Assignments 33 Figure 11. Z8593/Z8594 UPC Protopack Pin Assignments #### Addressing Modes The following notation is used to describe the addressing modes and instruction operations as shown in the instruction summary. R Register or working-register address Working-register address only 32 IR Indirect-register or indirect working-register address Ir Indirect working-register address only RR Register pair or working-register pair address IRR Indirect register pair or indirect working-register pair address Irr Indirect working-register pair only X Indexed address DA Direct address RA Relative address IM Immediate #### Additional Symbols dst Destination location or contents src Source location or contents cc Condition code (see list) @ Indirect address prefix SP Stack Pointer (control register FFH) PC Program Counter FLAGS Flag register (control register FCH) RP Register Pointer (control register FDH) IMR Interrupt Mask register (control register FBH) Assignment of a value is indicated by the symbol " $\leftarrow$ ". For example, dst ← dst + src indicates that the source data is added to the destination data and the result is stored in the destination location. The notation "addr(n)" is used to refer to bit "n" of a given location. For example, dst (7) refers to bit 7 of the destination operand. 2017-007, 008 | Flags | | ontrol Register FCH contains the following six | Affected flags are indicated by: | | | | | | |-------|------|------------------------------------------------|----------------------------------|---------------------------------------|--|--|--|--| | | flag | 8: | 0 | Cleared to zero | | | | | | | C | Carry flag | 1 | Set to one | | | | | | | Z | Zero flag | * | Set or cleared according to operation | | | | | | | S | Sign flag | _ | Unaffected | | | | | | | V | Overflow flag | x | Undefined | | | | | | | D | Decimal-adjust flag | | | | | | | | | H | Half-carry flag | | | | | | | | Condition | Value | Mnemonic | Meaning | Flags Set | |-----------|-------|----------|--------------------------------|-------------------------| | Codes - | 1000 | | Always true | | | | 0111 | С | Carry | C = 1 | | | 1111 | NC | No carry | C = 0 | | | 0110 | Z | Zero | Z = 1 | | | 1110 | NZ | Not zero | Z = 0 | | | 1101 | PL | Plus | S = 0 | | | 0101 | MI | Minus | S = 1 | | | 0100 | OV | Overflow | V = 1 | | | 1100 | NOV | No overflow | V = 0 | | | 0110 | EQ | Equal | Z = 1 | | | 1110 | NE | Not equal | Z = 0 | | | 1001 | GE | Greater than or equal | (S XOR V) = 0 | | | 0001 | LT | Less than | (S XOR V) = 1 | | | 1010 | GT | Greater than | [Z OR (S XOR V)] = 0 | | | 0010 | LE | Less than or equal | [Z OR (S XOR V)] = 1 | | | 1111 | UGE | Unsigned greater than or equal | C = 0 | | | 0111 | ULT | Unsigned less than | C = 1 | | | 1011 | UGT | Unsigned greater than | (C = 0 AND Z = 0) = 1 | | | 0011 | ULE | Unsigned less than or equal | (C OR Z) = 1 | | | 0000 | | Never true | | CCF, DI, EI, IRET, NOP, RCF, RET, SCF INC . #### One-Byte Instructions Two-Byte Instructions Three-Byte Instructions | - | | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | A | В | С | D | E | F | |--------------------|-----------------|-----------------------------------------|----------------------------------------|----------------------------------------------------------|--------------------------------------------------------|--------------------------------------------------------|---------------------------------------------------------|--------------------------------------------|---------------------------------------------|-----------------------------------------------------|----------------------------|-----------------------------------------------|-------------------------|----------------------------|--------------------------------|------------------|--------------------| | | 0 | 6, 5<br><b>DEC</b><br>R <sub>1</sub> | 6, 5<br><b>DEC</b><br>IR <sub>1</sub> | 6, 5<br><b>ADD</b><br>r <sub>1</sub> , r <sub>2</sub> | 6, 5<br><b>ADD</b><br>r <sub>1</sub> , Ir <sub>2</sub> | 10, 5<br><b>ADD</b><br>R <sub>2</sub> , R <sub>1</sub> | 10, 5<br><b>ADD</b><br>IR <sub>2</sub> , R <sub>1</sub> | 10, 5<br><b>ADD</b><br>R <sub>1</sub> , IM | 10, 5<br><b>ADD</b><br>IR <sub>1</sub> , IM | 6,5<br><b>LD</b><br>r <sub>1</sub> , R <sub>2</sub> | 6,5<br><b>LD</b><br>r2, R1 | 12/10,5<br><b>DJNZ</b><br>r <sub>1</sub> , RA | 12/10,0<br>JR<br>cc, RA | 6,5<br><b>LD</b><br>r1, IM | 12/10,0<br><b>JP</b><br>cc, DA | 6,5<br>INC<br>11 | | | | 1 | 6, 5<br><b>RLC</b><br>R <sub>1</sub> | 6,5<br>RLC<br>IR <sub>1</sub> | 6,5<br><b>ADC</b><br>11,12 | 6, 5<br><b>ADC</b><br>r <sub>1</sub> , Ir <sub>2</sub> | 10, 5<br><b>ADC</b><br>R <sub>2</sub> , R <sub>1</sub> | 10, 5<br><b>ADC</b><br>IR <sub>2</sub> , R <sub>1</sub> | 10, 5<br><b>ADC</b><br>R <sub>1</sub> , IM | 10,5<br>ADC<br>IR <sub>1</sub> ,IM | | | | | | | | | | | 2 | 6,5<br>INC<br>R <sub>1</sub> | 6, 5<br><b>INC</b><br>IR <sub>1</sub> | 6, 5<br><b>SUB</b><br>11, 12 | 6, 5<br><b>SUB</b><br>r <sub>1</sub> , Ir <sub>2</sub> | 10, 5<br><b>SUB</b><br>R <sub>2</sub> , R <sub>1</sub> | 10, 5<br><b>SUB</b><br>IR <sub>2</sub> , R <sub>1</sub> | 10,5<br><b>SUB</b><br>R <sub>1</sub> , IM | 10, 5<br><b>SUB</b><br>IR <sub>1</sub> , IM | | | | | | | | | | | 3 | 8,0<br><b>JP</b><br>IRR <sub>1</sub> | 6, 1<br>SRP<br>IM | 6,5<br><b>SBC</b><br>11,12 | 6, 5<br><b>SBC</b><br>r1, Ir2 | 10, 5<br><b>SBC</b><br>R <sub>2</sub> , R <sub>1</sub> | 10, 5<br><b>SBC</b><br>IR <sub>2</sub> , R <sub>1</sub> | 10,5<br><b>SBC</b><br>R <sub>1</sub> , IM | 10, 5<br><b>SBC</b><br>IR <sub>1</sub> , IM | | | | | | | | | | | 4 | 8,5<br><b>DA</b><br>R <sub>1</sub> | 8,5<br><b>DA</b><br>IR <sub>1</sub> | 6, 5<br>OR<br>r1, r2 | 6, 5<br>OR<br>r <sub>1</sub> , Ir <sub>2</sub> | 10, 5<br>OR<br>R <sub>2</sub> , R <sub>1</sub> | 10, 5<br><b>OR</b><br>IR <sub>2</sub> , R <sub>1</sub> | 10,5<br><b>OR</b><br>R <sub>1</sub> ,IM | 10, 5<br><b>OR</b><br>IR <sub>1</sub> , IM | | | | | | | | | | | 5 | 10,5<br><b>POP</b><br>R <sub>1</sub> | 10, 5<br><b>POP</b><br>IR <sub>1</sub> | 6,5<br>AND<br>11,12 | 6, 5<br><b>AND</b><br>r <sub>1</sub> , Ir <sub>2</sub> | 10, 5<br><b>AND</b><br>R <sub>2</sub> , R <sub>1</sub> | 10,5<br><b>AND</b><br>IR <sub>2</sub> , R <sub>1</sub> | 10,5<br><b>AND</b><br>R <sub>1</sub> ,IM | 10,5<br>AND<br>IR <sub>1</sub> ,IM | | | | | | | | | | Hex) | 6 | 6, 5<br>COM<br>R <sub>1</sub> | 6,5<br><b>COM</b><br>IR <sub>1</sub> | 6, 5<br><b>TCM</b><br>11, 12 | 6, 5<br><b>TCM</b><br>r <sub>1</sub> , Ir <sub>2</sub> | 10, 5<br><b>TCM</b><br>R <sub>2</sub> , R <sub>1</sub> | 10, 5<br><b>TCM</b><br>IR <sub>2</sub> , R <sub>1</sub> | 10, 5<br><b>TCM</b><br>R <sub>1</sub> , IM | 10, 5<br><b>TCM</b><br>IR <sub>1</sub> , IM | | | | | | | | | | Upper Nibble (Hex) | 7 | 10/12, 1<br>PUSH<br>R <sub>2</sub> | 12/14, 1<br>PUSH<br>IR <sub>2</sub> | 6, 5<br><b>TM</b><br>r1, r2 | 6,5<br><b>TM</b><br>r <sub>1</sub> , Ir <sub>2</sub> | 10, 5<br><b>TM</b><br>R <sub>2</sub> , R <sub>1</sub> | 10, 5<br><b>TM</b><br>IR <sub>2</sub> , R <sub>1</sub> | 10,5<br><b>TM</b><br>R <sub>1</sub> ,IM | 10,5<br><b>TM</b><br>IR <sub>1</sub> ,IM | | | | | | | | | | Upper l | 8 | 10, 5<br><b>DECW</b><br>RR <sub>1</sub> | 10,5<br><b>DECW</b><br>IR <sub>1</sub> | 12,0<br><b>LDE</b><br>r <sub>1</sub> ,Irr <sub>2</sub> | 18,0<br><b>LDEI</b><br>Ir1, Irr2 | | | | | | | | | | | | 6, 1<br><b>DI</b> | | | 9 | 6,5<br><b>RL</b><br>R <sub>1</sub> | 6,5<br><b>RL</b><br>IR <sub>1</sub> | 12,0<br><b>LDE</b><br>r <sub>2</sub> ,Irr <sub>1</sub> | 18,0<br>LDEI<br>Ir2,Irr1 | | | | | | | | | | | | 6, 1<br><b>EI</b> | | | A | 10,5<br>INCW<br>RR <sub>1</sub> | 10,5<br>INCW<br>IR <sub>1</sub> | 6,5<br><b>CP</b><br>r <sub>1</sub> , r <sub>2</sub> | 6, 5<br><b>CP</b><br>r <sub>1</sub> , Ir <sub>2</sub> | 10, 5<br><b>CP</b><br>R <sub>2</sub> , R <sub>1</sub> | 10, 5<br><b>CP</b><br>IR <sub>2</sub> , R <sub>1</sub> | 10,5<br><b>CP</b><br>R <sub>1</sub> ,IM | 10, 5<br><b>CP</b><br>IR <sub>1</sub> , IM | | | | | | | | 14,0<br><b>RET</b> | | | В | 6,5<br><b>CLR</b><br>R <sub>1</sub> | 6,5<br>CLR<br>IR <sub>1</sub> | 6,5<br>XOR<br>r1, r2 | 6,5<br><b>XOR</b><br>r <sub>1</sub> , Ir <sub>2</sub> | 10, 5<br><b>XOR</b><br>R <sub>2</sub> , R <sub>1</sub> | 10, 5<br><b>XOR</b><br>IR <sub>2</sub> , R <sub>1</sub> | 10,5<br><b>XOR</b><br>R <sub>1</sub> , IM | 10,5<br><b>XOR</b><br>IR <sub>1</sub> , IM | | | | | | | | 16, 0<br>IRET | | | С | 6,5<br><b>RRC</b><br>R <sub>1</sub> | 6,5<br>RRC<br>IR <sub>1</sub> | 12, 0<br><b>LDC</b><br>r <sub>1</sub> , Irr <sub>2</sub> | 18,0<br>LDCI<br>Ir <sub>1</sub> , Irr <sub>2</sub> | | | | 10,5<br><b>LD</b><br>r1, x, R2 | | | | | | | | 6, 5<br><b>RCF</b> | | | D | 6,5<br><b>SRA</b><br>R <sub>1</sub> | 6,5<br><b>SRA</b><br>IR <sub>1</sub> | 12,0<br><b>LDC</b><br>r <sub>2</sub> , Irr <sub>1</sub> | 18,0<br>LDCI<br>Ir <sub>2</sub> , Irr <sub>1</sub> | 20,0<br>CALL*<br>IRR <sub>1</sub> | | 20,0<br>CALL<br>DA | 10, 5<br><b>LD</b><br>r2, x, R <sub>1</sub> | | | | | | | | 6, 5<br><b>SCF</b> | | | E | 6,5<br><b>RR</b><br>R <sub>1</sub> | 6,5<br><b>RR</b><br>IR <sub>1</sub> | | 6, 5<br><b>LD</b><br>r <sub>1</sub> , Ir <sub>2</sub> | 10, 5<br><b>LD</b><br>R <sub>2</sub> , R <sub>1</sub> | 10, 5<br><b>LD</b><br>IR <sub>2</sub> , R <sub>1</sub> | 10,5<br><b>LD</b><br>R <sub>1</sub> ,IM | 10, 5<br><b>LD</b><br>IR 1, IM | | | | | | | | 6,5<br>CCF | | | F | 8,5<br><b>SWAP</b><br>R <sub>1</sub> | 8,5<br>SWAP<br>IR <sub>1</sub> | | 6,5<br><b>LD</b><br>Ir1, r2 | | 10, 5<br><b>LD</b><br>R <sub>2</sub> , IR <sub>1</sub> | | | <b>\</b> | <b>\</b> | \ | <b>\</b> | ↓ | | <b>↓</b> | 6, 0<br><b>NOP</b> | | | s per<br>uction | _ | | | | | | | | | | 2 | | | 3 | _ | 1 | | | | | | | Lower<br>Opcod<br>Nibble | е | | | | | | | | | | | | | | | | Exe | cution | ₩ | Pip | eline | | | | | T 3. | | | | | | #### Legend: $\begin{array}{ll} R = 8\text{-Bit Address} \\ r = 4\text{-Bit Address} \\ R_1 \text{ or } r_1 = \text{Dst Address} \\ R_2 \text{ or } r_2 = \text{Src Address} \end{array}$ #### Sequence: Opcode, First Operand, Second Operand Note: The blank areas are not defined. <sup>\*2-</sup>byte instruction; fetch cycle appears as a 3-byte instruction. #### Instruction Summary | ### ADC dst,src dst - dst + src + C ### ADD dst,src dst - dst + src ### ADD dst,src dst - dst AND src ### AND dst,src dst - dst AND src ### CALL dst ### SP - SP - 2 ### GSP - PC; PC - d ### CCF | (No | te l) te l) | Byte (Hex) 1 | | | *<br>* | * | | | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------|--------------|----------------------|---|---|--------|---|---|---| | dst - dst + src + C ADD dst,src dst - dst + src AND dst,src dst - dst AND src CALL dst SP - SP - 2 @SP - PC; PC - d | (No (No DA IRR st | te l) | 0□<br>5□<br>D6<br>D4 | * | * | * | * | | * | | dst ← dst + src AND dst,src dst ← dst AND src CALL dst SP ← SP - 2 @SP ← PC; PC ← d | (No<br>DA<br>IRR<br>st | | 5□<br>D6<br>D4 | - | * | * | | 0 | * | | dst ← dst AND src CALL dst SP ← SP - 2 @SP ← PC; PC ← d | DA<br>IRR<br>st | te l) | D6<br>D4 | - | * | * | 0 | _ | - | | $SP \leftarrow SP - 2$<br>$@SP \leftarrow PC; PC \leftarrow d$ | IRR<br>st<br>R | | D4 | - | _ | | | | | | CCF | | | pr | | | - | - | - | - | | C - NOT C | | | EF | * | - | _ | - | - | - | | CLR dst<br>dst - 0 | | | B0<br>B1 | - | - | - | - | - | - | | COM dst<br>dst NOT dst | R<br>IR | | 60<br>61 | _ | * | * | 0 | _ | - | | CP dst,src<br>dst - src | (No | te l) | A□ | * | * | * | * | - | - | | <b>DA</b> dst<br>dst - DA dst | R<br>IR | | 40<br>41 | * | * | * | Х | - | - | | <b>DEC</b> dst dst - dst - l | R<br>IR | | 00<br>01 | _ | * | * | * | - | - | | <b>DECW</b> dst<br>dst ← dst – l | RR<br>IR | | 80<br>81 | - | * | * | * | _ | - | | <b>DI</b><br>IMR (7) - 0 | | | 8F | - | _ | _ | - | - | _ | | <b>DJNZ</b> r,dst r - r - 1 | RA | | rA<br>r=0-F | _ | - | - | - | - | _ | | ıf r ≠ 0<br>PC ← PC + dst<br>Range: +127, -128 | | | | | | | | | | | <b>EI</b> IMR (7) - 1 | | | 9F | - | _ | - | - | - | - | | INC dst<br>dst dst + 1 | r<br>R | | rE<br>r=0-F<br>20 | - | * | * | * | _ | - | | INCW dst | IR<br>RR | | 21<br>A0 | _ | * | * | * | _ | _ | | dst ← dst + 1 IRET | IR | | A1<br>BF | | _ | _ | | _ | _ | | FLAGS - @ SP; SP<br>PC - @ SP; SP - S | ← SP<br>P + 2; | + l<br>IMR ( | | | | | | _ | | | JP cc,dst<br>if cc is true | DA | | cD<br>c=0-F | _ | - | - | - | - | _ | | PC ← dst | IRR | | 30 | | | | | | | | JR cc,dst<br>if cc is true,<br>PC PC + dst<br>Range: +127, -128 | RA | | cB<br>c=0-F | _ | _ | _ | _ | _ | _ | | LD dst,src<br>dst - src | r<br>r | IM<br>R | rC<br>r8 | - | - | - | - | - | - | | | R<br>r | r<br>X | r9<br>r=0-F<br>C7 | | | | | | | | | X<br>r | r<br>Ir | D7<br>E3 | | | | | | | | | Ir<br>R | r<br>R | F3<br>E4 | | | | | | | | | R<br>R | IR<br>IM | E5<br>E6 | | | | | | | | | IR<br>IR | IM<br>R | E7<br>F5 | | | | | | | | <b>LDC</b> dst,src dst ← src | r<br>Irr | Irr<br>r | C2<br>D2 | _ | - | - | _ | _ | _ | | LDCI dst,src<br>dst src<br>r r + 1; rr rr + | Ir<br>Irr<br>1 | Irr<br>Ir | C3<br>D3 | - | - | - | - | _ | - | | Instruction and Operation | Addr l | | Opcode<br>Byte | Fl | αg | s A | iffe | ect | ed | |----------------------------------------------------------|----------------|-----------|----------------|----|----|-----|------|-----|----| | | dst | src | (Hex) | С | Z | S | V | D | H | | <b>LDE</b> dst,src<br>dst ← src | r<br>Irr | Irr<br>r | 82<br>92 | - | - | - | - | - | - | | <b>LDEI</b> dst,src<br>dst ← src<br>r ← r + 1; rr ← rr + | Ir<br>Irr<br>1 | Irr<br>Ir | 83<br>93 | - | - | - | - | - | - | | NOP | | | FF | _ | _ | _ | _ | _ | _ | | OR dst,src<br>dst ← dst OR src | (Note | e l) | 4□ | - | * | * | 0 | - | - | | <b>POP</b> dst<br>dst ← @ SP<br>SP ← SP + 1 | R<br>IR | | 50<br>51 | - | - | - | - | _ | - | | PUSH src<br>SP - SP - 1; @ SP - | src | R<br>IR | 70<br>71 | - | - | - | - | - | - | | <b>RCF</b><br>C - 0 | | | CF | 0 | _ | - | - | - | _ | | RET<br>PC - @SP; SP - SI | P + 2 | | AF | - | - | - | - | - | - | | RL dst | R<br>IR | | 90<br>91 | * | * | * | * | - | - | | RLC dst | R<br>IR | | 10<br>11 | * | * | * | * | _ | - | | RR dst | R<br>IR | | E0<br>E1 | * | * | * | * | _ | - | | RRC dst | R<br>IR | | C0<br>C1 | * | * | * | * | - | _ | | SBC dst,src<br>dst - dst - src - C | (Note | 1) | 3□ | * | * | * | * | 1 | * | | <b>SCF</b> C + 1 | | | DF | l | - | - | - | _ | - | | SRA dst | ] R<br>IR | | D0<br>D1 | * | * | * | 0 | _ | - | | SRP src<br>RP — src | | Im | 31 | _ | _ | _ | - | - | - | | SUB dst,src<br>dst — dst – src | (Note | : 1) | 2□ | * | * | * | * | 1 | * | | SWAP dst 7 42 0 | R<br>IR | | FO<br>Fl | Х | * | * | Х | - | - | | TCM dst,src<br>(NOT dst) AND src | (Note | 1) | 6□ | - | * | * | 0 | - | _ | | TM dst,src<br>dst AND src | (Note | 1) | 7□ | _ | * | * | 0 | - | _ | | XOR dst,src<br>dst - dst XOR src | (Note | 1) | В□ | _ | * | * | 0 | - | _ | #### Note 1 These instructions have an identical set of addressing modes, which are encoded for brevity. The first opcode nibble is found in the instruction set table above. The second nibble is expressed symbolically by a $\Box$ in this table, and its value is found in the following table to the left of the applicable addressing mode pair. For example, to determine the opcode of an ADC instruction using the addressing modes r (destination) and Ir (source) is 13. | Addr | Mode | Lower | | |------|------|---------------|--| | dst | src | Opcode Nibble | | | r | r | 2 | | | r | Ir | 3 | | | R | R | 4 | | | R | IR | 5 | | | R | IM | 6 | | | IR | IM | 7 | | #### Registers #### R248 P1M #### Port 1 Mode Register UPC register address (Hex): F8 #### R246 P2M #### Port 2 Mode Register UPC register address (Hex): F6 #### R247 P3M #### Port 3 Mode Register UPC register address (Hex): F7 Figure 12. Port Mode Registers #### **R251 IMR** ### Interrupt Mask Register UPC register address (Hex): FB #### **R250 IRQ** #### Interrupt Request Register UPC register address (Hex): FA #### **R249 IPR** #### Interrupt Priority Register UPC register address (Hex): F9 (Write Only) Figure 13. Interrupt Control Registers #### R254 MIC ### Master CPU Interrupt Control Register UPC register address (Hex): FE ### R240 MIV ### Master CPU Interrupt Vector Register UPC register address (Hex): F0 Figure 14. Master CPU Interrupt Registers ### Registers (Continued) #### R252 FLAGS Flag Register UPC register address (Hex): FC #### R253 RP Register Pointer UPC register address (Hex): FD #### R255 SP Stack Pointer UPC register address (Hex): FF Figure 15. UPC Control Registers Figure 16. Master CPU-UPC Data Transfer Registers #### R245 PRE0 Prescaler 0 Register UPC register address (Hex): F5 Figure 17. UPC Counter/Timer Registers 2017 012, 014, 013 | Control Register | D <sub>7</sub> | D <sub>6</sub> | D <sub>5</sub> | D <sub>4</sub> | D <sub>3</sub> | D <sub>2</sub> | Dı | D <sub>0</sub> | Comments | |-------------------------------------------------------------|----------------|----------------|----------------|----------------|----------------|----------------|-----------------------|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 00 <sub>H</sub><br>Data Transfer Control Register | Х | Х | Х | Х | 0 | 0 | 0 | 0 | Disable data transfer from master CPU | | 04 <sub>H</sub><br>Limit Count Register | | | | Not De | fined | | | | | | 05 <sub>H</sub><br>Data Indirection Register | | | | Not De | fined | | | | | | F0 <sub>H</sub><br>Interrupt Vector Register | | | | Not De | fined | | | | | | Fl <sub>H</sub><br>Timer Mode | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Stops T0 and T1 | | F2 <sub>H</sub><br>T0 Register | | | | Not De | fined | | | | | | F3 <sub>H</sub><br>T0 Prescaler | Х | Х | Х | Х | Х | Х | 0 | 0 | Single-Pass mode | | F4 <sub>H</sub><br>T1 Register | | | | Not De | fined | | | | | | F5 <sub>H</sub><br>T1 Prescaler | Х | Х | Х | Х | Х | Х | 0 | 0 | Single-Pass mode<br>External clock source | | F6 <sub>H</sub><br>Port 2 Mode | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | Port 2 lines defined as inputs | | F7 <sub>H</sub><br>Port 3 Mode | 0 | 0 | 0 | 0 | Х | 1 | 0 | 0 | Port 1, 2 open drain;<br>P3 <sub>5</sub> = INT; P3 <sub>0</sub> , P3 <sub>1</sub> , P3<br>P3 <sub>3</sub> defined as input; P3 <sub>4</sub> ,<br>P3 <sub>6</sub> , P3 <sub>7</sub> defined as output | | F8 <sub>H</sub><br>Port 1 Mode | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | Port 1 lines defined as inputs | | F9 <sub>H</sub><br>Interrupt Priority | | | 1 | Not De | fined | | | | | | FA <sub>H</sub><br>Interrupt Request | Х | Х | 0 | 0 | 0 | 0 | 0 | 0 | Reset Interrupt Request | | FB <sub>H</sub><br>Interrupt Mask | 0 | Х | Х | Х | Х | Х | Х | Х | Interrupts disabled | | FC <sub>H</sub><br>Flag Register | | | ] | Not De | fined | | annalde - Periodo ann | | | | FD <sub>H</sub><br>Register Pointer | | | ] | Not De | fined | | | | | | FE <sub>H</sub><br>Master CPU Interrupt<br>Control Register | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Master CPU interrupt dis-<br>abled; wait enable when<br>write; lower chain enabled | | FF <sub>H</sub><br>Stack Pointer | | | ] | Not De | fined | | | | | NOTE: X means not defined. Table 4. Control Register Reset Conditions Registers (Continued) | Absolute<br>Maximum<br>Ratings | Voltages on all pins (except V <sub>BB</sub> ) with respect to GND0.5 V to +7.0 V Operating Ambient TemperatureSee Ordering Information Storage Temperature | Stresses greater than those listed used mum Ratings may cause permanent d. This is a stress rating only; operation condition above those indicated in the of these specifications is not implied. maximum rating conditions for extending the strength of | |--------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | Storage Temperature65°C to +150°C | device reliability. | #### Standard Test Conditions The characteristics below apply for the following standard test conditions, unless otherwise noted. All voltages are referenced to GND. Positive current flows into the reference pin. Standard conditions are as follows: Figure 18. Test Load 1 under Absolute Maxidamage to the device. n of the device at any he operational sections . Exposure to absolute nded periods may affect - $4.75 \text{ V} \leq \text{V}_{\text{CC}} \leq +5.25 \text{ V}$ $\text{V}_{\text{SS}} = \text{GND} = 0 \text{ V}$ - $0^{\circ}$ C $\leq T_{\tilde{A}} \leq +70^{\circ}$ C\* <sup>\*</sup>See Ordering Information section for package temperature range and product number Figure 19. Test Load 2 | DC | Syml | ool Parameter | <b>Min</b> 2.4 | Max<br>V <sub>CC</sub> | <b>Unit</b><br>V | Condition | Notes | |----------------------|------------------------|--------------------------------|----------------|------------------------|------------------|------------------------------------|-------| | Charac-<br>teristics | $v_{ch}$ | Clock Input High Voltage | | | | | | | | $V_{\mathrm{CL}}$ | Clock Input Low Voltage | -0.3 | 0.8 | V | | | | | $V_{\mathrm{IH}}$ | Input High Voltage | 2.0 | $V_{\rm CC}$ | V | | | | | $V_{\rm IL}$ | Input Low Voltage | -0.3 | 0.8 | V | | | | | $V_{OH}$ | Output High Voltage | 2.4 | | V | $I_{OH} = -250 \mu\text{A}$ | 1 | | | $v_{\rm OL}$ | Output Low Voltage | | 0.4 | V | $I_{OL} = +2.0 \text{ mA}$ | 1 | | | ${ m I}_{ m IL}$ | Input Leakage | -10 | 10 | μA | $0 \le V_{IN} \le +5.25 \text{ V}$ | | | | $I_{OL}$ . | Output Leakage | -10 | 10 | μA | $0 \le V_{IN} \le +5.25 \text{ V}$ | | | | $I_{\rm CC}{}^{\star}$ | V <sub>CC</sub> Supply Current | | 180 | mA | | | <sup>1</sup> For A\_0-A\_{11} and D\_0-D\_7, $\overline{\text{MDS}}$ , $\overline{\text{SYNC}}$ , $\overline{\text{MAS}}$ , and MR/ $\overline{\text{W}}$ /IACK on the 64-pin versions I\_OH = 100 $\mu$ A and I\_OL = 10 mA <sup>\*</sup>For Protopack versions I\_CC = 180 $\mu\text{A}$ plus the current for the memory IC used Master CPU Interface Timing Interrupt Acknowledge Timing | | | | | MHz | | MHz | | |------|---------------|----------------------------------------------------------------------------|------------|---------------------------|----------------|------|---------| | No. | Symbol | Parameter | Min | Мах | Min | Мах | Notes*† | | 1 | TrC | Clock Rise Time | | 20 | | 15 | | | 2 | TwCH | Clock High Width | 105 | 1855 | 70 | 1855 | | | 3 | TfC | Clock Fall Time | | 20 | | 10 | | | 4 | TwCl | Clock Low Width | 105 | 1855 | 70 | 1855 | | | 5 | TpC | Clock Period | 250 | 2000 | 165 | 2000 | | | 6- | — TsA/D(WR) — | — Ā/D to WR ↓ Setup Time ———— | 80 — | | 80 | | | | 7 | TsA/D(RD) | Ā/D to RD ↓ Setup Time | 80 | | 80 | | | | 8 | ThA/D(WR) | $\overline{A}/D$ to $\overline{WR}$ † Hold Time | 30 | | 25 | | | | 9 | ThA/D(RD) | $\overline{\mathtt{A}}/\mathtt{D}$ to $\overline{\mathtt{RD}}$ † Hold Time | 30 | | 25 | | | | 10 | TsCSf(WR) | CS ↓ to WR ↓ Setup Time | 0 | | 0 | | | | 11 - | - TsCSf(RD) - | — CS ↓ to RD ↓ Setup Time ———— | 0 - | | 0 <del>-</del> | | | | 12 | TsCSr(WR) | CS ↑ to WR ↓ Setup Time | 60 | | 60 | | | | 13 | TsCSr(RD) | CS ↑ to RD ↓ Setup Time | 60 | | 60 | | | | 14 | ThCS(WR) | CS to WR ↓ Hold Time | 0 | | 0 | | | | 15 | ThCS(RD) | CS to RD ↓ Hold Time | 0 | | 0 | | | | 16 – | −TsDI(WR) −−− | — Data in to WR ↓ Setup Time ———— | 0 — | mangan manga pakaban pers | 0 - | | | | 17 | Tw(WR) | WR Low Width | 390 | | 250 | | | | 18 | Tw(RD) | RD Low Width | 390 | | 250 | | | | 19 | ThWR(DI) | Data in to WR † Hold Time | 0 | | 0 | | | | 20 | TdRD(DI) | Data Valid from RD ↓ Delay | | | | | 1 | | 21 - | — ThRD(DI) —— | — Data Valıd to RD † Hold Time ———— | 0 <i>-</i> | | 0 | | | | 22 | $TdRD(DI_Z)$ | Data Bus Float Delay from RD † | | 70 | | 45 | | | 23 | $TdRD(DB_A)$ | RD ↓ to Read Data Active Delay | 0 | | 0 | | | | 24 | TdWR(W) | WR ↓ to WAIT ↓ Delay | | 150 | | 150 | | | 25 | TdRD(W) | RD ↓ to WAIT ↓ Delay | | 150 | | 150 | | | 26 | TdDI(W) | Data Valid to WAIT † Delay | 0 | | 0 | | | | | | | 4 M | Hz | 61 | | | |------|----------------|-----------------------------------------------|-----|-----|-----|-----|---------| | No. | Symbol | Parameter | Min | Мах | Min | Max | Notes*† | | 27 | TsACK(RD) | <u>INTACK</u> ↓ to <del>RD</del> ↓ Setup Time | 90 | | 80 | | 2 | | 28 | TdRD(DI) | RD ↓ to Vector Valid Delay | | 255 | | 180 | | | 29 | ThRD(ACK) | RD † to INTACK † Hold Time | 0 | | 0 | | | | 30 | ThIEI(RD) | IEI to RD ↑ Hold Time | 100 | | 100 | | | | 31 — | – TwRD1 – | - RD (Acknowledge) Low Width | 255 | | 250 | | | | 32 | TdIEI(IEO) | IEI to IEO Delay | | 120 | | 100 | | | 33 | TsIEI(RD) | IEI to RD ↓ Setup Time | 150 | | 120 | | | | 34 | $TdACK_f(IEO)$ | INTACK ↓ to IEO ↓ Delay | | 250 | | 250 | | | 35 | $TdADK_r(IEO)$ | INTACK † to IEO † Delay | | 250 | | 250 | | NOTES: 1. This parameter is dependent on the state of the UPC at the time of master CPU access. 2. In case where daisy chain is not used. 3. The timing characteristics given reference 2 0 V as High and 0.8 V as Low <sup>4.</sup> All output ac parameters use test load 1. $^*$ Timings are preliminary and subject to change. $\dagger$ Units in nanoseconds (ns). #### Handshake Timing Input Handshake Output Handshake #### Reset Timing #### RAM Version Program Memory Timing | | | | 4 | MHz | 6 1 | | | |-----|------------|-------------------------------------------------------------------|-----|--------------------|---------|-----------------------------|---------------------| | No. | Symbol | Parameter | Min | Мах | Min | Max | Notes*† | | 1 | TsDI(DA) | Data in Setup Time | 0 | | 0 | | • | | 2 | ThDA(DI) | Data in Hold Time | 230 | | 230 | | | | 3 | TwDA | Data Available Width | 175 | | 175 | | 1,2 | | 4 — | −TdDAL(RY) | — Data Available Low to Ready———————————————————————————————————— | 20- | — 175 <del>—</del> | 20<br>0 | <del></del> 175 <del></del> | 1,2 <del></del> 2,3 | | 5 | TdDAH(RY) | Data Available High to Ready<br>Delay Time | 0 | 150 | 0 | 150 | 1,2<br>2,3 | | 6 | TdDO(DA) | Data Out to Data Available Delay Time | 50 | | 50 | | 2 | | 7 | TdRY(DA) | Ready to Data Available Delay Time | 0 | 205 | 0 | 205 | 2 | | | | | 4 | MHz | 6 1 | MHz | | | |-----|-----------|-------------------------------------------------------------------------|-----|-----|-----|-----|---------|--| | No. | Symbol | Parameter | Min | Max | Min | Max | Notes*† | | | 1 | TdRDQ(WR) | Delay from RD ↑ to WR ↓ for No Reset | 40 | | 35 | | | | | 2 | TdWRQ(RD) | Delay from WR † to RD for No Reset | 50 | | 35 | | | | | 3 | TwRES | Minimum Width of $\overline{WR}$ and $\overline{RD}$ both Low for Reset | 250 | | 250 | | 4 | | | | | | | MHz | | MHz | | |------|---------------|------------------------------------------------------------------|-----|-----------------------------|-----|-----------------------------|---------| | No. | Symbol | Parameter | Min | Мах | Min | Мах | Notes*† | | 1 | TwMAS | Memory Address Strobe Width | 60 | | 55 | | 5 | | 2 | TdA(MAS) | Address Valid to Memory Address Strobe † Delay | 30 | | 30 | | 5 | | 3 | TdMR/W(MAS) | Memory Read/Write to Memory Address Strobe †<br>Delay | 30 | | 30 | | 5 | | 4 | TdMDS(A) | Memory Data Strobe † to Address Change Delay | 60 | | 60 | | | | 5— | -TdMDS(MR/W)- | – Memory Data Strobe † to Memory Read/Write Not –<br>Valid Delay | 80 | | 75 | | | | 6 | Tw(MDS) | Memory Data Strobe Width (Write Case) | 160 | | 110 | | 6 | | 7 | TdDO(MDS) | Data Out Valid to Memory Data Strobe Delay | 30 | | 30 | | 5 | | 8 | TdMDS(DO) | Memory Data Strobe † to Data Out Change Delay | 30 | | 30 | | 5 | | 9 | Tw(MDS) | Memory Data Strobe Width (Read Case) | 230 | | 230 | | 6 | | 10 — | TdMDS(DI) | −Memory Data Strobe ↓ to Data In Valid Delay −−−− | | <del></del> 160 <del></del> | | <del></del> 130 <del></del> | 7 | | 11 | TdMAS(DI) | Memory Address Strobe † to Data In Valid Delay | | 280 | | 220 | 7 | | 12 | ThMDS(DI) | Memory Data Strobe † to Data In Hold Time | 0 | | 0 | | | | 13 | TwSY | Instruction Sync Out Width | 160 | | 100 | | | | 14 | TdSY(MDS) | Instruction Sync Out to Memory Data Strobe Delay | 200 | | 160 | | | | 15 | TwI | Interrupt Request via Port 3 Input Width | 100 | | 100 | | | #### NOTES - Input Handshake Test Load 1 Output Handshake - Guipat Handshale Internal reset signal is ½ to 2 clock delays from external reset condition - condition Delay times are specified for an input clock frequency of 4 MHz. When operating at a lower frequency, the increase in input clock period must be added to the specified delay time Data strobe width is specified for an input clock frequency of 4 MHz. When operating at a lower frequency, the increase in three input clock periods must be added to the specified width Data strobe width varies according to the instruction being ex- - ecuted. 7 Address strobe and data strobe to data in valid delay times represent memory system access times and are given for a 4 MHz input frequency - \*All tuning references assume 2.0 V for a logic "1" and 0.8 V for a logic "0" All output ac parameters use test load 2 Timings are preliminary and subject to change. †Units in nanoseconds (ns). | Ordering<br>Information | Product<br>Number | Package/<br>Temp | Speed | Description | Product<br>Number | Package<br>Temp | /<br>Speed | Description | |-------------------------|-------------------|------------------|---------|---------------------------------------------------------|-------------------|-----------------|------------|------------------------------------------------------------| | | Z8590 | CE | 8.0 MHz | UPC (40-pin) | Z8592 | QS | 8.0 MHz | UPC External | | | Z8590 | CS | 8.0 MHz | Same as above | | | | RAM-based | | | Z8590 | DE | 8.0 MHz | Same as above | | | | Program Memory<br>(64-pin) | | | Z8590 | DS | 8.0 MHz | Same as above | Z8593 | RS | 8.0 MHz | UPC External | | | Z8590 | PE | 8.0 MHz | Same as above | | | | ROM-based | | | Z8590 | PS | 8.0 MHz | Same as above | | | | Program Memory<br>(Protopack) | | | Z8591 | QS | 8.0 MHz | UPC External<br>ROM-based<br>Program Memory<br>(64-pin) | Z8594 | RS | 8.0 MHz | UPC External<br>RAM-based<br>Program Memory<br>(Protopack) | NOTES C = Ceramic, D = Cerdip, P = Plastic, Q = Quip, R = Protopack, E = -40°C to +85°C, S = 0°C to +70°C. 00-2022-02 # za Family Zilog ### Zilog Z8® Family # The New Standard For Single-Chip Microcomputers June 1982 The Z8 Family of microcomputers offers the most sophisticated processing capability available on a single chip. As an extension of earlier generations of microcomputers, the Z8 Family provides standard on-chip functions, such as: - 2K or 4K bytes of ROM - 144 8-bit registers - 32 lines of programmable I/O - Clock oscillator In addition, the Z8 Family offers advanced on-chip features, including: - Two counter/timers - Six vectored interrupts - UART for serial I/O communication - Stack functions - Power-down option - TTL compatibility The capability of the Z8 Family of microcomputers is expandable off-chip to provide an additional 62K bytes of program memory and 62K bytes of data memory for the 2K-byte ROM version. It provides an additional 60K bytes of program memory and 60K bytes of data memory for the 4K-byte ROM version. The interface to external memory is accomplished through one, one and one-half, or two of the 8-bit I/O ports, depending on the number of address bits required for the external functions. The Z-BUS protocol allows easy interface to external functions including Zilog's family of peripheral chips. With the third-generation Z8 Family, Zilog is pushing the capability of microcomputers beyond the first and second generation of computers. The Z8 Family challenges the "multi-chip solution" design currently implemented by general-purpose microprocessors. Designs based on Z8-Family microcomputers offer a minimum chip-count configuration that can easily be expanded to meet requirements for enhancement options and for future improvements. Optimized Instruction Set. The instruction set of the Z8-Family microcomputers is optimized for high-code density and reduced execution time. This feature is supported by a "working register area" concept that uses short (4-bit) register addresses. The general-purpose registers can be used as accumulators, as address pointers for indirect addressing, as index registers, or for implementing an on-chip stack. The 47 instruction types and six addressing modes—together with the ability to operate on bits, 4-bit BCD digits, 8-bit bytes, and 16-bit words—offer unique programming capability and flexibility. Growing Family. The Z8 Family of microcomputers is growing to meet the needs of more complex designs. The 4K ROM version of the Z8 microcomputer (the Z8610 series) offers all the features of the Z8 Family, plus 4K bytes of on-chip ROM. The increased ROM allows the designer to take advantage of the code optimization inherent in the Z8 instruction set when using between 2K and 4K bytes of program memory. The ROMless microcomputer provides an alternative for designers seeking to take advantage of the on-chip features of the Z8601 in applications that require external program memory. A Z8681 microcomputer can be used to control a system that addresses up to 128K bytes of off-chip memory. The Z8671 microcomputer is a Z8-based BASIC/debug interpreter on a chip. The BASIC used in the Z8671 is a subset of Dartmouth BASIC with the added capability of interaction between the interpreter and its environment through the debug facility. The BASIC/debug interpreter resides in the 2K of onchip ROM, with all the features of the Z8 microcomputer at its disposal. Expanded Applications. The Z8 Family of microcomputers is finding its way into increasingly sophisticated designs. In addition to the low-end capability applications commonly used with microcomputers, the Z8 Family of microcomputers can be used effectively in such applications as: - Computer peripheral controllers - Smart terminals - Dumb terminals - Telephone switching systems - Arcade games and intelligent home games - Process control - Intelligent instrumentation - Automotive mechanisms An example of how a Z8 might be used in the design of an intelligent terminal is shown in Figure 1. The features of such a terminal depend on its specific requirements, but it is clear that the Z8 microcomputers offer unprecedented capability and flexibility to the microcomputer designer. Figure 1. Z8-Based Intelligent Terminal ### Z8° Family of Microcomputers Z8601 • Z8602 • Z8603 # Product Specification June 1982 Z8601 Single-Chip Microcomputer with 2K ROM Z8602 Development Device with Memory Interface Z8603 Prototyping Device with EPROM Interface #### Features - Complete microcomputer, 2K bytes of ROM, 128 bytes of RAM, 32 I/O lines, and up to 62K bytes addressable external space each for program and data memory. - 144-byte register file, including 124 general-purpose registers, four I/O port registers, and 16 status and control registers. - Average instruction execution time of 2.2 $\mu$ s, maximum of 4.25 $\mu$ s. - Vectored, priority interrupts for I/O, counter/timers, and UART. - Full-duplex UART and two programmable 8-bit counter/timers, each with a 6-bit programmable prescaler. - Register Pointer so that short, fast instructions can access any of nine working register groups in 1.5 μs. - On-chip oscillator which accepts crystal or external clock drive. - Low-power standby option which retains contents of general-purpose registers. - Single +5 V power supply—all pins TTL-compatible. #### General Description The Z8601 microcomputer introduces a new level of sophistication to single-chip architecture. Compared to earlier single-chip microcomputers, the Z8601 offers faster execution; more efficient use of memory; more sophisticated interrupt, input/output and bit-manipulation capabilities; and easier system expansion. Under program control, the Z8601 can be tailored to the needs of its user. It can be con- figured as a stand-alone microcomputer with 2K bytes of internal ROM, a traditional microprocessor that manages up to 124K bytes of external memory, or a parallel-processing element in a system with other processors and peripheral controllers linked by the Z-BUS. In all configurations, a large number of pins remain available for I/O. Figure 1. Pin Functions Figure 2. Pin Assignments 2037-001, 002 #### Architecture Z8601 architecture is characterized by a flexible I/O scheme, an efficient register and address space structure and a number of ancillary features that are helpful in many applications. Microcomputer applications demand powerful I/O capabilities. The Z8601 fulfills this with 32 pins dedicated to input and output. These lines are grouped into four ports of eight lines each and are configurable under software control to provide timing, status signals, serial or parallel I/O with or without handshake, and an address/data bus for interfacing external memory. Because the multiplexed address/data bus is merged with the I/O-oriented ports, the Z8601 can assume many different memory and I/O configurations. These configurations range from a self-contained microcomputer to a microprocessor that can address 124K bytes of external memory. Three basic address spaces are available to support this wide range of configurations: program memory (internal and external), data memory (external) and the register file (internal). The 144-byte random-access register file is composed of 124 general-purpose registers, four I/O port registers, and 16 control and status registers. To unburden the program from coping with real-time problems such as serial data communication and counting/timing, an asynchronous receiver/transmitter (UART) and two counter/timers with a large number of user-selectable modes are offered on-chip. Hardware support for the UART is minimized because one of the on-chip timers supplies the bit rate. Figure 3. Functional Block Diagram #### Pin Description AS. Address Strobe (output, active Low). Address Strobe is pulsed once at the beginning of each machine cycle. Addresses output via Port 1 for all external program or data memory transfers are valid at the trailing edge of AS. Under program control, AS can be placed in the high-impedance state along with Ports 0 and 1. Data Strobe and Read/Write. **DS.** Data Strobe (output, active Low). Data Strobe is activated once for each external memory transfer. **P0<sub>0</sub>-P0<sub>7</sub>, P1<sub>0</sub>-P1<sub>7</sub>, P2<sub>0</sub>-P2<sub>7</sub>, P3<sub>0</sub>-P3<sub>7</sub>.** *I/O Port Lines* (input/outputs, TTL-compatible). These 32 lines are divided into four 8-bit I/O ports that can be configured under program control for I/O or external memory interface. **RESET.** Reset (input, active Low). $\overline{RESET}$ initializes the Z8601. When $\overline{RESET}$ is deactivated, program execution begins from internal program location 000C<sub>H</sub>. $\mathbf{R}/\overline{\mathbf{W}}$ . Read/Write (output). $\mathbb{R}/\overline{\mathbf{W}}$ is Low when the Z8601 is writing to external program or data memory. **XTAL1. XTAL2.** Crystal 1, Crystal 2 (time-base input and output). These pins connect a series-resonant crystal (8 MHz maximum) or an external single-phase clock (8 MHz maximum) to the on-chip clock oscillator and buffer. #### Address Spaces **Program Memory.** The 16-bit program counter addresses 64K bytes of program memory space. Program memory can be located in two areas: one internal and the other external (Figure 4). The first 2048 bytes consist of on-chip mask-programmed ROM. At addresses 2048 and greater, the Z8601 executes external program memory fetches. The first 12 bytes of program memory are reserved for the interrupt vectors. These locations contain six 16-bit vectors that correspond to the six available interrupts. **Data Memory.** The Z8601 can address 62K bytes of external data memory beginning at programmed to appear on pin P34, is used to distinguish between data and program memory space. Register File. The 144-byte register file includes four I/O port registers (R0-R3), 124 general-purpose registers (R4-R127) and 16 control and status registers (R240-R255). These registers are assigned the address locations locations 2048 (Figure 5). External data memory may be included with or separated from the external program memory space. DM, an optional I/O function that can be shown in Figure 6. Z8601 instructions can access registers Figure 4. Program Memory Map Figure 5. Data Memory Map Figure 6. The Register File Figure 7. The Register Pointer 2037 004, 005, 006, 007 #### Address Spaces (Continued) directly or indirectly with an 8-bit address field. The Z8601 also allows short 4-bit register addressing using the Register Pointer (one of the control registers). In the 4-bit mode, the register file is divided into nine working-register groups, each occupying 16 contiguous locations (Figure 7). The Register Pointer addresses the starting location of the active working-register group. **Stacks.** Either the internal register file or the external data memory can be used for the stack. A 16-bit Stack Pointer (R254 and R255) is used for the external stack, which can reside anywhere in data memory between locations 2048 and 65535. An 8-bit Stack Pointer (R255) is used for the internal stack that resides within the 124 general-purpose registers (R4-R127). #### Serial Input/ Output Port 3 lines P3<sub>0</sub> and P3<sub>7</sub> can be programmed as serial I/O lines for full-duplex serial asynchronous receiver/transmitter operation. The bit rate is controlled by Counter/Timer 0, with a maximum rate of 62.5K bits/second. The Z8601 automatically adds a start bit and two stop bits to transmitted data (Figure 8). Odd parity is also available as an option. Eight data bits are always transmitted, regardless of parity selection. If parity is enabled, the eighth bit is the odd parity bit. An interrupt request (IRQ<sub>4</sub>) is generated on all transmitted characters. Received data must have a start bit, eight data bits and at least one stop bit. If parity is on, bit 7 of the received data is replaced by a parity error flag. Received characters generate the IRQ<sub>3</sub> interrupt request. #### Transmitted Data (No Parity) #### Received Data (No Parity) #### Received Data (With Parity) Figure 8. Serial Data Formats #### Counter/ Timers The Z8601 contains two 8-bit programmable counter/timers ( $T_0$ and $T_1$ ), each driven by its own 6-bit programmable prescaler. The $T_1$ prescaler can be driven by internal or external clock sources; however, the $T_0$ prescaler is driven by the internal clock only. The 6-bit prescalers can divide the input frequency of the clock source by any number from 1 to 64. Each prescaler drives its counter, which decrements the value (1 to 256) that has been loaded into the counter. When the counter reaches the end of count, a timer interrupt request— $IRQ_4$ ( $T_0$ ) or $IRQ_5$ ( $T_1$ )—is generated. The counters can be started, stopped, restarted to continue, or restarted from the initial value. The counters can also be programmed to stop upon reaching zero (single- pass mode) or to automatically reload the initial value and continue counting (modulo-n continuous mode). The counters, but not the prescalers, can be read any time without disturbing their value or count mode. The clock source for $T_1$ is user-definable and can be the internal microprocessor clock (4 MHz maximum) divided by four, or an external signal input via Port 3. The Timer Mode register configures the external timer input as an external clock (1 MHz maximum), a trigger input that can be retriggerable or non-retriggerable, or as a gate input for the internal clock. The counter/timers can be programmably cascaded by connecting the $T_0$ output to the input of $T_1$ . Port 3 line $P_{36}$ also serves as a timer output ( $T_{OUT}$ ) through which $T_0$ , $T_1$ or the internal clock can be output. The Z8601 has 32 lines dedicated to input and output. These lines are grouped into four ports of eight lines each and are configurable as input, output or address/data. Under software control, the ports can be programmed to provide address outputs, timing, status signals, serial I/O, and parallel I/O with or without handshake. All ports have active pull-ups and pull-downs compatible with TTL loads. **Port 1** can be programmed as a byte I/O port or as an address/data port for interfacing external memory. When used as an I/O port, Port 1 may be placed under handshake control. In this configuration, Port 3 lines P3<sub>3</sub> and P3<sub>4</sub> are used as the handshake controls RDY<sub>1</sub> and $\overline{DAV_1}$ (Ready and Data Available). Memory locations greater than 2048 are referenced through Port 1. To interface external memory, Port 1 must be programmed for the multiplexed Address/Data mode. If more than 256 external locations are required, Port 0 must output the additional lines. Port 1 can be placed in the high-impedance state along with Port 0, $\overline{AS}$ , $\overline{DS}$ and $R/\overline{W}$ , allow- ing the Z8601 to share common resources in multiprocessor and DMA applications. Data transfers can be controlled by assigning P3<sub>3</sub> as a Bus Acknowledge input and P3<sub>4</sub> as a Bus Request output. Figure 9a. Port 1 **Port 0** can be programmed as a nibble I/O port, or as an address port for interfacing external memory. When used as an I/O port, Port 0 may be placed under handshake control. In this configuration, Port 3 lines $P3_2$ and $P3_5$ are used as the handshake controls $\overline{DAV}_0$ and $RDY_0$ . Handshake signal assignment is dictated by the I/O direction of the upper nibble $P0_4$ – $P0_7$ . For external memory references, Port 0 can provide address bits $A_8$ – $A_{11}$ (lower nibble) or $A_8$ – $A_{15}$ (lower and upper nibble) depending on the required address space. If the address range requires 12 bits or less, the upper nibble of Port 0 can be programmed independently as I/O while the lower nibble is used for addressing. When Port 0 nibbles are defined as address bits, they can be set to the high-impedance state along with Port 1 and the control signals $\overline{\rm AS}$ , $\overline{\rm DS}$ and $\overline{\rm R/W}$ . Figure 9b. Port 0 Port 2 bits can be programmed independently as input or output. The port is always available for I/O operations. In addition, Port 2 can be configured to provide open-drain outputs. Like Ports 0 and 1, Port 2 may also be placed under handshake control. In this configuration, Port 3 lines $P3_1$ and $P3_6$ are used as the handshake controls lines $\overline{DAV}_2$ and $RDY_2$ . The handshake signal assignment for Port 3 lines $P3_1$ and $P3_6$ is dictated by the direction (input or output) assigned to bit 7 of Port 2. Figure 9c. Port 2 **Port 3** lines can be configured as I/O or control lines. In either case, the direction of the eight lines is fixed as four input (P3<sub>0</sub>-P3<sub>3</sub>) and four output (P3<sub>4</sub>-P3<sub>7</sub>). For serial I/O, lines P3<sub>0</sub> and P3<sub>7</sub> are programmed as serial in and serial out respectively. Port 3 can also provide the following control functions: handshake for Ports 0, 1 and 2 ( $\overline{DAV}$ and RDY); four external interrupt request signals (IRQ<sub>0</sub>-IRQ<sub>3</sub>); timer input and output signals ( $T_{\underline{IN}}$ and $T_{\underline{OUT}}$ ) and Data Memory Select ( $\overline{DM}$ ). #### Interrupts The Z8601 allows six different interrupts from eight sources: the four Port 3 lines $P3_0$ – $P3_3$ , Serial In, Serial Out, and the two counter/ timers. These interrupts are both maskable and prioritized. The Interrupt Mask register globally or individually enables or disables the six interrupt requests. When more than one interrupt is pending, priorities are resolved by a programmable priority encoder that is controlled by the Interrupt Priority register. All Z8601 interrupts are vectored. When an interrupt request is granted, an interrupt machine cycle is entered. This disables all subsequent interrupts, saves the Program Counter and status flags, and branches to the program memory vector location reserved for that interrupt. This memory location and the next byte contain the 16-bit address of the interrupt service routine for that particular interrupt request. Polled interrupt systems are also supported. To accommodate a polled structure, any or all of the interrupt inputs can be masked and the Interrupt Request register polled to determine which of the interrupt requests needs service. #### Clock The on-chip oscillator has a high-gain, series-resonant amplifier for connection to a crystal or to any suitable external clock source (XTAL1 = Input, XTAL2 = Output). The crystal source is connected across XTAL1 and XTAL2, using the recommended capacitors ( $C_1 = 15 \text{ pF}$ ) from each pin to ground. The specifications for the crystal are as follows: - AT cut, series resonant - Fundamental type, 8 MHz maximum - Series resistance, $R_s \le 100 \Omega$ #### Power Down Standby Option The low-power standby mode allows power to be removed without losing the contents of the 124 general-purpose registers. This mode is available to the user as a bonding option whereby pin 2 (normally XTAL2) is replaced by the $V_{MM}$ (standby) power supply input. This necessitates the use of an external clock generator (input = XTAL1) rather than a crystal source. The removal of power, whether intended or due to power failure, must be preceded by a software routine that stores the appropriate status into the register file. Figure 10 shows the recommended circuit for a battery back-up supply system. Figure 10. Recommended Driver Circuit for Power Down Operation #### Z8602 Development Device This 64-pin development version of the 40-pin mask-programmed Z8601 (Figure 11) allows the user to prototype the system in hardware with an actual device and to develop the code that is eventually mask-programmed into the on-chip ROM of the Z8601. The Z8602 is identical to the Z8601 with the following exceptions: - The internal ROM has been removed. - The ROM address lines and data lines are buffered and brought out to external pins. - Control lines for the new memory have been added. **Pin Description.** The functions of the Z8602 I/O lines, $\overline{AS}$ , $\overline{DS}$ , $R/\overline{W}$ , XTAL1, XTAL2 and $\overline{RESET}$ are identical to those of their Z8601 counterparts. The functions of the remaining 24 pins are as follows: **A<sub>0</sub>-A<sub>11</sub>.** Program Memory Address (outputs). $A_0$ -A<sub>11</sub> access the first 2K bytes of program memory. $A_{11}$ is a reserved pin. Figure 11. Z8602 Pin Assignments for Quip Package (Reverse Assignments for 64-Pin DIL) # Z8602 Development Device (Continued) **D<sub>0</sub>-D<sub>7</sub>.** Program Data (inputs). Program data from the first 2K bytes of program memory is input through pins D<sub>0</sub>-D<sub>7</sub>. **IACK.** Interrupt Acknowledge (output, active High). IACK is driven High in response to an interrupt during the interrupt machine cycle. MDS. Program Memory Data Strobe (output, active Low). MDS is Low during an instruction fetch cycle when the first 2K bytes of program memory are being accessed. **SCLK.** System Clock (output). SCLK is the internal clock output through a buffer. The clock rate is equal to one-half the crystal frequency. **SYNC.** Instruction Sync (output, active Low). This strobe output is forced Low during the internal clock period preceding an opcode fetch. #### Z8603 Protopack Emulator The Z8603 MPE (Protopack) is used for prototype development and preproduction of mask-programmed applications. The Protopack is a ROMless version of the standard Z8601, housed in a pin-compatible 40-pin package (Figure 12). To provide pin compatibility and interchangeability with the standard mask-programmed device, the Protopack carries (piggy-backs) a 24-pin socket for a direct interface to program memory (Figure 1). The 24-pin socket is equipped with 11 ROM Figure 12. The Z8603 Microcomputer Protopack Emulator address lines, 8 ROM data lines and necessary control lines for interface to 2716 EPROM for the first 2K bytes of program memory. Pin compatibility allows the user to design the pc board for a final 40-pin mask-programmed Z8601, and, at the same time, allows the use of the Protopack to build the prototype and pilot production units. When the final program is established, the user can then switch over to the 40-pin mask-programmed Z8601 for large volume production. The Protopack is also useful in small volume applications where masked ROM setup time, mask charges, etc., are prohibitive and program flexibility is desired. Compared to the conventional EPROM versions of the single-chip microcomputers, the Protopack approach offers two main advantages: - Ease of developing various programs during the prototyping stage. For instance, in applications where the same hardware configuration is used with more than one program, the Z8603 Protopack allows economical program storage in separate EPROMs (or PROMs), whereas the use of separate EPROM-based single-chip microcomputers is more costly. - Elimination of long lead time in procuring EPROM-based microcomputers. #### Instruction Set Notation **Addressing Modes.** The following notation is used to describe the addressing modes and instruction operations as shown in the instruction summary. IRR Indirect register pair or indirect working-register Irr Indirect working-register pair only X Indexed address DA Direct addressRA Relative address IM Immediate R Register or working-register address r Working-register address only IR Indirect-register or indirect working-register address Ir Indirect working-register address only RR Register pair or working register pair address **Symbols.** The following symbols are used in describing the instruction set. **dst** Destination location or contents src Source location or contents cc Condition code (see list) @ Indirect address prefix SP Stack pointer (control registers 254-255) PC Program counter FLAGS Flag register (control register 252) RP Register pointer (control register 253) IMR Interrupt mask register (control register 251) Assignment of a value is indicated by the symbol "—". For example, dst ← dst + src indicates that the source data is added to the destination data and the result is stored in the destination location. The notation "addr(n)" is used to refer to bit "n" of a given location. For example, dst (7) refers to bit 7 of the destination operand. Instruction Flags. Control Register R252 contains the following Affected flags are indicated by: Set 0 Cleared to zero Notation C Carry flag 1 Set to one (Continued) Z Zero flag Set or cleared according to operation S Sign flag Unaffected v Overflow flag x Undefined D Decimal-adjust flag н Half-carry flag | Condition | Value | Mnemonic | Meaning | Flags Set | |-----------|-------|----------|--------------------------------|-------------------------| | Codes | 1000 | | Always true | | | | 0111 | С | Carry | C = 1 | | | 1111 | NC | No carry | C = 0 | | | 0110 | Z | Zero | Z = 1 | | | 1110 | NZ | Not zero | Z = 0 | | | 1101 | PL | Plus | S = 0 | | | 0101 | MI | Minus | S = 1 | | | 0100 | OV | Overflow | V = 1 | | | 1100 | NOV | No overflow | V = 0 | | | 0110 | EQ | Equal | Z = 1 | | | 1110 | NE | Not equal | Z = 0 | | | 1001 | GE | Greater than or equal | (S XOR V) = 0 | | | 0001 | LT | Less than | (S XOR V) = 1 | | | 1010 | GT<br>LŢ | Greater than | [Z OR (S XOR V)] = 0 | | | 0010 | LE | Less than or equal | [Z OR (S XOR V)] = 1 | | | 1111 | UGE | Unsigned greater than or equal | C = 0 | | | 0111 | ULT | Unsigned less than | C = 1 | | | 1011 | UGT | Unsigned greater than | (C = 0 AND Z = 0) = 1 | | | 0011 | ULE | Unsigned less than or equal | (C OR Z) = 1 | | | 0000 | | Never true | <del></del> | Instruction Formats #### One-Byte Instructions Figure 13. Instruction Formats | Instruction | Instruction | Addr | Mode | Opcode | Flags Affected | |-------------|----------------------------------------------------------------------------------------|-------------------|---------------------|-------------------------|----------------| | Summary | and Operation | dst | src | Byte<br>(Hex) | CZSVDH | | | ADC dst,src<br>dst - dst + src + C | (Not | e l) | 1 🗆 | * * * * 0 * | | | ADD dst,src<br>dst ← dst + src | (Not | e 1) | 0□ | * * * * 0 * | | | AND dst,src<br>dst dst AND src | (Not | e l) | 5□ | - * * 0 | | | CALL dst<br>SP SP 2<br>@SP PC; PC c | DA<br>IRR<br>dst | | D6<br>D4 | | | | CCF<br>C - NOT C | | | EF | * | | | CLR dst<br>dst - 0 | R<br>IR | | BO<br>B1 | | | | COM dst<br>dst - NOT dst | R<br>IR | | 60<br>61 | - * * 0 | | | CP dst,src<br>dst - src | (Note | e 1) | A□ | * * * * | | | <b>DA</b> dst<br>dst — DA dst | R<br>IR | | 40<br>41 | * * * X | | | DEC dst<br>dst dst - 1 | R<br>IR | | 00<br>01 | -*** | | | DECW dst<br>dst - dst - l | RR<br>IR | | 80<br>81 | -*** | | | <b>DI</b> IMR (7) ← 0 | | | 8F | | | | <b>DJNZ</b> r,dst<br>$r \leftarrow r - 1$<br>if $r \neq 0$<br>$PC \leftarrow PC + dst$ | RA | | rA<br>r=0-F | | | | Range: +127, -128 EI IMR (7) - 1 | | | 9F | | | | INC dst<br>dst dst + 1 | r | | rE<br>r=0-F | _ * * * | | | | R<br>IR | | 20<br>21 | | | | INCW dst<br>dst ← dst + l | RR<br>IR | | A0<br>A1 | - * * * | | | IRET<br>FLAGS ← @ SP; SP<br>PC ← @ SP; SP ← S | | | BF<br>) ← 1 | * * * * * | | | IP cc,dst if cc is true PC - dst | DA<br>IRR | | cD<br>c=0-F<br>30 | | | | JR cc,dst<br>if cc is true,<br>PC - PC + dst<br>Range: +127, -128 | RA | | cB<br>c=0-F | | | | LD dst,src<br>dst + src | r<br>r<br>R | Im<br>R<br>r | rC<br>r8<br>r9<br>r=0-F | | | | | r<br>X<br>r<br>Ir | X<br>r<br>Ir<br>r | C7<br>D7<br>E3<br>F3 | | | | | R<br>R<br>R<br>IR | R<br>IR<br>Im<br>Im | E4<br>E5<br>E6<br>E7 | | | | | IR | R | F5 | | | IIIBII uciioii | Addr I | Mode | Opcode | Flags Affected | |----------------------------------------------------------|----------------|-----------|---------------|----------------| | and Operation | dst | src | Byte<br>(Hex) | CZSVDH | | LDE dst,src<br>dst - src | r<br>Irr | Irr<br>r | 82<br>92 | | | <b>LDEI</b> dst,src<br>dst ← src<br>r ← r + 1; rr ← rr + | Ir<br>Irr<br>l | Irr<br>Ir | 83<br>93 | | | NOP | | | FF | | | OR dst,src<br>dst - dst OR src | (Note | e 1) | 4□ | - * * 0 | | <b>POP</b> dst<br>dst - @ SP<br>SP - SP + 1 | R<br>IR | | 50<br>51 | | | PUSH src<br>SP ← SP - 1; @ SP ← | src | R<br>IR | 70<br>71 | | | <b>RCF</b> C ← 0 | | | CF | 0 | | RET<br>PC - @ SP; SP - SP | + 2 | | AF | | | RL dst | R<br>IR | | 90<br>91 | * * * * | | RLC dst | R<br>IR | | 10<br>11 | * * * * | | RR dst | R<br>IR | | E0<br>E1 | * * * * | | RRC dst | R<br>IR | | C0<br>C1 | * * * * | | SBC dst,src<br>dst ← dst - src - C | (Note | 1) | 3□ | * * * * 1 * | | <b>SCF</b><br>C + 1 | | | DF | 1 | | SRA dst | R<br>IR | | D0<br>D1 | * * * 0 | | SRP src<br>RP ← src | | Im | 31 | | | <b>SUB</b> dst,src<br>dst ← dst – src | (Note | 1) | 2□ | * * * * 1 * | | SWAP dst | R<br>IR | | FO<br>Fl | X * * X | | TCM dst,src<br>(NOT dst) AND src | (Note | 1) | 6□ | - * * 0 | | TM dst, src<br>dst AND src | (Note | 1) | 7□ | - * * 0 | | XOR dst,src<br>dst — dst XOR src | (Note | 1) | В□ | - * * 0 | #### Note 1 These instructions have an identical set of addressing modes, which are encoded for brevity. The first opcode nibble is found in the instruction set table above. The second nibble is expressed symbolically by a $\square$ in this table, and its value is found in the following table to the left of the applicable addressing mode pair. For example, to determine the opcode of an ADC instruction using the addressing modes r (destination) and Ir (source) is 13. | <br>Āddr | Mode | Lower | | |----------|------|---------------|--| | dst | src | Opcode Nibble | | | r | r | 2 | | | r | Ir | 3 | | | R | R | 4 | | | R | IR | 5 | | | R | IM | 6 | | | IR | IM | 7 | | | | | | | LDC dst,src LDCI dst,src $dst \leftarrow src$ $r \leftarrow r + 1; rr \leftarrow rr + 1$ Irr Irrr Ir Irr Ir Irr C2 D2 C3 D3 #### **R240 SIO** Serial I/O Register (FO<sub>H</sub>; Read/Write) #### R244 T0 Counter/Timer 0 Register (F4<sub>H</sub>; Read/Write) #### **R241 TMR** Timer Mode Register (Fl<sub>H</sub>; Read/Write) #### R245 PRE0 Prescaler 0 Register (F5<sub>H</sub>; Write Only) #### R242 T1 Counter Timer 1 Register (F2<sub>H</sub>; Read/Write) #### **R246 P2M** Port 2 Mode Register (F6<sub>H</sub>; Write Only) #### **R243 PRE1** Prescaler 1 Register (F3<sub>H</sub>; Write Only) #### R247 P3M Port 3 Mode Register (F7H; Write Only) Figure 14. Control Registers # Registers (Continued) #### R248 P01M Port 0 and 1 Mode Register (F8<sub>H</sub>; Write Only) #### R252 FLAGS Flag Register (FC<sub>H</sub>; Read/Write) #### R249 IPR Interrupt Priority Register (F9<sub>H</sub>; Write Only) #### R253 RP Register Pointer (FD<sub>H</sub>; Read/Write) # R250 IRQ Interrupt Request Register (FA<sub>H</sub>; Read/Write) #### R254 SPH Stack Pointer (FE<sub>H</sub>; Read/Write) #### R251 IMR Interrupt Mask Register (FB<sub>H</sub>; Read/Write) #### R255 SPL Stack Pointer (FF<sub>H</sub>; Read/Write) | Z860<br>Opc | | | | | | _ | | Low | er Nibble | e (Hex) | | | | | | | | |--------------------|--------------|--------------------------------------|---------------------------------------|---------------------------------------------------------|--------------------------------------------------------|--------------------------------------------------------|---------------------------------------------------------|--------------------------------------------|--------------------------------------------|-----------------------------------------------------|-----------------------------------------------------|---------------------------------------------------|--------------------------------|----------------------------|--------------------------------|-------------------------|---------------------| | Map | | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | A | В | С | D | E | F | | | 0 | 6, 5<br><b>DEC</b><br>R <sub>1</sub> | 6,5<br><b>DEC</b><br>IR <sub>1</sub> | 6,5<br><b>ADD</b><br>r1, r2 | 6, 5<br><b>ADD</b><br>r <sub>1</sub> , Ir <sub>2</sub> | 10, 5<br><b>ADD</b><br>R <sub>2</sub> , R <sub>1</sub> | 10, 5<br><b>ADD</b><br>IR <sub>2</sub> , R <sub>1</sub> | 10,5<br><b>ADD</b><br>R <sub>1</sub> ,IM | 10,5<br><b>ADD</b><br>IR <sub>1</sub> , IM | 6,5<br><b>LD</b><br>r <sub>1</sub> , R <sub>2</sub> | 6,5<br><b>LD</b><br>r <sub>2</sub> , R <sub>1</sub> | 12/10,5<br><b>DJNZ</b><br>r <sub>1</sub> , RA | 12/10,0<br><b>JR</b><br>cc, RA | 6,5<br><b>LD</b><br>r1, IM | 12/10,0<br><b>JP</b><br>cc, DA | 6,5<br><b>INC</b><br>r1 | | | | 1 | 6,5<br><b>RLC</b><br>R <sub>1</sub> | 6,5<br>RLC<br>IR <sub>1</sub> | 6,5<br>ADC<br>r <sub>1</sub> , r <sub>2</sub> | 6,5<br><b>ADC</b><br>r <sub>1</sub> ,Ir <sub>2</sub> | 10,5<br><b>ADC</b><br>R <sub>2</sub> , R <sub>1</sub> | 10,5<br><b>ADC</b><br>IR <sub>2</sub> , R <sub>1</sub> | 10,5<br><b>ADC</b><br>R <sub>1</sub> ,IM | 10,5<br>ADC<br>IR <sub>1</sub> ,IM | | | | | | | | | | | 2 | 6, 5<br><b>INC</b><br>R <sub>1</sub> | 6,5<br>INC<br>IR <sub>1</sub> | 6,5<br>SUB<br>11,12 | 6,5<br><b>SUB</b><br>r <sub>1</sub> , Ir <sub>2</sub> | 10, 5<br><b>SUB</b><br>R <sub>2</sub> , R <sub>1</sub> | 10,5<br><b>SUB</b><br>IR <sub>2</sub> , R <sub>1</sub> | 10, 5<br><b>SUB</b><br>R <sub>1</sub> , IM | 10,5<br><b>SUB</b><br>IR <sub>1</sub> ,IM | | | | | | | | | | | 3 | 8,0<br><b>JP</b><br>IRR <sub>1</sub> | 6, 1<br><b>SRP</b><br>IM | 6,5<br>SBC<br>11,12 | 6,5<br>SBC<br>r1, Ir2 | 10, 5<br><b>SBC</b><br>R <sub>2</sub> , R <sub>1</sub> | 10,5<br><b>SBC</b><br>IR <sub>2</sub> , R <sub>1</sub> | 10,5<br><b>SBC</b><br>R <sub>1</sub> , IM | 10,5<br><b>SBC</b><br>IR <sub>1</sub> , IM | | | | | | | | | | | 4 | 8,5<br><b>DA</b><br>R <sub>1</sub> | 8,5<br><b>DA</b><br>IR <sub>1</sub> | 6,5<br>OR<br>r1, r2 | 6, 5<br>OR<br>r1, Ir2 | 10, 5<br>OR<br>R <sub>2</sub> , R <sub>1</sub> | 10,5<br>OR<br>IR <sub>2</sub> , R <sub>1</sub> | 10,5<br><b>OR</b><br>R <sub>1</sub> ,IM | 10,5<br><b>OR</b><br>IR <sub>1</sub> , IM | | | | | | | | | | | 5 | 10,5<br><b>POP</b><br>R <sub>1</sub> | 10,5<br>POP<br>IR <sub>1</sub> | 6,5<br>AND<br>r1, r2 | 6, 5<br>AND<br>r1, Ir2 | 10, 5<br>AND<br>R <sub>2</sub> , R <sub>1</sub> | 10,5<br><b>AND</b><br>IR <sub>2</sub> , R <sub>1</sub> | 10,5<br><b>AND</b><br>R <sub>1</sub> ,IM | 10,5<br><b>AND</b><br>IR <sub>1</sub> , IM | | | | | | | | | | lex) | 6 | 6, 5<br>COM<br>R <sub>1</sub> | 6, 5<br><b>COM</b><br>IR <sub>1</sub> | 6, 5<br><b>TCM</b><br>r <sub>1</sub> , r <sub>2</sub> | 6,5<br><b>TCM</b><br>r <sub>1</sub> , Ir <sub>2</sub> | 10, 5<br>TCM<br>R <sub>2</sub> , R <sub>1</sub> | 10,5<br>TCM<br>IR <sub>2</sub> , R <sub>1</sub> | 10,5<br><b>TCM</b><br>R <sub>1</sub> , IM | 10,5<br><b>TCM</b><br>IR <sub>1</sub> , IM | | | | | | | | | | Upper Nibble (Hex) | 7 | 10/12, 1<br>PUSH<br>R <sub>2</sub> | 12/14, 1<br>PUSH<br>IR <sub>2</sub> | 6,5<br><b>TM</b><br>r <sub>1</sub> , r <sub>2</sub> | 6, 5<br><b>TM</b><br>r <sub>1</sub> , Ir <sub>2</sub> | 10, 5<br><b>TM</b><br>R <sub>2</sub> , R <sub>1</sub> | 10,5<br><b>TM</b><br>IR <sub>2</sub> , R <sub>1</sub> | 10,5<br><b>TM</b><br>R <sub>1</sub> ,IM | 10,5<br><b>TM</b><br>IR <sub>1</sub> , IM | | | | | | | | | | Upper N | 8 | 10,5<br>DECW<br>RR <sub>1</sub> | 10,5<br>DECW<br>IR <sub>1</sub> | 12,0<br><b>LDE</b><br>r <sub>1</sub> ,Irr <sub>2</sub> | 18,0<br>LDEI<br>Ir1,Irr2 | | | | | | | | | | | | 6, 1<br><b>DI</b> | | | 9 | 6, 5<br><b>RL</b><br>R <sub>1</sub> | 6, 5<br><b>RL</b><br>IR <sub>1</sub> | 12,0<br>LDE<br>r2,Irr1 | 18,0<br>LDEI<br>Ir2,Irr1 | | | | | | | | | | | | 6, 1<br><b>EI</b> | | | A | 10, 5<br>INCW<br>RR <sub>1</sub> | 10,5<br>INCW<br>IR <sub>1</sub> | 6, 5<br><b>CP</b><br>r1, r2 | 6, 5<br><b>CP</b><br>r1, Ir2 | 10,5<br><b>CP</b><br>R <sub>2</sub> , R <sub>1</sub> | 10, 5<br><b>CP</b><br>IR <sub>2</sub> , R <sub>1</sub> | 10,5<br><b>CP</b><br>R <sub>1</sub> ,IM | 10, 5<br><b>CP</b><br>IR <sub>1</sub> , IM | | | | | | | | 14,0<br>RET | | | В | 6, 5<br>CLR<br>R <sub>1</sub> | 6, 5<br><b>CLR</b><br>IR <sub>1</sub> | 6,5<br><b>XOR</b><br>r <sub>1</sub> , r <sub>2</sub> | 6,5<br><b>XOR</b><br>r <sub>1</sub> , Ir <sub>2</sub> | 10, 5<br><b>XOR</b><br>R <sub>2</sub> , R <sub>1</sub> | 10, 5<br><b>XOR</b><br>IR <sub>2</sub> , R <sub>1</sub> | 10,5<br><b>XOR</b><br>R <sub>1</sub> ,IM | 10,5<br><b>XOR</b><br>IR <sub>1</sub> , IM | | | | | | | | 16, 0<br>IRE | | | С | 6,5<br>RRC<br>R <sub>1</sub> | 6,5<br>RRC<br>IR <sub>1</sub> | 12,0<br><b>LDC</b><br>r <sub>1</sub> , Irr <sub>2</sub> | 18,0<br>LDCI<br>Ir1,Irr2 | | | | 10,5<br><b>LD</b><br>r1, x, R2 | | | | | | | | 6, 5<br>RCF | | | D | 6,5<br><b>SRA</b><br>R <sub>1</sub> | 6,5<br><b>SRA</b><br>IR <sub>1</sub> | 12,0<br>LDC<br>r2,Irr1 | 18,0<br>LDCI<br>Ir2, Irr1 | 20,0<br>CALL*<br>IRR1 | | 20,0<br>CALL<br>DA | 10,5<br><b>LD</b><br>r2, x, R1 | | | | | | | | 6, 5<br><b>SCF</b> | | | E | 6,5<br><b>RR</b><br>R <sub>1</sub> | 6, 5<br><b>RR</b><br>IR <sub>1</sub> | | 6, 5<br>LD<br>r1, Ir2 | 10, 5<br><b>LD</b><br>R <sub>2</sub> , R <sub>1</sub> | 10, 5<br><b>LD</b><br>IR <sub>2</sub> , R <sub>1</sub> | 10,5<br><b>LD</b><br>R <sub>1</sub> ,IM | 10, 5<br><b>LD</b><br>IR <sub>1</sub> , IM | | | | | | | | 6,5<br><b>CCI</b> | | | F | 8,5<br><b>SWAP</b><br>R <sub>1</sub> | 8,5<br><b>SWAP</b><br>IR <sub>1</sub> | | 6, 5<br>LD<br>Ir1, r2 | i | 10, 5<br><b>LD</b><br>R <sub>2</sub> , IR <sub>1</sub> | | | | | | | | | | 6, 0<br><b>NO</b> I | | | | | | | · | | | | | | | | | | | | <del></del> | | Bytes<br>Instru | per<br>ction | ı | 2 | 2 | | | 3 | 3 | | | | 2 | | | 3 | | 1 | | | | | | | Lower | e | | | | | | | | | | | | | | | | Fue | cution | Nibbl | | eline | | | | | | | | | | | | | | | | Cycles \ | \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ | | cles | | | | | Legend: $R = 8-Bit$ | Address | | | | | | | | | Upper<br>Opcode -<br>Nibble | <b>→</b> A | 10, 5<br><b>CP</b><br>R <sub>2</sub> , R <sub>1</sub> | | nemonic | ! | | | | r = 4-Bit<br>$R_1$ or $r_1 =$<br>$R_2$ or $r_2 =$ | = Dst Add: | | | | | | | | | | First | * | * | ond | | | | | Sequence<br>Opcode, | | perand, | Second C | perand | | | | | | Op | erand | | | erand | | | | | Note: T | ne blank | areas ar | e not def | ined. | | $<sup>^{\</sup>star}2\text{-byte}$ instruction; fetch cycle appears as a 3-byte instruction #### Standard Test Conditions The characteristics below apply for the following standard test conditions, unless otherwise noted. All voltages are referenced to GND. Positive current flows into the reference pin. Standard conditions are as follows: $\Box$ +4.75 V $\leq$ V $_{\rm CC}$ $\leq$ +5.25 V $\square$ GND = 0 V $\square \ 0^{\circ}\text{C} \leq T_{\text{A}} \leq +70^{\circ}\text{C}^{\star}$ \*See Ordering Information section for package temperature range and product number. Figure 15. Test Load 1 Figure 16. Test Load 2 Figure 17. External Clock Interface Circuit | DC | |------------| | Character- | | istics | | | | Syml | bol Parameter | Min | Мах | Unit | Condition | Notes | |---------------------|--------------------------------|------|--------------|------|---------------------------------------------------------------|-------| | $v_{CH}$ | Clock Input High Voltage | 3.8 | $v_{cc}$ | v | Driven by External Clock Generator | | | $v_{\rm CL}$ | Clock Input Low Voltage | -0.3 | 0.8 | V | Driven by External Clock Generator | | | $v_{IH}$ | Input High Voltage | 2.0 | $v_{cc}$ | V | | | | $\overline{v_{IL}}$ | Input Low Voltage | -0.3 | 0.8 | V | | | | $\overline{v_{RH}}$ | Reset Input High Voltage | 3.8 | $v_{cc}$ | V | | | | $\overline{v_{RL}}$ | Reset Input Low Voltage | -0.3 | 0.8 | V | | | | $v_{OH}$ | Output High Voltage | 2.4 | | V | $I_{OH} = -250 \mu\text{A}$ | 1 | | $v_{OL}$ | Output Low Voltage | | 0.4 | V | $I_{OL} = +2.0 \text{ mA}$ | 1 | | $\overline{I_{IL}}$ | Input Leakage | -10 | 10 | μΑ | $0 \text{ V} \leq \text{ V}_{\text{IN}} \leq +5.25 \text{ V}$ | | | $I_{OL}$ | Output Leakage | -10 | 10 | μΑ | $0 \text{ V} \leq \text{V}_{\text{IN}} \leq +5.25 \text{ V}$ | | | I <sub>IR</sub> | Reset Input Current | | -50 | μA | $V_{\rm CC} = +5.25 \text{ V}, V_{\rm RL} = 0 \text{ V}$ | | | $I_{CC}$ | V <sub>CC</sub> Supply Current | | 180 | mA | | | | I <sub>MM</sub> | V <sub>MM</sub> Supply Current | | 10 | mA | Power Down Mode | | | $\overline{v_{MM}}$ | Backup Supply Voltage | 3 | $v_{\rm CC}$ | V | Power Down | | | | | | | | <u> </u> | | <sup>1.</sup> For A0-A11, $\overline{\text{MDS}}$ , $\overline{\text{SYNC}}$ , SCLK and IACK on the Z8602 version, IOH = -100 $\mu\text{A}$ and IOL = 1.0 mA. | External I/O Number | | Symbol | Parameter | Min | Max | Unit | Notes | |-----------------------|----------|--------------|---------------------------------------------------|------------|-----|----------|------------| | or Memory<br>Read and | 1 | TdA(AS) | Address Valid to Address Strobe Delay | 50 | | ns | 1,2 | | Write Timing | 2 | TdAS(A) | Address Strobe to Address Float Delay | 70 | | ns | 1,2 | | | 3 | TdAS(DI) | Address Strobe to Data In Valid Delay | | 360 | ns | 1,4 | | | 4 | TwAS | Address Strobe Width | 80 | | ns | 1,2 | | | 5 | - TdA(DS) - | – Address Float to Data Strobe Delay – | o | | ns | 1 | | | 6a<br>6b | TwDS<br>TwDS | Data Strobe Width Read<br>Data Strobe Width Write | 250<br>160 | | ns<br>ns | 1,3<br>1,3 | | | 7 | TdDS(DI) | Data Strobe to Data In Valid Delay | | 200 | ns | 1,4 | | | 8 | - ThDS(DI) - | – Data In Hold Time – | o | | ns | | | | 9 | TdDS(A) | Data Strobe to Address Change Delay | 80 | | ns | 1,2 | | | 10 | TdDS(AS) | Data Strobe to Address Strobe Delay | 70 | | ns | 1,2 | | | 11 | TdR(AS) | Read Valid to Address Strobe Delay | 50 | | ns | 1,2 | Data Strobe to Read Change Delay Data Out Valid to Data Strobe Delay Write Valid to Address Strobe Delay Data Strobe to Write Change Delay Data Strobe to Data Out Change Delay #### NOTES: l Test Load 1. 12 13 14 15 16 Delay times given are for an 8 MHz crystal input frequency. For lower frequencies, the change in clock period must be added to the delay time. TdDS(R)- TdDO(DS) TdDS(DO) TdW(AS) TdDS(W) - Data Strobe Width is given for an 8 MHz crystal input frequency. For lower frequencies the change in three clock periods must be added to obtain the minimum width. The Data Strobe Width varies according to the instruction being executed. - 4. Address Strobe and Data Strobe to Data In Valid delay times represent memory system access times and are given for an 8 MHz crystal input frequency. For lower frequencies, the change in four clock periods must be added to TdAS(DI) and the change in three clock periods added to TdDS(DI). 1,2 1,2 1,2 1,2 1,2 ns ns ns ns 5. All timing references assume 2.0 V for a logic "1" and 0.8 V for a logic "0." 60 50 80 50 60 | Additional | Number | Symbol | Parameter | Min | Max | Unit | Notes | |-----------------|--------|------------|-------------------------------------------------------------------|-----|------|------|-------| | Timing<br>Table | 1 | TpC | Input Clock Period | 125 | 1000 | ns | | | | 2 | TrC, TfC | Input Clock Rise and<br>Fall Times | | 25 | ns | 3 | | | 3 | TwC | Input Clock Width | 37 | | ns | 3 | | | 4 | -TdSC(AS)- | – System Clock Out to Address ——————————————————————————————————— | | | ns | ——1— | | | 5 | TdSY(DS) | Instruction Sync Out to Data<br>Strobe Delay Time | 200 | | ns | 1,2 | | | 6 | TwSY | Instruction Sync Out Width | 160 | | ns | 1, 2 | | | 7 | TwI | Interrupt Request via<br>Port 3 Input Width | 100 | | ns | | #### NOTES: - 1 Test Conditions use Test Load 1 for SCLK when output through the Port 3 pins and Test Load 2 on the SCLK and SYNC direct outputs on Z8602. - 2. Times given assume an 8 MHz crystal input frequency. For lower frequencies, the change in two clock periods must be added - 3 From external clock generator - 4. All timing references assume 2 0 V for a logic "1" and 0 8 V for a logic "0" 2037-017 | Handshake<br>Timing | Number | Symbol | Parameter | Min | Мах | Unit | Notes | |---------------------|----------|-----------|-------------------------------------------------------------------------------|----------|-----|----------|-------------| | | 1 | TsDI(DA) | Data In Setup Time | 0 | | ns | | | | 2 | ThDA(DI) | Data In Hold Time | 230 | | ns | | | | 3 | TwDA | Data Available Width | 175 | | ns | 1,2 | | | 4a<br>4b | TdDAL(RY) | Data Avaılable Low to Ready — Delay Time ———————————————————————————————————— | 20<br>0- | 175 | ns<br>ns | 1,2<br>1,3- | | | 5a<br>5b | TdDAH(RY) | Data Available High to Ready<br>Delay Time | 0 | 150 | ns<br>ns | 1,2<br>1,3 | | | 6 | TdDO(DA) | Data Out to Data Available<br>Delay Time | 50 | | ns | 1 | | | 7 | TdRY(DA) | Ready to Data Available Delay Time | 0 | 205 | ns | 1 | NOTES: - 1. Test Load 1 2. Input Handshake 3. Output Handshake #### Input Handshake #### Output Handshake | Z8602, Z8603 | |--------------------| | <b>Memory Port</b> | | Timing | | Number | Symbol | Parameter | Min | Мах | Unit | Notes | |--------|---------|----------------------------------------------|-----|-----|------|-------| | 1 | TdA(DI) | Address Valid to Data In<br>Valid Delay Time | | 460 | ns | 1 | | 2 | ThDI(A) | Data in Hold Time | 0 | | ns | | #### NOTES: - 1. Test Load 2 2. Delay times are specified for an input clock frequency of 8 MHz. 3. All timing references assume 2.0 V for a logic "1" and 0.8 V for a logic "0". | Ordering<br>Information | Product<br>Number | Package/<br>Temp | Speed | Description | Product<br>Number | Package/<br>Temp | Speed | Description | |-------------------------|-------------------|------------------|---------|----------------------------|-------------------|------------------|---------|---------------------| | | Z8601 | CE | 8.0 MHz | Z8 MCU<br>(2K ROM, 40-pin) | Z8602 | QE | 8.0 MHz | Z8 MCU<br>(2K XROM, | | | Z8601 | CS | 8.0 MHz | Same as above | | | | 64-pin) | | | Z8601 | DE | 8.0 MHz | Same as above | Z8602 | QS | 8.0 MHz | Same as above | | | Z8601 | DS | 8.0 MHz | Same as above | Z8603 | RS | 8.0 MHz | Z8 MCU<br>(2K XROM, | | | Z8601 | PE | 8.0 MHz | Same as above | | | | Prototype Device, | | | Z8601 | PS | 8.0 MHz | Same as above | | | | 40-pin) | NOTES: C = Ceramic, D = Cerdip, P = Plastic, Q = Quip, R = Protopack; E = -40°C to +85°C, S = 0°C to +70°C. ### Z8° Family of Microcomputers Z8611 • Z8612 • Z8613 ## Product Specification June 1982 Z8611 Single-Chip Microcomputer with 4K ROM Z8612 Development Device with Memory Interface Z8613 Prototyping Device with EPROM Interface #### **Features** - Complete microcomputer, 4K bytes of ROM, 128 bytes of RAM, 32 I/O lines, and up to 60K bytes addressable external space each for program and data memory. - 144-byte register file, including 124 general-purpose registers, four I/O port registers, and 16 status and control registers. - Average instruction execution time of 2.2 $\mu$ s, maximum of 4.25 $\mu$ s. - Vectored, priority interrupts for I/O, counter/timers, and UART. - Full-duplex UART and two programmable 8-bit counter/timers, each with a 6-bit programmable prescaler. - Register Pointer so that short, fast instructions can access any of nine working-register groups in 1.5 μs. - On-chip oscillator which accepts crystal or external clock drive. - Low-power standby option which retains contents of general-purpose registers. - Single +5 V power supply—all pins TTL compatible. #### General Description The Z8611 microcomputer introduces a new level of sophistication to single-chip architecture. Compared to earlier single-chip microcomputers, the Z8611 offers faster execution; more efficient use of memory; more sophisticated interrupt, input/output and bit-manipulation capabilities; and easier system expansion. Under program control, the Z8611 can be tailored to the needs of its user. It can be con- figured as a stand-alone microcomputer with 4K bytes of internal ROM, a traditional microprocessor that manages up to 120K bytes of external memory, or a parallel-processing element in a system with other processors and peripheral controllers linked by the Z-BUS. In all configurations, a large number of pins remain available for I/O. Figure 1. Z8611 MCU Pin Functions Figure 2. Z8611 MCU Pin Assignments #### Architecture Z8611 architecture is characterized by a flexible I/O scheme, an efficient register and address space structure and a number of ancillary features that are helpful in many applications. Microcomputer applications demand powerful I/O capabilities. The Z8611 fulfills this with 32 pins dedicated to input and output. These lines are grouped into four ports of eight lines each and are configurable under software control to provide timing, status signals, serial or parallel I/O with or without handshake, and an address/data bus for interfacing external memory. Because the multiplexed address/data bus is merged with the I/O-oriented ports, the Z8611 can assume many different memory and I/O configurations. These configurations range from a self-contained microcomputer to a microprocessor that can address 120K bytes of external memory (Figure 3). Three basic address spaces are available to support this wide range of configurations: program memory (internal and external), data memory (external) and the register file (internal). The 144-byte random-access register file is composed of 124 general-purpose registers, four I/O port registers, and 16 control and status registers. To unburden the program from coping with real-time problems such as serial data communication and counting/timing, an asynchronous receiver/transmitter (UART) and two counter/timers with a large number of userselectable modes are offered on-chip. Hardware support for the UART is minimized because one of the on-chip timers supplies the bit rate. Figure 3. Functional Block Diagram #### Pin Description **AS.** Address Strobe (output, active Low). Address Strobe is pulsed once at the beginning of each machine cycle. Addresses output via Port 1 for all external program or data memory transfers are valid at the trailing edge of $\overline{AS}$ . Under program control, $\overline{AS}$ can be placed in the high-impedance state along with Ports 0 and 1, Data Strobe and Read/Write. **DS.** Data Strobe (output, active Low). Data Strobe is activated once for each external memory transfer. **P00-P07.** P10-P17. P20-P27. P30-P37. I/O Port Lines (input/outputs, TTL-compatible). These 32 lines are divided into four 8-bit I/O ports that can be configured under program control for I/O or external memory interface. **RESET.** Reset (input, active Low). RESET initializes the Z8611. When RESET is deactivated, program execution begins from internal program location $000C_{\rm H}$ . $\mathbf{R}/\overline{\mathbf{W}}$ . Read/Write (output). $R/\overline{\mathbf{W}}$ is Low when the Z8611 is writing to external program or data memory. **XTAL1. XTAL2.** Crystal 1, Crystal 2 (time-base input and output). These pins connect a series-resonant crystal (8 MHz maximum) or an external single-phase clock (8 MHz maximum) to the on-chip clock oscillator and buffer. #### Address Spaces **Program Memory.** The 16-bit program counter addresses 64K bytes of program memory space. Program memory can be located in two areas: one internal and the other external (Figure 4). The first 4096 bytes consist of on-chip mask-programmed ROM. At addresses 4096 and greater, the Z8611 executes external program memory fetches. The first 12 bytes of program memory are reserved for the interrupt vectors. These locations contain six 16-bit vectors that correspond to the six available interrupts. **Data Memory.** The Z8611 can address 60K bytes of external data memory beginning at Figure 4. Program Memory Map locations 4096 (Figure 5). External data memory may be included with or separated from the external program memory space. $\overline{\rm DM}$ , an optional I/O function that can be programmed to appear on pin P3<sub>4</sub>, is used to distinguish between data and program memory space. **Register File.** The 144-byte register file includes four I/O port registers (R0-R3), 124 general-purpose registers (R4-R127) and 16 control and status registers (R240-R255). These registers are assigned the address locations shown in Figure 6. Z8611 instructions can access registers Figure 5. Data Memory Map Figure 6. The Register File Figure 7. The Register Pointer 2038 004, 005 2037-006, 007 451 #### Address Spaces (Continued) directly or indirectly with an 8-bit address field. The Z8611 also allows short 4-bit register addressing using the Register Pointer (one of the control registers). In the 4-bit mode, the register file is divided into nine working-register groups, each occupying 16 contiguous locations (Figure 7). The Register Pointer addresses the starting location of the active working-register group. Stacks. Either the internal register file or the external data memory can be used for the stack. A 16-bit Stack Pointer (R254 and R255) is used for the external stack, which can reside anywhere in data memory between locations 4096 and 65535. An 8-bit Stack Pointer (R255) is used for the internal stack that resides within the 124 general-purpose registers (R4-R127). #### Serial Input/ Output Port 3 lines P3<sub>0</sub> and P3<sub>7</sub> can be programmed as serial I/O lines for full-duplex serial asynchronous receiver/transmitter operation. The bit rate is controlled by Counter/Timer 0, with a maximum rate of 62.5K bits/second. The Z8611 automatically adds a start bit and two stop bits to transmitted data (Figure 8). Odd parity is also available as an option. Eight data bits are always transmitted, regardless of parity selection. If parity is enabled, the eighth bit is the odd parity bit. An interrupt request (IRQ<sub>4</sub>) is generated on all transmitted characters. Received data must have a start bit, eight data bits and at least one stop bit. If parity is on, bit 7 of the received data is replaced by a parity error flag. Received characters generate the IRQ3 interrupt request. #### Transmitted Data (No Parity) #### Transmitted Data (With Parity) #### Received Data (With Parity) Figure 8. Serial Data Formats #### Counter/ Timers The Z8611 contains two 8-bit programmable counter/timers ( $T_0$ and $T_1$ ), each driven by its own 6-bit programmable prescaler. The $T_1$ prescaler can be driven by internal or external clock sources; however, the $T_0$ prescaler is driven by the internal clock only. The 6-bit prescalers can divide the input frequency of the clock source by any number from 1 to 64. Each prescaler drives its counter, which decrements the value (1 to 256) that has been loaded into the counter. When the counter reaches the end of count, a timer interrupt request—IRQ4 (T<sub>0</sub>) or IRQ5 (T<sub>1</sub>)—is generated. The counters can be started, stopped, restarted to continue, or restarted from the initial value. The counters can also be programmed to stop upon reaching zero (single- pass mode) or to automatically reload the initial value and continue counting (modulo-n continuous mode). The counters, but not the prescalers, can be read any time without disturbing their value or count mode. The clock source for $T_1$ is user-definable and can be the internal microprocessor clock (4 MHz maximum) divided by four, or an external signal input via Port 3. The Timer Mode register configures the external timer input as an external clock (1 MHz maximum), a trigger input that can be retriggerable or non-retriggerable, or as a gate input for the internal clock. The counter/timers can be programmably cascaded by connecting the $T_0$ output to the input of $T_1$ . Port 3 line $P_0$ also serves as a timer output ( $T_{OUT}$ ) through which $T_0$ , $T_1$ or the internal clock can be output. 452 #### I/O Ports The Z8611 has 32 lines dedicated to input and output. These lines are grouped into four ports of eight lines each and are configurable as input, output or address/data. Under software control, the ports can be programmed to provide address outputs, timing, status signals, serial I/O, and parallel I/O with or without handshake. All ports have active pull-ups and pull-downs compatible with TTL loads. **Port 1** can be programmed as a byte I/O port or as an address/data port for interfacing external memory. When used as an I/O port, Port 1 may be placed under handshake control. In this configuration, Port 3 lines P3 $_3$ and P3 $_4$ are used as the handshake controls RDY $_1$ and $\overline{\rm DAV}_1$ (Ready and Data Available). Memory locations greater than 4096 are referenced through Port 1. To interface external memory, Port 1 must be programmed for the multiplexed Address/Data mode. If more than 256 external locations are required, Port 0 must output the additional lines. Port 1 can be placed in the high-impedance state along with Port 0, $\overline{AS}$ , $\overline{DS}$ and $R/\overline{W}$ , allowing the Z8611 to share common resources in multiprocessor and DMA applications. Data transfers can be controlled by assigning P3<sub>3</sub> as a Bus Acknowledge input, and P3<sub>4</sub> as a Bus Request output. Figure 9a. Port 1 **Port 0** can be programmed as a nibble I/O port, or as an address port for interfacing external memory. When used as an I/O port, Port 0 may be placed under handshake control. In this configuration, Port 3 lines $P_{32}$ and $P_{35}$ are used as the handshake controls $\overline{DAV_0}$ and $RDY_0$ . Handshake signal assignment is dictated by the I/O direction of the upper nibble $P_{04}$ – $P_{07}$ . For external memory references, Port 0 can provide address bits $A_8$ – $A_{11}$ (lower nibble) or $A_8$ – $A_{15}$ (lower and upper nibble) depending on the required address space. If the address range requires 12 bits or less, the upper nibble of Port 0 can be programmed independently as I/O while the lower nibble is used for addressing. When Port 0 nibbles are defined as address bits, they can be set to the high-impedance state along with Port 1 and the control signals $\overline{\rm AS}$ , $\overline{\rm DS}$ and ${\rm R/W}$ . Figure 9b. Port 0 **Port 2** bits can be programmed independently as input or output. This port is always available for I/O operations. In addition, Port 2 can be configured to provide open-drain outputs. Like Ports 0 and 1, Port 2 may also be placed under handshake control. In this configuration, Port 3 lines $P3_1$ and $P3_6$ are used as the handshake controls lines $\overline{DAV}_2$ and $RDY_2$ . The handshake signal assignment for Port 3 lines $P3_1$ and $P3_6$ is dictated by the direction (input or output) assigned to bit 7 of Port 2. Figure 9c. Port 2 **Port 3** lines can be configured as I/O or control lines. In either case, the direction of the eight lines is fixed as four input (P3<sub>0</sub>-P3<sub>3</sub>) and four output (P3<sub>4</sub>-P3<sub>7</sub>). For serial I/O, lines P3<sub>0</sub> and P3<sub>7</sub> are programmed as serial in and serial out respectively. Port 3 can also provide the following control functions: handshake for Ports 0, 1 and 2 ( $\overline{DAV}$ and RDY); four external interrupt request signals (IRQ<sub>0</sub>-IRQ<sub>3</sub>); timer input and output signals ( $\overline{T_{IN}}$ and $\overline{T_{OUT}}$ ) and Data Memory Select ( $\overline{DM}$ ). Figure 9d. Port 3 #### Interrupts The Z8611 allows six different interrupts from eight sources: the four Port 3 lines $P3_0$ – $P3_3$ , Serial In, Serial Out, and the two counter/ timers. These interrupts are both maskable and prioritized. The Interrupt Mask register globally or individually enables or disables the six interrupt requests. When more than one interrupt is pending, priorities are resolved by a programmable priority encoder that is controlled by the Interrupt Priority register. All Z8611 interrupts are vectored. When an interrupt request is granted, an interrupt machine cycle is entered. This disables all subsequent interrupts, saves the Program Counter and status flags, and branches to the program memory vector location reserved for that interrupt. This memory location and the next byte contain the 16-bit address of the interrupt service routine for that particular interrupt request. Polled interrupt systems are also supported. To accommodate a polled structure, any or all of the interrupt inputs can be masked and the Interrupt Request register polled to determine which of the interrupt requests needs service. #### Clock The on-chip oscillator has a high-gain, series-resonant amplifier for connection to a crystal or to any suitable external clock source (XTAL1 = Input, XTAL2 = Output). The crystal source is connected across XTAL1 and XTAL2, using the recommended capacitors ( $C_1 = 15 \text{ pF}$ ) from each pin to ground. The specifications for the crystal are as follows: - AT cut, series resonant - Fundamental type, 8 MHz maximum - Series resistance, $R_s \le 100 \Omega$ #### Power Down Standby Option The low-power standby mode allows power to be removed without losing the contents of the 124 general-purpose registers. This mode is available to the user as a bonding option whereby pin 2 (normally XTAL2) is replaced by the $V_{MM}$ (standby) power supply input. This necessitates the use of an external clock generator (input = XTAL1) rather than a crystal source. The removal of power, whether intended or due to power failure, must be preceded by a software routine that stores the appropriate status into the register file. Figure 10 shows the recommended circuit for a battery back-up supply system. Figure 10. Recommended Driver Circuit for Power Down Operation #### Z8612 Development Device This 64-pin development version of the 40-pin mask-programmed Z8611 (Figure 11) allows the user to prototype the system in hardware with an actual device and to develop the code that is eventually mask-programmed into the on-chip ROM of the Z8611. The Z8612 is identical to the Z8611 with the following exceptions: - The internal ROM has been removed. - The ROM address lines and data lines are buffered and brought out to external pins. - Control lines for the new memory have been added. **Pin Description.** The functions of the Z8612 I/O lines, AS, DS, R/W, XTAL1, XTAL2 and RESET are identical to those of their Z8611 counterparts. The functions of the remaining 24 pins are as follows: **A<sub>0</sub>-A<sub>11</sub>.** Program Memory Address (outputs). $A_0$ -A<sub>11</sub> access the first 4K bytes of program memory. Figure 11. Z8612 Pin Assignments # Z8612 Development Device (Continued) **D**<sub>0</sub>**-D**<sub>7</sub>. *Program Data* (inputs). Program data from the first 4K bytes of program memory is input through pins D<sub>0</sub>-D<sub>7</sub>. **IACK.** Interrupt Acknowledge (output, active High). IACK is driven High in response to an interrupt during the interrupt machine cycle. MDS. Program Memory Data Strobe (output, active Low). MDS is Low during an instruction fetch cycle when the first 4K bytes of program memory are being accessed. **SCLK.** System Clock (output). SCLK is the internal clock output through a buffer. The clock rate is equal to one-half the crystal frequency. **SYNC.** Instruction Sync (output, active Low). This strobe output is forced Low during the internal clock period preceding an opcode fetch. #### Z8613 Protopack Emulator The Z8613 MPE (Protopack) is used for prototype development and preproduction of mask-programmed applications. The Protopack is a ROMless version of the standard Z8611, housed in a pin-compatible 40-pin package (Figure 12). To provide pin compatibility and interchangeability with the standard mask-programmed device, the Protopack carries (piggy-backs) a 24-pin socket for a direct interface to program memory (Figure 1). The 24-pin socket is equipped with 12 ROM Figure 12. The Z8613 Microcomputer Protopack Emulator address lines, 8 ROM data lines and necessary control lines for interface to 2732 EPROM for the first 4K bytes of program memory. Pin compatibility allows the user to design the pc board for a final 40-pin mask-programmed Z8611, and, at the same time, allows the use of the Protopack to build the prototype and pilot production units. When the final program is established, the user can then switch over to the 40-pin mask-programmed Z8611 for large volume production. The Protopack is also useful in small volume applications where masked ROM setup time, mask charges, etc., are prohibitive and program flexibility is desired. Compared to the conventional EPROM versions of the single-chip microcomputers, the Protopack approach offers two main advantages: - Ease of developing various programs during the prototyping stage: For instance, in applications where the same hardware configuration is used with more than one program, the Z8613 Protopack allows economical program storage in separate EPROMs (or PROMs), whereas the use of separate EPROM-based single-chip microcomputers is more costly. - Elimination of long lead time in procuring EPROM-based microcomputers. #### Instruction Set Notation **Addressing Modes.** The following notation is used to describe the addressing modes and instruction operations as shown in the instruction summary. | IRR | Indirect register pair or indirect working-register pair address | |-----|------------------------------------------------------------------| | Irr | Indirect working-register pair only | X Indexed addressDA Direct addressRA Relative address IM ImmediateR Register or working-register address Working-register address only Indirect-register or indirect working-register address Ir Indirect working-register address only RR Register pair or working register pair address **Symbols.** The following symbols are used in describing the instruction set. dst Destination location or contents src Source location or contents cc Condition code (see list) @ Indirect address prefix SP Stack pointer (control registers 254-255) PC Program counter FLAGS Flag register (con FLAGS Flag register (control register 252) RP Register pointer (control register 253) IMR Interrupt mask register (control register 251) Assignment of a value is indicated by the symbol "—". For example, dst - dst + src indicates that the source data is added to the destination data and the result is stored in the destination location. The notation "addr(n)" is used to refer to bit "n" of a given location. For example, dst (7) refers to bit 7 of the destination operand. Instruction Flags. Control Register R252 contains the following Affected flags are indicated by: Set six flags: 0 Cleared to zero Notation 1 С Carry flag Set to one (Continued) Z Zero flag Set or cleared according to operation S Unaffected Sian flag v Undefined Overflow flag X D Decimal-adjust flag Н Half-carry flag | Condition | Value | Mnemonic | Meaning | Flags Set | |-----------|-------|----------|--------------------------------|-------------------------| | Codes | 1000 | | Always true | | | | 0111 | С | Carry | C = 1 | | | 1111 | NC | No carry | C = 0 | | | 0110 | Z | Zero | Z = 1 | | | 1110 | NZ | Not zero | Z = 0 | | | 1101 | PL | Plus | S = 0 | | | 0101 | MI | Minus | S = 1 | | | 0100 | OV | Overflow | V = 1 | | | 1100 | NOV | No overflow | V = 0 | | | 0110 | EQ | Equal | Z = 1 | | | 1110 | NE | Not equal | Z = 0 | | | 1001 | GE | Greater than or equal | (S XOR V) = 0 | | | 0001 | LT | Less than | (S XOR V) = 1 | | | 1010 | GT | Greater than | [Z OR (S XOR V)] = 0 | | | 0010 | LE | Less than or equal | [Z OR (S XOR V)] = 1 | | | 1111 | UGE | Unsigned greater than or equal | C = 0 | | | 0111 | ULT | Unsigned less than | C = 1 | | | 1011 | UGT | Unsigned greater than | (C = 0 AND Z = 0) = 1 | | | 0011 | ULE | Unsigned less than or equal | (C OR Z) = 1 | | | 0000 | | Never true | | # Instruction Formats #### **One-Byte Instructions** Figure 13. Instruction Formats | ADC dst,src dst + dst + src + C ADD dst,src dst - dst + src AND dst,src dst - dst AND src | (Note | | Byte (Hex) | * | Z S | * ( | | and Operation LDE dst,src dst src | | |---------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------|----------------------------|----------------------------------|-----------------------------------------------------------------------------------------------|--------------| | dst + dst + src + C ADD dst,src dst + dst + src AND dst,src | | | | * | * * | * ( | ) * | | 1 | | dst + dst + src AND dst,src | (Note | e l) | 0 | | | | | COL DIC | | | | | | 0 | * | * * | * ( | ) * | LDEI dst,src<br>dst - src | | | | (Note | e 1) | 5□ | - | * * | 0 - | | $\frac{\mathbf{r} - \mathbf{r} + 1; \ \mathbf{rr} - \mathbf{rr} - \mathbf{rr}}{\mathbf{NOP}}$ | + 1 | | CALL dst<br>SP - SP - 2<br>@SP - PC; PC - d | DA<br>IRR<br>lst | | D6<br>D4 | - | | | | OR dst,src<br>dst - dst OR src | | | CCF<br>C - NOT C | | | EF | * | | | | <b>POP</b> dst<br>dst ← @SP<br>SP ← SP + 1 | ] | | CLR dst<br>dst - 0 | R<br>IR | | B0<br>B1 | - | | | | PUSH src<br>SP - SP - 1; @ SP - | – s | | COM dst<br>dst - NOT dst | R<br>IR | | 60<br>61 | - | * * | 0 - | | <b>RCF</b><br>C <b>-</b> 0 | | | CP dst,src<br>dst - src | (Note | ∍ l) | A□ | * | * * | * - | | RET<br>PC - @ SP; SP - S | SP - | | DA dst<br>dst - DA dst | R<br>IR | | 40<br>41 | * | * * | х - | | RL dst | h l | | DEC dst<br>dst - dst - 1 | R<br>IR | | 00<br>01 | - | * * | * - | | RLC dst | <sub>1</sub> | | DECW dst<br>dst dst - 1 | RR<br>IR | | 80<br>81 | - | * * | * - | | RR dst | ր լ | | <b>DI</b> IMR (7) ← 0 | | | 8F | | | | | RRC dst | ا<br>i | | | RĀ | | | | | | | SBC dst,src<br>dst — dst – src – C | ( | | $r \leftarrow r - 1$ if $r \neq 0$ | | | r = 0-F | | | | | <b>SCF</b><br>C - 1 | | | Range: +127, -128 | | | | | | | | SRA dst | ا<br>ا | | <b>EI</b> IMR (7) - 1 | | | 9F | | | | | SRP src<br>RP ← src | | | INC dst<br>dst ← dst + l | r | | rE<br>r=0-F | - | * * | * - | | SUB dst,src<br>dst - dst - src | ( | | | IR | | 21 | | | | | SWAP dst | ] I | | $\frac{dst \leftarrow dst + 1}{}$ | RR<br>IR | | Al | _ | * * | * - | - | TCM dst,src<br>(NOT dst) AND src | ( | | | | | | * ' | * * | * * | * | TM dst, src<br>dst AND src | ( | | <pre>JP cc,dst if cc is true PC ← dst</pre> | DA<br>IRR | | cD<br>c=0-F<br>30 | | | | | XOR dst,src<br>dst dst XOR src | ( | | JR cc,dst if cc is true. | RA | | cB<br>c=0-F | | | | | Note 1 | | | PC ← PC + dst<br>Range: +127, -128 | | | | | | | | These instructions modes, which are e | ncc | | LD dst,src<br>dst src | r<br>r<br>R | Im<br>R<br>r | rC<br>r8<br>r9 | | | | - <del>-</del> | nibble is found in the<br>second nibble is extable, and its value<br>left of the applicable | pre<br>1s f | | | r<br>X<br>r | X<br>r<br>Ir | C7<br>D7<br>E3 | | | | | For example, to dinstruction using the Ir (source) is 13. | | | | R | r<br>R | E4 | | | | | Addr N | lod | | | R<br>IR | Im<br>Im | E6<br>E7 | | | | | dst | sr | | | IR | R | F5 | | | | | r | r | | LDC det erc | | Irr | C2 | | . – | | _ | r | T- | | LDC dst,src<br>dst - src<br>LDCI dst,src | r<br>Irr<br>Ir | Irr<br>r<br>Irr | C2<br>D2<br>C3 | | | | | r<br>R | Ir<br>R | | | C - NOT C CLR dst dst - 0 COM dst dst - NOT dst CP dst,src dst - Src DA dst dst - DA dst DEC dst dst - dst - 1 DI IMR (7) - 0 DINZ r,dst r - r - 1 if r ≠ 0 PC - PC + dst Range: +127, -128 INC dst dst - dst + 1 INC dst dst - dst + 1 INC dst dst - dst + 1 INC dst dst - dst + 1 IRET FLAGS - @ SP; SP PC - @ SP; SP - S IP cc,dst if cc is true PC - dst Range: +127, -128 LD dst,src | C - NOT C CLR dst dst - 0 IR COM dst dst - NOT dst IR CP dst,src dst - PA dst IR DEC dst dst - dst - 1 IR DECW dst dst - dst - 1 IR DI IMR (7) - 0 DINZ r,dst r - r - 1 if r ≠ 0 PC - PC + dst Range: +127, -128 EI INC dst dst - dst + 1 IR INCW dst dst - dst + 1 IR INCW dst dst - dst + 1 IR IR INCW dst dst - dst + 1 IR IR IR IR IR IR IR IR IR I | C - NOT C CLR dst dst - 0 IR COM dst R dst - NOT dst IR CP dst,src dst - P R dst - DA dst IR DEC dst R dst - dst - 1 IR DECW dst R dst - dst - 1 IR DI IMR (7) - 0 DINZ r,dst RA r - r - 1 if r ≠ 0 PC - PC + dst Range: +127, -128 EI INC dst dst - dst + 1 IR INC dst R dst - dst + 1 IR INC H IR INC R IR INC R IR IR IR IR IR IR IR IR IR I | C - NOT C CLR dst dst - 0 IR B0 dst - 0 IR B1 COM dst R 60 ct - NOT dst IR 61 CP dst,src dst - src DA dst R 40 dst - DA dst IR 41 DEC dst R 00 dst - dst - 1 IR 01 DECW dst RR 80 dst - dst - 1 IR 81 DI IMR (7) - 0 8F DINZ r,dst RA rA rA r - r - 1 if r ≠ 0 PC - PC + dst Range: +127, -128 EI INCW dst dst - dst + 1 IR A1 IRET FLAGS - @SP; SP - SP + 1 PC - @SP; SP - SP + 2; IMR (7) - 1 IP co,dst IR RA cB if cc is true, PC - PC + dst Range: +127, -128 LD dst,src r Im rC cs - FR Range: +127, -128 LD dst,src r Im rC cs - FR Range: +127, -128 LD dst,src r Im rC cs - FR Range: +127, -128 LD dst,src r R Ra Range: -127, -128 LD dst,src r -127 | C - NOT C CLR dst dst - 0 | C - NOT C CLR dst dst - 0 | C - NOT C CLR dst dst - 0 IR B0 | C - NOT C CLR dst dst | CCF | | Instruction | Addr | Mode | Opcode | Flags Affected | |---------------------------------------------------|----------------|-----------|---------------|----------------| | and Operation | dst | src | Byte<br>(Hex) | CZSVDH | | LDE dst,src<br>dst - src | r<br>Irr | Irr<br>r | 82<br>92 | | | LDEI dst,src<br>dst ← src<br>r ← r + 1; rr ← rr + | Ir<br>Irr<br>l | Irr<br>Ir | 83<br>93 | | | NOP | | | FF | | | <b>OR</b> dst,src<br>dst ← dst OR src | (Note | e l) | 4□ | - * * 0 | | <b>POP</b> dst<br>dst - @ SP<br>SP - SP + 1 | R<br>IR | | 50<br>51 | | | PUSH src<br>SP - SP - 1; @ SP - | - src | R<br>IR | 70<br>71 | | | <b>RCF</b><br>C <b>-</b> 0 | | | CF | 0 | | RET<br>PC - @SP; SP - S | P + 2 | | AF | | | RL dst | ] R<br>IR | | 90<br>91 | * * * * | | RLC dst | ] R<br>IR | | 10<br>11 | * * * * | | RR dst | R<br>IR | | EO<br>E1 | * * * * | | RRC dst | □ R<br>IR | | C0<br>C1 | * * * * | | SBC dst,src<br>dst - dst - src - C | (Note | 1) | 3□ | * * * * 1 * | | <b>SCF</b> C + 1 | | | DF | 1 | | SRA dst | ] R<br>IR | | D0<br>D1 | * * * 0 | | SRP src<br>RP ← src | | Im | 31 | | | SUB dst,src<br>dst - dst - src | (Note | 1) | 2□ | * * * * 1 * | | SWAP dst 7 43 0 | R<br>IR | | FO<br>Fl | X * * X | | TCM dst,src<br>(NOT dst) AND src | (Note | 1) | 6□ | - * * 0 | | TM dst, src<br>dst AND src | (Note | 1) | 7□ | - * * 0 | | XOR dst,src<br>dst - dst XOR src | (Note | 1) | В□ | - * * 0 | | Note 1 | | | | | have an identical set of addressing coded for brevity. The first opcode e instruction set table above. The ressed symbolically by a $\square$ in this s found in the following table to the addressing mode pair. etermine the opcode of an ADC addressing modes r (destination) and | Addr | Mode | Lower<br>Opcode Nibble | |------|------|------------------------| | dst | src | | | r | r | 2 | | r | Ir | 3 | | R | R | 4 | | R | IR | 5 | | R | IM | 6 | | IR | IM | 7 | Figure 14. Control Registers | Ope | ode | | | | | | | Low | er Nibble | e (Hex) | | | | | | | | |--------------------|-----------------|-----------------------------------------|----------------------------------------|---------------------------------------------------------|-----------------------------------------------------------|--------------------------------------------------------|---------------------------------------------------------|--------------------------------------------|---------------------------------------------|---------------------|----------------------------|----------------------------------------------------------------------------------------------------|-------------------------|----------------------------|--------------------------------|------------------|--------------------| | Maj | , | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | A | В | С | D | E | F | | | 0 | 6, 5<br><b>DEC</b><br>R <sub>1</sub> | 6,5<br>DEC<br>IR <sub>1</sub> | 6, 5<br><b>ADD</b><br>r1, r2 | 6, 5<br><b>ADD</b><br>r <sub>1</sub> , Ir <sub>2</sub> | 10,5<br><b>ADD</b><br>R <sub>2</sub> , R <sub>1</sub> | 10, 5<br><b>ADD</b><br>IR <sub>2</sub> , R <sub>1</sub> | 10, 5<br><b>ADD</b><br>R <sub>1</sub> , IM | 10, 5<br><b>ADD</b><br>IR <sub>1</sub> , IM | 6,5<br>LD<br>r1, R2 | 6,5<br><b>LD</b><br>r2, R1 | 12/10,5<br><b>DJNZ</b><br>r1, RA | 12/10,0<br>JR<br>cc, RA | 6,5<br><b>LD</b><br>r1, IM | 12/10,0<br><b>JP</b><br>cc, DA | 6,5<br>INC<br>r1 | | | | 1 | 6, 5<br><b>RLC</b><br>R <sub>1</sub> | 6,5<br>RLC<br>IR <sub>1</sub> | 6, 5<br><b>ADC</b><br>11, 12 | 6, 5<br><b>ADC</b><br>r <sub>1</sub> , Ir <sub>2</sub> | 10, 5<br><b>ADC</b><br>R <sub>2</sub> , R <sub>1</sub> | 10, 5<br><b>ADC</b><br>IR <sub>2</sub> , R <sub>1</sub> | 10, 5<br><b>ADC</b><br>R <sub>1</sub> , IM | 10,5<br>ADC<br>IR <sub>1</sub> ,IM | | | | | | | | | | | 2 | 6, 5<br>INC<br>R <sub>1</sub> | 6,5<br><b>INC</b><br>IR1 | 6,5<br>SUB<br>r1, r2 | 6, 5<br><b>SUB</b><br>r <sub>1</sub> , Ir <sub>2</sub> | 10, 5<br><b>SUB</b><br>R <sub>2</sub> , R <sub>1</sub> | 10,5<br><b>SUB</b><br>IR <sub>2</sub> , R <sub>1</sub> | 10,5<br><b>SUB</b><br>R <sub>1</sub> , IM | 10, 5<br><b>SUB</b><br>IR 1, IM | | | | | | | | | | | 3 | 8,0<br><b>JP</b><br>IRR <sub>1</sub> | 6, 1<br>SRP<br>IM | 6,5<br><b>SBC</b><br>r <sub>1</sub> , r <sub>2</sub> | 6, 5<br>SBC<br>r1, Ir2 | 10,5<br>SBC<br>R <sub>2</sub> , R <sub>1</sub> | 10, 5<br><b>SBC</b><br>IR <sub>2</sub> , R <sub>1</sub> | 10, 5<br><b>SBC</b><br>R <sub>1</sub> , IM | 10, 5<br><b>SBC</b><br>IR <sub>1</sub> , IM | | | | | | | | | | | 4 | 8,5<br><b>DA</b><br>R <sub>1</sub> | 8,5<br><b>DA</b><br>IR <sub>1</sub> | 6,5<br>OR<br>r1, r2 | 6, 5<br>OR<br>r <sub>1</sub> , Ir <sub>2</sub> | 10, 5<br>OR<br>R <sub>2</sub> , R <sub>1</sub> | 10, 5<br>OR<br>IR <sub>2</sub> , R <sub>1</sub> | 10, 5<br><b>OR</b><br>R <sub>1</sub> , IM | 10,5<br><b>OR</b><br>IR <sub>1</sub> , IM | | | | | | | | | | | 5 | 10, 5<br><b>POP</b><br>R <sub>1</sub> | 10,5<br><b>POP</b><br>IR <sub>1</sub> | 6,5<br>AND<br>r1, r2 | 6, 5<br>AND<br>r1, Ir2 | 10, 5<br><b>AND</b><br>R <sub>2</sub> , R <sub>1</sub> | 10, 5<br><b>AND</b><br>IR <sub>2</sub> , R <sub>1</sub> | 10, 5<br><b>AND</b><br>R <sub>1</sub> , IM | 10,5<br><b>AND</b><br>IR <sub>1</sub> , IM | | | | | | | | | | Jex) | 6 | 6,5<br>COM<br>R <sub>1</sub> | 6,5<br>COM<br>IR <sub>1</sub> | 6,5<br>TCM<br>r1, r2 | 6, 5<br><b>TCM</b><br>r <sub>1</sub> , Ir <sub>2</sub> | 10,5<br>TCM<br>R <sub>2</sub> , R <sub>1</sub> | 10,5<br><b>TCM</b><br>IR <sub>2</sub> , R <sub>1</sub> | 10, 5<br><b>TCM</b><br>R <sub>1</sub> , IM | 10, 5<br><b>TCM</b><br>IR <sub>1</sub> , IM | | | | | | | | | | Upper Nibble (Hex) | 7 | 10/12, 1<br>PUSH<br>R <sub>2</sub> | 12/14, 1<br>PUSH<br>IR <sub>2</sub> | 6,5<br><b>TM</b><br>r <sub>1</sub> , r <sub>2</sub> | 6, 5<br><b>TM</b><br>r1, Ir2 | 10,5<br><b>TM</b><br>R <sub>2</sub> ,R <sub>1</sub> | 10, 5<br><b>TM</b><br>IR <sub>2</sub> , R <sub>1</sub> | 10,5<br><b>TM</b><br>R <sub>1</sub> ,IM | 10,5<br><b>TM</b><br>IR <sub>1</sub> ,IM | | | | | | | | | | Upper N | 8 | 10, 5<br><b>DECW</b><br>RR <sub>1</sub> | 10,5<br><b>DECW</b><br>IR <sub>1</sub> | 12,0<br><b>LDE</b><br>r <sub>1</sub> , Irr <sub>2</sub> | 18, 0<br><b>LDEI</b><br>Ir 1, Irr 2 | | | | | | | | | | | | 6, 1<br><b>DI</b> | | | 9 | 6, 5<br><b>RL</b><br>R <sub>1</sub> | 6,5<br><b>RL</b><br>IR <sub>1</sub> | 12,0<br><b>LDE</b><br>r2, Irr1 | 18,0<br>LDEI<br>Ir2,Irr1 | | | | | | | | | | | | 6, 1<br><b>EI</b> | | | A | 10,5<br>INCW<br>RR <sub>1</sub> | 10,5<br>INCW<br>IR <sub>1</sub> | 6, 5<br><b>CP</b><br>r1, r2 | 6, 5<br><b>CP</b><br>r <sub>1</sub> , Ir <sub>2</sub> | 10, 5<br>CP<br>R <sub>2</sub> , R <sub>1</sub> | 10, 5<br><b>CP</b><br>IR <sub>2</sub> , R <sub>1</sub> | 10,5<br><b>CP</b><br>R <sub>1</sub> ,IM | 10,5<br><b>CP</b><br>IR <sub>1</sub> ,IM | | | | | | | | 14,0<br><b>RET</b> | | | В | 6, 5<br><b>CLR</b><br>R <sub>1</sub> | 6,5<br>CLR<br>IR <sub>1</sub> | 6,5<br><b>XOR</b><br>r <sub>1</sub> , r <sub>2</sub> | 6, 5<br><b>XOR</b><br>r <sub>1</sub> , Ir <sub>2</sub> | 10,5<br><b>XOR</b><br>R <sub>2</sub> , R <sub>1</sub> | 10, 5<br><b>XOR</b><br>IR <sub>2</sub> , R <sub>1</sub> | 10,5<br><b>XOR</b><br>R <sub>1</sub> , IM | 10,5<br><b>XOR</b><br>IR <sub>1</sub> ,IM | | | | | | | | 16, 0<br>IRE: | | | С | 6, 5<br>RRC<br>R <sub>1</sub> | 6,5<br>RRC<br>IR <sub>1</sub> | 12,0<br><b>LDC</b><br>r <sub>1</sub> , Irr <sub>2</sub> | 18,0<br><b>LDCI</b><br>Ir <sub>1</sub> , Irr <sub>2</sub> | | | | 10,5<br><b>LD</b><br>r1, x, R2 | | | | | | | | 6, 5<br>RCF | | | D | 6,5<br><b>SRA</b><br>R <sub>1</sub> | 6,5<br><b>SRA</b><br>IR <sub>1</sub> | 12,0<br>LDC<br>r2, Irr1 | 18,0<br>LDCI<br>Ir2, Irr1 | 20,0<br>CALL*<br>IRR1 | | 20,0<br>CALL<br>DA | 10,5<br><b>LD</b><br>12, x, R1 | | | | | | | | 6, 5<br><b>SCF</b> | | | E | 6,5<br><b>RR</b><br>R <sub>1</sub> | 6,5<br><b>RR</b><br>IR <sub>1</sub> | | 6, 5<br><b>LD</b><br>r1, Ir2 | 10, 5<br><b>LD</b><br>R <sub>2</sub> , R <sub>1</sub> | 10, 5<br><b>LD</b><br>IR <sub>2</sub> , R <sub>1</sub> | 10, 5<br><b>LD</b><br>R <sub>1</sub> , IM | 10,5<br><b>LD</b><br>IR <sub>1</sub> ,IM | | | | | | | | 6, 5<br>CCF | | | F | 8,5<br><b>SWAP</b><br>R <sub>1</sub> | 8,5<br>SWAP<br>IR <sub>1</sub> | | 6, 5<br>LD<br>Ir1, r2 | | 10, 5<br><b>LD</b><br>R <sub>2</sub> , IR <sub>1</sub> | | | | | | | | | | 6,0<br><b>NO</b> F | | | | | | | | | | | | | | ~ | | | _ | | <del>-</del> | | | s per<br>uction | 1 | 2 | 2 | Lower<br>Opcod | e | Š | 3 | | | | 2 | | | 3 | | 1 | | | | | | cution<br>Cycles | \<br>\<br>\<br>\ | Pip | eline<br>:les | | | | | <b>Legend:</b><br>R = 8-Bit | | | | | | | | | | Upper<br>Opcode -<br>Nibble | <b>→</b> A | 10, 5<br><b>CP</b><br>R <sub>2</sub> , R <sub>1</sub> | | nemonic | : | | | | r = 8-bit<br>r = 4-Bit<br>R <sub>1</sub> or r <sub>1</sub> =<br>R <sub>2</sub> or r <sub>2</sub> = | Address<br>Dst Add | | | | | | | | | | First | <del>/</del> | Sec | ond | | | | | <b>Sequenc</b><br>Opcode, | | perand, | Second ( | Operand | l | | | | | Op | erand | | Op | erand | | | | | Note: Th | ne blank | areas ar | e not def | ined. | | <sup>\*2-</sup>byte instruction; fetch cycle appears as a 3-byte instruction | Absolute<br>Maximum<br>Ratings | Voltages on all pins with respect to GND0.3 V to +7.0 V Operating Ambient TemperatureSee Ordering Information | |--------------------------------|----------------------------------------------------------------------------------------------------------------| | | Storage Temperature65°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 characteristics below apply for the following standard test conditions, unless otherwise noted. All voltages are referenced to GND. Positive current flows into the reference pin. Standard conditions are as follows: $\Box$ +4.75 V $\leq$ V $_{\rm CC}$ $\leq$ +5.25 V $\square$ GND = 0 V $\square \ 0^{\circ}\text{C} \leq T_{\text{A}} \leq +70^{\circ}\text{C}^{\star}$ \*See Ordering Information section for package temperature range and product number. Figure 15. Test Load 1 Figure 16. Test Load 2 Figure 17. External Clock Interface Circuit | DC | |------------| | Character- | | istics | | | | Symb | ol Parameter | meter Min Max | | Unit | Condition | Notes | |----------------------------|--------------------------------|---------------|----------|------|---------------------------------------------------------------|-------| | V <sub>CH</sub> | Clock Input High Voltage | 3.8 | $v_{cc}$ | V | Driven by External Clock Generator | | | $v_{CL}$ | Clock Input Low Voltage | -0.3 | 0.8 | V | Driven by External Clock Generator | | | $\overline{v_{IH}}$ | Input High Voltage | 2.0 | $V_{CC}$ | V | | | | $\overline{v_{\text{IL}}}$ | Input Low Voltage | -0.3 | 0.8 | V | | | | $v_{RH}$ | Reset Input High Voltage | 3.8 | $v_{cc}$ | V | | | | $\overline{v_{RL}}$ | Reset Input Low Voltage | -0.3 | 0.8 | V | | | | $v_{OH}$ | Output High Voltage | 2.4 | | V | $I_{OH} = -250 \mu\text{A}$ | 1 | | V <sub>OL</sub> , | Output Low Voltage | | 0.4 | V | $I_{OL} = +2.0 \text{ mA}$ | 1 | | $I_{IL}$ | Input Leakage | -10 | 10 | μΑ | $0 \text{ V} \leq \text{ V}_{\text{IN}} \leq +5.25 \text{ V}$ | | | I <sub>OL</sub> | Output Leakage | -10 | 10 | μΑ | $0 \text{ V} \leq \text{ V}_{\text{IN}} \leq +5.25 \text{ V}$ | | | I <sub>IR</sub> | Reset Input Current | | -50 | μΑ | $V_{CC} = +5.25 \text{ V}, V_{RL} = 0 \text{ V}$ | | | $\overline{I_{CC}}$ | V <sub>CC</sub> Supply Current | | 180 | mA | | | | I <sub>MM</sub> | V <sub>MM</sub> Supply Current | | 10 | mA | Power Down Mode | | | V <sub>MM</sub> | Backup Supply Voltage | 3 | $v_{cc}$ | V | Power Down | | <sup>1</sup> For A<sub>0</sub>-A<sub>11</sub>, $\overline{\text{MDS}}$ , $\overline{\text{SYNC}}$ , SCLK and IACK on the Z8612 version, $I_{OH} = -100~\mu\text{A}$ and $I_{OL} = 1.0~\text{mA}$ . | External I/O | |--------------| | or Memory | | Read and | | Write Timing | | Number | Symbol | Parameter | Min | Мах | Unit | Notes† | |----------|--------------|---------------------------------------------------|----------------------------|-----|----------|-----------------------------| | 1 | TdA(AS) | Address Valid to Address Strobe Delay | 50 | | ns | 1,2 | | 2 | TdAS(A) | Address Strobe to Address Float Delay | 70 | | ns | 1,2 | | 3 | TdAS(DI) | Address Strobe to Data In Valid Delay | | 360 | ns | 1,4 | | 4 | TwAS | Address Strobe Width | 80 | | ns | 1,2 | | 5 | - TdA(D\$) | – Address Float to Data Strobe Delay —— | <del></del> 0 | | ns | — 1 — | | 6a<br>6b | TwDS<br>TwDS | Data Strobe Width Read<br>Data Strobe Width Write | 250<br>160 | | ns<br>ns | 1,3<br>1,3 | | 7 | TdDS(DI) | Data Strobe to Data In Valid Delay | | 200 | ns | 1,4 | | 8 | ThDS(DI) | Data In Hold Time | 0 | | ns | | | 9 | - TdDS(A) | – Data Strobe to Address Change Delay — | <del></del> 80 <del></del> | | ns | <del></del> 1,2 <del></del> | | 10 | TdDS(AS) | Data Strobe to Address Strobe Delay | 70 | | ns | 1,2 | | 11 | TdR(AS) | Read Valid to Address Strobe Delay | 50 | | ns | 1,2 | | 12 | TdDS(R) | Data Strobe to Read Change Delay | 60 | | ns | 1,2 | | 13 | TdDO(DS) | Data Out Valid to Data Strobe Delay | 50 | | ns | 1,2 | | 14 | - TdDS(DO) - | -Data Strobe to Data Out Change Delay - | — 80 — | | ns | <del></del> 1,2 <del></del> | | 15 | TdW(AS) | Write Valid to Address Strobe Delay | 50 | | ns | 1,2 | | 16 | TdDS(W) | Data Strobe to Write Change Delay | 60 | | ns | 1,2 | #### NOTES: - † All units in nanoseconds (ns). - 1. Test Load 1. - Delay times given are for an 8 MHz crystal input frequency. For lower frequencies, the change in clock period must be added to the delay time, - Data Strobe Width is given for an 8 MHz crystal input frequency. For lower frequencies the change in three clock periods must be added to obtain the minimum width. The Data Strobe Width varies according to the instruction being executed. - 4. Address Strobe and Data Strobe to Data In Valid delay times represent memory system access times and are given for an 8 MHz crystal input frequency. For lower frequencies; the change in four clock periods must be added to TdAS(DI) and the change in three clock periods added to TdDS(DI). - 5. All timing references assume 2.0 V for a logic "l" and 0.8 V for a logic "0." | Additional<br>Timing | Number | Symbol | Parameter | Min | Мах | Unit | Notes | |----------------------|--------|-------------|-----------------------------------------------------------------|----------------------------------------|------|------|------------------| | Table | 1 | TpC | Input Clock Period | 125 | 1000 | ns | | | | 2 | TrC, TfC | Input Clock Rise and<br>Fall Times | | 25 | ns | 3 | | | 3 | TwC | Input Clock Width | 37 | | ns | 3 | | | 4 | - TdSC(AS)- | System Clock Out to Address ——————————————————————————————————— | ······································ | | ns | — 1 <del>–</del> | | | 5 | TdSY(DS) | Instruction Sync Out to Data<br>Strobe Delay Time | 200 | | ns | 1,2 | | | 6 | TwSY | Instruction Sync Out Width | 160 | | ns | 1, 2 | | | 7 | TwI | Interrupt Request via<br>Port 3 Input Width | 100 | | ns | | #### NOTES - 1 Test Conditions use Test Load 1 for SCLK when output through the Port 3 pins and Test Load 2 on the SCLK and SYNC direct outputs on Z8612 - 2 Times given assume an 8 MHz crystal input frequency For lower frequencies, the change in two clock periods must be added - 3 From external clock generator - 4 All timing references assume 2 0 V for a logic "1" and 0 8 V for a logic "0" | Handshake<br>Fiming | Number | Symbol | Parameter | Min | Мах | Unit | Notes | |---------------------|----------|-----------|-----------------------------------------------------------------------------|---------|-----|----------|-------------| | iming | 1 | TsDI(DA) | Data In Setup Time | 0 | | ns | | | | 2 | ThDA(DI) | Data In Hold Time | 230 | | ns | | | | 3 | TwDA | Data Available Width | 175 | | ns | 1,2 | | | 4a<br>4b | TdDAL(RY) | Data Available Low to Ready —Delay Time———————————————————————————————————— | 20<br>0 | 175 | ns<br>ns | 1,2<br>1,3- | | | 5a<br>5b | TdDAH(RY) | Data Available High to Ready<br>Delay Time | 0 | 150 | ns<br>ns | 1,2<br>1,3 | | | 6 | TdDO(DA) | Data Out to Data Available<br>Delay Time | 50 | | ns | 1 | | | 7 | TdRY(DA) | Ready to Data Available Delay Time | 0 | 205 | ns | 1 | #### NOTES. - 1. Test Load 1 2. Input Handshake 3. Output Handshake #### Input Handshake #### Output Handshake #### Z8612, Z8613 **Memory Port** Timing | Number | Symbol | Parameter | Min | Мах | Unit | Notes | |--------|---------|----------------------------------------------|-----|-----|------|-------| | 1 | TdA(DI) | Address Valid to Data In<br>Valid Delay Time | | 460 | ns | 1 | | 2 | ThDI(A) | Data in Hold Time | 0 | | ns | | - NOTES. 1 Test Load 2 2 Delay times are specified for an input clock frequency of 8 MHz 3. All timing references assume 2 0 V for a logic "1" and 0.8 V for a logic "0" 2037-018, 019 464 | Ordering<br>Information | Product<br>Number | Package/<br>Temp | Speed | Description | Product<br>Number | Package<br>Temp | /<br>Speed | Description | |-------------------------|-------------------|------------------|---------|----------------------------|-------------------|-----------------|------------|--------------------------------| | | Z8611 | CE | 8.0 MHz | Z8 MCU<br>(4K ROM, 40-pin) | Z8612 | QE | 8.0 MHz | Z8 MCU<br>(4K XROM, | | | Z8611 | CS | 8.0 MHz | Same as above | | | | 64-pin) | | | Z8611 | DE | 8.0 MHz | Same as above | Z8612 | QS | 8.0 MHz | Same as above | | | Z8611 | DS | 8.0 MHz | Same as above | Z8613 | RS | 8.0 MHz | Z8 MCU | | | Z8611 | PE | 8.0 MHz | Same as above | | | | (4K XROM,<br>Prototype Device, | | | Z8611 | PS | 8.0 MHz | Same as above | | | | 40-pin) | NOTES: C = Ceramic, D = Cerdip, P = Plastic, Q = Quip, R = Protopack; E = $-40^{\circ}$ C to $+85^{\circ}$ C, S = $0^{\circ}$ C to $+70^{\circ}$ C. # Z8° Family Z8671 Microcomputer BASIC/Debug Interpreter ## Product Brief #### June 1982 #### Features - The Z8671 MCU is a complete microcomputer preprogrammed with a BASIC/ Debug interpreter. Interaction between the interpreter and its user is provided through an on-board UART. - BASIC/Debug can directly address the Z8671's internal registers and all external memory. It provides quick examination and modification of any external memory location or I/O port. - The BASIC/Debug interpreter can call machine language subroutines to increase execution speed. - The Z8671's auto start-up capability allows a program to be executed on power-up or Reset without operator intervention. - Single +5 V power supply—all pins TTL-compatible. #### Description The Z8671 Single-Chip Microcomputer (MCU) is one of a line of preprogrammed chips—in this case with a BASIC/Debug interpreter in ROM—offered by Zilog. As a member of the Z8 Family of microcomputers, it offers the same abundance of resources as the other Z8 microcomputers. Because the BASIC/Debug interpreter is already part of the chip circuit, programming is made much easier. The Z8671 MCU thus offers a combination of software and hardware that is ideal for most industrial control appli- cations. The Z8671 MCU allows fast hardware tests, and bit-by-bit examination and modification of any memory location, I/O port, or register. It also allows bit manipulation and logical operations. A self-contained line editor supports interactive debugging, further speeding up program development. The BASIC/Debug interpreter, a subset of Dartmouth BASIC, operates with two kinds of memory: on-chip registers and external ROM or RAM. The BASIC/Debug interpreter is located in the 2K bytes of on-chip ROM. Figure 1. Pin Functions Figure 2. Pin Assignments 2150-001, 002 | Description (Continued) | Addincture subrothe at on pointerv | or of data memory with program ining at location 800 hex. This to 124K bytes of useable memory ew 8-bit microcomputers can sthis amount of memory. Microcomputer has 24 I/O lines, pister file, an on-board UART, er/timers. | | | | | | |-------------------------|------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|----------------------------------------------------------------------------------------------------|--|--|--| | Language | The | e following listing represents all the | | expressions a,b. | | | | | Capabilities | stater | essions, operators, functions, and<br>ments that can be used with the<br>C/Debug interpreter. | USR (a,b,c) | Calls an assembly language routine at address a. The expressions b,c may be used to | | | | | | Expre | essions: | | pass arguments to the routine. | | | | | | Varia | ble Names A-Z | | The assembly language routine | | | | | | Signe<br>to +3 | ed decimal numbers in the range –32768<br>32767 | Statements: | must return a value. | | | | | | | decimal numbers (preceded by ''%'') in ange 0 to 65535 | GO@ | Branches to an assembly language routine. This statem | | | | | | Oper | ators: | | is similar to USR except no value is returned by the | | | | | | Relati | ional Operators: | | assembly language routine. | | | | | | = | equal | GOSUB | Calls a subroutine at line | | | | | | <= | less than or equal | | number. | | | | | | < | less than | GOTO | Branches to a line number. | | | | | | <> | not equal | IF/THEN | Used for conditional operations and branches. | | | | | | > | greater than | INPUT | | | | | | | >= | greater than or equal | INPUI | Inputs expressions separated by commas. | | | | | | Arith | metic Operators: | IN | Same as INPUT except values | | | | | | + | addition | | remaining in the input buffer | | | | | | - | subtraction | | are used first, then new data is | | | | | | * | multiplication | TET | requested. | | | | | | / | division | LET | Assigns the value of an expression to a variable or memory | | | | | | \ | unsigned division | | location. | | | | | | Memo | ory Operators: | LIST | Lists the current program. | | | | | | @ | Any byte may be referenced by placing the byte signal character "@" | NEW | Establishes a new start-of-<br>program address. | | | | | | | in front of the address. For example,<br>LET $X = @ \%1000$ assigns the<br>value at address $\%1000$ to $X$ .<br>LET $@ (C*100) = A$ assigns the value | PRINT | Lists its arguments, which may<br>be text messages or numerical<br>values, on the output terminal. | | | | | | | of A to the byte at address ( $C*100$ ). | REM | Used to insert comments. | | | | | | † | Sixteen-bit words may be referenced with an address preceded | RETURN | Returns control to line following GOSUB statement. | | | | | | | by the word signal character "1". For example, PRINT 118 will print the sixteen-bit value pointed to by the contents of the word at location 8. | RUN | Initiates sequential execution of all instructions in current program. | | | | | | | torres or the work at location o. | STOP | Gracefully ends program | | | | STOP 00-2150-01 Gracefully ends program execution. Functions: AND (a,b) Performs a logical AND of the # Z8° Family Z8681 Microcomputer ## Product Brief June 1982 #### **Features** "ROMless" version of the Z8601 single-chip microcomputer, capable of addressing up to 128K bytes of external memory space. - \_\_\_\_ - 40-pin package, single +5 V supply, all pins TTL compatible. ■ Up to 24 programmable I/O lines. #### General Description The Z8681 MCU is the "ROMless" version of the Z8601 single-chip microcomputer and offers all the outstanding features of the Z8 Family architecture. Using the Z8681, it is possible to design a powerful microprocessor system incorporating a minimum number of support devices. Port 1 is configured to function as a multiplexed Address/Data bus $(AD_0-AD_7)$ , while Port 0 is software configurable to output address bits $A_8-A_{15}$ . This provides for program memory and data memory space of up to 64K bytes each. Located on-chip are 144 bytes of RAM, organized as a register file of 124 general-purpose registers, 16 control and status registers, and three I/O port registers. (Port 1 cannot be utilized as an I/O register.) This file is divided into groups of working registers in such a way that short format instructions may be used to quickly access a register within a certain group. #### Functional Description Register File. The internal register organization of the Z8681 centers around a 144-byte random-access register file composed of 124 general-purpose registers, 16 control registers, and the three I/O port registers. Any general-purpose register can be an accumulator, address pointer, index register, or part of the internal stack. The register file is divided into nine groups of 16 working registers. A register pointer uses short-format instructions to quickly access any one of the nine groups, resulting in fast and easy task-switching. I/O Ports. The I/O ports (Ports 0, 2, and 3) are software configurable as input, output, or additional address lines. These ports can also provide timing, status signals, and serial or parallel I/O (with or without handshake). I/O port space is mapped into the register file, creating an efficient and convenient means of moving data. Figure 1. Pin Functions Figure 2. Pin Assignments # Functional Description (Continued) **Interrupts.** The Z8681 can respond to six separate interrupts from eight sources. The interrupts are maskable and prioritized by software control, thus allowing greater design flexibility. Using vectored interrupts, control is automatically passed to the appropriate service routine. The interrupts are organized as four external lines and four internal status signals. The internal interrupts control the serial port handshake and the two counter/timers. **UART.** The Z8681 also offers the serial I/O capability of interfacing to asynchronous data communications. The on-chip counter (T0) is used to supply the baud rate for the serial data transfer. The UART is capable of transferring data at a rate of up to 62.5K b/s. Counter/Timers. Also on-chip are two 8-bit programmable counter/timers (T0 and T1), each driven by its own 6-bit programmable prescaler. Both counter/timers can operate independently of the processor instruction sequence, thereby unburdening the program from such time-critical operations as event-counting or elapsed-time calculations. The counters can be started, stopped, continued, or restarted from the initial value by program control. #### Instruction Set for the Z8681 The basic instruction set for the Z8681 consists of 47 instruction types and utilizes seven addressing modes. The instructions can operate on several types of data elements, including individual bits, 4-bit BCD characters, bytes, or words. All 124 general-purpose registers can be used as accumulators, address pointers, index registers, or as internal stack, resulting in fast data manipulation for real-time applications. The internal pipelining of instructions dramatically increases throughput by allowing instruction fetches during the previous instruction execution cycles. #### Z8681 Applications The Z8681 is a Z-BUS-compatible device and can be interfaced to various Z-BUS peripherals such as the Z-CIO, Z-SCC, or FIO. Que to the flexibility of Port 0 and the data memory select feature, the Z8681 can also support a great variety of memory configurations. Figures 3 and 4 illustrate two design approaches using the Z8681. Figure 3. Z8681 Interfacing to External Memory # Z8681 Applications (Continued) Figure 4. Z8681 Interfacing to Memory-Mapped I/O | Ordering<br>Information | Product<br>Number | Package/<br>Temp | Speed | Description | Product<br>Number | Package/<br>Temp | Speed | Description | |-------------------------|-------------------|------------------|---------|----------------------------|-------------------|------------------|---------|-----------------------------| | | Z8681 | CE | 8.0 MHz | Z8 MCU<br>(ROMless, 40-pm) | Z8681 | DS | 8.0 MHz | Z8 MCU<br>(ROMless, 40-pin) | | | Z8681 | CS | 8.0 MHz | Same as above | Z8681 | PE | 8.0 MHz | Same as above | | | Z8681 | DE | 8.0 MHz | Same as above | Z8681 | PS | 8.0 MHz | Same as above | NOTES C = Ceramic, D = Cerdip, P = Plastic, E = -40°C to +85°C, S = 0°C to +70°C. 2040-004 00-2040-A | | a a | |--|-----| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | # Additional Information Zilog # **Z-BUS® Component Interconnect** ### **Summary** #### June 1982 #### Features - Multiplexed address/data bus shared by memory and I/O transfers. - 16 or more memory address bits; 16-bit I/O addresses; 8 or 16 data bits. - Supports polling and vectored or nonvectored interrupts. - Daisy-chain interrupt structure services interrupts without a separate priority controller. - Direct addressing of registers within a peripheral facilitates I/O programming. - Bus signals allow asynchronous CPU and peripheral clocks. - Daisy-chain bus-request structure supports distributed control of the bus. - Shared resources can be managed by a general-purpose, distributed resourcerequest mechanism. #### General Description The Z-BUS is a high-speed parallel shared bus that links components of the Z8000 Family. It provides family members with a common communication interface that supports the following kinds of interactions: - Data Transfer. Data can be moved between bus controllers (such as a CPU) and memories or peripherals. - Interrupts. Interrupts can be generated by peripherals and serviced by CPUs over - Resource Control. Distributed management of shared resources (including the bus itself) is supported by a daisy-chain priority mechanism. The heart of the Z-BUS is a set of multiplexed address/data lines and the signals that control these lines. Multiplexing data and addresses onto the same lines makes more efficient use of pins and facilitates expansion of the number of data and address bits. Multiplexing also allows straightforward addressing of a peripheral's internal registers, which greatly simplifies I/O programming. A daisy-chained priority mechanism resolves interrupt and resource requests, thus allowing distributed control of the bus and eliminating the need for separate priority controllers. The resource-control daisy chain allows wide physical separation of components. The Z-BUS is asynchronous in the sense that peripherals do not need to be synchronized with the CPU clock. All timing information is provided by Z-BUS signals. Figure 1. Z-BUS Signals #### Z-BUS Components A Z-BUS component is one that uses Z-BUS signals and protocols, and meets the specified ac and dc characteristics. Most components in the Z8000 Family are Z-BUS components. The four categories of Z-BUS components are as follows: **CPUs.** A Z-BUS system contains one CPU, and this CPU has default control of the bus and typically initiates most bus transactions. Besides generating bus transactions, it handles interrupt and bus-control requests. The Z8001 Segmented CPU and Z8002 Non-Segmented CPU are Z-BUS CPUs. **Peripherals.** A Z-BUS peripheral is a component capable of responding to I/O transactions and generating interrupt requests. The Z8036 Counter Input/Output Circuit (Z-CIO), Z8038 FIFO Input/Output, Interface Unit (Z-FIO), the Z8030 Serial Communication Controller (Z-SCC), the Z8090 Universal Peripheral Controller (Z-UPC), and the Z8052 CRT Controller (Z-CRT) are all Z-BUS peripherals. **Requesters.** A Z-BUS requester is any component capable of requesting control of the bus and initiating transactions on the bus. A Z-BUS requester is usually also a peripheral. The *Z8016 DMA Transfer Controller (Z-DTC)* is a Z-BUS requester and a peripheral. **Memories.** A Z-BUS memory is one that interfaces directly to the Z-BUS and is capable of fetching and storing data in response to Z-BUS memory transactions. The *Z6132 Quasi-Static RAM* is a Z-BUS memory. #### Other Components The Z8 Microcomputer—in its microprocessor configuration—conforms to Z-BUS timing (which allows it to use Z-BUS peripherals and memories), but is missing a wait input and certain status outputs. The Z8010 Memory Management Unit (Z-MMU) is a Z8000 CPU support component that interfaces with part of the Z-BUS on the CPU side and provides demultiplexed addresses on the memory side. The Z8060 First-In-First-Out Buffer (Z-FIFO) is not a Z-BUS component; rather, it is used to expand the buffer depth of the Z-FIO or to interface the I/O ports of the Z-UPC, Z-CIO, or Z-FIO to user equipment. Z-80 Family components, while not Z-BUS compatible, are easily interfaced to Z-BUS CPUs. #### Operation Two kinds of operations can occur on the Z-BUS: transactions and requests. At any given time, one device (either the CPU or a bus requester) has control of the Z-BUS and is known as the bus master. A transaction is initiated by a bus master and is responded to by some other device on the bus. Four kinds of transactions occur in Z-BUS systems: - *Memory*. Transfers 8 or 16 bits of data to or from a memory location. - *I/O*. Transfers 8 or 16 bits of data to or from a peripheral. - Interrupt Acknowledge. Acknowledges an interrupt and transfers an identification/status vector from the interrupting peripheral. - *Null*. Does not transfer data. Typically used for refreshing memory. Only one transaction can proceed on the bus at a time, and it must be initiated by the bus master. A request, however, may be initiated by a component that does not have control of the bus. There are three kinds of requests: - *Interrupt*. Requests the attention of the Z-BUS CPU. - Bus. Requests control of the Z-BUS to initiate transactions. - Resource. Requests control of a particular resource. When a request is made, it is answered according to its type: for interrupt requests an interrupt-acknowledge transaction is initiated; for bus and resource requests an acknowledge signal is sent. In all cases a daisy-chain priority mechanism provides arbitration between simultaneous requests. #### Signal Lines The Z-BUS consists of a set of common signal lines that interconnect bus components (Figure 1). The signals on these lines can be grouped into four catagories, depending on how they are used in transactions and requests. **Primary Signals.** These signals provide timing, control, and data transfer for Z-BUS transactions. $AD_0$ - $AD_{15}$ . Address/Data (active High). These multiplexed data and address lines carry I/O addresses, memory addresses, and data during Z-BUS transactions. A Z-BUS may have 8 or 16 bits of data depending on the type of CPU. In the case of an 8-bit Z-BUS, data is transferred on $AD_0$ - $AD_7$ . Extended Address. (active High). These lines extend AD<sub>0</sub>-AD<sub>15</sub> to support memory addresses greater than 16 bits. The number of lines and the type of address information carried is dependent on the CPU. Status. (active High). These lines designate the kind of transaction occurring on the bus and certain additional information about the transaction (such as program or data memory access or System versus Normal Mode). $\overline{AS}$ . Address Strobe (active Low). The rising edge of $\overline{AS}$ indicates the beginning of a transaction and that the Address, Status, $R/\overline{W}$ , and $B/\overline{W}$ signals are valid. $\overline{DS}$ . Data Strobe (active Low). $\overline{DS}$ provides timing for data movement to or from the bus master. $R/\overline{W}$ . Read/Write (Low = write). This signal determines the direction of data transfer for memory or I/O transactions. $B/\overline{W}$ . Byte/Word (Low = word). This signal indicates whether a byte or word of data is to be transmitted on a 16-bit bus. This signal is not present on an 8-bit bus. **WAIT**. (active Low). A Low on this line indicates that the responding device needs more time to complete a transaction. RESET. (active Low). A Low on this line resets the CPU and bus users. Peripherals may be reset by RESET or by holding AS and DS Low simultaneously. $\overline{CS}$ . Chip Select (active Low). Each peripheral or memory component has a $\overline{CS}$ line that is decoded from the address and status lines. A Low on this line indicates that the peripheral or memory component is being addressed by a transaction. The Chip Select information is latched on the rising edge of $\overline{AS}$ . Bus Request Signαls. These signals make bus requests and establish which component should obtain control of the bus. **BUSREQ.** Bus Request (active Low). This line is driven by all bus requesters. A Low indicates that a bus requester has or is trying to obtain control of the bus. <u>BUSACK</u>. Bus Acknowledge (active Low). A Low on this line indicates that the Z-BUS CPU has relinquished control of the bus in response to a bus request. BAI, BAO. Bus Acknowledge In, Bus Acknowledge Out (active Low). These signals form the bus-request daisy chain. #### Z-BUS Connections | Signal | CPU | Requester | Peripheral | Memory | |----------------------------------------------------|---------------------------------------|---------------------------------------|---------------------------------------|---------------------------------------| | <b>A</b> D <sub>0</sub> - <b>A</b> D <sub>15</sub> | Bidirectional <sup>2</sup><br>3-state | Bidirectional <sup>2</sup><br>3-state | Bidirectional <sup>1</sup><br>3-state | Bidirectional <sup>2</sup><br>3-state | | Extended<br>Address <sup>8</sup> | Output<br>3-state | Output<br>3-state | | Input | | Status | Output<br>3-state | Output<br>3-state | $Input^{10}$ | | | $R/\overline{\overline{W}}$ | Output<br>3-state | Output<br>3-state | Input | Input | | <b>B</b> / <del>W</del> 9 | Output | Output — | Input <sup>3</sup> | Input | | WAIT | Input | Input | Output <sup>8</sup><br>Open Drain | Output <sup>8</sup><br>Open Drain | | ĀS | Output<br>3-state | Output<br>3-state | Input | Input | | DS | Output<br>3-state | Output<br>3-state | Input | Input | | CS <sup>4</sup> | | | Input | Input | | RESET - | Input | Input13 | Input <sup>5</sup> | | | BUSREQ | Input | Bidırectional<br>Open Drain | | | | BUSACK | Output | | | | | BAI <sup>7</sup> | | Input | | | | BAO7 | | Output —— | | | | INT | Input | | Output<br>Open Drain | | | INTACK6 | | | Inputl1 | | | IEI <sup>7</sup> | | | Input | | | IEO <sup>7</sup> | | | Output | | | MMRQ 12 | Output<br>Open Drain | | | | | MMST12 | Input | | | | | MMAI7, 12 | Input | | | | | MMAO7, 12 | Output | | | | <sup>1.</sup> Only AD<sub>0</sub>-AD<sub>7</sub>, unless peripheral is 16-Bit. - 8. Optional signal(s). - 9. For 16-bit data bus only. - Optional—usually only input on peripherals that are also requesters. - 11. May be omitted if peripheral inputs status lines. - Optional signal; any component may attach to the resource request lines. - Optional signal; a bus requestor may also be reset by AS and DS going Low and BAI being High simultaneously. - $\hfill\square$ No Connection **Table 1. Z-BUS Component Connections to Signal Lines.** This table shows how the various Z-BUS components attach to each signal line. When a device is both a bus requester and a peripheral, the attributes in both columns of the table should be combined (e.g., input combined with output and 3-state becomes bidirectional and 3-state.) <sup>2.</sup> For an 8-bit bus, only AD<sub>0</sub>-AD<sub>7</sub> are bidirectional. Only for a 16-bit peripheral. <sup>4.</sup> Derived signal, one for each peripheral or memory; decoded from status and address lines. Optional—peripherals are typically reset by AS and DS being Low simultaneously, however, they can have a reset input. <sup>6.</sup> Derived signal; decoded from status lines. <sup>7.</sup> Daisy-chain lines. #### Signal Lines (Continued) Interrupt Signals. These signals are used for interrupt requests and for determining which interrupting component is to respond to an acknowledge. To support more than one type of interrupt, the lines carrying these signals can be replicated. (The Z8000 CPU supports three types of interrupts: non-maskable, vectored, and non-vectored.) *INT. Interrupt (active Low)*. This signal can be driven by any peripheral capable of generating an interrupt. A Low on INT indicates that an interrupt request is being made. INTACK. Interrupt Acknowledge (active Low). This signal is decoded from the status lines. A Low indicates an interrupt acknowledge transaction is in progress. This signal is latched by the peripheral on the rising edge of $\overline{\rm AS}$ . IEI, IEO. Interrupt Enable In, Interrupt Enable Out (active High). These signals form the interrupt daisy chain. **Resource Request Signals.** These signals are used for resource requests. To manage more than one resource, the lines carrying these signals can be replicated. (The Z8000 supports one set of resource request lines.) MMRQ. Multi-Micro Request (active Low). This line is driven by any device that can use the shared resource. A Low indicates that a request for the resource has been made or granted. MMST. Multi-Micro Status (active Low). This pin allows a device to observe the value of the MMRQ line. An input pin other than MMRQ facilitates the use of line drivers for MMRQ. MMAI, MMAO. Multi-Micro Acknowledge In, Multi-Micro Acknowledge Out (active Low). These lines form the resource-request daisy chain. #### Transactions All transactions start with Address Strobe being driven Low and then raised High by the bus master (Figure 2). The Status lines are valid on the rising edge of Address Strobe and indicate the type of transactions being initiated. If the transaction requires an address, it must also be valid on the rising edge of Address Strobe. For all transactions except null transactions (which do nothing beyond this point), data is then transferred to or from the bus master. The bus master uses Data Strobe to time the movement of data. For a read $(R/\overline{W} = High)$ , the bus master makes $AD_0$ – $AD_{15}$ inactive before driving Data Strobe Low so that the addressed memory or peripheral can put its data on the bus. The bus master samples this data just before raising Data Strobe High. For a write ( $R/\overline{W} = Low$ ), the bus master puts the data to be written on $AD_0$ – $AD_{15}$ before forcing Data Strobe Low. For an 8-bit Z-BUS, data is transferred on AD<sub>0</sub>–AD<sub>7</sub>. Address bits may remain on AD<sub>8</sub>–AD<sub>15</sub> while $\overline{\rm DS}$ is Low. Figure 2. Typical Transaction Timing #### Memory Transactions For a memory transaction, the Status lines distinguish among various address spaces, such as program and data or system and normal, as well as indicating the type of transaction. The memory address is put on AD0-AD15 and on the extended address lines. For a Z-BUS with 16-bit data, the memory is organized as two banks of eight bits each (Figure 3). One bank contains all the upper bytes of all the addressable 16-bit words. The other bank contains all the lower bytes. When a single byte is written ( $R/\overline{W} = Low$ , $B/\overline{W} = High$ ), only the bank indicated by address bit $A_0$ is enabled for writing. For a Z-BUS with 8-bit data, the memory is organized as one bank which contains all bytes. This bank always inputs and outputs its data on AD<sub>0</sub>-AD<sub>7</sub>. Figure 3. Byte/Word Memory Organization #### I/O Transactions I/O transactions are similar to memory transactions with two important differences. The first is that I/O transactions take an extra clock cycle to allow for slow peripheral operation. The second is that byte data (indicated by B/W High on a 16-bit bus) is always trans- mitted on AD<sub>0</sub>–AD<sub>7</sub>, regardless of the I/O address. (AD<sub>8</sub>–AD<sub>15</sub> contain arbitrary data in this case.) For an I/O transaction, the address indicates a peripheral and a particular register or function within that peripheral. #### Null Transactions The two kinds of null transactions are distinguished by the Status lines: internal operation and memory refresh. Both transactions look like a memory read transaction except that Data Strobe remains High and no data is transferred. For an internal operation transaction, the Address lines contain arbitrary data when Address Strobe goes High. This transaction is initiated to maintain a minimum transaction rate when a bus master is doing a long internal operation (to support memories which generate refresh cycles from Address Strobe). For a memory refresh transaction, the Address lines contain a refresh address when Address Strobe goes High. This transaction is used to refresh a row of a dynamic memory. Any memory or I/O transaction can be suppressed (effectively turning it into a null transaction) by keeping Data Strobe High throughout the transaction. 480 2031-0182 #### Interrupts A complete interrupt cycle consists of an interrupt request followed by an interrupt-acknowledge transaction. The request, which consists of $\overline{\text{INT}}$ pulled Low by a peripheral, notifies the CPU that an interrupt is pending. The interrupt-acknowledge transaction, which is initiated by the CPU as a result of the request, performs two functions: it selects the peripheral whose interrupt is to be acknowledged, and it obtains a vector that identifies the selected device and cause of interrupt. A peripheral can have one or more sources of interrupt. Each interrupt source has three bits that control how it generates interrupts. These bits are an Interrupt Pending bit (IP), and Interrupt Enable bit (IE), and an Interrupt Under Service bit (IUS). A peripheral may also have one or more vectors for identifying the source of an interrupt during an interrupt-acknowledge transaction. Each interrupt source is associated with one interrupt vector and each interrupt vector can have one or more interrupt sources associated with it. Each vector has a Vector Includes Status bit (VIS) controlling its use. Finally, each peripheral has three bits for controlling interrupt behavior for the whole device. These are a Master Interrupt Enable bit (MIE), a Disable Lower Chain bit (DLC), and a No Vector bit (NV). Figure 4. Interrupt Connections 2031 0189 481 Interrupts (Continued) Peripherals are connected together via an interrupt daisy chain formed with their IEI and IEO pins (Figure 4). The interrupt sources within a device are similarly connected into this chain with the overall effect being a daisy chain connecting the interrupt sources. The daisy chain has two functions: during an interrupt-acknowledge transaction, it determines which interrupt source is being acknowledged; at all other times it determines which interrupt sources can initiate an interrupt request. Figure 5 is a state diagram for interrupt processing for an interrupt source (assuming its IE bit is 1). An interrupt source with an interrupt pending (IP = 1) makes an interrupt request (by pulling $\overline{\text{INT}}$ Low) if, and only if, it is enabled (IE = 1, MIE = 1), it does not have an interrupt under service (IUS = 0), no higher priority interrupt is being serviced (IEI = High), and no interrupt-acknowledge transaction is in progress (as indicated by $\overline{\text{INTACK}}$ at the last rising edge of $\overline{\text{AS}}$ ). IEO is not pulled down by the interrupt source at this time; IEO continues to follow IEI until an interrupt-acknowledge transaction occurs. Some time after $\overline{\text{INT}}$ has been pulled Low, the CPU initiates an interrupt-acknowledge transaction (indicated by $\overline{\text{INTACK}}$ Low). Between the rising edge of $\overline{\text{AS}}$ and the falling edge of $\overline{\text{DS}}$ , the IEI/IEO daisy chain settles. Any interrupt source with an interrupt pending (IP = 1, IE = 1, MIE = 1) or under service (IUS = 1) holds its IEO line Low; all other interrupt sources make IEO follow IEI. When $\overline{\text{DS}}$ falls, only the highest priority interrupt source with a pending interrupt (IP = 1) has its IEI input High, its IE bit set to 1, and its IUS bit set to 0. This is the interrupt source being acknowledged, and at this point it sets Its IUS bit to 1, and, if the peripheral's NV bit is 0, identifies itself by placing the vector on $AD_0\text{-}AD_7$ . If the NV bit is 1, then the peripheral's $AD_0\text{-}AD_7$ pins remain floating, thus allowing external circuitry to supply the vector. (All interrupts, including the Z8000's nonvectored interrupt, need a vector for identifying the source of an interrupt.) If the vector's VIS bit is 1, the vector will also contain status information further identifying the source of the interrupt. If the VIS bit is 0, the vector held in the peripheral will be output without modification. While an interrupt source has an interrupt under service (IUS = 1), it prevents all lower priority interrupt sources from requesting interrupts by forcing IEO Low. When interrupt servicing is complete, the CPU must reset the IUS bit and, in most cases, the IP bit (by means of an I/O transaction). A peripheral's Master Interrupt Enable bit (MIE) and Disable Lower Chain bit (DLC) can modify the behavior of the peripheral's interrupt sources in the following way: if the MIE bit is 0, the effect is as if every Interrupt Enable bit (IE) in the peripheral were 0; thus all interrupts from the peripheral are disabled. If the DLC bit is 1, the effect is to force the peripheral's IEO output Low, thus disabling all lower priority devices from initiating interrupt requests. Polling can be done by disabling interrupts (using MIE and DLC) and by reading peripherals to detect pending interrupts. Each Z-BUS peripheral has a single directly addressable register that can be read to determine if there is an interrupt pending in the device and, if so, what interrupt source it is from. # Interrupts (Continued) Figure 5. State Diagram for an Interrupt Source #### Transition Legend - The peripheral detects an interrupt condition and sets Interrupt Pending. - B All higher priority peripherals finish interrupt service, thus allowing IEI to go High. - $\bigcirc$ An interrupt-acknowledge transaction starts, and the IEI/IEO daisy chain settles. - The interrupt-acknowledge transaction terminates with the peripheral selected. Interrupt Under Service (IUS) is set to 1, and Interrupt Pending (IP) may or may not be reset. - The interrupt-acknowledge transaction terminates with a higher priority device having been selected. - The Interrupt Pending bit in the peripheral is reset by an I/O operation. - A new interrupt condition is detected by the peripheral, causing IP to be set again. - Interrupt service is terminated for the peripheral by resetting IUS. - IF is reset to zero, causing interrupts to be disabled. - IE is set to one, re-enabling interrupts. - 1. This diagram assumes MIE = 1. The effect of MIE = 0 is the same as that of setting IE = 0. - The DLC bit does not affect the states of individual interrupt sources. Its only effect is on the IEO output of a whole peripheral. #### State Legend - 0 No interrupts are pending or under service for this peripheral. - $\boxed{1}$ An interrupt is pending, and an interrupt request has been made by pulling $\overline{\text{INT}}$ Low. - 2 An interrupt is pending, but no interrupt request has been made because a higher priority peripheral has an interrupt under service, and this has forced IEI Low. - An interrupt-acknowledge sequence is in progress, and no higher priority peripheral has a pending interrupt. - 4 An interrupt-acknowledge sequence is in progress, but a higher priority peripheral has a pending interrupt, forcing IEI Low. - The peripheral has an interrupt under service. Service may be temporarily suspended (indicated by IEI going Low) if a higher priority device generates an interrupt. - 6 This is the same as State 5 except that an interrupt is also pending in the peripheral. - 7 Interrupts are disabled from this source because IE = 0. - [8] Interrupts are disabled from this source and lower priority sources because IE = 0 and IUS = 1. - 3. Transition I to state 6 or 7 can occur from any state except 3 or 4 (which only occur during interrupt acknowledge). - Transition J from state 6 or 7 can be to any state except 3 or 4, depending on the value of IEI, IP, and IUS. #### Interrupts (Continued) Figure 6. Bus Request Mechanism States #### **Bus Requester Legend** - Requester may or may not want bus; it is pulling BUSREQ Low in either case. - Requester is not pulling $\overline{\text{BUSREQ}}$ Low; it it wants control of the bus, it must wait for $\overline{\text{BUSREQ}}$ and $\overline{\text{BAI}}$ to rise before requesting the bus. - Requester is either using the bus or propagating the Low on its \$\overline{BA}\overline{I}\$ input. It will stop driving \$\overline{BUSREQ}\$ when its \$\overline{BA}\overline{O}\$ output goes Low. If it wants to use the bus, but did not want to at the time \$\overline{BUSREQ}\$ and \$\overline{BA}\overline{I}\$ were last High or \$\overline{BUSREQ}\$ went from Low to High, then it must wait for \$\overline{BUSREQ}\$ and \$\overline{BA}\overline{I}\$ to rise before requesting and using the bus. - Requester is not pulling BUSREQ Low. If it wants to use the bus, it must wait for its BAI to become High before requesting the bus. - Requester is propagating the High on its BAI input. If it wants the bus it will pull BUSREQ Low. - Requester is not pulling BUSREQ Low. If it wanted the bus at the time BUSREQ went from Low to High, it may request the bus when its $\overline{BAI}$ input rises; otherwise if it wants the bus, it must wait for $\overline{BUSREQ}$ to rise. #### **Bus State Legend** - 1 The CPU owns the bus and no one is requesting it. - 3 A Low from the CPU's BUSACK is propagating down the BAI/BAO daisy chain. Bus requesters are using the bus. - The Low from BUSACK has propagated to the end of the daisy chain causing all bus requesters to release BUSREQ, which floats High. The CPU has not yet acknowledged return of the bus. - The CPU acknowledges the High on BUSREQ with a High on BUSACK, which has propagated down the BAI/BAO daisy chain. - The CPU has responded to a Low on BUSREQ with a Low on BUSACK. The previous High state on BUSACK is still propagating down the BAI/BAO daisy chain. #### Interrupts (Continued) #### Transition Legend - A A bus requester requests the bus by pulling down on BUSREO. - B The CPU reponds to BUSREQ by pulling down BUSACK - C The Low from BUSACK propagates to the end of the BAI/BAO daisy chain, causing all the bus requesters to let BUSREQ rise. - D The CPU responds to BUSREQ High by driving BUSACK High. - E The High from BUSREQ propagates to the end of the BAI/BAO daisy chain. #### Bus Requests Figure 7 shows how the bus request lines connect bus requesters and the CPU on a Z-BUS. Figure 8 shows the states of the bus request mechanism as the Z-BUS is acquired, used, and released. To generate transactions on the bus, a bus requester must gain control of the bus by making a bus request. This is done by pulling down BUSREQ. A bus request can be made in either of two cases: - BUSREQ is initially High and BAI is High, indicating that the bus is controlled by the CPU and no other requester is requesting the bus. - BAI is High and the requester had wanted to request the bus at the time of the last Low-to-High transition of BUSREQ. This insures that a module will not be locked out indefinitely by a higher priority bus requester. After BUSREQ is pulled Low, the Z-BUS CPU relinquishes the bus and indicates this condition by making BUSACK Low. The Low on BUSACK is propagated through the BAI/BAO daisy chain (Figure 7). BAI follows BAO for components not requesting the bus, and any component requesting the bus holds its BAO High, thereby locking out all lower priority requesters. A bus requester gains con- Figure 7. Bus Request Connections trol of the bus when its $\overline{BAI}$ input goes Low. When it is ready to relinquish the bus, it stops pulling $\overline{BUSREQ}$ Low and allows $\overline{BAO}$ to follow $\overline{BAI}$ . This permits lower priority devices that made simultaneous requests to gain control of the bus. When all simultaneously requesting devices have relinquished the bus, and the Low on $\overline{BAI/BAO}$ has propagated to the lowest priority requester, $\overline{BUSREQ}$ goes High, returning control of the bus to the CPU. The CPU responds to the High on $\overline{BUSREQ}$ by driving BUSACK High. The High on $\overline{BUSACK}$ is propagated down the $\overline{BAI}/\overline{BAO}$ daisy chain, thus allowing bus requesters to make new bus requests. Because high priority bus requesters can pull $\overline{BUSREQ}$ Low before low priority devices have a High on $\overline{BAI}$ , a way is needed for low priority devices to request the bus when $\overline{BUSREQ}$ is Low. That is provided by the rule that a requester may request the bus at the time the last Low-to-High transition on $\overline{BUSREO}$ . As soon as \$\overline{BUSREQ}\$ is pulled Low by any requester, each of the other requesters on the bus drives \$\overline{BUSREQ}\$ Low and continues to do so until it drives its \$\overline{BAO}\$ output Low. This provides a handshake between the \$\overline{CPU}\$ and the bus requesters by ensuring that \$\overline{BUSREQ}\$ will not go High until the \$\overline{CPU}\$'s acknowledgement of \$\overline{BUSACK}\$ has reached every requester. Bus requesters can therefore run asynchronously to the \$\overline{CPU}\$. This rule also allows the bidirectional \$\overline{BUSREQ}\$ line to be buffered using the logic shown in Figure 8. This logic is similar to the logic inside a bus requester that keeps \$\overline{BUSREQ}\$ Low when it has initially been pulled Low by a different requester. Figure 8. Bus Request Line Buffering #### Resource Requests Resource requests are used to obtain control of a resource that is shared between several users. The resource can be a common bus, a common memory or any other resource. The requestor can be any component capable of implementing the request protocol. Unlike the Z-BUS itself, no component has control of a general resource by default; every device must acquire the resource before using it. All devices sharing the general resource drive the $\overline{\text{MMRQ}}$ line (Figure 9). When Low, the $\overline{\text{MMRQ}}$ line indicates that the resource is being acquired or used by some device. The $\overline{\text{MMST}}$ pin allows each device to observe the state of the $\overline{\text{MMRQ}}$ line. When MMRQ is High, a device may initiate a resource request by pulling MMRQ Low (Figure 10). The resulting Low on MMRQ is propagated through the MMAI/MMAO daisy chain. If a device is not requesting the resource, its MMAO output follows its MMAI input. Any device making a resource request forces its MMAO output High to deny use of the resource to lower priority devices. A device gains control of the resource if its MMAI input is Low (and its MMAO output is High) after a sufficient delay to let the daisy chain settle. If the device does not obtain the resource after this short delay, it must stop pulling MMRQ Low and make another request at some later time when MMRQ is again High. When a device that has gained control of a resource is finished, it releases the resource by allowing MMRQ to go High. Figure 9. Resource Request Connections The four unidirectional lines of the resource request chain allow the use of line drivers, thus facilitating connection of components separated by some distance. In the case of the Z8000 CPU, the four resource request lines may be mapped into the CPU MI and MO pins using the logic shown in Figure 11. With this configuration, the Multi-Micro Request Instruction (MREQ) performs a resource request. Figure 10. Resource Request Protocol For any resource requested, this wait time must be less than the minimum wait time plus resource usage time of all other requesters. Figure 11. Bus Request Logic for Z8000 #### Test Conditions The timing characteristics given in this document reference 2.0 V as High and 0.8 V as Low. The following test load circuit is assumed. The effect of larger capacitive loadings can be calculated by delaying output signal transitions by 10 ns for each additional 50 pF of load up to a maximum 200 pF. | DC | |-----------| | Charac- | | teristics | | | | | The following table states the dc characteristics for the input and output pins of Z-BUS components. All voltages are relative to ground. | istics for th | ne input and output pins of Z-BUS | ground | l. | | | |----------------------|-----------------------------------------|--------|---------------------|---------|-------------------------------------------| | Symbol | Parameter | Min | Max | Unit | Test Condition | | $v_{\text{IL}}$ | Input Low Voltage | -0.3 | 0.8 | V | | | $v_{\text{IH}}$ | Input High Voltage | 2.0 | $V_{\rm CC} + 0.3$ | V | | | V <sub>IHRESET</sub> | Input High Voltage on RESET pin | 2.4 | $V_{\rm CC}$ to 0.3 | V | | | $v_{OL}$ | Output Low Voltage | | 0.4 | V | $I_{OL} = 2.0 \text{mA}$ | | $V_{OH}$ | Output High Voltage | 2.4 | | V | $I_{OH} = 250 \mu A$ | | $I_{IL}$ | Input Leakage Current | -10 | +10 | $\mu$ A | $V_{IN} = 0.4 \text{ to } 2.4 \text{ V}$ | | $I_{OL}$ | 3-State Output Leakage Current in Float | -10 | +10 | μA | $V_{OUT} = 0.4 \text{ to } 2.4 \text{ V}$ | #### Capacitance The following table gives maximum pin capacitance for Z-BUS components. Capacitance is specified at a frequency of 1 MHz over the temperature range of the component. Unused pins are returned to ground. | Symbol | Parameter | Max (pF) | |-----------------|---------------------------|----------| | C <sub>IN</sub> | Input Capacitance | 10 | | $C_{OUT}$ | Output Capacitance | 15 | | $C_{\rm I/O}$ | Bidirectional Capacitance | 15 | #### Timing Diagrams The following diagrams and tables give the timing for each kind of transaction (except null transactions). Timings are given separately for bus masters and for peripherals and memories and are intended to give the minimum timing requirements which a Z-BUS component must meet. An individual component will have more detailed and sometimes more stringent timing specifications. The differences between bus master timing and peripheral and memory timing allow for buffer and decoding circuit delays and for signal skew. The timing given for memories is a constraint on bus-compatible memories (like the Z6132 Quasi-Static RAM) and is not intended to constrain memory subsystems constructed from conventional components. Besides these timings, there is a requirement that at least 128 transactions be initiated in any 2 ms period. This accommodates memories that generate refresh cycles from Address Strobe. Parameters 1-25 are common to all transactions. #### I/O Transaction Timing #### Interrupt Acknowledge Timing 2031-0240, 0187, 0191 | No. | Symbol | Parameter | 4<br>Min | MHz<br>Max | 6 i<br>Min | MHz<br>Max | Notes*† | |-----------|----------------------|-----------------------------------------------------------------------|--------------------|------------------------------|-----------------------------|-----------------------------|---------| | | | All Transactions | | | | | | | 1 | TpC | Clock Period | 250 | 2000 | 165 | 2000 | | | 2<br>3 | TwCh | Clock High Width | 105 | | 70 | | | | 3<br>4 | TwCl<br>TfC | Clock Low Width<br>Clock Fall Time | 105 | 20 | 70 | 10 | | | 5- | -TrC | — Clock Rise Time — | | 20 | | 15 | | | 6 | TdC(S) | Clock 1 to Status Valid Delay | | 110 | | 85 | | | 7 | TdC(ASr) | Clock ↓ to AS ↑ Delay | | 90 | | 80 | | | 8 | TdC(ASf) | Clock † to AS Delay | | 80 | | 60 | | | 9<br>10 | TdS(AS) | Status Valid to $\overline{AS}$ † Delay | 50 | | 30 | | | | 11 | —TwAS————<br>TdDS(S) | — AS Low Width ———————————————————————————————————— | 80<br>75 | | 55 <del></del><br>55 | | | | 12 | TdAS(DS) | AS to DS t Delay | 80 | 2095 | 55 | | 3 | | 13 | TsDR(C) | Read Data to Clock Setup Time | 30 | 2000 | 20 | | Ü | | 14 | TdC(DS) | <u>Cl</u> ock ↓ <u>to DS</u> ↑ Delay | | 70 | | 65 | | | 15- | -TdDS(AS) | — DS ↑ to ĀS ↓ Delay ———————————————————————————————————— | <del> 7</del> 0 | | 35 | | | | 16<br>17 | TdC(Az) | Clock † to Address Float Delay | | 65 | | 55 | | | 17 | TdC(A)<br>TdA(AS) | Clock † to Address Valid Delay<br>Address Valid to AS † Delay | 50 | 100 | 35 | 75 | 1 | | 19 | TdA(AS) | Address Valid to AS Delay AS to Address Not Valid Delay | 70 | | 35<br>45 | | 1 | | 20- | -TwA | - Address Valid Width | — 150 — | | 85 | | | | 21 | ThDR(DS) | Read Data to $\overline{\rm DS}$ † Hold Time | 0 | | 0 | | | | 22 | TdDS(A) | DS † to Address Active Delay | 80 | | 45 | | | | 23 | TdDS(DW) | DS † to Write Data Not Valid Delay | 50 | | 45 | | | | 24<br>25— | TsW(C)<br>-ThW(C) | WAIT to Clock ↓ Setup Time WAIT to Clock ↓ Hold Time | 50<br>10 | | 30<br>10- | | 2.4 | | 20 | 11144(C) | WAIT to Clock + Hold Time | 10 | | 10 | | 2,4 | | 00 | T I T C(TAT) | Memory Transactions | | • | | 45 | | | 26<br>27 | TdAS(W)<br>TdC(DSR) | AS 1 to WAIT Required Valid | | 90 | | 45 | | | 28 | TdDSR(DR) | Clock ↓ to DS (Read) ↓ Delay DS (Read) ↓ to Read Data Required Valid | | 120<br>200 | | 85<br>130 | | | 29 | TwDSR | DS (Read) Low Width | | 250 | 185 | 150 | | | 30- | -TdA(DS) | —Address Valid to DS Delay | <del></del> 180 | 200 | 110- | | | | 31 | TdAz(DSR) | Address Float to DS (Read) Delay | 0 | | 0 | | | | 32 | TdAS(DR) | AS 1 to Read Data Required Valid | | 360 | | 220 | | | 33<br>34 | TdA(DR) | Address Valid to Read Data Required Valid | | 410 | | 305 | | | 35 — | TdC(DSW)<br>-TwDSW | Clock ↓ to DS (Write) ↓ Delay DS (Write) Low Width | <del>-</del> 160 - | 95 | <del></del> 110 <del></del> | 80 | | | 36 | TdDW(DSWf) | Write Data Valid to DS (Write) Delay | 50 | | 35 | | | | 37 | TdDW(DSWr) | Write Data Valid to DS (Write) † Delay | 230 | | 195 | | | | | | I/O Transactions | | | | | | | 38 | TdAS(DR) | AS 1 to Read Data Required Valid | | 610 | | 385 | | | 39 | TdA(DR) | Address Valid to Read Data Required Valid | | 660 | | 470 | | | 40- | TdAz(DSI) | Address Float to DS (I/O) 1 | <del></del> 0 - | | <del>0</del> | | | | 41 | TdC(DSI) | Clock ↓ to DS (I/O) ↓ | | 120 | | 90 | | | 42<br>43 | TdDSI(DR)<br>TwDSI | DS (I/O) ↓ to Read Data Required Valid DS (I/O) Low Width | 400 | 330 | 255 | 210 | | | 44 | TdA(DSI) | Address Valid to DS (I/O) \ Delay | 180 | | 110 | | | | 45- | TdDW(DSIf) — | -Write Data to DS (I/O) ↓ Delay | <del></del> 50 | | 35 | | | | 46 | TdDW(DSIr) | Write Data to DS (I/O) † Delay | 480 | | 320 | | | | 47 | TdAS(W) | AS to WAIT Required Valid | | 340 | | 210 | | | | | Interrupt-Acknowledge Transactions | | | | | | | 48 | TdAS(DSA) | AS ↑ to DS (Acknowledge) ↓ Delay | 960 | | 690 | | | | 49 | TdC(DSA) | Clock 1 to DS (Acknowledge) Delay | | 120 | | 85 | | | 50- | TdDSA(DR) | —DS (Acknowledge) ↓ to Read Data Required Valid — | 400 | <del> 4</del> 55 <del></del> | 210 | <del></del> 295 <del></del> | | | 51<br>52 | TwDSA<br>TdAS(W) | DS (Acknowledge) Low Width | 485 | 940 | 315 | 540 | | | 53 | TdDSA(W) | AS 1 to Wait Required Valid DS (Acknowledge) to Wait Required Valid | | 840<br>185 | | 540<br>120 | | | | | 20 (1101110 riouge) + to fruit frequired + dild | | 100 | *** | 120 | | #### NOTES Timing for extended addresses is CPU dependent, however, extended addresses must be valid at least as soon as addresses are valid on AD<sub>0</sub>-AD<sub>15</sub> and must remain valid at least as long as addresses are valid on AD<sub>0</sub>-AD<sub>15</sub> The exact clock cycle that wait is sampled on depends on the <sup>2</sup> The exact clock cycle that wait is sampled on depends on the type of transaction, however, wait always has the given setup and hold times to the clock <sup>3</sup> The maximum value for TdAS(DS) does not apply to Interrupt-Acknowledge Transactions. <sup>4</sup> The setup and hold times for WAIT to the clock must be met. If WAIT is generated asychronously to the clock, it must be synchronized before input to a bus master. <sup>\*</sup> Timings are preliminary and subject to change <sup>†</sup> Units in nanoseconds (ns) Except where otherwise stated, maximum rise and fall times for inputs are 200 ns | No. | Chal | Parameter | 4 l<br>Min | MHz<br>Max | 6 I<br>Min | MHz<br>Max | Massath | |-------------|----------------------------|------------------------------------------------------------------------------------------------------|-----------------------------|----------------|-----------------------------|------------|---------------| | 110. | Symbol | rarameter | Min | Max | Min | Max | Notes*† | | , | F (30/ 10) | All Transactions | • | | | | • | | 1<br>2 | TsCS(AS)<br>ThCS(AS) | CS to AS † Setup Time<br>CS to AS † Hold Time | 0 | | 0 | | 1 | | 3 | TsS(AS) | Status to AS Floid Time Status to AS Setup Time | 60<br>20 | | 40<br>0 | | 1<br>2 | | 4 | ThS(DS) | Status to $\overline{DS}$ † Hold Time | 55 | | 40 | | 2 | | 5- | -TsA(AS) | — Address to AS Setup Time | <del></del> 30 | | 10 | | 1 | | 6 | ThA(AS) | Address to AS † Hold Time | 50 | | 30 | | i | | 7 | TwAS | AS Low Width | 70 | | 50 | 0 | | | 8 | TdDS(DR) | DS 1 to Read Data Not Valid Delay | 0 | | | | | | 9 | TdDS(DRz) | DS † to Read Data Float Delay | | 70 | 45 | | | | 10- | TdAS(DS)—— | — AS ↑ to DS ↓ Delay — | <del></del> 60 | —2095 <b>—</b> | <del> 40</del> | | 5 <del></del> | | 11 | TdDS(AS) | DS † to AS Delay | 50 | | 25 | | | | 12 | ThDW(DS) | Write Data to $\overline{\rm DS}$ † Hold Time | 30 | | 20 | | 1 | | | | Memory Transactions | | | | | | | 13 | TdA(DR) | Address Required Valid to Read Data Valid Delay | | 320 | | 255 | | | 14 | TdAS(DR) | AS to Read Valid Delay | | 270 | • | 170 | | | 15—<br>16 | —TdAz(DSR) ——<br>TdDSR(DR) | — Address Float to DS (Read) ↓ Delay ———————————————————————————————————— | <del></del> 0 | 110 | 0 | 80 | | | 17 | TwDSR | DS (Read) ↓ to Read Data Valıd Delay<br>DS (Read) Low Wıdth | 240 | 110 | 180 | 80 | | | 18 | TdA(DS) | Address to DS Setup | 160 | | 100 | | | | 19 | TwDSW | DS (Write) Low Width | 150 | | 105 | | | | 20 | TsDW(DSWf) | Write Data to DS (Write) Setup Time | 30 | | 20 | | | | 21- | | Write Data to DS (Write) † Setup Time | — 210 <b>—</b> | | 180 | | | | | | I/O Transactions | | | | | | | 22 | TdA(DR) | Address Required Valid to Read Data Valid Delay | | 570 | | 420 | | | 23 | TdAS(DR) | AS t to Read Data Valid Delay | | 520 | | 335 | | | 24 | TdDSI(DR) | DS (I/O) ↓ to Read Data Valid Delay | | 250 | | 180 | | | 25 | TdAz(DSI) | Address Float to DS (I/O) ↓ Delay | 0 | | 0 | | | | 26 — | TdA(DSI) | — <u>Ad</u> dress to <del>DS</del> (I/O) ↓ Setup | <del></del> 160 <del></del> | | <del></del> 100 <del></del> | | | | 27 | TwDSI | DS (I/O) Low Width | 390 | | 250 | | | | 28 | TsRWR(DSI) | $R/\overline{W}$ (Read) to $\overline{DS}$ (I/O) $\downarrow$ Setup Time | 100 | | 100 | | | | 29 | TsRWW(DSI) | $R/\overline{W}$ (Write) to $\overline{DS}$ (I/O) $\downarrow$ Setup Time | 0 | | 0 | | | | 30<br>31 | TsDW(DSIf)<br>TsDW(DSIr) | Write Data to $\overline{DS}$ (I/O) Setup Time<br>Write Data to $\overline{DS}$ (I/O) Setup Time | 30 | | 20 | | | | 32 — | TdAS(W) | - AS to WAIT Valid Delay | 460<br><del></del> 195 | | 305<br>160 | | | | 02 | Tarib(W) | • | | | 100 | | | | 33 | TsIA(AS) | Interrupt-Acknowledge Transaction $\overline{\text{INTACK}}$ to $\overline{\text{AS}}$ † Setup Time | O | | 0 | | | | 34 | ThIA(AS) | INTACK to AS Hold Time | 250 | | 250 | | | | 35 | TdAS(DSA) | AS t to DS (Acknowledge) Delay | 940 | | 675 | | | | 36 | TdDSA(DR) | DS (Acknowledge) I to Read Delay Valid Delay | 365 | | 245 | | | | 37 <b>—</b> | -TwDSA | - DS (Acknowledge) Low Width | — 475 — | | <del>310</del> | | | | 38 | TdAS(IEO) | ĀS↓to IEO↓ Delay | | | | | 3,4 | | 39 | TdIEIf(IEO) | IEI to <u>IE</u> O Delay | | | | | 4 | | 40 | TsIEI(DSA) | IEI to $\overline{\rm DS}$ (Acknowledge) $\downarrow$ Setup Time | | | | | 4 | | | | | | | | | | #### NOTES. - l Parameter does not apply to Interrupt Acknowledge Trans- - 2. Does not cover R/W for I/O Transactions. - 3. Applies only to a peripheral which is pulling INT Low at the - beginning of the Interrupt Acknowledge Transaction. These parameters are device dependent. The parameters for the devices in any particular daisy chain must meet the following constraint for any two peripherals in the daisy chain, TdAS(DSA) must be greater than the sum of TdAS(IEO) for the - higher priority peripheral, and TdIEIf(IEO) for each peripheral separating them in the daisy chain. The maximum value for TdAS(DS) does not apply to Interrupt Acknowledge Transactions. Timings are preliminary and subject to change. Units in nanoseconds (ns) Except where otherwise stated, maximum rise and fall times for inputs are 200 ns. ## ZBI Z-BUS Backplane Interconnect System # Product Description June 1982 #### Features - The bus structure for the 80's - Compatible with the Z-BUS Component Interconnect system - Designed for the powerful Zilog Family of Microprocessors - □ Z8 CPU - □ Z80 CPU - □ Z8000 CPU - □ Future microprocessors - Flexibility in application - □ 8-, 16- or 32-bit operations - ☐ Unsegmented, segmented, or memory mapped systems - Future growth - ☐ Allows 32-bit operations - ☐ 5-bit status field #### \_\_\_\_ - Designed-in reliability - $\hfill\square$ Byte-oriented parity and parity error line - □ High reliability pin and socket connectors - ☐ Distributed ground lines - ☐ High-current power distribution - □ Terminated bus lines #### Description The Z-BUS Backplane Interconnect (ZBI) system is a high performance, application-oriented system bus designed to utilize the full capabilities of all Zilog microprocessors—the Z8, Z80 and Z8000. Thirty-two address/data lines coupled with twenty-eight control lines provide the resources needed for growth paths to future, more complex 32-bit microprocessors. A member of the Z-BUS family of microcom- puter bus structures, the ZBI bus is compatible with the Z-BUS Component Interconnect (ZCI) system used for communications at the chip level between Zilog processors and their peripheral support modules. Reliability has been designed into the ZBI structure: parity lines have been included; ground lines are distributed between signals to reduce noise; and all bus lines are terminated. # Functional Description **Mechanical Configuration.** The ZBI bus is defined for three sizes of modular boards. The single size modules measure $6.3^{\prime\prime} \times 3.9^{\prime\prime}$ (160 mm $\times$ 100 mm). The double size boards are $6.3^{\prime\prime} \times 9.2^{\prime\prime}$ (160 mm $\times$ 233.4 mm), and the double extended size measure 11.0" $\times$ 9.2" (280 mm $\times$ 233.4 mm). All ZBI boards are consistent with the standard European form factor. The single size boards have a single bus connector while the double boards have two connectors. The connector has a matrix of 96 pins on .100" (2.54 mm) centers which are aligned in 3 rows of 32 pins each. A molded plastic housing surrounds the pin array, providing mechanical rigidity and protecting the pins from mechanical damage. The backplanes use a similar style of mating connector. These connectors are highly reliable because connection surfaces are completely enclosed and shielded from dirt and dust when the connectors are mated. Another advantage of this connector is its high density which permits the design of compact boards. In addition, the connectors are self-aligning # Functional Description (Continued) and keyed to prevent improper insertion. All of the signals on the double boards are assigned to one connector so that single boards can be used in the same backplane with double boards. The second connector on the double boards is unspecified and available for use by the designer. Figure 2. The ZBI backplane accepts two sizes of boards; both are compatible with European standards. The dimensions are in inches (upper) and millimeters (lower). #### Signal Description The ZBI consists of 96 lines: 32 bidirectional address/data lines with four parity lines, nine interrupt lines, 28 control lines, 21 power-supply lines for $\pm\,12$ V, $\pm\,5$ V and ground and two reserve lines. The pin layout was defined to provide the most convenient connection from the board and the backplane, with signals collected into logical groups for placement on the connector. Address and Data. The address/data group is laid out to enable the lines to enter the board in order on both two-layer and four-layer boards. Low-order lines are placed next to the power pins for easier routing through buffers. The high-order address/data pins are positioned near the control pins to facilitate decoding of the state of the bus. Address and data information is transmitted over 32 bidirectional lines with separate address and data strobe lines arbitrating the information flow. The use of shared address/data lines enables a compact connection while still allowing 32-bit word sizes. Word size is controlled by two lines that indicate the data width of the current operation on the bus, making possible 8-bit, 16-bit and 32-bit word transfers in the same system. Data is aligned in the lower byte ( $AD_0$ - $AD_7$ ) of the data field for 8-bit transfers, and the lower word ( $AD_0$ - $AD_1$ 5) for 16-bit transfers. The ZBI includes four parity lines and an error-indication line to detect errors in memory devices and transmissions on the bus. One parity bit is provided for each byte of the 32-bit address/data field, enabling parity-checking at both the byte and word levels. **Control Signals.** The ZBI bus has 28 lines that are used for bus control and status, grouped into the following categories: Clocking. Two lines provide a master clock and a bus clock. The master clock supplies a constant frequency and is used as a master timing reference; the bus clock is derived from the master. - Extended processor architectures. Two lines enable the CPU to interact with an Extended Processor Unit. - Resource sharing. Three lines enable processors to lock other processors off the bus. This is a software implementation, and all processors must be aware of these signals for the lockout to be effective. - Direct memory access. Three lines provide the control signals required for data to be transmitted in burst mode across the bus. When a DMA device wants to transmit information, it issues a request that causes the processor to get off the bus. Once off the bus, the processor issues an acknowledge signal indicating that the bus is free. The DMA device then begins transferring data to the specified address. When the transfer is complete, the processor regains use of the bus. - Multiprocessor. Four lines enable multiple processors to share a common bus. (Arbitration logic to prevent contention errors must be included on each module.) - Data/Address Strobe. Two lines indicate whether address or data information is on the address/data lines. - Status. Five lines designate the kind of transaction occurring on the bus. - Word-size select. Two lines determine the word size of the transaction on the bus Interrupts. The ZBI bus has three independent interrupt groups. Each group has an interrupt request line and an interrupt enable input and output daisy chain. A different priority level is assigned to each of the three interrupt groups and position-dependent priority is assigned to each device within the groups. The treatment of the interrupt signal is processor-dependent and can be maskable, non-maskable, vectored, or non-vectored depending upon the configuration of the system CPU. **Bus Conditioning.** All bus lines are terminated in resistor pairs to provide the highest integrity and best noise immunity for the system. This forces all undriven lines to approximately +3 V. #### Signal Definition Table 1 defines the signals necessary to the ${\it ZBI}$ structure. All signals, with the exception of the data and address lines, are negative true signals, where logical 1 = < 0.5 V and logical 0 = > +2.4 V. Any exception to this standard is noted in the table. Naming conventions are as follows: NAME: a single line, negative-true logic level NAME: a single line, positive-true logic level NAME<0.3>: 4 lines, positive-true logic level NAME1/NAME2: a doubly named line, High/Low logic levels The abbreviations used to describe signal types are: BD: Bidirectional data lines TS: 3-state, undirectional lines OC: Open collector HC: High-current driver line, not 3-state DC: Daisy-chained signal—OUT on one board connects to IN of the next board | Signal<br>Name | Number<br>of Lines | Signal<br>Type | Function | |-------------------------|--------------------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Address and<br>AD<0:31> | Data Group -<br>32 | BD | <b>Address and Data Lines.</b> Address and data information is time-multiplexed onto these lines. The times they are valid are defined by address strobe $(\overline{\rm DS})$ and data strobe $(\overline{\rm DS})$ . Additional information can be derived from the BCLK signal for synchronous operation. | | Parity Group | ) ———— | | | | P<0:3> | 4 | BD | Parity-Check Bits. For bus transfer integrity, one parity bit is provided for each byte of the 32-bit address/data bus. Even parity ensures that a read from a non-existent resource will generate a parity fault. | | PE | 1 | OC | <b>Parity Error.</b> Indicates to the Bus Master that a parity error in a data transfer on the bus has been caught by the parity check logic. | | Interrupt Gro | oup ——— que | ~~~~ | | | ĪNTĪ | 1 | OC | <b>Level 1 Interrupts.</b> Highest priority interrupt in the system. If a non-maskable interrupt is present, it must be here. | | ĪNT2 | 1 | OC | <b>Level 2 Interrupt.</b> Second highest priority interrupt in the system. If a vectored interrupt is present, it must be here. | | ĪNT3 | 1 | OC | <b>Level 3 Interrupt.</b> Lowest priority interrupt in the system. If a non-vectored interrupt is present, it must be here. | | IEI1 | 1 | DC | Level 1 Interrupt Enable In | | IEO1 | 1 | DC | Level 1 Interrupt Enable Out | | IEI2 | 1 | DC | Level 2 Interrupt Enable In | | IEO2 | 1 | DC | Level 2 Interrupt Enable Out | | IEI3 | 1 | DC | Level 3 Interrupt Enable In | | IEO3 | 1 | DC | Level 3 Interrupt Enable Out | | Control Gro | oup ———— | | | | PWRBAD | 1 | OC | <b>Power Bad.</b> An early warning signal that the dc power for the system will soon disappear. This signal is generated by the power supply to give the processor enough time to store the machine state (if appropriate storage is available) before power drops below critical levels. | | Clocking — | | | | | MCLK | 1 | HC | <b>Master Clock.</b> System master clock—16 to 32 MHz. Frequency is a $4 \times$ multiple of the desired bus clock frequency. | | BCLK | 1 | HC | <b>Bus Clock.</b> Bus transaction clock, derived from Master Clock and used by all synchronous elements in the system. | | Extended Pro | ocessing Archi | itecture | | | N/S | l | TS | Normal/System. Indicates the mode of the CPU controlling the bus—Normal user mode or System mode (able to execute privileged instructions) | | STOP | 1 | OC | $\mbox{\bf Stop Line.}$ Stop the processor in control of the bus for synchronization of activities with the CPU. | | Address/Date | Strobes | | | | Address/ Date<br>AS | l | TS | <b>Address Strobe.</b> Indicates that the AD lines contain a valid address. The $\overline{AS}$ line is pulsed low by a board controlling the transaction for program or data memory access. Addresses are valid at the trailing (rising) edge of $\overline{AS}$ . | | DS | 1 | TS | <b>Data Strobe.</b> Data is placed on or accepted from the AD bus lines when $\overline{\rm DS}$ is low. | | | | | Table 1. Signal Definitions | | Signal<br>Name | Number<br>of Lines | Signal<br>Type | Function | | | | | |---------------------------------------------|-----------------------|--------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--| | Status ———————————————————————————————————— | 5 | TS | Status Lines. These lines designate the type of transaction occurring on the bus. | | | | | | | | | Toursesties | | | | | | | | <b>S<sub>4</sub> S<sub>3</sub> S<sub>2</sub> S<sub>1</sub> S<sub>0</sub></b> 0 0 0 0 | Transaction Internal Operation 0 1 0 1 0 Data Mem <> EPU | | | | | | | | 0 0 0 0 1 0 | Memory Refresh transfer | | | | | | | | 0 0 0 1 1 | Special I/O transfer | | | | | | | | 0 0 1 0 0 | Reference 0 1 1 0 0 Prog Ref - nth cycle<br>Segment Trap Ack 0 1 1 0 1 Prog Ref - 1st cycle | | | | | | | | 0 0 1 0 1 | Intl Interrupt Ack 0 1 1 1 0 EPU <> CPU | | | | | | | | $ \begin{array}{cccccccccccccccccccccccccccccccccccc$ | Int2 Interrupt Ack transfer Int3 Interrupt Ack 0 1 1 1 1 Reserved | | | | | | | | 0 1 0 0 0 | Data Memory 1 X X X X Reserved | | | | | | | | 0 1 0 0 1 | Request<br>Stack Memory<br>Request | | | | | | Word Size Se | | | | | | | | | B/W<br>W/ <del>LW</del> | 1<br>1 | TS<br>TS | Byte/Word Select. Used in conjunction with $W/\overline{LW}$ to define data access width. Word/Long Word Select. Used in conjunction with $B/\overline{W}$ to define the data access | | | | | | | | | width. (A logical 1 is a high voltage level.) B/W W/LW Access Width | | | | | | | | | l Byte (8-bit)—Data on AD < 0:7> | | | | | | | | | 0 l Word (16-bit)—Data on AD <0:15> | | | | | | | | | 1 0 Double Word (32-bit)—Data on AD <0:31> 0 0 Reserved | | | | | | | | | o inciservou | | | | | | Resource Sha<br>MMREQ | ring ———<br>l | OC | Multimicro Request. This is a software request to another processor for software synchronization. | | | | | | MMĀI | 1 | DC | Multimicro Acknowledge In. Forms the logical chain among processors to perform software arbitration, in conjunction with the MMAO signal. The effect of this line is dependent on the software present on the processor board. | | | | | | MMAO | 1 | DC | Multimicro Acknowledge Out. Completes the logical chain to the next processor MMAI pin. | | | | | | Direct Memor | v Access - | | | | | | | | BAI | l l | DC | Bus Acknowledge In From Priority Chain. This signal and $\overline{BAO}$ form the bus priority chain. | | | | | | BAO | 1 | DC | Bus Acknowledge Out to Priority Chain. Completes the circuit to the next device in the bus priority chain. | | | | | | BUSREQ | 1 | OC | <b>Bus Request.</b> Used to request access to the bus. A request to a processor to relinquish the bus at the end of the current instruction cycle. This signal is used with the $\overline{\text{BAI}}$ and $\overline{\text{BAO}}$ signals to control bus sharing by DMA devices not able to become bus masters. | | | | | | | r Contro | 1 | CPU Acknowledge In. | | | | | | | | ВО | CPU Acknowledge Out. | | | | | | Multiprocesso CAI CAO | 1 | DC | | | | | | | CAO<br>CAO | 1<br>1 | DC<br>DC | | | | | | | CAI | | DC<br>DC | <b>CPU Request.</b> A request to the processor currently in control of the bus to relinquish control at the end of the current instruction cycle. This signal is used with | | | | | | CAO | | | CPU Request. A request to the processor currently in control of the bus to relinquish control at the end of the current instruction cycle. This signal is used with CAI, CAO, and CAVAIL to control sharing of the bus by devices able to become | | | | | | CAT CAO CPUREQ CAVAIL Miscellaneous | l<br>l<br>s Control l | DC<br>TS | CPU Request. A request to the processor currently in control of the bus to relinguish control at the end of the current instruction cycle. This signal is used with $\overline{CAI}$ , $\overline{CAO}$ , and $\overline{CAVAIL}$ to control sharing of the bus by devices able to become bus masters. CPU Available. Used in conjunction with $\overline{CAI}$ and $\overline{CAO}$ to transfer bus control from one bus master to another. | | | | | | CAI CAO CPUREQ CAVAIL Miscellaneous RESET | l l s Control l | TS Lines OC | CPU Request. A request to the processor currently in control of the bus to relinguish control at the end of the current instruction cycle. This signal is used with $\overline{CAI}$ , $\overline{CAO}$ , and $\overline{CAVAIL}$ to control sharing of the bus by devices able to become bus masters. CPU Available. Used in conjunction with $\overline{CAI}$ and $\overline{CAO}$ to transfer bus control from one bus master to another. Reset. Connected to the master reset switch and power-up reset circuit. | | | | | | CAT CAO CPUREQ CAVAIL | l<br>l<br>s Control l | DC<br>TS | CPU Request. A request to the processor currently in control of the bus to relinguish control at the end of the current instruction cycle. This signal is used with $\overline{CAI}$ , $\overline{CAO}$ , and $\overline{CAVAIL}$ to control sharing of the bus by devices able to become bus masters. CPU Available. Used in conjunction with $\overline{CAI}$ and $\overline{CAO}$ to transfer bus control from one bus master to another. | | | | | Table 1. Signal Definitions (continued) # Advanced Architectural Features of the Z8000 CPU #### Tutorial Information June 1982 #### Introduction The Zilog Z8000 CPU microprocessor is a major advance in microcomputer architecture. It offers many minicomputer and mainframe features for the first time in a microprocessor chip. This tutorial describes the Z8000 CPU with emphasis placed on those features that set it apart from its microprocessor predecessors. For a detailed description of all Z8000 CPU features, consult the Zilog publications listed in the bibliography at the end of this tutorial. The features to be discussed are grouped into four areas: CPU organization, handling of interrupts and traps, use of memory, and new \_\_\_\_\_ Instructions and data capabilities. Before discussing these features in more detail, a word about nomenclature is in order. The term Z8000 refers to the concept and architecture of a family of parts. Zilog has adopted the typical conductor industry 4-digit designation for Z8000 Family parts, while also keeping the traditional 3-letter acronym that proved so popular for the Z-80 Family. Thus, the 48-pin version of the Z8000 CPU is called the Z8001 CPU; the 40-pin version is known as the Z8002 CPU. #### CPU Organization The Z8000 CPU is organized around a general-purpose register file (Figure 1). The register file is a group of registers, any one of which can be used as an accumulator, index register, memory pointer, stack pointer, etc. The only exception is Register 0, as explained later. Flexibility is the major advantage of a general-purpose register organization over an organization that dedicates particular registers to each function. Computation-oriented routines can use general registers as accumulators for intermediate results whereas data manipulation routines can use these registers for memory pointers. Dedicated registers, however, have a disadvantage: when more registers of a given type are needed than are supplied by the machine, the performance degrades by the extra instructions to swap registers and memory locations. For example, a processor with two index registers suffers when three are needed because a temporary variable in memory (or in another register) must be used for the third index. When the third index is needed, it must be swapped into an index register. In contrast, on a general-register machine three of the registers could be dedicated for index use. In addition, since the need for index registers may vary over the course of a program, a general-register architecture, such as the Z8000, can be adapted to the changing needs of the computation with respect to the number of accumulators, memory pointers and index registers. Thus flexibility results in increased performance and ease of use. In addition, the registers of the Z8000 are organized to process 8-bit bytes, 16-bit words, 32-bit long words and 64-bit quadruple words. This readily accommodates applications that process data of variable sizes as well as different tasks that require different data sizes. Although all registers can—in general—be used for any purpose, certain instructions such as Subroutine Call and String Translation make use of specific registers in the general register file, and this must be taken into account when these instructions are used. Figure 1. CPU Organization ### CPU (Continued) The Z8000 CPU also contains a number of Organization special-purpose registers in addition to the general-purpose ones. These include the Program Counter, Program Status registers and Figure 2. Z8001 General Purpose Registers the Refresh Counter. These registers are accessible through software and provide some of the interesting features of Z8000 CPU architecture. Figure 3. Z8002 General Purpose Registers ## Register All general-purpose registers can be used as Organization accumulators, and all but one as index registers or memory pointers. The one register that cannot be used as an index register is Register 0. Specifying Register 0 is used as an escape mechanism to change the address mode from IR to IM, from X to DA, or-with Load instructions—from BA to RA. This has been done so that the two addressing mode bits in the instruction can specify more than four addressing modes for the same opcode. > The Z8000 CPU register file can be addressed in several groupings: as sixteen byte registers (occupying the upper half of the file only), as sixteen word registers, as eight long-word registers, as four guadruple-word registers, or as a mixture of these. Instructions either explicitly or implicitly specify the type of register. Table 1 illustrates the correspondence between the 4-bit source and destination register fields in the instruction (Figure 4) and the location of the registers in the register file (Figures 2 and 3). | Register<br>Designator | Byte | Word | Long<br>Word | Quadruple<br>Word | |------------------------|------|------|--------------|-------------------| | 0000 | RH0 | RO | RR0 | RQ0 | | 0001 | RHl | Rl | | | | 0010 | RH2 | R2 | RR2 | | | 0011 | RH3 | R3 | | | | 0100 | RH4 | R4 | RR4 | RQ4 | | 0101 | RH5 | R5 | | | | 0110 | RH6 | R6 | RR6 | | | 0111 | RH7 | R7 | | | | 1000 | RLO | R8 | RR8 | RQ8 | | 1001 | RLl | R9 | | | | 1010 | RL2 | R10 | RR10 | | | 1011 | RL3 | R11 | | | | 1100 | RL4 | R12 | RR12 | RQ12 | | 1101 | RL5 | R13 | | | | 1110 | RL6 | R14 | RR14 | | | 1111 | RL7 | R15 | | | Table 1 2048-0207, 0208 ### Register (Continued) Note that the byte register-addressing Organization sequence (most significant bit distinguishes between the two bytes in a word register) is different from the memory addressing sequence (least significant bit distinguishes between the two bytes in a word). Long-word (32-bit) and quadruple-word (64-bit) registers are addressed by the binary number of their starting word registers (most significant word). For example, RR6 is addressed by a binary 6 and occupies word registers 6 and 7. | BYTE OR<br>WORD | мо | DE | OPCODE | В | /W | | SOURCE | DESTINATION | |----------------------|----|----|----------------|---|----|---|--------|-------------| | WORD OR<br>LONG WORD | мо | DE | OPCODE | | | _ | SOURCE | DESTINATION | | MODE<br>REGISTER | 1 | 1 | | | | | | | | IMMEDIATE<br>DIRECT | 0 | 0 | FOR SOURCE = 0 | 0 | 0 | 0 | | | | INDIRECT | 0 | 0 | FOR SOURCE # 0 | 0 | 0 | 0 | | | Figure 4. Instruction Format ### System/ of Operation The Z8000 CPU can run in one of two Normal Mode modes: System or Normal. In System Mode, all of the instructions can be executed and all of the CPU registers can be accessed. This mode is intended for use by programs that perform operating system type functions. In Normal Mode, some instructions, such as I/O instructions, are not all allowed, and the control registers of the CPU are inaccessible. In general, this mode of operation is intended for use by application programs. This separation of CPU resources promotes the integrity of the system since programs operating in Normal Mode cannot access those aspects of the CPU which deal with time-dependent or system interface events. > Normal Mode programs that have errors can always reproduce those errors for debugging purposes by simply re-executing the programs with their original data. Programs using facilities available only in System Mode may have errors due to timing considerations (e.g., based on the frequency of disk requests and disk arm position) that are harder to debug because these errors are not easily reproduced. Thus a preferred method of program development would be to partition the task into that portion which can be performed without recourse to resources accessible only in System Mode (which will usually be the bulk of the task) and that portion requiring System Mode resources. The classic example of this partitioning comes from current minicomputer and mainframe systems: the operating system runs in System Mode and the individual users write their programs to run in Normal Mode. To further support the System/Normal Mode dichotomy, there are two copies of the stack pointer—one for the System Mode and another for Normal. Although the stacks are separated. it is possible to access the normal stack registers while in the System Mode by using the LDCTL instruction. #### Status Lines The Z8000 CPU outputs status information over its four status lines (ST<sub>0</sub>-ST<sub>3</sub>) and the System/Normal line (S/N). This information can be used to extend the addressing range or to protect accesses to certain portions of memory. The types of status information and their codes are listed in Table 2. Status conditions are mutually exclusive and can, therefore, be encoded without penalty. Most status definitions are self-explanatory. One code is reserved for future enhancements of the Z8000 Family. Extension of the addressing range is accomplished in a Z8000 system by allocating physical memory to specific usage (program vs. data space, for example) and using external circuitry to monitor the status lines and select the appropriate memory space for each address. For example, the direct addressing range of the Z8002 CPU is limited to 64K bytes; however, a system can be configured with 128K bytes if additional logic is used. say, to select the lower 64K bytes for program references and the upper 64K bytes for data references. | ST <sub>3</sub> -ST <sub>0</sub> | Definition | | | |----------------------------------|--------------------------------------|--|--| | 0000 | Internal operation | | | | 0001 | Memory refresh | | | | 0010 | I/O reference | | | | 0011 | Special I/O reference | | | | 0100 | Segment trap acknowledge | | | | 0101 | Non-maskable interrupt acknowledge | | | | 0110 | 0 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 | Instruction space access | | | | 1101 | Instruction fetch, first word | | | | 1110 | Extension processor transfer | | | | 1111 | Reserved | | | Table 2 ## Status Lines (Continued) Protection of memory by access types is accomplished similarly. The memory is divided into blocks of locations and associated with each block is a set of legal status signals. For each access to the memory, the external circuit checks whether the CPU status is appropriate for the memory reference. The Z8010 Memory Management Unit is an example of an external memory-protection circuit, and it is discussed later in this tutorial. The first word in an instruction fetch has its own dedicated status code, namely 1101. This allows the synchronization of external circuits to the CPU. During all subsequent fetch cycles within the same instruction (remember, the longest instruction requires a total of four word fetches), the status is changed from 1101 to 1100. Load Relative and Store Relative also have a status of 1100 with the data reference, so information can be moved from program space to data space. #### Refresh The idea of incorporating the Refresh Counter in the CPU was pioneered by the Z-80 CPU, which performs a refresh access in a normally unused time slot after each opcode fetch. The Z8000 is more straightforward (each refresh has its own memory-access time slot of three clock cycles), and is more versatile (the refresh rate is programmable and capable of being disabled altogether). The Refresh Register contains a 9-bit Row Counter, a 6-bit Rate Counter and an Enable Bit (Figure 5). The row section is output on AD<sub>0</sub>-AD<sub>8</sub> during a refresh cycle. The Z8000 CPU uses word-organized memory, wherein An is only employed to distinguish between the lower and upper bytes within a word during reading or writing bytes. An therefore plays no role in refresh—it is always 0. The Row Counter is—at least conceptually—always incremented by two whenever the rate counter passes through zero. The Row Counter cycles through 256 addresses on lines AD<sub>1</sub>-AD<sub>8</sub>, which satisfies older and current 64- and 128-row addressing schemes, and can also be used with 256-row refresh schemes for 64K RAMs. 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 from 1 to 64 $\mu s$ with a 4 MHz clock. A value of zero in the counter field indicates the maximum time between refreshes; a value of n indicates that refresh is to be performed every 4n clock cycles. Refresh can be disabled by programming the Refresh Enable Bit to be zero. A memory refresh occurs as soon as possible after the indicated time has elapsed. Generally, this means after the $T_3$ clock cycle of an instruction if an instruction execution has commenced. When the CPU does not have control of the bus (during the bus-request/bus-acknowledge sequence, for example), it cannot issue refresh commands. Instead, it has internal circuitry to record "missed" refreshes; when the CPU regains control of the bus it immediately issues the "missed" refresh cycles. The Z8001 and Z8002 CPU can record up to two "missed" refresh cycles. Figure 5. Refresh Counter #### Instruction Prefetch (Pipelining) Most instructions conclude with two or three clock cycles being devoted to internal CPU operations. For such instructions, the subsequent instruction-fetch machine cycle is overlapped with the concluding operations, thereby improving performance by two or three clock cycles per instruction. Examples of instructions for which the subsequent instruction is fetched while they complete are Arithmetic and Shift instructions. Some instructions for which the overlap is logically impossible are the Jump instructions (because the following instruction location has not been determined until the instruction completes). Some instructions for which overlap is physically impossible are the Memory Load instructions (because the memory is busy with the current instruction and cannot service the fetch of the succeeding instruction). # Extended Instruction Facility The Z8000 architecture has a mechanism for extending the basic instruction set through the use of external devices. Special opcodes have been set aside to implement this feature. When the CPU encounters instructions with these opcodes in its instruction stream, it will perform any indicated address calculation and data transfer, but otherwise treat the "extended instruction" as being executed by the external device. Fields have been set aside in these extended instructions which can be interpreted by external devices (called Extended Processing Units—EPUs) as opcodes. Thus by using appropriate EPUs, the instruction set of the Z8000 can be extended to include specialized instructions. In general, an EPU is dedicated to performing complex and time consuming tasks in order to unburden the CPU. Typical tasks suitable for specialized EPUs include floating-point arithmetic, data base search and maintenance operations, network interfaces, graphics support operations—a complete list would include most areas of computing. EPUs are generally designed to perform their tasks on data resident in their internal registers. Moving information into and out of the EPU's internal registers, as well as instructing the EPU as to what operations are to be performed, is the responsibility of the CPU. For the Z8000 CPU, control of the EPUs takes the following form. The Z8000 CPU fetches instructions, calculates the addresses of operands residing in memory, and controls the movement of data to and from memory. An EPU monitors this activity on the CPU's AD lines. If the instructions fetched by the CPU are extended instructions, all EPUs and the CPU latch the instruction (there may be several different EPUs controlled by one CPU). If the instruction is to be executed by a particular EPU, both the CPU and the indicated EPU will be involved in executing the instruction. If the extended instruction indicates a transfer of data between the EPU's internal registers and the main memory, the CPU will calculate the memory address and generate the appropriate timing signals (AS, DS, MREQ, etc.), but the data transfer itself is between the memory and the EPU (over the AD lines). If a transfer of data between the CPU and EPU is indicated, the sender places the data on the AD lines and the receiver reads the AD lines during the next clock period. If the extended instruction indicates an internal operation to be performed by the EPU. the EPU begins execution of that task and the CPU is free to continue on to the next instruction. Processing then proceeds simultaneously on both the CPU and the EPU until a second extended instruction is encountered that is destined for the same EPU (if more than one EPU is in the system, all can be operating simultaneously and independently). If an extended instruction specifies an EPU still executing a previous extended instruction, the EPU can suspend instruction fetching by the Z8000 CPU until it is ready to accept the next extended instruction: the mechanism for this is the STOP line, which suspends CPU activity during the instruction fetch cycle. There are four types of extended instructions in the Z8000 CPU instruction repertoire; EPU internal operations; data transfers between memory and EPU; data transfers between EPU and CPU; and data transfer between EPU flag registers and CPU flag and control word. The last type is useful when the program must branch based on conditions determined by the EPU. Six opcodes are dedicated to extended instructions: OE, OF, 4E, 4F, 8E and 8F (in hexadecimal). The action taken by the CPU upon encountering these instructions is dependent upon an EPU control bit in the CPU's FCW. When this bit is set, it indicates that the system configuration includes EPUs; therefore, the instruction is executed. If this bit is clear, the CPU traps (extended instruction trap), so that a trap handler in software can emulate the desired operation. In conclusion, the major features of this capability are, that multiple EPUs can be operating in parallel with the CPU, that the five main CPU addressing modes (Register, Immediate, Indirect Register, Direct Address, Indexed) are available in accessing data for the EPU; that each EPU can have more than 256 different instructions; and that data types manipulated by extended instructions can be up to 16 words long. # Program Status Information The Program Status Information consists of the Flag And Control Word (FCW) and the Program Counter (PC). The Z8000 CPU uses one byte in FCW to store flags and another byte to store control bits. **Arithmetic Flags.** Flags occupy the low byte in the FCW and are loaded, read, set and reset by the special instruction LDCTLB, RESFLG and SETFLG. The flags are: C Carry Z Zero Sign (1 = negative; two's complement notation is used for all arithmetic on data elements) P/V Even Parity or Overflow (the same bit is shared) Decimal Adjust (differentiates between addition and subtraction) H Half Carry (from the low-order nibble) **Control Bits.** The control bits occupy the upper byte in the FCW. They are loaded and read by the LDCTL instruction, which is privileged in that it can be executed only in the System Mode. The control bits are: **NVIE** Non-Vectored Interrupt Enable VIE Vectored Interrupt Enable S/N System or Normal Mode SEG Segmented Mode Enable (Z8001 only) The SEG bit is always 0 in the Z8002 even if the programmer attempts to set it. In the Z8001, a 1 in this bit indicates segmented operation. A 0 in the Z8001 SEG bit forces non-segmented operation and the CPU interprets all code as non-segmented. Thus, the Z8001 can execute modules of user code developed for the non-segmented Z8002. #### Interrupt and Trap Structure The Z8000 provides a 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), three internal traps (system call, unimplemented instruction, privileged instruction) and a segmentation trap. The vectored and nonvectored interrupts are maskable. The descending order of priority for traps and interrupts is: internal traps, non-maskable interrupts, segmentation trap, vectored interrupts and non-vectored interrupts. #### Effects of Interrupts on Program Status The Flag and Control Word and the Program Counter are collectively called the Program Status Information—a useful grouping because both the FCW and PC are affected by interrupts and traps. When an interrupt or trap occurs, the CPU automatically switches to the System Mode and saves the Program Status plus an identifier word on the system stack. The identifier supplies the reason for the interrupt. (The Z8002 pushes three words on the stack; the Z8001 pushes four words.) After the pre-interrupt or "old" Program Status has been stored, the "new" Program Status is automatically loaded into the FCW and PC. This new Program Status Information is obtained from a specified location in memory, called the Program Status Area. The Z8000 CPU allows the location of the Program Status Area anywhere in the addressable memory space, although it must be aligned to a 256-byte boundary. Because the Status Line code is 1100 (program reference) when the new Program Status is loaded, the Program Status must be located in program memory space if the memory uses this attribute (for example, when using the Z8010 Memory Management Unit or when separate memory modules are used for program and for data). The Program Status Area Pointer (PSAP) specifies the beginning of the Program Status Area. In the Z8002, the PSAP is stored in one word, the lower byte of which is zero. The Z8001, however, stores its PSAP in two words. The first contains the segment number and the second contains the offset, the lower byte of which is again zero. The PSAP is loaded and read by the LDCTL instruction. In the Z8002, the first 14 words (28 bytes) of the Program Status Area contain the Program Status Information for the following interrupt conditions: | Location<br>(In Bytes) | Condition | | | |------------------------|------------------------------------------------------------------------|--|--| | 0-3 | Not used (reserved for future use) | | | | 4-7 | Unimplemented instruction has been fetched, causing a trap | | | | 8-11 | Privileged instruction has been fetched in Normal Mode, causing a trap | | | | 12-15 | System Call instruction | | | | 16-19 | Not used | | | | 20-23 | Non-maskable interrupt | | | | 24-27 | Non-vectored interrupt | | | Effects of Interrupts on Program Status (Continued) Bytes 28-29 contain the FCW that is common to all vectored interrupts. Subsequent locations contain the vector jump table (new PC for vectored interrupts). These locations are addressed in the following way: the 8-bit vector that the interrupting device has put on the lower byte of the Address/Data bus $(AD_0-AD_7)$ is doubled and added to PSAP + 30. Thus, Vector 0 addresses PSAP + 30, Vector 1 addresses PSAP + 32, and Vector 255 addresses PSAP + 540. In the segmented Z8001, the first 28 words of the Program Status Area (56 bytes) contain the Program Status Information (reserved word, FCW, segment number, offset), for the following interrupt conditions: | Location<br>(In bytes) | Condition | | | | |------------------------|-------------------------------------------------------------------------------------------|--|--|--| | 0-7 | Not used (reserved for future use) | | | | | 8-15 | Unimplemented instruction has been fetched causing a trap | | | | | 16-23 | Privileged instruction has been<br>fetched in Normal Mode causing<br>a trap | | | | | 24-31 | System Call instruction | | | | | 32-39 | Segmentation trap (memory viola-<br>tion detected by the Z8010 Memory<br>Management Unit) | | | | | 40-47 | Non-maskable ınterrupt | | | | | 48-55 | Non-vectored interrupt | | | | Bytes 56-59 contain the reserved word and FCW common to all vectored interrupts. Subsequent locations contain the vector jump table (the new segment number and offset for all vectored interrupts). These locations are addressed in the following way: the 8-bit vector that the interrupting device has put on the lower byte of the Address/Data bus $(AD_0-AD_7)$ is doubled and added to PSAP + 60. Thus, Vector 0 addresses PSAP + 60, Vector 2 addresses PSAP + 64, and Vector 254 addresses PSAP + 568. Care must be exercised in allocating vector locations to interrupting devices; always use even vectors. Thus there are effectively only 128 entries in the vector jump table. (Figure 6 illustrates the Program Status Area.) Figure 6. Program Status Ārea 504 #### Z8000 CPU Memory Features The way a processor addresses and manages its memory is an important aspect in both the evaluation of the processor and the design of a computer system that uses the processor. Z8000 architecture provides a consistent memory address notation in combining bytes into words and words into long words. All three data types are supported for operands in the Z8000 instruction set. I/O data can be either byte- or word-oriented. The Z8001 CPU provides a segmented addressing space with 23-bit addressing. The Z8010 Memory Management Unit can increase the address range of this processor. To support a memory management system, the Z8001 processor generates Processor Status Information. These signals are also generated by the Z8002 CPU and—as mentioned earlier—can be used to increase the address range of this processor beyond its nominal 64K byte limit. It is not necessary to use a Z8010 Memory Management Unit with a Z8001. The segment number (upper six bits of the address) can be used directly by the memory system as part of the absolute address. These issues are discussed in more detail in the following sections, along with a description of the method used to encode certain segmented addresses into one word. A brief comment on the use of 16K Dynamic RAMs with the Z8001 concludes this group of sections that deal with Z8000 CPU memory features. #### Address Notation In the Z8000 CPU, memory and I/O addresses are always byte addresses. Words or long words are addressed by the address of their most significant byte (Figure 7). Words always start on even addresses ( $A_0=0$ ), so both bytes of a word can be accessed simultaneously. Long words also start on even addresses. Within a word, the upper (or more significant) byte is addressed by the lower (and always even) address. Similarly, within a long word, the upper (more significant) word is addressed by the lower address. Note that this format differs from the PDP-11 but is identical to the IBM convention. There is good reason for choosing this format. Because the Z8000 CPU can operate on 32-bit long words and also on byte and word strings, it is important to maintain a continuity of order when words are concatenated into long words and strings. Making ascending addresses proceed from the highest byte of the first word to the lowest byte of the last word maintains this continuity, and allows compar- ing and sorting of byte and word strings. Bit labeling within a byte does not follow this order. The least significant bit in a byte, word or long word is called Bit 0 and occurs in the byte with the highest memory address. This is consistent with the convention where bit n corresponds to position $2^n$ in the conventional binary notation. This ordering of bit numbers is also followed in the registers. Figure 7. Memory Addressing 2048-0205 #### Memory and I/O Addressing Like most 16-bit microprocessors, the Z8000 CPU uses a 16-bit parallel data bus between the CPU and memory or I/O. The CPU is capable of reading or writing a 16-bit word with every access. Words are always addressed with even addresses ( $A_0 = 0$ ). All instructions are words or multiple words. The Z8000 CPU can, however, also read and write 8-bit bytes, so memory and I/O addresses are always expressed in bytes. The Byte/Word (B/ $\overline{W}$ ) output indicates whether a byte or word is addressed (High = byte). $A_0$ distinguishes between the upper and lower byte in memory or I/O. The most significant byte of the word is addressed when $A_0$ is Low (Figure 8). For word operations in both the read and write modes, $B/\overline{W} = Low$ , $A_0$ is simply ignored and A<sub>1</sub>-A<sub>15</sub> address the memory or I/O. For byte operations in the read mode, $B/\overline{W} = High$ , $A_0$ is again ignored, and a whole word (both bytes) is read, but the CPU internally selects the appropriate byte. For byte operations in the write mode, the CPU outputs identical information on both the Low $(AD_0-AD_7)$ and the High $(AD_8-AD_{15})$ bytes of the Address/Data bus. External TTL logic must be used to enable writing in one memory byte and disable writing in the other byte, as defined by A<sub>0</sub>. The replication of byte information for writes is for the current implementation and may change for subsequent Z8000 CPUs; therefore system designs should not depend upon this feature. Figure 8. Byte/Word Selection #### Segmentation In organizing memory, segmentation is a powerful and useful technique because it forms a natural way of dividing an address space into different functional areas. A program typically partitions its available memory into disjointed areas for particular uses. Examples of this are storing the procedure instructions, holding its global variables, or serving as a buffer area for processing large, disk-resident data bases. The requirements for these different areas may differ, and the areas themselves may be needed only part of the time. Segmentation reflects this use of memory by allowing a user to employ a different segment for each different area. A memory management system can then be employed to provide system support, such as swapping segments from disk to primary memory as requested (as in overlays), or in monitoring memory accesses and allowing only certain types of accesses to a particular segment. Thus, dealing with segments is a convenient way of specifying portions of a large address space. When segmentation is combined with an address translation mechanism to provide relocation capability, the advantages of segmentation are enhanced. Now segments can be of variable user-specifiable sizes and located anywhere in memory. The Z8001 generates 23-bit logical addresses, consisting of a 7-bit segment number and a 16-bit offset. Thus each of its six memory address spaces consists of 128 segments, and each segment can be up to 64K bytes. Different routines of a program can reside in different segments, and different data sets can reside in different segments. The Z8010 Memory Management Unit translates these logical addresses into physical-memory locations. 2048-0206 #### Long Offset and Short Offset Addressing When a segmented address is stored in memory or in a register, it occupies two 16-bit words as previously described for the PC and PSAP. This is a consequence of the large addressing range. When a segmented address is part of an instruction in the Direct Address and Indexed Address Modes, there are two representations: Long and Short Offset addressing. In the general unrestricted case of Long Offset, the segmented address occupies two words, as described before. The most significant bit in the segment word is a 1 in this case. The Short Offset Mode squeezes the segment number and offset into one word, saving program size and execution time. Since 23 bits obviously don't fit into a 16-bit word, the 8 most significant bits of the offset are omitted and implied to be zero. The most significant bit of the address word is made 0 to indicate Short Offset Mode. Short Offset addresses are thus limited to the first 256 bytes at the beginning of each segment. This may appear to be a severe restriction, but it is very useful, especially in the Index Mode, where the index register can always supply the full 16-bit range of the offset. Short Offset saves one instruction word and speeds up execution by two clock cycles in Direct Address Mode and three clock cycles in Indexed Mode. #### Using the Z8010 Memory Management Unit The Z8001 CPU can be combined with another 48-pin LSI device—the Z8010 MMU—for sophisticated memory management. The MMU provides address translation from the logical addresses generated by the Z8001 CPU to the physical addresses used by the memory. An address translation table, containing starting addresses and size information for each of the 64 segments, is stored in the MMU. The translation table can be written and read by the CPU using Special I/O instructions. The MMU thus provides address relocation under software control, making software addresses (i.e., logical addresses) independent of the physical memory addresses. But the MMU provides much more than address relocation; it also monitors and protects memory access. The MMU provides a Trap input to the CPU and—if necessary—an inhibit signal (SUP) to the memory write logic when specific memory-access violations occur. The MMU provides the following types of memory protection: - Accesses outside the segment's alloted memory can be prevented. - Any segment can be declared invalid or non-accessable to the CPU. - Segments can be declared Read Only. - By designating a segment as System Only, access can be prohibited during the Normal Mode. - Declaring a segment Execute Only means it can be accessed only during instruction access cycles. Data or stack use is prohibited. - Any segment can be excluded from DMA access. - Segments can have a Direction And Write Warning attribute, which generates a trap when a write access is made in the last 256 bytes of its size. This mechanism can be used to prevent stack overflow. Multiple MMUs must be used when more than 64 segments are needed. Thus, to support the full complement of 128 segment numbers provided for each Z8001 CPU address space, two MMUs are required. The MMU has been designed for multiple-chip configurations, both to support 128-segment translation tables and to support multiple translation table systems. Note that the memory management features do not interfere with the ability to directly address the entire memory space. Once programmed, the MMU (or MMUs) translates and monitors any memory address generated by the CPU. The MMU contains status bits that describe the history of each segment. One bit for each segment indicates whether the segment has been accessed; another bit indicates whether the segment has been written. This is important for certain memory management schemes. For example, the MMU indicates which segments have been updated and, therefore, must be saved on disk before the memory can be used by another program. When translating logical addresses to physical memory addresses, the MMU must do the following: access its internal $64 \times 32$ -bit RAM, using the segment number as the address, then add the 16 bits of RAM output to the most significant address byte (AD<sub>8</sub>-AD<sub>15</sub>) and finally place the result on its Address outputs. The least significant byte (AD<sub>0</sub>-AD<sub>7</sub>) bypasses the MMUI The internal RAM access time is approximately 150 ns. Throughput delay is avoided by making the segment number available early: $SN_0$ - $SN_7$ are output one clock period earlier than the address information on $AD_0$ - $AD_7$ . In summary, the Z8000 CPU supports sophisticated memory management through such architectural features as the Status Lines, the $R/\overline{W}$ and $S/\overline{N}$ lines, Segment Trap input line, and early output of segment numbers. #### Using 16K Dynamic RAMs with the Z8001 Z8000 systems usually implement most of their memory with $16K \times 1$ -bit dynamic RAMs that have time-multiplexed addresses (Zilog also manufactures this device—the Z6116). In Z8001-based systems with MMUs, CPU Address/Data lines $AD_1$ - $AD_7$ supply row addresses, MMU address outputs $A_8$ - $A_{14}$ supply column addresses, and MMU outputs $A_{15}$ - $A_{23}$ are decoded to generate Chip Select signals that gate either $\overline{RAS}$ or $\overline{CAS}$ or both. Gating RAS reduces power consumption because all non-selected memories remain in the standby mode. But this technique requires that $\overline{\text{RAS}}$ must wait for the availability of the most significant address bits from the MMU. During refresh, the $\overline{\text{RAS}}$ decoder must be changed to activate all memories simultaneously. Gating $\overline{\text{CAS}}$ does not achieve lower power consumption; however, this technique allows the use of slower memories because $\overline{\text{RAS}}$ can be activated as soon as the CPU address outputs are stable, without waiting for the MMU delay. Also, there is no need to change the $\overline{\text{CAS}}$ decoder during refresh. #### Data Types and Instructions The Z8000 architecture directly supports bits, digits, bytes, and 16- or 32-bit integers as primitive operands in its instruction set. In addition, the rich set of addressing modes supports higher-level data constructs such as arrays, lists and records. The Z8000 also intro- duces a number of powerful instructions that extend the capabilities of microprocessors. The remaining sections of this paper describe Z8000 data types, addressing modes, and a selection of novel instructions. #### Data Types Operands are 1, 4, 8, 16, 32, or 64 bits, as specified by the instruction. In addition, strings of 8- or 16-bit data can be manipulated by single instructions. Of particular interest are the increased precisions of the arithmetic instructions. Add and Subtract instructions can operate on 8-, 16-, or 32-bit operands; Multiply instructions can operate on 16- or 32-bit multiplicands; and Divide instructions can operate on 32- or 64-bit dividends. The Shift instructions can operate on 8-, 16-, and 32-bit registers. #### Addressing Modes The rich variety of addressing modes offered by Z8000 architecture includes: Register, Immediate, Indirect Register, Direct Address, Index, Relative Address, Base Address, and Base Index. Three are of particular interest with respect to high-level data structures: Indirect Register, Base Address, and Base Index. These modes can be used for lists, records, and arrays, respectively. Indirect Register. In this addressing mode, the contents of the register are used as a memory address. This mode is needed whenever special address arithmetic must be performed to reference data. Essentially, the address is calculated in a register and then used to fetch the data. For example, this mode is useful when manipulating a linked list, where each entry contains a memory pointer to the memory location of the next entry. Essentially, the pointer is loaded into a register and used to access the next item on the list. When the list item is large or has a complex structure, the Base Address or Base Index Modes can be used to access various components of the item. **Base Address.** In this addressing mode, the memory address contained in the register (the base) is modified by a displacement in the instruction (known at compile time). This mode is useful, for example, in accessing fields within a record whose format is fixed at compile time. **Base Index.** The memory address in this addressing mode is contained in a register (the base) and is modified by the contents of another register (the index). This mode can be useful in accessing the components of an array, because the index of the component is usually calculated during execution time—as a function of the index of a DO-Loop, for example. **Index vs. Base Address.** In the Z8002 and in the Z8001 running non-segmented, these two addressing modes are functionally equivalent, because the base address and displacement are both 16-bit values. When the Z8001 runs segmented, there is a difference: in the Index mode, the base address (including the segment number) is contained in the instruction, in either Short Offset or Long Offset notation. The 16-bit displacement stored in a register is then added to the offset in the base address to calculate the effective address. In the Base Address Mode, on the other hand, the 16-bit displacement is specified in the instruction and is added to the offset of the base address that is stored in a long-word register. #### The Instruction Set The Z8000 offers an abundant instruction set that represents a major advance over its predecessors. The Load and Exchange instructions have been expanded to support operating system functions and conversion of existing microprocessor programs. The usual Arithmetic instructions can now deal with higher-precision operands, and hardware Multiply and Divide instructions have been added. The Bit Manipulation instructions can access a calculated bit position within a byte or word, as well as specify the position statically in the instruction. The Rotate and Shift instructions are considerably more flexible than those in previous microprocessors. The String instructions are useful in translating between different character codes. Special I/O instructions are included to manage peripheral devices, such as the Memory Management Unit, that do not respond to regular I/O commands. Multiple-processor configurations are supported by special instructions. The following instructions exemplify the innovative nature of the Z8000 instruction set. A complete list of Z8000 instructions can be found in the reference materials listed at the end of this tutorial. #### Load and Exchange Instructions. Exchange Byte (EX) is practical for converting Z-80, 8080, 6800 and other microprocessor programs into Z8000 code, because the Z8000 uses the opposite assignment of odd/even addresses in 16-bit words. **Load Multiple (LDM)** saves n registers and is useful for switching tasks. **Load Relative (LDR)** loads fixed values from program space into data space. #### **Arithmetic Instructions.** Add With Carry and Subtract With Carry (ADC, SBC) are conventionally used in 8-bit microprocessors for multiprecision arithmetic operations. These instructions are rarely used with the Z8000 CPU because it has 16- and 32-bit arithmetic instructions. Decrement By N and Increment By N (DEC, INC) are intended for address and pointer manipulation, but can also be used for Quick Add/Subtract Immediate with 4-bit nibbles. The flag setting is different from Add/Subtract instructions—as is conventional—in that the Carry and Decimal adjust flags are unaffected by the Increment and Decrement instructions to support multiple precision arithmetic. **Decimal Adjust (DAB)** automatically generates the proper 2-digit BCD result after a byte Add or Subtract operation, and eliminates the need for special decimal arithmetic instructions. Multiply (MULT) provides signed (two's complement) multiplication of two words, generating a long-word result; or of two long-words generating a quadruple word result. No byte multiply exists because it is rarely used and, after sign extension, can be performed by a word multiply. Divide (DIV) provides signed (two's complement) division of a long word by another word, generating a word quotient and a remainder word; or of one quadruple-word by a longword, generating a long-word quotient and long-word remainder. Both Multiply and Divide use a conforming register assignment. That is, a multiply followed by a divide on the same registers is essentially a no-op. The register designation used in the operation description must be even for word operations and must be a multiple of four for long-word operations. #### Logical Instructions. Test Condition Code (TCC) performs the same test as a Jump instruction, but affects the least significant bit of a specified register instead of changing the PC. #### Program Control Instructions. Call Relative (CALR) is a shorter, faster version of Call, but with a limited range. Decrement And Jump If Non-Zero (DJNZ) is a one-word basic looping instruction. Jump Relative (JR) is a shorter, faster version of Jump, but with a limited range. #### Bit Manipulation Instructions. Test Bit, Reset Bit, Set Bit (BIT, RES, SET) are available in two forms: static and dynamic. For the static form, any bit (the position is defined in the immediate word of the instruction) located in any byte or word in any register or in memory can be set, reset or tested (inverted and routed into the Z flag). For the dynamic form, any bit (the position is defined by the content of a register that is, in turn, specified in the instruction) located in any byte or word in any register, but not in memory, can be set, reset or tested. Test And Set (TSET) is a read/modify/write instruction normally used to create operating system locks. The most significant bit of a byte or word in a register or in memory is routed into the S flag bit and the whole byte or word is then set to all 1s. During this instruction, the processor does not relinquish the bus. Test Multi-Micro Bit and Multi-Micro Request/Set/Reset (MBIT, MREQ, MSET, MRES) are used to synchronize the access by multiple microprocessors to a shared resource, # The Instruction Set (Continued) such as a common memory, bus, or I/O device. Note that the instruction MREQ (Multi-Microprocessor Request) has nothing what-soever in common with the $\overline{\text{MREQ}}$ (Memory Request) output from the Z8000 CPU. #### Rotate and Shift Instructions. The Z8000 CPU has a complete set of shift instructions that shift any combination of bytes or words, right or left, arithmetically or logically, by any meaningful number of positions as specified either in the instruction (static) or in a register (dynamic). The CPU also has a smaller repertoire of rotate instructions that rotates bytes or words, either right or left, through carry or not, and by one bit or by two bits. The instructions Rotate Digit Left and Rotate Digit Right (RLDB, RRDB) rotate 4-bit BCD digits right or left, and are used in BCD arithmetic operations. ### Block Transfer and String Manipulation Instructions. Translate And Decrement/Increment (TRDB, TRIB) is used for code conversion, such as ASCII to EBCDIC. These instructions translate a byte string in memory by substituting one string by its table-lookup equivalent. TRDB and TRIB execute one operation and decrement the contents of the length register; thus they are useful as part of loop performing several actions on each character. Translate, Decrement/Increment and Repeat (TRDRB, TRIRB) are the same as TRDB and TRIB, except they repeat automatically until the contents of the length register become zero. They are therefore useful in straightforward translation applications. Translate And Test, Decrement/Increment (TRTDB, TRTIB) tests a character according to the contents of the translation table. Translate And Test, Decrement/Increment And Repeat (TRTDRB, TRTIRB) scans a string of characters. The first character is tested and, depending on the contents of the translation table, the process stops or skips to the next character. Stopped characters can be used for further processing. #### I/O and Special I/O Instructions. The Z8000 CPU has two complete sets of I/O instructions: Standard I/O and Special I/O. The only difference is the status information on the ST<sub>0</sub>-ST<sub>3</sub> outputs. Standard I/O instructions are used to communicate with Z-Bus compatible peripherals. Special I/O instructions are typically used for communicating with the Memory Management Unit. Both types of instructions transfer 8 or 16 bits and use a type of 16-bit addressing analogous to the Z8002 memory-addressing scheme: For word operations, $A_0$ is always zero; in byte-input operations, $A_0$ is used internally by the CPU to select the appropriate byte; in byte-output operations, the byte is duplicated in the high and low bytes of the address/data bus, and external logic uses $A_0$ to enable the appropriate output device. #### Biliography Selected Publications on the Z8000 Family Z8001/Z8002 CPU Product Specification (00-2045) Z8000 CPU Instruction Set (03-8020-01) Z8000 PLZ/ASM Assembly Language Programming Manual (03-3055-01) Z8010 Z-MMU Product Specification (00-2046) # An Introduction to the Z8010 MMU Memory Management Unit #### Tutorial Information #### June 1982 #### Introduction The declining cost of memory, coupled with the increasing power of microprocessors, has accelerated the trend in microcomputer systems to the use of high-level languages, sophisticated operating systems, complex programs and large data bases. The Z8001 microprocessor supports these advances by offering multiple 8M byte address spaces as well as a rich and powerful instruction set. The Z8010 Memory Management Unit (MMU) supports the Z8001 processor in the efficient and flexible use of its large address space. Support for managing a large memory can take many forms: - Providing a logical structure to the memory space that is largely independent of the actual physical location of the data - Protecting the user from inadvertent mistakes such as attempting to execute data - Preventing one user from unauthorized access to memory resources or data - Protecting the operating system from unexpected access by the users. The Z8010 provides all these features plus additional features that permit a variety of system hardware configurations and system designs. This paper examines the various uses of memory management in computer systems and how memory management techniques generally meet these requirements. The major features of the Z8010 MMU illustrate how memory management functions can be supported by hardware. A few examples demonstrate how this LSI circuit can be used to configure several different memory management systems. #### Motivations for Memory Management The primary memory of a computer is one of its major resources. As such, the management of this resource becomes a major concern as demands on it increase. These demands can arise from different sources, three of which are of interest in the present context. The first stems from multiple users (or multiple tasks within a dedicated application) contending for a limited amount of physical memory. The second comes from the desire to increase the integrity of the system by limiting access to various portions of the memory. The final source arises from issues surrounding the development of large, complex programs or systems. Each of these three sources involves a multifaceted group of related issues. When multiple tasks constitute a given system (for example, multiple users of a system or multiple sub-tasks of a dedicated application), the possibility exists that not all tasks may be in primary memory at the same time. (A task is the action of executing a program on its data; a task may be as simple as a single procedure or as complex as a set of related routines.) If the population of memory-resident tasks can vary over time, a useful feature of a system would be the ability for a task to recide anywhere in memory, and perhaps in several different locations during its lifetime. Such tasks are called relocatable, and a system in which all tasks are relocatable generally offers greater flexibility in responding to changing system environments than a system in which each task must reside in a fixed location. A second issue that arises in multi-task environments is that of sharing. Separate tasks may execute the same program on different data, and may therefore share common code. For example, several users compiling FOR-TRAN programs may wish to share the compiler rather than each user having a separate copy in memory. Alternatively, several tasks may wish to execute different programs using the same data as input, and it may be possible for these tasks to access the same copy of the Motivations for Memory Management (Continued) input. For example, a user may wish to print a PASCAL program while it is being compiled; the print process and the compiler process could access the same copy of the text file. A third issue in multi-task systems is protecting one task from unwanted interactions with another. The classic example of unwanted interaction is one user's unauthorized reading of another user's data. Prohibiting all such interactions conflicts with the goal of sharing and so this issue is usually one of selectively prohibiting certain types of interactions. The issue of protecting memory resources from unauthorized access is usually included in the larger set of issues relating to system integrity. System integrity takes many forms in addition to protecting a task's data from unwanted access. Another aspect is preventing user tasks from performing operating system functions and thereby interrupting the orderly dispatch of these tasks. For example, most large systems prevent a user task from directly initiating I/O operations because this can disrupt the correct functioning of the system. Another aspect of separating users from system functions relates to separating system I/O transfers from user tasks, especially with respect to error conditions. For example, an error during a direct memory access, say to a nonexistant memory location, should not cause an error in the program that is currently executing. A final example of increasing the system integrity is protecting a user task from itself. Obvious errors, such as trying to execute data or overflowing an area set aside for a stack, can be detected while a program is executing and handled appropriately, provided the system is given sufficient information. The notion of protecting an executing task from performing certain types of actions known to be erroneous introduces a third general motivation for memory management, namely support for the design and correct implementation of large, complex programs and systems. Protecting a task from itself obviously helps in debugging a large program, but there are other system features that can aid in developing complex systems. Modern methodology for developing large systems dictates partitioning a task into a number of small, simple, selfcontained sub-tasks with well defined interfaces. Each sub-task generally interacts with only a few other sub-tasks and this communication is carefully controlled. This methodology promotes a systems design that can be readily modified, but it also tends to promote the creation of a large number of nearly independent sub-tasks and many data structures accessible to only one or a few of these sub-tasks. Because modern systems are increasingly driven to support many interacting tasks, possibly written and compiled separately, they must also enforce some communication protocol without sacrificing efficient operation. Modern memory management systems can offer effective tools for implementing large systems designed using this methodology. In summary, the major goals of memory management systems are to: - Provide flexible and efficient allocation of memory resources during the execution of tasks - Support multiple, independent tasks that can share access to common resources - Provide protection from unauthorized or unintentional access to data or other memory resources - Detect obviously incorrect use of memory by an executing task - Separate users from system functions. Most of today's memory management systems support these functions to some degree. The extent of this support is largely a question of resources to be devoted to these functions and the understood demands of the intended applications for these systems. The Fundamentals of Memory Management Memory management has two functions: the *allocation* and the *protection* of memory. Dynamic relocation of tasks during their execution is accomplished by an address translation mechanism. The restriction of memory access is accomplished by memory attribute checking. Both operations occur with each memory request during the execution of a program and both are transparent to the user. Address translation simply means treating the memory addresses generated by the program as logical addresses to be interpreted or translated into actual physical memory locations before dispatching the memory access requests to the memory unit. Memory attribute checking means that each area of memory has associated with it information as to who can access it and what types of access can be made by each task. Each memory reference is checked to insure that the task has the right to access that location in the given fashion (for example, to read the contents of the location or to write data to that location). Instead of a linear address space, more elaborate memory management systems have a hierarchical structure in which the memory consists of a collection of memory areas, called segments. Access to this structured memory requires the specification of a segment and an offset within that segment. Thus, instead of specifying memory location 1050 in a linear address space, a task specifices memory location 5 in segment number 23, for example. The Fundamentals of Memory Management (Continued) Generally, segments can be of variable size, within limits, and a user can specify the size of each segment to be used. Thus one user may have two segments of two thousand and ten thousand words for his FORTRAN program and data, respectively, while another user might have three segments of three thousand, six thousand and two thousand words for her PASCAL program, data, and run-time stack. If the first user called his data segment number 5, then the first word in his data set would be accessed by the logical address (5,0) indicating segment 5, offset 0. The memory management system translates this symbolic name into the correct physical memory address. Figure 1 gives a conceptual realization of these two users' logical program spaces. The first user, User A, has his program segment called "Segment 6" and his data segment called "Segment 5." The second user, User B, has her program segment called "Segment 5," her data segment called "Segment 12" and her stack segment called "Segment 2." Notice that both users have named one of their segments "Segment 5," but they refer to different entities. This causes no problem since the system keeps the two memory areas separate. The situation is analogous to both users having an integer variable called "I" in their programs: The system realizes that these are two separate variables stored in different memory locations. User A's data segment, "Segment 5," is ten thousand words. If he references word 10,050 USER A SEG, 5 PROGRAM USER B SEG 5 PROGRAM SEG 12 DATA SEG 2 STACK Figure 1. Two User's Logical Address Space of Segment 5 he gets an error message from the system indicating that he has exceeded the allocation limit for Segment 5. Note that he does not access word 50 of Segment 6. That is, segments are logically distinct and unordered. A reference to one segment cannot inadvertently result in access to another segment. Thus, in this example, User A is prevented from accidentally (or deliberately) accessing his program as though it were part of his data segment. Figure 2 illustrates one way that these segments could be arranged in the physical memory. The dotted lines indicate the memory-mapping function from the logical address space of the user to the physical memory locations allocated to him. The figure also indicates the access attributes associated with each user's segments. For example, program segments are "execute only" and data segments are "read/write." Thus a user is prevented from executing a data segment or writing into a code segment. Figure 2. Mapping Logical Segments to Physical Memory The Fundamentals of Memory Management (Continued) Figure 3 illustrates what happens when both users have access to the same data set in primary memory, say the results of a questionnaire that both intend to analyze. Each user has a logical name associated with that data set to specify the segment in which the data set is to reside. Note that the two users have chosen to put the data set in different segments of their personal address spaces. The system-mapping function translates these different segment names to the same physical memory locations. Thus User A's access to address (2, 17) references the same physical memory location as User B's access to address (7, 17). In the figure, note that two of B's segments have been moved in physical memory to create a space large enough to hold the questionnaire data. Another topic in memory management that is supported by Z8001-Z8010 architecture but requires additional support hardware is demand swapping, or segmented virtual memory, which means that the logical memory Figure 3. Two Users Sharing a Common Segment area may not actually reside in physical memory until a task actually tries to access it. At the time an access is made to a segment missing from physical memory, the instruction execution is held in abeyance until the logical memory can be brought into the physical memory and then the instruction is allowed to proceed with the memory access. The address translation is performed, access protection is checked and the instruction proceeds as if the logical memory area had been in the physical memory at the beginning of the instruction. The instructions in the Z8001 must run to completion before the CPU can perform any action, such as responding to a missing segment trap. But with the conjunction of hardware and software to simulate the above functions, a segmented virtual memory scheme can be implemented. A final topic in memory management is paging, which is another method for partitioning a user address space and mapping it onto the physical memory. Paging is most effective when demand swapping can be supported. Essentially, paging divides the logical memory into fixed-size blocks, called pages. Like segments, the individual pages can be located anywhere in the physical memory and a translation mechanism maps logical addresses to physical memory locations. There are two differences between paging and segmenting a logical memory. First, pages are of fixed size whereas segments are of various sizes. Second, under paging, the logical memory is still linear, that is, a task accesses memory using a single number, rather than a pair as in segmentation. The major advantage of paging is in treating memory as blocks of fixed sizes, which simplifies allocating memory to users and deciding where to place the logical pages in physical memory. The major disadvantage of paging is in assigning different protection attributes to different areas in a user address space because a paged memory appears homogeneous to the user and the operating system. Paging can be combined with segmentation to produce a memory management system with the advantages of both paging and segmentation. The implementation of paging for the Z8001 requires additional support hardware and may be implemented independent of the Z8010. Before proceeding to the mechanism of memory management, it is instructive to review how a segmented address translation mechanism with protection attributes achieves the five major goals of memory management outlined in the previous section. The first goal permits dynamic allocation of memory during the execution of tasks; that is, a task could be located anywhere in memory and even moved about when its execution is suspended. The address translation mechanism provides this flexibility because the task deals exclusively #### The Fundamentals of Memory Management (Continued) with logical addresses and hence is independent of the addresses of the physical memory locations it accesses. Moving the task to different physical memory locations requires that the address mapping function be changed to reflect the change in memory location, but the task's code need not be modified. Of course, this flexibility does incur the price of managing the various system tables required to implement memory management. The second goal supports sharing of common memory areas by different tasks. This is accomplished by mapping different logical areas in different tasks to the same physical memory locations. The third provides protection against certain types of memory accesses. This is accomplished by associating accessing attributes with each logical segment and checking the type of access to see if each access is permitted. The fourth goal detects obvious execution errors related to memory accessing. This can be accomplished by checking each access to a segment to see whether the address falls within the allocated physical memory for that segment. It could also include affixing a read/write attribute to data to prevent a task from trying to execute a data segment, and affixing an execute-only attribute to code segments to prevent a task from trying to read or write data to this segment. Additionally, if a segment is used for a stack, the system could issue a warning to a task when the stack approaches the allocated limit of the segment. The task could then request more memory for the stack before the stack overflows and creates a fatal error. The final goal listed for memory manage- ment systems separates user functions from system functions. For processors that distinguish between System mode and User mode of operation, this goal can be accomplished by associating a system-only attribute with system segments so users cannot directly access system tables and tasks. As a final point, it should be noted how segmentation can be used to support the development and execution of large, complex programs and systems. The concept of segmentation corresponds to the concept of partitioning a large system into procedures and data structures where each procedure and data structure can be associated with a separate segment. A task can then invoke a procedure or sub-task or access a data structure by referring to its logical segment name. Access to these objects can be individually restricted by using the protection-checking mechanism of the memory management system. As a specific example of how segmentation could be used in the design of a large system, consider a multi-user interactive BASIC system with a large data base shared by all users. Such a system could be designed with segments 0 through 15 reserved for system use, segments 16 through 31 reserved for the BASIC interpreter and its internal tables, segments 32 through 63 allocated to user tasks and segments 64 through 127 reserved for portions of the data base when they are in primary memory being accessed by users. For this system, segments 0 through 31 would probably always be in memory; the other segments would be assigned as needed and the memory they require allocated dynamically. # The Mechan- Essentially there are four issues in impleics of Memory menting a memory management system: how Management addresses are specified, how these addresses are translated, what attributes are checked for each access, and how the protection mechanism is implemented. Some of the major alternatives in each of these issues are briefly discussed here, primarily from the point of view of a segmented memory. > Two approaches have traditionally been taken for specifying addresses in a segmented memory. For simplicity, only addresses in instructions are discussed. The first way puts all the addressing information in the instruction itself. That is, each memory address in an instruction contains both the segment name and the offset within the segment. The alternative sets aside special registers that contain some of this information, for example the segment name or the address in physical memory where the segment resides. The advantage of the latter approach lies in the fact that fewer bits are needed in an instruction to specify addresses. Thus programs may be shorter. Also, because there is reduced traffic between the memory and the processor for fetching shorter instructions, a program may execute faster. On the other hand, these special registers must be manipulated to access more segments than there are registers, and this manipulation adds to the number of instructions, the program size and the execution time. In practice, these can destroy the advantages described above. If the special registers contain physical memory locations, then these must be protected from user access to maintain the integrity of the system, and changing segments requires system calls which can be time consuming if too few registers are supplied. The Z8001 architecture specifies the complete logical address in the instruction. Address translation is performed by adding the logical segment offset to the memory location where the segment begins. Thus, when an address of the form (a, b) is presented to the translation mechanism, the segment name "a" is used to determine where segment "a" resides in memory. Assume that it resides in locations 10000 to 25000. Then the actual (Continued) The Mechan- memory location of (a, b) is memory location ics of Memory 10000 + b. The major option in implementing **Management** this type of address translation is in determining the segment location in physical memory. When special registers have been set aside to contain the starting location of the segment instead of putting all address information in the instruction, the addressing mechanism is similar to using the segment register as an index register or a base register. > When logical addresses are either completely specified in the instruction or when the special register contains the symbolic segment name, a table must be used to translate the logical segment name into a physical memory location. The table may have an associative capability, that is, the segment name is presented to the table and the device returns the physical memory location where the segment begins. Alternatively, the table could have one entry for every possible segment name. The Z8010 implementation of the address translation table sets aside a specific table entry for each logical segment name. > A number of attributes can be associated with a segment and checked during each access. One of these is the allocated length of the segment, and each access is checked to see if it falls within the bounds of the segment. The Z8010 provides limit checking. Another type of attribute deals with ownership or class of ownership: tasks are grouped into classes and only those in certain classes are permitted access. The simplest example is the system versus user classification, where tasks are either one or the other and this determines whether or not any type of access can be made to the segment. The Z8010 has this feature—users are prevented from accessing system segments. Other types of attributes that can be associated with a segment involve modes of accessing, for example read only, read/write or execute only. For these attributes, the processor must indicate the type of access to be made, be it code fetch, read from memory, write to memory, etc. The Z8001 indicates when it is fetching code, reading or writing data, or performing stack operations, and thus the Z8010 can offer protection for these operations. The other issue with respect to attributes is whether they are permissive or prohibitive. That is, whether the attribute is in the form of "write to this segment is permitted" or of the form "write to this segment is prohibited." The Z8010 adopts the approach of specifying attributes that prohibit certain types of accessing. The final issue in the mechanics of memory management systems is the implementation of the protection attributes. These may be associated either with the logical address space or with the physical memory itself. The IBM 360 series, for example, places the memory protection information with the physical memory itself. Thus the processor generates a memory address and the memory module checks to see if the access is permitted. The main difficulty with this approach is in the lack of flexibility, because protection is associated with fixed memory partitions. Also, sharing memory is cumbersome because each user is given a protection key to match the memory key; thus both users must have the same access key or a universal access key. Associating access attributes with the logical segment permits a versatile memory management scheme because different users can access the same segment and have different access attributes associated with their accessing. The Z8010 implements access attributes using the segment mapping information. Other information associated with each segment does not pertain to the protection mechanism but can be of use to the memory management system. This information generally relates to the history of the segment; for example, whether a segment has been modified while resident in primary memory. If it has not been modified and the system requires the memory for another segment, the memory can be freed immediately; otherwise, the updated version of the segment must be stored in secondary memory and the primary memory is not available until the segment has been saved. Although not strictly necessary, such information can improve the performance of the memory management system. The Z8010 collects information on segment usage, and this information can be used to enhance performance of systems that use this device. The Z8010 Memory Management Unit The Z8001 CPU generates segmented addresses consisting of a 7-bit segment number and a 16-bit segment offset address. In addition, the CPU generates status signals indicating its current mode of operation (such as Instruction Fetch, Data Memory Reference, Stack Memory Reference, and Internal Operation), whether it is performing a Read or a Write Memory Reference and whether it is in Normal (User) or System Mode. The Z8010 Memory Management Unit uses this information to perform its memory management functions. This section describes the Z8010 MMU in some detail, beginning with the translation procedure and continuing with a description of the internal registers of the chip. The section concludes with a description of the system commands that alter the contents of these registers. The Z8010 MMU has three functional states. The first is the memory management state: when a logical address is presented to the unit, the MMU checks the access to insure its validity and translates the logical address to a physical memory location. The second state is a command state: when a special I/O instrucThe Z8010 Memory Management Unit (Continued) tion is issued to the MMU, such as reading or writing one of its internal registers, the MMU responds to the command as appropriate. The third state is a quiescent state: when the CPU issues an I/O instruction or a refresh cycle, the MMU address lines remain 3-stated. The inputs to the MMU are the Address/Data lines (A/D lines), Segment Number lines, Bus Status and Timing Lines, and special control lines for chip selection and DMA. The outputs from the MMU are Address lines, a Segment Trap line and a Suppress line (Figure 4). During address translation and access protection, logical addresses are presented to the MMU on the Segment Number and Address/Data lines; the MMU puts the translated physical memory location on its Address lines and, if appropriate, activates the Segment Trap and/or Suppress lines. Segment Trap is a special type of synchronous interrupt for the Z8001 CPU; Suppress aborts the memory access. In the command state, the MMU receives commands on the A/D lines; data to be read from or written into the MMU is also placed on the A/D lines. The MMU selects which of the three states it will be in according to the status information on the Bus Status lines during the initial clock cycle of an instruction or DMA cycle. The MMU performs address translation during a memory reference for either a regular instruction or a DMA request. Only I/O instructions (either regular or special), memory refresh and reserved bus status states cause the MMU to cease performing memory address translations and enter another state. The MMU uses the segment number to access an internal table of segment descriptor registers, each register containing the starting memory location of the segment (called the base address), the segment's limit (used to determine the range of legal address offsets) and the types of accesses permitted to that segment. Physical memory for segments is allocated in blocks of 256 bytes. The eight least significant bits of the base address are all zero and are not stored in the Segment Descriptor Register. Also, since the eight low-order bits of the segment base are always zero, the eight low-order bits of the segment offset need not participate Figure 4. Z8010 MMU Pin Functions in the addition of the base address to the offset. Rather, they can be juxtaposed to the result of adding the high-order byte of the offset to the most significant 16 bits of the base address. This process is illustrated in Figure 5. Note that the low-order eight bits of the offset are not used by the MMU. Figure 6 goes through an example of mapping the logical address (5, 1528) to a physical memory location when segment 5 begins at location 231100. Figure 6a illustrates the full addition to be performed during address translation. The segment number 5 selects Segment Descriptor Register 5 in the MMU. The base address field in this register contains 2311 which corresponds to a base address of 231100. The offset, 1528, is then added to 231100 to produce the physical memory location 232628. Figure 6b represents the same logical procedure, but illustrates the actual operation of the MMU. Again segment number 5 is used to select the base address. However, only the high-order byte of the offset is added to the contents of the Figure 5. Generation of the Physical Memory Location from a Logical Address # The Z8010 Memory Management Unit (Continued) MMU base-address field: 15 is added to 2311 to produce the most significant 16 bits of the physical memory location. The low-order byte of the physical location is the same as the low-order byte of the offset. The results of the two processes illustrated in figures 6a and 6b are the same, but in 6a a 24-bit addition is implied whereas in 6b only a 16-bit addition is needed. Also, the low-order eight bits of the offset are not needed by the MMU and this reduces the number of pins required by the MMU package. The MMU checks memory references for two types of trap conditions. The first type is an access violation. This occurs when a memory reference is performed in a mode that is not allowed by the read-only, execute-only, CPU-inhibit or system-only attribute of a segment. A memory reference outside the allocated memory for the segment also constitutes an access violation. The second type is a write warning. This occurs when a write is made to the last 256 bytes of a special type of segment (indicated by a special attribute flag called the Direction And Warning Flag). These segments are typically used for stacks and are therefore logically organized so that successive writes (or stack pushes) access lower-numbered memory locations. By generating a segment trap request when a write is performed into the lowest-numbered 256 bytes of the memory allocated for these segments, the MMU is signaling that a stack is in danger of overflowing. The operating system in servicing this trap can increase the memory allocated for the segment and avoid a fatal stack overflow condition. The MMU generates two control signals that can be used by the system to perform memory management functions. Segment Trap Request is generated upon the first detected occur- Figure 6. Two Methods of Address Translation rance of a violation or write warning. Once asserted, this signal remains set until a trap acknowledge signal is received. Only when the Fatal Flag, a special MMU control flag, is set will a detected violation not cause a segment trap request. This flag is set only when a second violation is detected while a previous trap is being processed and thus indicates that the system software is in error. The other control signal generated by the MMU is Suppress. Once a violation has been detected, this signal is asserted on that and every succeeding memory reference for the remainder of the instruction. In particular, I/O and Special I/O instructions are checked for memory access violations, and once a memory access violation is detected, subsequent memory accesses cause Suppress signals to be generated. I/O addresses, of course, bypass the MMU and are neither translated nor checked. Intervening DMA cycles and memory refresh cycles are exceptions to this rule. During such cycles Suppress is not asserted unless a violation is detected during that cycle. Only DMA can generate a violation: refresh can never cause a violation. Suppress can be used by the memory system to inhibit writes, thus protecting the memory from illegal alterations. #### MMU Internal Registers There are three groups of registers in the MMU: Segment Descriptor Registers, Control Registers and Status Registers. The Segment Descriptor Registers contain all the information relating to the address translation and access protection of a particular segment. The Con- trol Registers contain information used to control the various functions of the MMU, including how to interpret various signals generated by the CPU. The Status Registers contain all the information the MMU generates when it detects an access violation. #### Segment Descriptor Registers Because there are 64 Segment Descriptor Registers in the MMU, two MMUs are required to handle all 128 segments that the Z8001 can manipulate directly. An MMU is programmed to handle either segments 0 through 63 or segments 64 through 127; the particular set of 64 segments in an MMU can be changed using special operating system commands. Each Segment Descriptor contains three fields, a 16-bit Base Field, an 8-bit Limit Field and an 8-bit Attribute Field (Figure 7). The segment number of a logical address determines which segment descriptors are used in address translation. The Base Field specifies the starting location in memory of the segment. The Limit Field specifies the segment size in blocks of 256 bytes. The address offset is compared against the segment limit and a size violation occurs if the offset falls outside the segment boundaries. A write warning occurs if the destination is in the last block of a segment being used as a stack. Segment Descriptor Registers (Continued) Figure 7. A Segment Descriptor The Attribute Field contains eight flags. Five flags protect the segment against certain types of access, one indicates a special orientation of the segment, and two indicate the types of accesses that have been made to the segment. The following brief description explains how these flags are used. The Read-Only Flag (RD) indicates that the only accesses to this segment are reads. Writes are prohibited when this flag is set. Thus this flag is a write-inhibit flag; in particular, code can be executed from a read-only segment. This flag is useful in protecting data from being written by unauthorized users. For example, if one user wants to give another access to a document that he has created, but does not want this user to be able to modify it. the system can set the Read-Only Flag when it copies the file into the user's address space. If the data is already in memory (in a read-only mode), then this same memory area can be made accessible to that user without another copy of the document being required. The System-Only Flag (SYS) indicates that only accesses made in System Mode are to be permitted. When this flag is set, accesses in the Normal Mode are prohibited. This attribute is useful in protecting system tables and tasks from being accessed by users. For example, system I/O routines can be left in the memory with this flag set and a user is unable to call them directly. This feature is useful if a system is designed so that users are given certain segment names and other segment names are reserved for system use. This flag prevents users from accessing system segments, even though they can generate the logical addresses. The CPU-Inhibit Flag (CPUI) indicates that the segment is not to be referenced by the CPU. When this flag is set, CPU access to this segment is prohibited, but DMA channels can access the segment. This flag is useful in preventing a program from accessing a segment whose data resides on secondary storage and has not been brought into primary memory. For example, a user may request the operating system to read a file from disk into segment number 19; if the operating system returns control to the user before the file has been read, this flag should be set in Segment Descriptor Register 19. The Execute-Only Flag (EXC) indicates that the segment is to be referenced only during the instruction fetch cycle of the processor. When this flag is set, access to the segment during any other cycle of an instruction, for example during the memory request cycle, is prohibited. This flag is useful in preventing a program from making a copy of a proprietary program. For example, if this flag is set for a segment containing code that a user can access, that code is protected from being read and hence from being copied. The DMA-Inhibit Flag (DMAI) indicates that the segment is not to be referenced by a DMA Channel. When this flag is set, only the CPU has access to the segment. This flag is useful in preventing a DMA device from modifying a segment being used by an executing task. For example, segments with valid data should have this flag set to protect them from modification by a DMA device. The Direction And Warning Flag (DIRW) indicates that memory accesses are to be monitored and certain accesses are to be signaled, although allowed to proceed. When this flag is set, any write to the lowest 256 bytes of the segment generates a write warning. This flag is useful for segments that are used as stacks since the Z8001 has special stack instructions to manipulate stacks that grow toward lower memory locations. Thus a write warning for a stack indicates that the stack may soon overflow its allotted memory space and that more physical memory should be obtained. For example, if a segment serves as a run-time stack for a block-structured programming language such as PASCAL, memory can be allocated to this segment only as a program requires during its execution. The alternative in a fixed allocation environment is to allocate as much memory for the stack as the system expects the program to need, whether or not it is actually used by the program. The Changed Flag (CHG) indicates that a write has occurred to this segment. This flag is set automatically whenever a program or DMA device writes into the segment. This flag is useful in indicating which segments have been modified in the case where the segment must be written to a secondary storage device. Segments that have not been updated need not be copied back to disk if a copy already exists. For example, when a user task is suspended in a multiple-user environment and his task is to be swapped out of memory temporarily to make room for another task, only those segments that have been changed need to be updated on the disk. The Referenced Flag (REF) indicates that a memory access has been made to a segment. This flag is set automatically whenever a program or DMA device accesses the segment. This flag is useful in indicating which segments are active in the case that a segment must be Segment Descriptor Registers (Continued) selected to be swapped out of primary memory to make room for another task. For example, seldom-used operating-system tasks that usually reside in primary memory may be swapped out to make room for users with large memory requirements. This flag is a way of ascertaining which segments contain seldom used tasks. #### Control Registers Three user-accessible 8-bit registers in the MMU control the functioning of the MMU (Figure 8). The Mode Register provides a sophisticated method for selectively enabling MMUs in a multiple-MMU configuration. The Segment Address Register (SAR) selects a particular segment descriptor to be accessed by a system routine when it is changing the organization of primary memory. The Descriptor Selection Counter Register selects the particular byte in the Segment Descriptor Register that is accessed. Two flags in the Mode Register govern the functioning of the MMU. The Master Enable Flag (MSEN) indicates whether the device will perform address translation. When this flag is set, addresses translated by the MMU are placed on its Address lines; when this flag is clear, the Address lines are 3-stated. Thus, once this flag is reset, no memory request can pass through the MMU. In a single-MMU configuration, MSEN set to zero requires that the CPU must have access to a special memory, since it will not be able to fetch an instruction from the primary memory. This flag can be set during hardware reset (this is discussed later). The second flag in the mode register that governs the functioning of the MMU is the Translate Flag (TRNS). This flag indicates whether the MMU is to translate the addresses presented to it. When the flag is set, the MMU translates logical addresses to physical memory locations and checks to see if a violation will occur on that access. When the flag is clear, addresses presented to the MMU are passed to the output Address lines without change, and no protection checking is done. When multiple-MMUs are used in a memory-management system, some mechanism must be present to select those devices that are to be active during the memory translation process. More specifically, if two MMUs are employed so that all 128 segments can be used at random by an executing process, then some way must exist for each of the MMUs to know which 64 Segment Descriptors are located in its Segment Descriptor Registers. The Upper Range Select Flag (URS) indicates which set of 64 descriptors is stored in the MMU. When the flag is set, the MMU contains descriptors 64 through Figure 8. MMU Control Registers 127; when the flag is reset, the MMU contains descriptors 0 through 63. When multiple-MMU devices keep separate tables for system descriptors and user descriptors, the Multiple Segment Table Flag (MST) and the Normal Mode Select Flag (NMS) in the Mode Register distinguish which MMUs contain system descriptors and which contain user descriptors. When the MST flag is set, multiple tables are present in the configuration, and each MMU is dedicated to one of the tables. In this case the MMU translates addresses only when the $N/\overline{S}$ signal matches the NMS flag. Thus, if there are two tables in the memory management system (one for the system and one for users), the NMS flag is set in those MMUs containing the users' segment descriptors, and is not set in the remaining MMUs. All MMUs in the system have the MST flag set to indicate more than one table in the system. The final piece of control information in the Mode Register is a 3-bit Identification Field (ID) that indicates a logical name for the MMU. When a segment trap is acknowledged by the CPU, the MMU uses this field to select one of the A/D lines; each enabled MMU should select a different line. If an MMU requested a segment trap, it outputs a 1 on its assigned A/D line; otherwise it outputs a 0. Since the ID field is three bits, up to eight MMUs can be uniquely identified. One instruction might result in multiple violations in different MMUs, so that the segment trap software might have to deal with several MMUs to process the trap. The other two control registers in the MMU are the Segment Address Register (SAR), which points to one of the 64 segment descriptors, and the Descriptor Selection Counter Register. Commands to read or write a segment descriptor use the SAR pointer to select which descriptor is to be accessed. This register has an auto-incrementing capability for accessing consecutive descriptors in succession without having to reload the SAR. Thus if descriptors 0 through 4 are to be modified, the SAR is initialized to 0 and then auto-incremented to point to descriptors, 1, 2, 3 and 4 in succession. The Segment Descriptor Number is a 6-bit field that contains the address of the descriptor within the MMU. If the MMU holds segments 64 through 127 (that is, if the URS flag is set), the segment named 64 is accessed when the SAR number field is 0. This is a result of the 6-bit limit of the descriptor number field. The field indicates the 6 least-significant bits of the logical segment descriptor number. #### Control Registers (Continued) Segment Descriptors consist of four bytes; the Descriptor Selection Counter indicates which byte is being accessed during a command (commands to the MMU can read or write only one byte at a time). A counter value of 0 indicates the high-order byte of the base address is being accessed, 1 indicates the low-order byte of the base address, 2 indicates the limit field, and 3 indicates the attribute field. This counter is used by MMU commands that access multiple bytes within a descriptor. In general, the counter is handled automatically by the MMU commands. Only when a command could be interrupted—and intervening MMU commands issued—should this register be saved and later restored by the interrupting program. #### Status Registers Six 8-bit registers contain information useful in recovering from memory trap conditions (Figure 9). The Violation Type Register describes the conditions that generated the segment trap. The Violation Segment Number and Offset Registers contain the segment number and upper byte of the segment address offset for the logical address that caused the segment trap. The Instruction Segment Number and Offset Registers contain the segment number and upper byte of the segment address offset for the last instruction before the segment trap was issued. The Bus Cycle Status Register records the status of the bus at the time the trap condition was detected. Only violations caused by CPU access have trap information stored in the status registers; DMA violations cause Suppress to be asserted, but the Status Registers are not altered. Thus if a DMA violation occurs between a CPU violation and entry to the trap service routine, the service routine still has the CPU trap information available to process the trap. It is the responsibility of the DMA device to save enough information in the event of a violation so that a software DMA violation service routine can process the violation correctly. Eight flags in the Violation Type Register describe the cause of the segment trap. Four flags correspond to access protection modes in the segment descriptor attribute mode. A read-only violation sets the RDV flag, a system-only violation sets the SYSV flag, a CPU access to a CPU-Inhibit segment sets the CPUIV flag, an execute-only violation sets the EXCV flag. Three flags correspond to addressing violation or warnings. The Segment Length Violation Flag (SLV) is set whenever the offset of the logical address falls outside the memory space allocated to the segment. The Primary Write Warning Flag (PWW) is set whenever a write occurs in the last 256 bytes of a segment whose Direction And Warning Flag is set (that is, for segments being used as stacks where the top of the stack is within 256 bytes of the allocated memory space of the segment). The Secondary Write Warning Flag (SWW) is similar to the PWW flag, only it is set when the CPU is in system mode, a stack push is being performed to a segment with a Direction And Warning Flag set, and some other addressing violation or warning has occurred (the EXCV, CPUIV, SLV, SYSV, RDV or PWW flags have been set). When the SWW flag is set it indicates that the system stack is in danger of overflowing its allotted memory. Once the SWW flag is set, further write warnings are suppressed. This prevents the system from repeatedly being interrupted for the same warning while it is in the process of eliminating the cause of the warning. The final violation-type register flag to be discussed is the Fatal Condition Flag (FATL). This flag is set when any other flag in the violation type register is set and either a violation is detected or a write-warning condition occurs in normal mode. This flag is not set during a stack push in system mode that results in a warning condition. This flag indicates that a memory access error has occurred in the trap processing routine. Once this flag has been set, no Trap Request signals are generated on subsequent violations. However, Suppress signals are generated on this and subsequent CPU violations until the FATL flag has been reset. The Bus Cycle Status Register contains information pertaining to the status of the bus when a trap condition is detected. This includes CPU Status ( $ST_0$ – $ST_3$ ), plus flags indicating whether a read or a write was being performed and whether or not the $N/\overline{S}$ line was asserted. The Violation Segment Number and Offset Registers record the first logical address to cause a trap. Only the high-order byte of the offset is saved, however, so that external support circuitry is needed to save the low-order eight bits of the logical address offset. If the trap occurred during the instruction fetch cycle, this information is the logical address of the instruction; otherwise it indicates the Figure 9. MMU Violation Information Registers #### Status Registers (Continued) logical address of a data item which was to be accessed. The Instruction Segment Number and Offset Registers record the logical address of the last instruction fetch that occurred before the trap. Only the high-order byte of the offset is saved, however, so external support circuitry is needed to save the low-order eight bits of the offset. If an instruction fetch caused the trap, these registers indicate the logical address of the previous instruction. Such information is useful if the preceding instruction was a branch instruction to an invalid address since—in this case—these registers indicate which branch instruction led to the erroneous situation. If a data reference caused the segment trap, then these registers indicate the logical address of the instruction that specified the illegal access. #### Stack Segments Segments are specified by a base address and a range of legal offsets to this base address. On each access to a segment, the offset is checked against this range to insure that the access falls within the allowed range. If an access outside the segment is attempted, a Trap Request and a Suppress signal are generated. Normally the legal range of offsets within a segment is from 0 to 256N + 255 bytes, where $0 \le N \le 255$ . (N is the value in the limit field of the segment descriptor.) However, a segment may be specified so that legal offsets range from 256N to 65,535 bytes, where $0 \le N \le 255$ . The latter type of segment is useful for stacks because the Z8001 stack-manipulation instructions cause stacks to grow toward lower memory locations. Thus, when a stack grows to the limit of its allocated segment, additional memory can be allocated on the correct end of the segment. As an aid in maintaining stacks, the MMU detects when a write is performed to the lowest allocated 256 bytes of these segments and generates a Trap Request. No Suppress signal is generated so the write is allowed to proceed. This write warning can then be used to indicate that more memory should be allocated to the segment. The DIRW flag indicates that a segment is to be treated in this special way by the MMU. When the DIRW flag is set, the range of allowed offsets is from 256N to 65,535 bytes and writes into the range 256N to 256N + 255 generate Segment Trap but not Suppress, indicating a write warning. #### Segment Trap and Acknowledge The Z8010 MMU generates a Segment Trap whenever it detects an access violation or a write warning condition. In the case of an access violation, the MMU also activates Suppress. Suppress can be used to inhibit memory writes and to request that special data be returned on a read access. Segment Trap remains Low until a Trap Acknowledge signal is received. If a violation occurs, Suppress is asserted for that cycle and all subsequent CPU memory references until the end of the instruction. Intervening DMA cycles are not suppressed, however, unless they generate a violation. Violations detected during DMA cycles cause Suppress to be asserted during that cycle only; no segment trap requests are ever generated during DMA cycles. This is because the CPU would not be able to respond to these traps until the conclusion of the DMA cycle. Segment traps to the Z8001 CPU are handled similarly to other types of interrupts. To service a segment trap, the CPU enters a segment trap acknowledge cycle. The acknowledge cycle is always preceded by an instruction fetch cycle that is aborted. The MMU has been designed so that this dummy instruction fetch cycle is ignored. During the acknowledge cycle, all enabled MMUs use the Address/Data lines to indicate their status. An MMU that has generated a Segment Trap request outputs a l on the A/D line associated with the number in its ID field. An MMU that has not generated a segment trap request outputs a 0 on its associated A/D line. A/D lines for which no MMU is associated remain 3-stated. During a segment trap acknowledge cycle, an MMU uses A/D line 8+i if the content of its ID field is i Following the acknowledge cycle, the CPU automatically pushes the program status words and program counter onto the system stack, and loads a new program status word and program counter from the program status area. The Segment Trap line is reset during the segment trap acknowledge cycle, and no Suppress signal is generated during the stack push. If the store creates a write warning condition, a segment trap request is generated and is serviced at the end of the context swap; the SWW flag is also set. Servicing this second Segment Trap request also creates a write warning condition, but—because the SWW flag is set—no Segment Trap request is generated. If a violation rather than a write warning condition occurs during the context swap, the FATL flag is set rather than the SWW flag. In this case, subsequent violations cause the Suppress to be asserted but not Trap Request. Without the SWW and FATL flags, trap processing routines that generate memory violations would repeatedly be interrupted and called to proSegment Trap and (Continued) cess the violations they create. The CPU routine to process a trap request Acknowledge should first check the FATL flag to determine if a fatal system error has occurred. If not, the SWW flag should be checked to determine if more memory is required for the system stack. Finally, the trap itself should be processed and the violation type register reset. #### Commands to the MMU When a memory management system must read or change information in the MMU to respond to a segment trap or to re-organize the physical memory, it can issue control commands to the MMU. These commands fall into two generic categories: reset commands and read/write commands. Reset commands are simply orders to the MMU to set or clear specified fields. For these commands, the Z8001 Special I/O output command can be used with the destination field set to be the MMU command code corresponding to the desired action. Read and write commands are slightly more complicated because they consist of both commands and data. Such commands to the MMU are issued using the Z8001 Special I/O instructions. These instructions have a source and a destination field. For an input instruction, the source field contains an MMU command code and the destination field indicates where in primary memory the data is placed. For an output instruction, the destination field contains an MMU command and the source field indicates where the data to be written into the MMU resides in memory. The high-order byte of the command contains the opcode for that command; the loworder byte of the command can be used to specify the particular MMU to be accessed. The MMU does not receive information on AD<sub>0</sub>-AD<sub>7</sub>, so external circuitry must decode information on these lines during the Special I/O commands and then select a particular MMU. The encoding of the low-order byte is dependent upon the system implementation. This paper always uses the convention that bit i specifies MMU number 1. The reset commands to the MMU are: Reset Violation Type Register, Reset SWW Flag In Violation Type Register, and Reset Fatal Flag In Violation Type Register. Resetting the Violation Type Register is similar to a hardware reset in that it clears this register and returns the internal control of the MMU to an initial state (as if no violation had occurred since system initialization). Resetting the SWW flag or the FATL flag in the Violation Type Register clears these flags. Two other commands are similar to reset commands in that they have no data associated with them. These are Set All CPU-Inhibit Flags in the segment attribute fields and Set All DMA-Inhibit Flags in the segment attribute fields, both of which cause all segment descriptors in the MMU to have the CPUI or DMAI flags set, respectively. These two set commands can be useful in initializing address translation tables or when swapping between tasks. For example, when swapping between tasks the Set All CPUI Flags command automatically makes the previous task's segments inaccessible to the next task, unless the system explicitly initializes the segment attribute field in these segments. As an example of using the Special Output instruction SOUT to control an MMU, consider resetting the fatal flag of MMU #1. The MMU command opcode for this is "%14" (% denotes hexadecimal). The assembler syntax for the SOUT instruction is "SOUT destination field, source field" so that the instruction to reset the fatal flag of MMU #1 is "SOUT %1402, R0." Specifying register 0 in this instruction is an arbitrary choice—the content of this register is placed on the A/D lines during the data phase of the SOUT instruction, but it is ignored by the MMU. The low-order byte of the command (the destination field of the instruction) encodes which MMU is to reset its fatal flag. The convention followed in this paper is that MMU i is specified by setting bit i in the low order byte of the command. (Bit 1 set is hex "%02.") The rest of the MMU commands consist of both operation and data. The following internal registers can be read or written: the Mode Register, the Segment Address Register, the Descriptor Registers and the Descriptor Selection Counter Register. A Descriptor Register can be read or written as a whole, or selected subfields can be accessed. In addition, by using the auto-increment feature of the Segment Address Register, successive Descriptor Registers can be accessed, or a selected field within successive Descriptor Registers can be accessed. For example, one Special I/O command in block mode could read a number of segment attribute fields. This is useful in determing which segments have been modified. As an example of using the Special Output instruction SOUT to write data into an MMU, consider writing the contents of Register 6 into the Mode Register of MMU #2. The opcode for this command is "%00" and so the command is "SOUT %0004, R6." Here the high-order byte of the destination field contains the opcode and the low-order byte has bit 2 set (hexadecimal 4 if 0100 in binary) indicating MMU #2. #### Commands to the MMU (Continued) Certain MMU internal registers can only be read—there is no corresponding write instruction. This is because these registers contain information relating to a detected violation and thus it is not necessary to be able to write into these registers. These registers are the Violation Type Register, the Violation Segment Number Register, the Violation Offset Register, the Instruction Segment Number Register, the Instruction Offset Register and the Violation Bus Status Register. Although the Violation Type Register cannot be written, it should be noted that it can be cleared and that two of its flags can be individually cleared: the SWW flag and the FATL flag. #### Direct Memory Access DMA operations may occur between Z8001 machine cycles and can be handled through the MMU. The MMU permits DMA in either the System or Normal Mode of operation. For each memory access, segment attributes are checked and—if a violation is detected—a Suppress signal is generated. Unlike a CPU violation, which automatically causes Suppress signals to be generated on subsequent memory accesses until the next instruction, DMA violations generate a Suppress only on a permemory-access basis. The DMA device should note the Suppress signal and record sufficient information to enable the system to recover from the access violation. No Segment Trap Request is ever generated during DMA (hence warning conditions are not signaled). There are no trap requests because the CPU would not acknowledge the request until the end of the DMA cycle. At the start of a DMA cycle, the DMASYNC line must go Low, indicating to the MMU the beginning of a DMA cycle. A Low DMASYNC inhibits the MMU from using an indeterminate segment number on lines SN<sub>0</sub>-SN<sub>6</sub>. When the DMA logical memory address is valid, DMASYNC must be High on one rising edge of Clock and the MMU then performs its addresstranslation and access-protection functions. Upon the release of the bus at the termination of the DMA cycle, DMASYNC must again be High. After two clock cycles of DMASYNC High, the MMU assumes that the CPU has control of the bus and that subsequent memory references are CPU accesses. The first instruction fetch occurs at least two clock cycles after the CPU regains bus control. During CPU cycles, DMASYNC should always be High. #### Hardware and Software Reset The MMU can be reset by either hardware or software mechanisms but note that they have different effects. A hardware reset occurs on the falling edge of the Reset input; a software reset is performed by an MMU command. A hardware reset clears the Mode Register, Violation Type Register and Descriptor Selection Counter. If the Chip Select line is Low while Reset is Low the Master Enable Flag in the Mode Register is set to 1. All other registers are undefined. After reset, the A/D and A lines are 3-stated. The SUP and SEGT open-drain outputs are not driven. If the Master Enable Flag is not set during reset, the MMU does not respond to subsequent addresses on its A/D lines. To enable an MMU after a hardware reset, an MMU command must be used in conjunction with Chip Select. A software reset occurs when the Reset Violation Type Register command is issued. This command clears the Violation Type Register and returns the MMU to its initial state as if no violations or warnings had occurred. #### Multiple-MMU Configurations Z8010 MMU architecture supports system configurations that use more than one MMU. Multiple MMU devices can be used either to manage 128 CPU segments rather than the 64 supported by one MMU, or to manage multiple translation tables. The Z8001 CPU generates logical addresses that can specify up to 128 different segment names. Because the MMU contains only 64 Segment Descriptor Registers, two MMUs are needed to perform address translation for 128 logical segments. Systems designed with only one MMU device still have the power and flexibility offered by memory management, although tasks in such a system are restricted to manipu- lating only 64 logical segment names. These names must either be 0 through 63 or 64 through 127. If the MMU in a single-MMU configuration is set to translate segment names in one range and the CPU generates a logical segment name in the other range, the MMU does not perform address translation and no physical memory location is output. In this case, no request is made to memory. Therefore, a single-MMU configuration should have additional external logic to detect erroneous segment names and generate a Segment Trap and Suppress signal. The Upper Range Select flag (URS) is used in multiple MMU configurations to indicate which group of logical segment names #### Configurations (Continued) Multiple-MMU are to be translated by an MMU. When this flag is set, the Segment Descriptor Registers in the MMU are used in translating logical addresses in the range 64 through 127. When the flag is clear, the range is 0 through 63. Thus the URS flag corresponds to the most significant bit (bit 6) in the logical segment names that the MMU translates. Because this flag is under program control, the range of logical segment names can be changed during execution in System Mode. > MMU architecture also supports multiple segment translation tables. This feature is useful when separate tables are maintained for different tasks. Each task has its own table and switching between tasks requires enabling the appropriate MMU devices. In contrast, systems with only one translation table must either restrict the logical segment names that an individual task can use, or change the Descriptor Register entries whenever tasks are swapped. Two flags in the Mode Register, together with the $N/\overline{S}$ signal, are used in multiple table configurations. > The Multiple Segment Table (MST) flag indicates whether the configuration is being used to support multiple tables. When this flag is set, the MMU will compare the $N/\overline{S}$ line against the Normal Mode Select Flag (NMS) before generating a physical memory location on its Address lines. When the line and the flag match (both asserted or both de-asserted), the MMU is enabled and an address translation is performed (assuming the URS flag matches the most significant bit in the logical segment name). If the $N/\overline{S}$ line fails to match the state of the NMS flag, no translated address is generated by the MMU. The MST flag and the NMS flag are under program control and can be changed in System Mode. The simplest multiple translation table configuration has one table for Normal Mode access and one for System Mode access. In such a configuration, the Multiple Table Flag is set in all MMUs and the $N/\overline{S}$ line of each MMU receives its input from the $N/\overline{S}$ output of the Z8001 CPU. MMUs containing descriptors of system segments have the NMS flag clear, and those containing descriptors to be used in Normal Mode have the flag set. When the Z8001 is in System Mode, the $N/\overline{S}$ line is Low and it matches the NMS flag in those MMUs whose Descriptor Registers contain system segment information. Therefore, these MMUs are used in address translation for system references. When the Z8001 is in Normal Mode, the $N/\overline{S}$ line is High and it matches the NMS flag in those MMUs whose Descriptor Registers contain user segment information. Consequently, these MMUs are used in address translation for user segments. In this configuration, system segments are separated from user segments. When the Z8001 changes from Normal to System Mode of operation, the appropriate translation table is automatically selected. A more elaborate example of a configuration with multiple translation tables is given in the next section. #### Examples This section describes two Z8001-Z8010 configurations: one contains two MMUs and one address translation table; the other contains seven MMUs and four address translation tables. These examples are given in sufficient detail to illustrate some of the major ideas in constructing memory-management systems around the Z8010 MMU. High-level block diagrams illustrate some of the major features of typical hardware configurations and short programs illustrate software techniques for using the MMU. The first example system is the two-MMU configuration illustrated in Figure 10. The two MMUs are called MMU #1 and #2, and they are selected during a command cycle by AD1 and AD<sub>2</sub> being Low, respectively. Since a Special I/O instruction is being used bit 0 must always be zero. Thus, when a low-order byte of a command is "%02," MMU #1 responds; when it is "%04," MMU #2 responds; and when it is "%06," both MMUs respond. (Note that AD, is inverted before attachment to the CS pin.) The $A/D_1$ line, which controls MMU #1 through the Chip Select input, is first combined with the Reset line. This allows the Master Enable Flag to be set upon system initialization, so the logical addresses generated by the CPU are passed to the physical memory. This is done because—upon reset the mode register is otherwise cleared, the Translate Flag is clear and addresses pass through the MMUs untranslated. The bootstrap program can therefore reside in absolute memory locations in the physical memory. If the Reset line is not an input to the Chip Select line, the Master Enable Flag would not be set during system initialization and the CPU would not be able to address memory through the MMUs. Note that there is a direct path from the CPU and DMA to the system bus. This path is used during I/O and memory refresh because the MMUs are quiescent during these cycles. It is also used for data on memory reads and writes. Also, note that the Suppress line goes both to the memory, where it can be used to protect the memory from erroneous Examples (Continued) writes, and back to the DMA device to save information upon the event of a DMA access error. Of further interest in the example, address latches are used to buffer addresses between the Z8001 and a demultiplexed bus. This is required to demultiplex the address and data onto the bus. The address latch for AD<sub>8</sub>-AD<sub>15</sub> may not be needed if the I/O device does not use separate address and data lines. A detailed example indicates how such a system could be used. First, consider setting Segment Descriptor Register 65 to point to a read-only segment of 768 bytes starting at memory location %115200. The segment is to be accessed in Normal Mode. The Descriptor Register should be %115202 01. The first two bytes, %1152, indicate the starting location of the segment (note that the low-order byte of the memory address is all zeros and is not stored in the Descriptor Register). The third byte, %02, indicates that three blocks of 256 bytes have been allocated to this segment. The fourth byte, %01, indicates that only the read-only segment flag has been set. To write this descriptor into the MMU, a copy of the descriptor should be created in primary memory and a Special I/O block transfer instruction used. The SOTIRB instruction can be used for this. This instruction has the assembler syntax "SOTIRB destination, source, count register" where both the destination and source are registers. The destination register contains the command to the MMU, the memory location pointed to by the source register contains the first byte of the data to be transferred, and the Count Register contains the number of bytes to be transferred. The opcode to load the Descriptor Register is "%0B". Segment Descriptor Register 65 is Segment Descriptor Register 1 of MMU #2, so the MMU command is "%0B04". To specify which Segment Descriptor Register to write, it is necessary to load the Segment Address Register of MMU #2 with 1. The MMU opcode to do this is ``%01'' and so the command is ``%0104.'' The segment number (in this case 65) is a parameter to the example routine, passed in register 0. The Figure 10. A Dual-MMU Configuration | Examples (Continued) | | BIT<br>JR<br>SOUTB<br>LD<br>JR | RO, #6<br>Z, OVER<br>%0104, RH0<br>'R1, #%0B04<br>NEXT | !Test to see if Descriptor Register is in MMU #1!<br>!or MMU #2!<br>!Set SAR in MMU #2!<br>!Prepare to write descriptor! | |----------------------|-------|--------------------------------|--------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------| | | OVER: | SOUTB<br>LD | %0102, RH0<br>R1, #%0B02 | !Set SAR in MMU #1!<br>!Prepare to write descriptor! | | | NEXT: | LD<br>SOTIRB | R0, #4<br>@R1, @RR2, R0 | !Load count field—4 bytes!<br>!Write descriptor! | descriptor to be written is another parameter to this routine: RR2 contains the address in memory where this information resides. The SOUTB instruction has a similar syntax to the SOTIRB instruction explained previously except that it writes one byte instead of a series of bytes, and the destination I/O address is in the instruction itself instead of in a register specified by the instruction. The routine on this page initializes the Segment Descriptor. Its parameters are found in Register R0, which contains the segment number to be written, and in Register RR2, which points to the descriptor information in primary memory. Registers R0 through R3 are used by this routine. Now suppose that the user tries to write into location <<65>>%9328. This causes a segment trap both because of the write to a readonly segment and because the access exceeds the segment limit. At the end of the instruction that has the illegal memory access, the CPU acknowledges the trap. During the trap acknowledge cycle, MMU #2 asserts AD<sub>10</sub> (assuming its ID field is "010") and this information is placed on the system stack for the trap-handling routine. The trap-handling routine reads the violation information registers from the MMU. The violation type register contains "%05" indicating both a length violation and a read-only violation. The Violation Bus Status Normal Register contains "%28". The first nibble indicates a write in Normal Mode was in progress and the second nibble indicates a memory data access cycle was in progress. The violation segment register contains "%41" indicating segment 1 of MMU #2 caused the violation (which is segment number 65), and the violation offset register contains "%93" indicating the highorder byte of the logical address offset. The operating system can then issue an error message to the user indicating a read-only violation to segment 65. Using the program counter that was stacked when the segment trap was acknowledged, the system can also indicate the next instruction that was to be executed. Note that in this system the loworder byte of the violation offset is lost. This condition is corrected in the next example system. #### Examples (Continued) Figure 11. 16-MMU Configuration Figure 11 gives a high-level diagram of the second system to be discussed. This configuration contains 16 MMUs, and the A/D lines select the appropriate MMU when in Command mode. The major innovation in this example, aside from the additional MMUs, is the latch that retains the least significant byte of an address offset when a violation is detected. This latch is enabled when a segment trap is generated by an MMU and holds the low-order byte of the address that generates an access violation. In addition, external decoding logic for selecting one MMU Chip Select line is indicated. Seven MMUs is the limit in one configuration without additional decoding logic for selecting one MMU Chip Select line. (The reason why ${\rm AD}_0$ cannot be used to control an eighth MMU is due to the Special I/O input convention of the CPU. When the CPU inputs a byte of information and AD<sub>0</sub> is asserted, the data is taken from AD<sub>0</sub>-AD<sub>7</sub>, which are not driven by the MMU.) #### Switching Tables in a 16-MMU System. The 16-MMU configuration can support a memory management system designed with two MMUs permanently allocated to the operating system and the others allocated in pairs to different user tasks. Thus, seven user tasks can have translation tables resident in the 14-user MMUs, and switching between active tasks requires the appropriate MMUs to be enabled and disabled. This selection process can be effected by manipulating the Master Enable (MSEN) flags in the mode registers of the appropriate MMUs. ### Examples (Continued) The routine performs the selective enabling of MMUs required by a task swap. This routine disables all user MMUs (thus disabling the currently enabled user MMUs), then enables the appropriate pair. (The system pair is always enabled.) The code selecting the new task is passed in register R1; it contains %n, if task n is to be dispatched. Two peculiarities of this example are worth noting. First, each user ID number corresponds to seven MMUs (for example, all upper-range user MMUs). The Segment Trap processing routine has to take this into account. Second, the Chip Select code is assumed to be as follows: | | $AD_0-AD_7$ | MMU Selected | |---------|-------------|---------------------------| | System: | 02 | #1 $ID = 0$ , $URS = 0$ | | | 04 | #2 $ID = 1$ , $URS = 1$ | | User 0: | 08 | #3, $ID = 2$ , $URS = 0$ | | | 10 | #4, ID = 3, URS = 1 | | User 1: | 18 | #5, ID = 2, URS = 0 | | | 20 | #6, $ID = 3$ , $URS = 1$ | | User 2: | 28 | #7, ID = 2, URS = 0 | | | 30 | #8, ID = 3, URS = 1 | | | | | | | | | | | | | | User 6: | 68 | #15, $ID = 2$ , $URS = 0$ | | | 70 | #16, $ID = 3$ , $URS = 1$ | It is also assumed that %F8 will select all user MMUs. | CLR | R0 | !Clear RO! | |----------------|--------------|-------------------------------------------------------------------| | SOUT | %00F8,R0 | !Disable all user MMUs by clearing their mode registers! | | SLA | R1,#1 | !Multiply R1 by 2—the number of bytes in a memory word! | | LD | R1,TABLE(R1) | !Get the command word (opcode always %00) for user n, $URS = 0$ ! | | LDA | RR2,DATA | !Get the new mode register bit pattern (%DA)! | | SOUTIB | @R1,@RR2,R0 | !Send %DA to lower-range MMU and increment RR2 to DATA +1! | | INC | R1, #8 | !Command word for URS = 1! | | SOUTIB<br>END: | @R1,@RR2,R0 | !Send %FB to upper range MMU! | DATA: BYTES(%DA,%FB) !Mode register bit patterns! TABLE: ## WORDS (%8,%18,%28,%38,%48,%58,%68) Program to Switch Tables | | 1.09.4 10 5 41.01. | | | | | | | |----------------|--------------------|-------------------------------------|--------|-------------------------------------------------|--|--|--| | MMU<br>Command | Opcode | Operation | Opcode | Operation | | | | | Summary | 00<br>01 | Read/Write Mode Register | 0C | Read/Write Base Field And<br>Increment SAB | | | | | | | Read/Write Segment Address Register | 0D | Read/Write Limit Field And | | | | | | 02 | Read Violation Type Register | | Increment SAR | | | | | | 03 | Read Violation Segment<br>Number | OE | Read/Write Attribute Field<br>And Increment SAR | | | | | | 04 | Read Violation Offset (high byte) | OF | Read/Write Descriptor And<br>Increment SAR | | | | | | 05 | Read Bus Cycle Status Register | 10 | Reserved | | | | | | 06 | Read Instruction Segment | 11 | Reset Violation Type Register | | | | | | | Number | 12 | Reserved | | | | | | 07 | Read Instruction Offset (high | 13 | Reset SWW Flag In VTR | | | | | | | byte) | 14 | Reset FATL Flag In VTR | | | | | | 08 | Read/Write Base Field In | 15 | Set All CPU-Inhibit Flags | | | | | | | Descriptor | 16 | Set All DMA-Inhibit Flags | | | | | | 09 | Read/Write Limit Field In | 17-1F | Reserved | | | | | | | Descriptor | 20 | Read/Write Descriptor Selector | | | | | | OΑ | Read/Write Attribute Field In | 20 | Counter Register | | | | | | | Descriptor | 21-3F | Reserved | | | | | | OB | Read/Write Descriptor (all fields) | 21-31 | Hesel vea | | | | 00 2049 A # High-Reliability Microcircuits ### Military Specification Standards June 1982 #### General Description Zilog offers high-reliability versions of the entire family of Z80 and Z8000 logic circuits, processed in accordance with the requirements of MIL-STD-833 level B (Test Methods and Procedures for Microelectronics). The Z80 and Z8000 Families are currently in the process of qualifying for inclusion in the MIL-M-38510 Qualified Products List. **General Considerations.** Zilog high-reliability microcircuits are designed to meet the full military temperature range of -55°C to + 125°C and are packaged in hermetic dual-in-line packages. These packages can reliably withstand the thermal shock requirements of MIL-STD-833, method 1011, Condition C (-65°C to +150°C). For industrial users, Zilog offers an extended operating temperature range of -40°C to +85°C. All of Zilog's high-reliability microcircuits receive 5005 processing in accordance with the requirements of MIL-STD-833 level B or C (as specified). Table 1 lists the screening tests performed on the two levels. An X indicates that the test is performed 100% of the time and a Z indicates that the test can be done upon request. Table 2 lists the Zilog products available with the 100% testing process shown with X's in Table 1. | | | | STD-883 | | αss | |-------------------------|----------------------------|--------------|----------------------|--------|--------| | Test | Condition | Method | Condition | В | С | | SEM Inspection | _ | 2018 | - | Z | Z | | Precap Visual | _ | 2010 | В | X | Х | | Seal and Lot I.D. | _ | - | | Х | Х | | Stabilization Bake | 48 hrs. @ 150°C | 1008 | С | Х | X | | Temperature Cycling | 10 cycles | 1010 | С | Х | X | | Centrifuge | Y <sub>1</sub> Plane | 2001 | E | Х | Х | | Fine Leak | _ | 1014 | A | Х | Х | | Gross Leak | _ | 1014 | С | Х | Х | | Electrical Test | Per Zılog Data Sheets | - | _ | Х | Х | | Burn-In | 168 hr.<br>240 hr. | 1015<br>1015 | 160 hrs.<br>240 hrs. | X<br>Z | _ | | Final Electrical | 25°C, -55°C,<br>and +125°C | _ | _ | X<br>X | X<br>X | | Radiographic Inspection | As required | 2012 | - | Z | Z | | External Visual | | 2009 | _ | Х | Х | NOTES: S = Sample testing only, X = 100% testing, Z = Optional (tested if requested). Table 1. Total Lot Screening | General<br>Description | Product* | Speed | Mil Temp<br>Range | Extended<br>Temp Range | |------------------------|----------|---------|-------------------|------------------------| | (Continued) | Z80 CPU | 2.5 MHz | Yes | Yes | | | Z80A CPU | 4.0 MHz | Yes | Yes | | | Z80 PIO | 2.5 MHz | Yes | Yes | | | Z80A PIO | 4.0 MHz | Yes | Yes | | | Z80 SIO | 2.5 MHz | Yes | Yes | | | Z80A SIO | 4.0 MHz | Yes | Yes | | | Z80 DMA | 2.5 MHz | Yes | Yes | | | Z80A DMA | 4.0 MHz | Yes | Yes | | | Z80 CTC | 2.5 MHz | Yes | Yes | | | Z80A CTC | 4.0 MHz | Yes | Yes | 78001 CPU Z8002 CPU Yes Yes 4.0 MHz 4.0 MHz Table 2. High-Reliability Products Available #### Manufacturing and Process Controls Zilog high-reliability microcircuits are processed and assembled in accordance with the Zilog Product Assurance Program Plan, which conforms to the requirements of Appendix A of MIL-M-38510. The following are some of the items contained in the plan: - A clear, concise procedure for converting a customer specification to a Zilog internal specification, assuring the customer that parts received meet or exceed specified requirements. The converted document controlled by Zilog document control. - A formalized training and testing program for all operator and inspection personnel to ensure that each operation is performed correctly. - An inspection system that includes a complete Incoming Inspection Laboratory, a Chemical Analysis Laboratory, and a Failure Analysis Laboratory to assure that - all materials, utilities, and work-in-progress meet Zilog requirements. - Rigid requirements for the cleanliness of work areas and the maintenance of a Class 100 environment at all stations where critical operations are performed. - A document control system to control changes in design, materials, and processes. Yes Yes - A system for maintaining documents and records in active files for three years and in archive files for ten years. - An instrument maintenance and calibration system complying to the requirements of MIL-STD-45662 (Calibration System Requirements). - A quality audit system in accordance with MIL-Q-9858 (Quality Program Requirements). <sup>\*</sup>NOTE See Ordering Information for package and temperature designators. For Qualified Product Listings availability call the Military Assurance Program Office # Package Dimensions Zilog | | | 1 | |--|--|---| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | #### **Package Dimensions** #### June 1982 #### Package Summary This table summarizes the microprocessor components available from Zilog by number of pins and package type. Following the table are detailed drawings for each package type. For further information on specific components, see the Ordering Information section of each product specification. | Pins | Package | Component | Pins | Package | Component | |------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------|---------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------| | 18 | Ceramic, Cerdip, Plastic | Z8581 Clock Generator and Controller | 40 | Protopack | Z8093 Z8000 Z-UPC<br>Z8094 Z8000 Z-UPC | | 28 | Ceramic, Cerdip, Plastic | Z8430 Z80 CTC | | | Z8593 UPC<br>Z8594 UPC | | 28 | Leadless Carrier, Ceramic | Z8430 Z80 CTC | | | Z8603 Z8 MCU | | 40 | 40 Ceramic, Cerdip, Plastic Z8002 Z8000 CPU Z8030 Z8000 Z-SCC Z8036 Z8000 Z-CIO Z8038 Z8000 Z-FIO Z8090 Z8000 Z-FIO Z8090 Z8000 Z-UPC Z8400 Z80 CPU Z8410 Z80 DMA Z8420 Z80 PIO Z8440 Z80 SIO/0 Z8441 Z80 SIO/1 Z8442 Z80 SIO/1 Z8442 Z80 SIO/2 | 44 | Leadless Carrier, Ceramic | Z8613 Z8 MCU Z8002 Z8000 CPU Z8030 Z8000 Z-SCC Z8036 Z8000 Z-CIO Z8038 Z8000 Z-FIO Z8400 Z80 CPU Z8410 Z80 DMA Z8420 Z80 PIO Z8444 Z80 SIO* Z8530 SCC Z8536 CIO | | | | | Z8449 Z80 SIO/9<br>Z8470 Z80 DART<br>Z8530 SCC | 48 | Ceramic, Plastic | Z8001 Z8000 CPU<br>Z8010 Z8000 Z-MMU | | | | Z8536 CIO<br>Z8538 FIO<br>Z8590 UPC | 52† | Leadless Carrier, Ceramic | Z8010 Z8000 Z-MMU<br>Z8001 Z8000 CPU | | | | Z8601 Z8 MCU<br>Z8611 Z8 MCU<br>Z8671 Z8 MCU<br>Z8681 Z8 MCU | | | | <sup>\*</sup>NOTE As a result of size of package, all three SIO versions are included in one version, the Z8444 <sup>† 52-</sup>pin Leadless Carrier Diagram unavailable at time of publication. #### Package Dimensions (Continued) 18-Pin Ceramic Package 18-Pin Cerdip Package 18-Pin Plastic Package 28-Pin Ceramic Package 0.040 ±.020 28-Pin Cerdip Package 28-Pin Plastic Package 40-Pin Ceramic Package 40-Pin Cerdip Package 40-Pin Plastic Package 40-Pin Protopack Package #### Package Dimensions (Continued) 0.600 D.125 D.050 BOTH ENDS D.0100 TYP 48-Pin Plastic Package #### Package Dimensions (Continued) 28-Pin Leadless Package 44-Pin Leadless Package # Board Products Zilog | | ř | | | | | |---|---|--|--|---|--| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | • | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | * | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | # The Problem Solvers for Microcomputer Systems The Z80 MCB family of buscompatible microcomputer boards features powerful performance and application flexibility at a low total systems cost. For every application, from a single-board solution to a highperformance board set, the MCB family provides the right combination to easily solve most microcomputer system problems. Performance. The powerful architecture of the Z80 Central Processing Unit (CPU) is at the heart of the MCB family. The dual-register set of the Z80 CPU allows high-speed interrupt processing, context switching and other forms of foreground/background programming. Each register set includes an 8-bit storage register which can also be used as three 16-bit memory address or general-purpose registers. Two index registers provide greater memory addressing capability. A 16-bit external stack pointer permits unlimited subroutine nesting and temporary data storage. In addition, the CPU features vectored interrupts and supports dynamic memories requiring periodic refresh. Economy. Because each Z80 micro-computer board provides a large number of functions within a convenient and compact size, implementing an MCB family solution requires fewer boards and less space than comparable alternatives. Fewer boards mean lower power consumption, lower cost power supply, less heat generation and, therefore, lower cooling costs and greater economy in connector and other mechanical costs. Feature for feature, the MCB family adds up—a superior solution with unbeatable economy. The Competitive Edge. The time it takes from product conception to market introduction may mean the difference between success or failure. Success is assured with the Z80 MCB family. The boards are compatible, can be integrated into a system quickly, are easy to learn and use, allow the convenient addition of last minute features, and are available off-the-shelf. **Proven Design.** The MCB family has been used in hundreds of applications throughout the world, demonstrating reliability and performance day after day. All Zilog microcomputer boards undergo extensive burn-in with both pre and post burn-in testing to ensure constant performance and reliability. Family Members. The Z80 microcomputer board family includes powerful CPU and memory boards as well as a variety of versatile, high-performance I/O expansion boards. The Z80 Microcomputer Board (MCB) is a complete single-board microcomputer with its own self-contained memory plus serial and parallel I/O ports. The Z80 Memory and Disk Controller (MDC) adds up to 48K bytes of system memory and interface for up to eight floppy disk drives. The Z80 Serial Interface Board (SIB) provides four highperformance serial interface channels to solve a variety of data communications problems. Analog interface is simplified with the Z80 Analog Input Board (AIB) or the Analog Input/Output (AIO) board—each provides up to 32 input channels and 12-bit resolution. Flexible, parallel I/O is provided by the Z80 Input/Output Board (IOB) with 64 I/O lines and a liberal amount of "wire-wrap" area to give the user a head start on special interface solutions. Memory expansion is easily handled by the Z80 RAM Memory Board (RMB). It contains both RAM (up to 64K bytes) and fixed memory socket area, while the Z80 PROM Memory Board (PMB) allows up to 32K bytes of non-volatile memory. **16-Bit Power.** With the introduction of the Z8000 Dual-Processor Upgrade Package, the option of upgrading Z80-based systems to 16 bits is available. The Z8000 CPU-based board provides complete software development tools and 256K bytes of RAM—and still allows existing Z80 programs to run. Make vs Buy. The make vs buy decision impacts both strategic and economic issues including new product introduction schedules, product reliability, text fixture design, resource allocation, spare parts inventory, field maintenance and many others. These issues all involve hidden costs and potential product development delays. When all costs are considered, it is often more economical to purchase, rather than manufacture, microcomputer boards. Purchasing microcomputer boards for initial production quantities and later switching to in-house manufacture of these boards provides an effective compromise solution. Zilog supports this approach by licensing the manufacture of its microcomputer boards. The high front-end manufacturing costs can thereby be postponed until the success of the product is confirmed by market acceptance. #### Z80° MCB Z80 Microcomputer Board ## Product Description June 1982 #### FUNCTIONAL DESCRIPTION 4K bytes of E/P/ROM all on a compact All address, data and control lines are fully buffered to standard TTL levels for easy expansion with other boards in the Z80 MCB family. The MCB employs an on-board dc-dc con- verter to allow operation from a single +5 V power supply; the converter cir- cuit generates the +12 V and -5 V necessary for the dynamic RAM array and -10 V for serial communication interface. $7.7 \times 7.5$ in. circuit board. Central Processing Unit. The MCB is controlled by the Z80 CPU with 158 instructions including 16-bit arithmetic, block moves and block I/O, bit manipulation and versatile addressing modes. This powerful set of instructions provides programming ease and, for convenient portability, contains all 8080 instructions as a proper subset. The CPU has an operating frequency of 2.457 MHz derived from a 19.6608 MHz system clock and is able to execute instructions as fast as $1.6~\mu s$ . The CPU has a powerful and versatile vectored interrupt capability which allows identification of up to 128 unique interrupt service subroutines without additional hardware. See the Z80 CPU Product Specification for additional information. Memory—RAM Array. The MCB includes a dynamic Ramdom Access Memory (RAM) array of either 4K or 16K bytes. A unique refresh register in the CPU sends a new refresh address to the memory array after each op code fetch; therefore, automatic refresh is transparent and no wait states are imposed. This manner of memory refresh removes all the disadvantages of dynamic memory while still retaining economy and speed performance. The addressable memory space may be located at any 4K byte boundary by changing the position of two jumpers on the board. Systems requiring additional fixed memory, such as the Z80® PROM Memory Board (PMB) can thereby obtain a large block of continuous address space starting at zero. This same memory paging scheme generates a RAM SELECT signal routed to the array by a pair of connectors. Thus, external hardware may be used to disable the memory for bank selection. Figure 1 shows the memory addressing for the MCB/4 and MCB/16. Figure 1. Memory Addressing for MCB/4 and MCB/16 Memory - E/P/ROM Array. The MCB includes four 24-pin sockets that can accommodate up to 4K bytes of nonvolatile memory. The type of memory device to be used—Erasable Programmable Read Only Memory (EPROM), Programmable Read Only Memory (PROM) or Read Only Memory (ROM)—can be selected by changing the jumper wires. Although the MCB dc-dc converter generates the voltages required by P/ROM arrays, it cannot deliver sufficient current from these outputs to drive EPROM devices. When 2708 or 2704 EPROMs are used, external supplies must provide the required voltages. This option is easily implemented by selecting the appropriate jumpers on the board. Table 1 lists devices that can be used in these sockets. The standard board configuration is for the 2708. | Non-Volatile<br>Memory | Device<br>Number | | | |------------------------|----------------------------------|----------------------|--| | MOS<br>E/PROM | 2704<br>2708<br>2716 | 8704<br>8708<br>2316 | | | Bipolar<br>P/ROM | 6341<br>6381<br>82S181<br>82S191 | | | Table 1. Non-Volatile Memory Devices As with the RAM array, addressing is designed to allow the user to relocate the E/P/ROM array to any 4K byte boundary within the address range of the CPU. A ROM SELECT output signal and corresponding input contacts on the edge connector allow the user to implement shadow E/P/ROM or select an alternate PROM set. Counter-Timer. The Z80 CTC contains four independent 8-bit counter channels which can be programmed by system software for a broad range of counting and timing applications. One of the four channels is used as a baudrate generator for serial interface; the additional channels can be used to satisfy other system requirements. Each of the four channels may be decremented either from an external input in the counter mode or from a prescaled version of the system clock. Upon reaching zero, a pulse is available from three of the channels and interrupts may be generated by all four channels if they are programmed to do so. The device will supply an interrupt vector indicating which channel is causing the interrupt. The four independent input lines are each available on a separate position of the edge connector. The input signal may serve as a positive or negative trigger for the timer mode or as the actual event to be counted. Each output may be used as the input or trigger to a subsequent channel in order to achieve long time delays. If an external device must cause an interrupt to indicate a status change, one channel of the CTC can be used as a vectored interrupt generator by programming in a time constant of 1 and driving the input trigger with a transition signal from the external device. Thus, when no other parallel data need to be transferred, interrupts can occur without using the PIO strobe line. The output of channel 1 serves as the transmit and receive clock for the USART, providing a convenient way to implement software programmable baud rates. This signal is routed to the edge connector of the board and is returned on a separate contact. Consequently, channel 1 of the CTC may be used as either the USART clock or in the user's application, depending on edge connector wiring. See the 280 CTC Product Specification for details. I/O Capability. The MCB provides both parallel and serial I/O via a Counter-Timer Circuit (CTC), Parallel Input/Output (PIO) device and a Universal Synchronous/Asynchronous Receiver/Transmitter (USART). These devices occupy eleven locations of port-assigned I/O space as shown in Table 2. Jumper options allow relocation of the I/O devices within the portassigned address space. MCB I/O PORT ASSIGNMENTS | FUNCTION | PORT | |----------------------|------| | CTC Channel 0 | D4 | | CTC Channel 1 | D5 | | CTC Channel 2 | D6 | | CTC Channel 3 | D7 | | PIO Port A Data | D8 | | PIO Port B Data | D9 | | PIO Port A Control | DA | | PIO Port B Control | DB | | Switch Register | DD | | USART Data | DE | | USART Status/Control | DF | Table 2. MCB Port Assignments Serial I/O. A serial data communication channel provides support for either asynchronous or synchronous data transfer with either half- or full-duplex signaling. Driver and receiver devices are included to provide RS-232C compatible interface to passive 20 mA equipment simply by relocating two jumpers and attaching the serial line to the appropriate locations on the edge connector. Although the 8251 USART is designed for polled operations, it is possible to utilize the mode 2 interrupt structure of the CPU by coupling the transmitter ready and receiver ready lines from the USART to the input lines of the parallel I/O device. The baud-rate clock is derived from the 19.6608 MHz crystal oscillator and channel 1 of the CTC device. This allows baud-rate selection under program control as shown in Table 3. | BAUD<br>RATE | TIME<br>CONSTANT | |--------------|------------------| | 50 | 96 | | 75 | 64 | | 110 | 44 | | 150 | 32 | | 200 | 24 | | 300 | 16 | | 600 | 8 | | 1200 | 4 | | 2400 | 2 | | 4800 | 1 | | 9600 | 4) Counter | | 19200 | 2 Mode | | 38400 | l ) Mode | Table 3. Programmable Baud Rates for Serial I/O As an alternative to the on-board clock, user-selected jumpers allow independent transmit and receive clocks from external sources to be applied directly to the USART. A single external clock operating at twice the desired frequency may be applied to the on-board wave-shaping flip-flop, thus providing a clean, reliable clock signal. Parallel I/O. The Z80 PIO contains two independent 8-bit parallel I/O ports. It can be configured by the CPU to operate in any of four major modes—input, output, bidirectional or control. Data direction characteristics can be programmed individually or in byte configuration. Each byte has two independent handshake lines for completely asynchronous data transfers with any general-purpose interface. To allow maximum flexibility for the user, the 16 PIO data lines and four handshake lines are totally uncommitted. Also, four 16-pin IC sockets may be wired to accept any necessary logic device or terminator package. See the 280 PIO Product Specification for details. Z80® MCB Block Diagram #### **SPECIFICATIONS** Processor Zılog Z80 CPU **Operating Frequency** 2.5 MHz RAM Array MCB/4 $4K \times 1$ RAMs, $t_{AC} = 250$ ns MCB/16 $16K \times 1 \text{ RAMs}, t_{AC} = 250 \text{ ns}$ E/P/ROM Sockets Four 24-Pin Sockets E/P/ROM Types E/PROM 2704, 2708 or Equivalent P/ROM 6341,6381,82S181,82S191 or Equivalent Serial I/O Channels 1 Channel - RS232C or 20 mA Current Loop Serial Modes Synchronous or Asynchronous Data Rates 50 to 38.4K Baud Parallel I/O Lines 16 Lines with 4 Handshake Lines Connectors 122-Pin Edge (100 mil spacing) $+5 \text{ V } \pm 5\% \text{ @ 2 A (max)}$ (with 3 PROMs) Environmental Temperature 0 to 50°C Humidity 0 to 90% noncondensing Physical 7.5" (191 mm) Width Heiaht 7.7" (196 mm) #### ORDERING INFORMATION Part No. 05-6009-01 Description MCB/4 Z80 Microcomputer Board with 4K bytes RAM Part No. 05-6009-02 Description MCB/16 Z80 Microcomputer Board with 16K bytes RAM Part No. 05-6009-19 Description MCB/16 Z80 Microcomputer Board with 16K bytes RAM for use with RIOTMoperating system software #### Z80<sup>®</sup> RMB **Z80 RAM Memory Board** #### **Product Description** June 1982 provides system memory expansion for the MCB family of microcomputer boards. Containing both RAM as well as sockets for E/P/ROM memory, the RMB board provides a flexible means of implementing additional system memory. Each board contains a dc-dc converter that generates +12 V and -5 V bias voltages, thereby allowing operation from a single +5 V system power supply. #### **FUNCTIONAL DESCRIPTION** Address Map. The RMB memory address selection is completely compatible with the MCB microcomputer board. Figure 1 shows the memory map for the RMB/16 and RMB/48. Location of the memory array may be altered by the user. The RAM chipselect logic allows each 4K segment to have a starting address at any of 16 boundries within the 64K of addressable memory space. Chip selection is accomplished by using a PROM decoder to select the Row Address Strobe (RAS) signal to the appropriate bank of devices. This method of bank selection minimizes overall system power since only the selected bank dissipates active power. The address select PROM is socketed so that it may be easily replaced by the user for address reassignment. PROM Sockets. The RMB contains eight 24-pin sockets that may be used for a variety of E/P/ROM devices. Through selection of appropriate jumpers the socket area can be configured to accept the device types shown in Table 1. Figure 1. RMB Memory Map | Non-Volatile<br>Memory | | vice<br>mber | |------------------------|----------------------------------|----------------------| | MOS<br>E/PROM | 2704<br>2708<br>2716 | 8704<br>8708<br>2316 | | Bipolar<br>P/ROM | 6341<br>6381<br>82S181<br>82S191 | | Table 1. Non-Volatile Memory Devices Chip selection is accomplished by means of a PROM decoder, supplied socketed and unprogrammed so that the user has complete flexibility in its application. When using EPROM devices the -5 V and +12 V requirements must be supplied from a source external to the board. **Refresh.** Although dynamic RAMs are used, the RMB does not require any additional circuitry for refresh. Unique characteristics of the MCB CPU allow memory to be refreshed automatically and in a transparent mode. Following each op-code fetch, a new refresh address is available on the system address bus while the op-code is being decoded within the CPU. The CPU does not require wait states; therefore, there is no degradation of system performance (See Figure 2). Figure 2. Automatic Refresh Generation Z80® RMB Block Diagram #### **SPECIFICATIONS** #### Memory Capacity Dynamic RAM 64K E/P/ROM 16K #### Memory Size Standard Configurations 16K or 48K RAM #### Connectors 122-Pin Edge (100 mil spacing) #### Power +5 V ±5% @ 1.6 Å (max) #### DC-DC Converter Output +12 V @ 320 mA (max) -5 V @ 50 mA (max) #### Environmental Temperature 0 to 50°C Humidity 0 to 90% noncondensing #### Physical Height 7.5" (191 mm) Width 7.7" (196 mm) #### ORDERING INFORMATION | Part No. | Description | Part No. | Description | |------------|---------------------------------------|------------|---------------------------------------| | 05-6003-02 | Z80 RMB/16<br>16K RAM Memory<br>Board | 05-6003-04 | Z80 RAM/48<br>48K RAM Memory<br>Board | | 05-0104-00 | Z80 RMB/32<br>32K RAM Memory<br>Board | 05-6003-05 | Z80 RMB/64<br>64K RAM Memory<br>Board | 552 1031-001, 002 00-1031-02 # Z80° AIO/AIB Z80 Analog Input/Output and Analog Input Boards ### Product Description June 1982 - 16 Single-Ended or 32 Differential Inputs for Application Flexibility - Fast 45 ms Channel Conversion - On-Board dc-dc Converter for Convenient Low-Power Operation - Polled or Vectored Interrupt Control for Programming Convenience - Multiple Voltage Ranges for Easy Interface #### **OVERVIEW** The Z80 Analog Input Board (AIB) provides 16 differential input channels that may be configured as 32 single-ended channels. Through a combination of user-selectable input voltage ranges and a programmable gain amplifier, input signals ranging from millivolts to as high as 10 V can be converted to a 12-bit word. In order to ensure accuracy and compatibility with the other MCB family boards, a 5 V dc-dc converter is included as a standard feature. The Z80 Analog Input/Output (AIO) Board has input features identical to the AIB except that there are also two 12-bit D/A output channels, each with a wide range of user-selectable output voltages. #### FUNCTIONAL DESCRIPTION Input Ranges. The AIB and AIO contain an input multiplexer, an amplifier whose gain may be altered from 1 to 1000, and an analog-to-digital converter module. Five basic input ranges are shown in *Table 1*. The bipolar inputs are converted into a 12-bit value in twos complement format; the unipolar inputs are converted into a 12-bit straight binary value. | 0.0 | to | +4.9988 V | |---------|----|-----------| | 0.0 | to | +9 9975 V | | -2.500 | to | +2.4988 V | | -5.000 | to | +4.9975 V | | -10 000 | to | +9.9951 V | Table 1. Input and Output Voltage Ranges **Amplifier Gain.** Amplifier gain is set to 1 but can be changed by a resistor substitution according to the following formula: $$R = \frac{20 \text{ k}\Omega}{\text{Gain} - 1}$$ Increasing the gain of the amplifier effectively allows the input voltage range to be scaled by the reciprocal of the gain factor. For example, by increasing the amplifier gain to 1000, an input voltage range of ±2.5 V becomes ±2.5 mV. As the gain is increased the settling time of the amplifier will also increase. Because the AIO and AIB use a fixed timing sequence between channel selection and the start of data conversion, the system delay time must be lengthened, via a resistor change, to allow for the greater settling time of the amplifier at higher gain (see *Table 2*). | Amplifier<br>Gain | Delay Time<br>µs | Resistance<br>kΩ | |-------------------|------------------|------------------| | 1 | 20 | 13.3 | | 10 | 30 | 14.3 | | 100 | 40 | 19.0 | | 1000 | 100 | 47.5 | Table 2. Recommended System Delay Time vs Amplifier Gain **Input Modes.** The standard 16-channel differential input configuration is recommended in areas of commonmode noise and for low-level inputs. For input signals of 1.0 V or more, a 32-channel single-ended configuration can be jumper selected. **Equivalent Input Circuit.** Source output impedance has an effect on the settling time of the multiplexer. The formula for the time constant and the Figure 1. Input Equivalent Circuit equivalent single-ended input circuit is shown in Figure 1. The multiplexer must be allowed to settle to $\pm .01\%$ (approximately nine time constants) to insure accuracy. For high source impedance, it may be necessary to increase the system delay time beyond that shown in Table 2. For the differential input configuration, the multiplexer time constant is one half of that in Figure 1. System Interface. The AIO and AIB occupy 10 locations within the MCB CPU's I/O address space as shown in Table 3. Input status, control and data are interfaced through a PIO while the data for the two output channels is written to a set of 12-bit output registers. The location of the port assignments may be moved anywhere within valid I/O space of the CPU, with the restriction that both the PIO and output registers must reside within the same 20H block of I/O addresses. These address changes are jumper-selectable. Data may be obtained in either a polled or fully vectored interrupt mode. The mode is selected entirely by software control. Output Ranges. The AIO board is configured with two independent 12-bit digital-to-analog convertor output channels. Output voltage range is selectable by the appropriate jumper configuration. The available full scale output ranges are shown in Table 1. Output quantities are represented as twos complement numbers for bipolar ranges and as straight binary numbers for the unipolar configuration. | Function | Port | | |-----------------------|------|------| | P10 Port A Data | 80 | | | P10 Port B Data | 81 | | | P10 Port A Control | 82 | | | P10 Port B Control | 83 | | | Address Register | | | | (Channel Select) | 88 | | | Status Register | 89 | | | DAC1 Output (Lo Byte) | 8C | | | DAC1 Output (Hi Byte) | 8D | AIO | | DAC2 Output (Lo Byte) | 8E | Only | | DAC2 Output (Hi Byte) | 8F | • | | • ' • ' | | | Table 3. AIO/AIB Port Assignments Z80 AIO/AIB Block Diagram #### **SPECIFICATIONS** Input Characteristics Number of Channels 32 Single-ended/ 1 32 Single-ended/ 16 Differential ADC Gain Ranges 0-5 V, 0-10 V, ±2.5V, ±5 V, ±10 V Amplifier Gain Ranges 1 to 1000 Max Input Voltage ±26 V Input Impedance 100 M $\Omega$ , 10pF OFF Channel 100 M $\Omega$ ON Channel Bias Current Differential Bias Current 10 nA Resolution 12 Bits Throughput Time Gain = 1 45 $\mu$ s Channel Gain = 1 45 $\mu$ s Channel Gain = 100 100 $\mu$ s Channel Accuracy Gain = 1 $\pm 0.025\%$ FSR Gain = 1000 $\pm 0.100\%$ FSR Linearity ±1/2 LSB Differential Linearity ±1/2 LSB Quantizing Error ±1/2 LSB Temperature Stability Gain = 1 $\pm$ 30ppm of FSR/°C Gain = 1000 $\pm$ 80ppm of FSR/°C Dynamic Accuracy Sample and Hold Aperature 30 ms Aperature Time Variation ±5 ms Differential Amplifier CMR 74 db (dc to 1 kHz) Crosstalk 80 db down @ 1 kHz for OFF and ON Channel Output Characteristics Number of Channels 2 Output Voltage Ranges 0-5 V, 0-10 V, ±2.5V, ±5 V, ±10 V Output Current 5 mA Output Impedance Resolution 12 bits Output Settling Time 10 µs (max) Accuracy Ccuracy Output Accuracy ± 0.0125% FSR Temperature Coefficient ± 30ppm of FSR/°C Connectors 122-Pin Edge (100 mil spacing) Power +5V ±5% @ 1.6 A (max) Environmental Temperature 0 to 50°C Humidity 0 to 90% noncondensing Physical Height 7.5" (191 mm) Width 7.7" (196 mm) #### ORDERING INFORMATION **Part No. Description** 05-6075-01 Z80 AIO Analog Input/Output Board 05-6075-02 Z80 AIB Analog Input Board **A**EE01 00 #### Z80° IOB Z80 Input/Output Board # Product Description June 1982 ■ 64 Data and 16 Handshake Lines for Easy Interface ■ Fully Vectored Interrupt Operation Allows Convenient Program Design Port Assignment May Be Altered to Allow Several IOBs in a Single System Uses Z80A PIO Devices for Full Compatibility with Other Members of MCB Family #### OVERVIEW The Z80A Input/Output Board (IOB) provides system expansion to external digital I/O devices. It is fully compatible with other boards in the MCB family and provides eight parallel I/O ports to augment the two contained on the Z80 Microcomputer Board (MCB). Designed for user flexibility, the IOB contains four Z80A Parallel Input/Output (PIO) devices, a large pre-drilled user interface area, daisy-chain interrupt priority logic and user-selectable port address assignment. #### **FUNCTIONAL DESCRIPTION** The IOB contains four PIO controllers which provide 64 programmable I/O lines. These lines may be configured either as individual data lines with independent data direction or as groups of eight lines for byteoriented data transfer. The IOB gives the user a headstart on special inter- face requirements by providing a large pre-drilled, pre-etched interface area. The hole array is spaced on .3" and .6" centers in a flexible arrangement that accommodates 16-pin, 24-pin or 40-pin ICs. Parallel Input/Output. Each Z80A PIO device is a programmable, dualport circuit that provides a TTLcompatible interface between peripheral devices and the Z80 CPU. The PIO interfaces to peripherals via two independent general-purpose I/O ports designated Port A and Port B. Each port has eight data bits and two handshake signals, READY and STROBE, which control data transfer. The READY output indicates to the peripheral that the port is ready for a data transfer; STROBE is an input from the peripheral that indicates that the data transfer has occurred. In addition, the eight output lines from Port B can drive Darlington transistors (1.5 mA at 1.5 V). Operating Modes. Each group of eight lines is capable of being programmed in one of four modes of operation—byte output, byte input/output and bit input/output. Input Operation. The PIO device allows fully vectored interrupt operation with a unique vector for each port. The interrupt ability of each port may be enabled or disabled independently of the other ports. Interrupt priority is established by a hardware daisy-chain arrangement. Each group of lines has a fixed position within the priority structure; individual lines within each port are assigned equal priority. (See the 280 PIO Product Specification for details.) Port Assignments. By jumper placement, the four PIOs can be placed in any of eight 32-byte address ranges allowing the system to be easily configured and expanded. Z80A® IOB Block Diagram #### **SPECIFICATIONS** #### I/O Lines 64 Programmable #### Operational Modes Input, Output, Bidirectional, Bit Control #### Handshake 8 Ready and 8 Strobe Lines #### Interrupt Vectors 8 #### I/O Port Locations 16 User-selectable within 1-of-8 Blocks #### Output Voltage HIGH 2.4 V (min) @ 250 mA Output Current LOW 0.4 V (max) @ 2.0 mA Sink Current #### Curren Port B of Each PIO 3.8 mA (max) @ 1.5 V #### Input Voltage HIGH 2.0 V (min) LOW 0.8 V (max) #### Connectors 122-Pin Edge (100 mil spacing) #### Power +5 V ±5% @ 0.5 A (max) (without user ICs) #### Environmental Temperature 0 to 50°C Humidity 0 to 90% noncondensing Humidity Physical Height 7.5" (191 mm) Width 7.7" (196 mm) #### ORDERING INFORMATION Part No. Description 05-6006-03 Z80 IOB Input/Output Board 1034-001 00-1034A #### **Z80<sup>®</sup> SIB Z80 Serial Interface Board** #### **Product Description** June 1982 powerful, convenient features. Four independent channels, provided by 8251 USART devices, allow synchronous or asychronous data transfer with either half or full duplex signal handling. All four channels have drivers and receivers for RS-232C system interface and one will also accommodate a 20 mA current-loop interface. A dc-dc converter generates all necessary voltages from a single +5 V supply. An on-board crystal oscillator provides communication timing independent of the system clock. #### FUNCTIONAL DESCRIPTION The four SIB channels are capable of independent operation in either asynchronous or synchronous protocols. The system program may initiate and control either mode by selecting the appropriate command words. Both the transmitter and receiver sections are double-buffered for maximum performance and convenience. All data transfer status signals, such as TxRDY and RxRDY, are available in a readable status register or as external signals so that either polled operation or full interrupt control may be selected by the user under software control. In addition to the normal data transmission, each channel can generate break signals and be individually reset under software control. Asynchronous Mode. In the asynchronous mode, the system program controls the number of data bits (5, 6, 7, or 8), the number of stop bits (1, $1\frac{1}{2}$ , or 2,) and the sense of parity protection (even or odd) if enabled. Each channel has a programmable baud rate factor of 1, 16, or 64 controlling the relationship between the transmitted or received data rates and the frequency of the baud rate reference clock. See Figure 1 for a description of the asynchronous mode control word. Error detection signals are available for each channel and may be read from the channel status register; these signals include parity error (PE), framing error (FE), and receiver overrun error (OE). Figure 2 describes the channel status register. Synchronous Mode. In the synchronous receive mode, character synchronization may be obtained from an external device or internally from the received data stream. The nature of the SYNC connection for each channel is programmed as either an input when the channel is expecting an external sync signal or as an output to identify that sync has been achieved. In addition, each channel may be programmed to operate with either single or double synchronizing characters. **Timing.** The transmitter and receiver clocks for each USART channel can be derived from either the on-board crystal oscillator, thereby enabling operations to be independent of the main system clock frequency, or provided externally by the appropriate jumper selection. For internal clock signal generation, input signals to two Counter/Timer Circuits (CTC) can be jumper-selected to be either 1/2 or 1/32 of the crystal frequency. The outputs of the CTCs are further divided by flip-flops to provide a 50% duty cycle to the USARTs. By programming each channel of the third on-board CTC with the proper time constant, baud rates of 50 to 38.4K are possible. Table 1 shows time constants for various data rates when the USART has been programmed for a baud rate faster than 16. | Baud<br>Rate | Time Cor<br>Decimal | nstant<br>Hex | | |--------------|---------------------|---------------|--| | 50 | 96 | 60 | | | 75 | 64 | 40 | | | 110 | 44 | 2C | | | 134.5 | 36 | 24 | | | 150 | 32 | 24 | | | 200 | 24 | 18 | | | 300 | 16 | 10 | | | 600 | 8 | 8 | | | 1200 | 4 | 4 | | | 2400 | . 2 | 2 | | | 4800 | 1 | 1 | | | 9600 | 4* | 4* | | | 19200 | 2* | 2* | | | 38400 | 1* | 1* | | <sup>\*</sup>CTC in counter mode Table 1. Baud Rate vs Time Constant for 16 × Baud Rate Factor Interrupt Control. Each channel may be selected to operate in either a polled mode or a fully vectored interrupt mode. The interrupt capability for each channel may be enabled or disabled by the programmer to allow mixing both modes. Each channel may be programmed to have a unique interrupt vector for the receiver ready and the transmitter ready signals, allowing independent interrupt service subroutines for each direction of data transfer. Interrupt priorities are assigned by the hardware on a daisychain basis. The four receiver ready signals are given priority over the four transmitter ready signals. The channel priority for each group ranges from channel 0 having highest priority to channel 3 the lowest. Hardware Interface. Each of the four channels has drivers and receivers to allow full industry standard RS-232C interface parameters to external equipment. All voltages necessary for this | RANGE | J4 JUMPERS | |------------|----------------------------------------| | 1F | 5-16, 1-7, 3-6 | | 3 <b>F</b> | 5-15, 1-7, 3-6 | | 5 <b>F</b> | 5-16, 2-7, 3-6 | | 7F | 5-15, 2-7, 3-6 | | 9 <b>F</b> | 5-16, 1-7, 4-6 | | BF | 5-15, 1-7, 4-6 | | DF | 5-16, 2-7, 4-6 | | FF | 5-15, 2-7, 4-6 | | | 1F<br>3F<br>5F<br>7F<br>9F<br>BF<br>DF | Table 2. Port Address Range Figure 1. Channel Mode Control Word Figure 2. Channel Status Register 560 interface are provided by the dc-dc converter operating from a single +5 V input. Channel 3 is supplied with an active 20 mA current loop interface which the user may disable in favor of the RS-232C interface by selecting the appropriate jumper. In addition to the separate transmit and receive data signals, standard modem control signals such as DSR (data set ready), DTR (data terminal ready), CTS (clear to send), and RTS (request to send) are provided for each channel. The sense of each channel's interface is jumperselectable so that the board may behave as either a terminal device or a modem device. **Port Selection.** The SIB utilizes port assigned I/O and occupies locations within the I/O port assignment space. By selection of appropriate jumpers the user may place the SIB into any one of eight port address ranges, each offering 32 available port addresses. Table 2 shows the possible address ranges for the SIB. Each of the four USARTs and the three CTCs may be placed at a unique location within the selected range. The user selects the appropriate jumper configuration for the location. Z80 SIB Block Diagram #### **SPECIFICATIONS** Number of Channels Mode Full or Half Duplex **Baud Rates** 50 to 38.4K Baud **Baud Rate Reference Clock** 19.6608 MHz Synchronization Method External or Internal Character Match Channels 0-3 RS232C Channel 3 Current Loop Available Connectors 122-Pin Edge (100 mil spacing) Power +5 V ±5% @ 1.5 A (max) Environmental 0 to 50°C Temperature Humidity 0 to 90% noncondensing Physical Height 7.5" (191 mm) 7.7" (196 mm) Width #### ORDERING INFORMATION Part No. **Description** Z80 SIB 05-6007-01 Serial Interface Board 00-1036-A #### Z80<sup>®</sup> PPB **PROM Programmer Board** #### **Product Description** June 1982 Board (MCB) to program a variety of MOS E/PROM or bipolar PROM devices. The PPB is available in two configurations, PPB and PPB/16, each capable of programming a specific type of E/PROM. All necessary programming voltages are generated on the boards making them completely compatible with the MCB family, MCZTM microcomputers or ZDS development systems. #### FUNCTIONAL DESCRIPTION The PPB uses Z80 PIO devices to interface between the E/PROM sockets and the system microprocessor. Singlebyte data transfers in both directions permit either reading or programming of the selected E/PROM socket. Additional parallel I/O lines control the mode of operation and provide chip select to the desired socket. Zero force insertion sockets are used in the programming locations to provide convenience, reliability and long life. The programmer board extends beyond the card cage for easy access to programming sockets mounted near the board edge. Each board contains one 16-pin and two 24-pin sockets. | Device | Organization | |---------------|-----------------| | MOS E/PROMs | | | 2704 | 512 × 8 | | 2708 | $1024 \times 8$ | | Bipolar PROMs | | | 7610 | $256 \times 4$ | | 7611 | $256 \times 4$ | | 7620 | $512 \times 8$ | | 7621 | 512 × 8 | | 7640 | $1024 \times 8$ | | 7641 | 1024 × 8 | Table 1. PPB E/PROM Devices **PROM Types.** The PPB is designed to program 2704 and 2708 E/PROM devices and Harris-type bipolar devices. (See *Table 1* for device selection.) The PPB/16 allows programming of 5 V 2716-type E/PROM devices and Signetic-type bipolar devices (see *Table 2*). | Device | Organization | |---------------|-----------------| | MOS E/PROMs | | | 2716 | 2048 × 8 | | Bipolar PROMs | | | 82S126 | $256 \times 4$ | | 82S129 | $256 \times 4$ | | 82S130 | $512 \times 4$ | | 82S131 | $512 \times 4$ | | 82S140 | 512 × 8 | | 82S141 | 512 × 8 | | 82S180 | $1024 \times 8$ | | 82S181 | $1024 \times 8$ | | 82S2708 | 1024 × 8 | Table 2. PPB/16 E/PROM Devices Software. Both programmer boards are supported by the Z-PROG utility which is part of Zilog's RIO<sup>TM</sup> operating system. Z-PROG is an easy to use interactive program that allows E/PROMs to be read, programmed from disk file and duplicated, and allows the user to select the appropriate socket by specifying the E/PROM type and the word length. Z-PROG also provides address boundary selection for partial E/PROM programming. Z80® PPB/16 Block Diagram Z80® PPB Block Diagram #### **SPECIFICATIONS** #### E/PROM Sockets One 16-Pin Zero Force Insertion Two 24-Pin Zero Force Insertion #### E/PROM Types 24-Pin MOS 2704 (512 × 8) PPB 2708 (1024 × 8) PPB 2716 (2048 × 8) PPB/16 24-Pin Bipolar 7640 (1024 × 8) PPB 7641 (1024 × 8) PPB 82S140 (512 × 8) PPB/16 82S180 (1024 × 8) PPB/16 82S180 (1024 × 8) PPB/16 82S2708 (1024 × 8) PPB/16 16-Pin Bipolar 7610 (256 × 4) PPB 7611 (256 × 4) PPB 7620 (512 × 8) PPB 7621 (512 × 8) PPB 82S181 (1024 × 8) PPB/16 82S126 (256 × 4) PPB/16 82S129 (256 × 4) PPB/16 82S130 (512 × 4) PPB/16 82S131 (512 × 4) PPB/16 #### Control Interface TTL Interface with MCZ Series Data, Address and Control Signals #### Connectors 122-Pin Edge (100 mil spacing) #### Power +5 V ±5% @ 2.5 A during Programming 1.5 A during Read #### Environmental Temperature 0 to 50°C Humidity 0 to 90% noncondensing #### Physical: Height 9.0 in. (229 mm) Width 7.7 in. (196 mm) #### ORDERING INFORMATION Part No. Description 05-6005-01 Z80 PPB PROM Programming Board 05-6079 Z80 PPB/16 PROM Programming Board #### Z80° PMB Z80 PROM Memory Board # Product Description June 1982 #### FUNCTIONAL DESCRIPTION Memory Array. The PMB contains 16 24-pin sockets to accommodate a variety of E/P/ROM devices as shown in Table 1. Flexibility in the selection of the device type is provided in the form of jumpers that may be installed on a 16-pin component carrier. Chip selection logic allows each socket within the array to be configured to have a unique address starting on 1K byte boundaries. In addition, each socket may be programmed to have either a 1K byte or 2K byte granularity depending upon the memory device chosen. Chip selection is accomplished by a pair of socketed 32 × 8 PROMs. Parallel I/O. An on-board Z80 PIO device provides additional system I/O via 16 status or data lines which may be configured individually or in two groups of eight. (See Z80 PIO Product Specification for additional details.) There are two sets of Ready-Strobe handshake lines for each group of I/O lines. Drivers for both ports are provided for use in the output mode; termination resistor sockets are available for use in the input mode. | Non-Volatile<br>Memory | Device<br>Number | | |------------------------|----------------------------------|----------------------| | MOS<br>E/PROM | 2704<br>2708<br>2716 | 8704<br>8708<br>2316 | | Bipolar<br>P/ROM | 6341<br>6381<br>82S181<br>82S191 | | Table 1. Non-Volatile Memory Devices Counter/Timer. An on-board Z80 Counter/Timer Circuit provides expanded timing capability. The Z80 CTC includes four independent 8-bit counter/timers and can be programmed by system software for event counting, interrupt and interval timing, and general clock rate generation (See Z80 CTC Product Specification for specific details.) Port Assignments. The chip select logic allows each of the two I/O devices (CTC and PIO) to be located within any one of eight port assignment blocks each containing 20H bytes for I/O locations. Each device must occupy four consecutive locations within the chosen block. The configuration desired by the user is easily achieved by selecting appropriate jumpers that reside on component carriers. Z80® PMB Block Diagram #### **SPECIFICATIONS** #### **Memory Capacity** 32K (Populated with 2K Devices) #### E/P/ROM Socket Array Number 16 (24-pin) #### E/P/ROM Device Types 2708, 2716, 6381 #### Parallel I/O Number of Lines—16 (Programmable) Operating Modes—Input, Output, Bidirectional, Bit Control Handshake Lines—Ready, Strobe Interrupt Vectors—2 (User Programmable) #### Counter, Timer Channels 4 (8 Bits Each) Interrupt Vectors 4 (User Programmable) #### Connector 122-Pin Edge (100 mil spacing) #### Power - +5 V ±5% - @ 0.60 A (max) without Memory - @ 2.28 A (max) 2716 - @ 3.40 A (max) 6381 - @ 0.84 A (max) 2708 #### $-5 V \pm 5\%$ - @ 0.96 A (max) 2708 - +12 V ±5% - @ 1.28 A (max) 2708 #### DC-DC Converter Output +12 V @ 320 mÅ (max) -5 V @ 50 mÅ (max) #### Environmental Temperature 0 to 50°C Humidity 0 to 90% noncondensing #### Physical Height 7.5" (191 mm) Width 7.7" (196 mm) #### ORDERING INFORMATION Part No. 05-6023-01 **Description** Z80 PMB PROM Memory Board ## **Z80<sup>®</sup> MDC Z80 Memory and Disk Controller Board** ## **Product Description** June 1982 #### FUNCTIONAL DESCRIPTION with the MCB/16 Microcomputer Board. Together these two boards com- prise a complete microcomputer system that includes 64K bytes of RAM, 4K serial interface, and control of up to eight floppy disk drives—on a 115 sq. in. circuit board which operates from a bytes of PROM, parallel interface, single +5 V power supply. Memory Array. The memory array is implemented using $16K \times 1$ -bit dynamic RAM devices to provide 16K bytes to 48K bytes of main system memory. Although dynamic RAMs are used in the memory array, additional refresh circuitry is not required due to the unique memory refresh characteristic of the MCB CPU. Following each op-code fetch, a new refresh address is available on the system address bus while the op-code is being decoded within the processor. An on-board dc-dc converter generates the -5 and +12 V signals for the dynamic memory devices, enabling the MDC board to be operated from a single +5 V power supply. Memory address selection is completely compatible with the MCB/16. This two-board combination provides 64K bytes of continuous memory within the address space of the MCB CPU. For maximum flexibility, the RAM chip select logic is designed to allow the memory to be addressed in 4K byte blocks that may be located anywhere within the address range of the CPU. Chip selection is accomplished using a PROM decoder to select the Row Address Strobe (RAS) signal to the appropriate bank of devices. This address select PROM is socketed so that it may easily be replaced by the user for address reassignment. Disk Control. The disk control signals, formatting information and data transfer are provided by the CPU under program control. A PIO device is used as the interface element to transfer disk control and status information between the CPU and the control circuitry on the disk drive units. Disk status signals include READY, TRACK 0, SECTOR MARKER, WRITE PROTECT, and CRC ERROR. The control signals are DIRECTION, STEP, four DISK SELECT lines, READ, WRITE, and ENABLE CRC. The MDC includes a CRC used during read and write operations. This circuit generates a 16-bit word which is appended to the end of the data stream during write operations. During read operations a 16-bit word is again computed and then compared with the value previously written on the disk. A CRC error condition causes an error flag to be read into the CPU through the PIO interface. Data is recorded onto the floppy diskette in a serial format. Parallelto-serial and serial-to-parallel data conversion is performed by on-board circuitry. During the frequency modulation recording mode, each data bit recorded on the diskette has an associated clock bit recorded. Formatting of serial data into the disk is accomplished under program control by the MCB CPU. Optional PROM-based firmware to control up to two Shugart 801R Floppy Disk Drives is available from Zilog. This firmwave assumes that 32 data sectors (records) are utilized per track and 77 tracks are utilized per disk. The firmwave provides all control functions for the disk and performs all data transfer. The sector data format is illustrated in Figure 1. Figure 1. Sector Data Format Z80 MDC Block Diagram #### **SPECIFICATIONS** Disk Drive Capability 8 Single-Sided Drives Disk Drive Characteristics Sector Type Hard Recording Single Density Sectors per Track 32 Tracks per Disk Capacity Data Transfer Mode Programmed I/O 77 308K Bytes Data values. Connectors Memory Capacity 48K Bytes Memory Configurations 122-Pin Edge (100 mil spacing) 16K, 32K, or 48K Bytes Dynamic RAM. Each 4K page may have its starting address assigned to any of 16 possible Power +5 V ±5% @ 1.6 A max. Environmental Temperature 0 to 50°C Humidity 0 to 90% noncondensing Physical Height 7.5" (191 mm) Height 7.5" (191 mm) Width 7.7" (196 mm) #### ORDERING INFORMATION **Part No.** 05-6011-04 **Description** Z80 MDC/16 280 MDC/16 16K Memory and Disk Controller **Part No.** 05-6209-00 **Description** Z80 MDC/32 Z80 MDC/32 32K Memory and Disk Controller **Part No.** 05-6011-02 Z80 MDC/48 48K Memory and Disk Controller Description # **Z8000™ Dual-Processor System Upgrade Package** # Product Description June 1982 #### Features - Upgrades an MCZ<sup>TM</sup> or PDS system to a 16-bit system with 256K bytes of memory. - Provides complete Z8000-based software development tools that execute at 6MHz: screen editor, translator, compiler/assembler, debugger. - All software supplied in source code form to allow customization for applications. - Existing Z80 programs continue to run. #### Overview The Z8000 Dual-Processor System Upgrade Package provides 16-bit processing power, 256K bytes of random access memory, and software development tools for Zilog's Z80-based MCZ and PDS systems. The package consists of a Z8000 Microprocessor Board (MPB/256), a screen editor, Z80 to Z8000 translator, and a Z8000 assembler and debugger. The Z8000 MPB plugs directly into the backplane of the Z80 system and works with the Z80 and RIO. When the Z8000 is running, the Z80 acts as a peripheral processor that manages the resources of the host system. When the Z8000 is not activated, the system is controlled by the Z80 and there is no functional change due to the additional Z8000 MPB. # Functional Description Hardware. The Z8000 MPB contains a 6MHz Z8001 CPU and 256K bytes of RAM. The board uses a FIFO for inter-CPU block transfers. The FIFO is implemented using control logic and a 1Kx8 static RAM chip and can be accessed sequentially by either the Z80 or the Z8000. Software resolves any contention for ownership. The MPB can be plugged directly into the top slot of an MCZ-1/05 with no modification to the system. Or, it can be used in any vacant slot of an MCZ-1/20 or PDS 8000 system, and may require minor modification to the backplane. **Software.** The software tools provided with the Z8000 Dual-Processor System Upgrade Package include a screen editor, Y (a multilevel language compiler), a symbolic debugger, a Z80 to Z8000 translator, and the interface software between the Z80 and Z8000. The screen editor takes advantage of the 6MHz Z8000 and 256K RAM to provide an easy-to-use, efficient means of entering and modifying programs. The screen provides a "window" over the current copy of the file in memory. The cursor may be moved anywhere in the window to indicate the position where characters are to be added, deleted or Functional Description (Continued) replaced. In addition, commands are available to find and change strings of text and to delete, move or copy blocks of text. The screen editor is designed to be used with an Infoton 200 or a Visual 200 terminal. It can, however, be modified to work with almost any CRT. The compiler, Y, is a multi-level language. It includes Z8000 assembly language with Zilog mnemonics, Pascal-like control structures, data types, arithmetic expressions with automatic or specified allocation of registers, procedure calls with parameter passing, and a descriptive compiler language. The different levels may, for the most part, be freely mixed. The Y compiler features direct, one-pass code generation into memory, immediate execution of statements, conditional compilation, userdefined language extensions and symbolic debugging. The debugger can operate in two modes: Debug and Command. With the symbolic debugger in Debug mode, any instruction typed is executed immediately, with registers preserved from one line to the next. In addition, there is a special set of debug commands. The set includes commands to display and change memory and/or registers, set and remove breakpoints (up to eight), locate strings in memory, display stack history and execute a specific number of instructions. # Development Products Zilog ## Comprehensive Development Environments for All Zilog Microprocessors Innovative Design. Zilog's development system products feature ideal environments for software development for the Z8, Z80, and Z8000 microprocessors. The modularized design approach of the Zilog development systems allows the user a choice of hardware and software modules to meet current needs, while providing the necessary upgradability for future requirements. Proven Components. The PDS 8000 Family and ZDS-1 Family of development systems provide development support for the Z8, Z80, and Z8000 microprocessors. The PDS 8000 systems are software development stations, while the ZDS-1 systems contain integrated Z80 emulators, which permit full hardware and software debugging of the Z80 target system. Each of these systems offers variable configuration choices and extra card slots for additional peripherals. Ample provisions have been made for the expansion of memory, disk-storage, PROM programming, and external interface. And each system is supplied with Zilog's fieldproven RIO operating system and the necessary utilities. The Z-LAB concept partitions software and hardware development tools into specially tailored devices. Software and hardware checkout are handled by separate but compatible products. You can develop software on both Zilog and non-Zilog hosts using available compilers and cross-compilers. In either case, compatible hardware emulation systems are available at several levels of complexity. Standard RS-232 links provide for uploading and downloading of programs between hosts and emulators. System 8000 Z-LAB, a highperformance, multiuser, multitasking software development host combines the Zilog System 8000 and the Z-LAB concept. The 6 MHz Z8000-based System 8000 hardware incorporates a high-performance Winchester disk, as well as intelligent disk and tape controllers to further improve performance. ZEUS, the UNIX\*-based operating system, is specifically designed for software development and text processing. Numerous development tools are available, including the programming languages PLZ/ASM. PLZ/SYS, C, FORTRAN 77, and Pascal; various libraries; and a symbolic debugger. Because ZEUS treats emulators as System 8000 peripherals, System 8000 Z-LAB can combine with EMS 8000, Z-SCAN 8000, ZDS 1/40, or with non-Zilog emulators to provide total product development support for multiple microprocessors. The newest addition to Zilog's development products, EMS 8000, is a sophisticated emulation management system that aids in the development of Z8000 implementations. By providing logic state analysis, high-speed emulations (up to 6 MHz), complex triggering, a large real-time trace buffer, and large mappable memory, emulation and debugging are made both easier and faster. Yet another aid to Z8000 emulation is Z-SCAN 8000. An in-circuit emulator, Z-SCAN is also Z8000-based. It can be configured as a stand-alone unit, as well as linked to System 8000 or to any other mainframe host. Or it can be used as a peripheral to Zilog's PDS 8000 or ZDS/1 systems. The Z8 and Z8000 Development Modules are complete single-board microcomputers that permit the development of code for the Z8 or Z8000. They facilitate prototyping with large wire-wrap areas and are totally transparent to the CRTs and host CPU systems. **Software.** To facilitate program development, Zilog offers the complementary PLZ application languages, PLZ/SYS and PLZ/ASM. Similar constructs within the PLZ languages permit the user to combine high-level, machine-independent modules together with machine-dependent modules. PLZ/SYS is a procedure-oriented language with a style that blends elements of other well known languages such as Pascal, ALGOL, PL/I and C. PLZ/ASM is a structured assembly language that provides all the capabilities needed to manage the microprocessor resources such as registers, memory accesses, and I/O operations. This modular programming technique enables the programmer to concentrate on program design rather than on development system software. The Z8000 Cross-Software Package, running on UNIX, enables multi-user access for enhanced software development. The package consists of a complete set of software tools for developing Z8000 programs on DEC's PDP 11/44, 11/45, and 11/70 systems. The C language, including compiler and code optimizer, protects the user's software investment by permitting program transportability. The ZRTS Kernel, a small executive program, saves software development time by providing the core of a real-time multitasking operating system in PROMable form. Using ZCL, a high-level configuration language, the designer can define the target system and produce a memory-efficient, cost-effective end product. Even more software products include the RIO Electric Blackboard, a multiwindow full-screen text editor, and software development packages with utility programs that aid and simplify software development for the Z8 MCU and for Z8000 programs on the Z8000 Development Module. \*UNIX is a trademark of Bell Laboratories ## Product Description #### April 1982 #### **Features** - A 6 MHz Z8001A CPU and three Z8010A Memory Management Units (MMUs). This combination provides high performance and a potential 8M bytes of address space, enabling the System 8000 Z-LAB (Figure 1) to support advanced software tools. - ZEUS, Zilog's enhanced UNIX\* operating system. It supports 8 or 16 users in a software development environment that improves programmer productivity. - Comprehensive text processing software and a screen-oriented text editor. Both automate tedious tasks involved in developing software and documentation. - Universal software development host. It supports all of Zilog's microprocessors directly and can support other microprocessors with the addition of cross software packages. - A selection of high-level languages for the Z8000: C, Pascal, Fortran 77, and PLZ/SYS. The implementor can choose the language appropriate for the application. - In-circuit emulators are peripherals. This enables the System 8000 Z-LAB to support multiple emulators for different microprocessors concurrently and allows existing emulators to be used. - Presently 1M byte of error-correcting memory. Error-correcting memory increases - \*UNIX is a trademark of Bell Laboratories Zilog is licensed by Western Electric Company, Inc. - system reliability, and a large physical memory size improves system performance by minimizing the amount of swapping done. - System 8000 Z-LAB and ZEUS are designed to be upgraded for use with 32-bit microprocessors. This assures compatibility with the next generation of microprocessors. Figure 1. System 8000 Z-LAB #### General Description System 8000 Z-LAB is a high-performance Z8000-based system that combines the Zilog System 8000 and the Z-LAB concept. The Z-LAB concept for microprocessor product development separates hardware and software development tools into specially tailored devices; increases the effectiveness of each development tool; and assures that each development tool works alone, with the other, and with those made by other companies. # General Description (Continued) Figure 2. Example of System 8000 Configuration System 8000 Z-LAB can be combined with EMS 8000, Z-SCAN 8000, ZDS 1/40, and non-Zilog microprocessor emulators to provide complete product development support for multiple microprocessors (Figure 2). This is possible because emulators are treated as peripherals to System 8000 by the ZEUS operating system. **Software.** ZEUS is a general-purpose, multiuser, multitasking operating system designed specifically for software development and text processing. The structure of the ZEUS programming environment is shown in Figure 3. The major operating system features are: - Hierarchical file system - Compatible file, device, and interprocess input/output - Separate code and data address spaces - Multiple processes per user - User configurability The system utilities include the command interpreter and file maintenance, status inquiry, and system accounting programs. The command interpreter is selected on a per-user basis, enabling the system to be tailored to the needs of different users. Data communications utilities are also included for handling peripheral emulators and for networking over a serial link to other local or remote ZEUS- or UNIX-based computer systems. Figure 3. The ZEUS Programming Environment The ZEUS development tools consist of programming languages, libraries, a symbolic debugger, and more than 150 other utilities to aid software development. Z8000 programming languages include C, PLZ/SYS, and the PLZ/ASM assembler. There are optional Z8000 Pascal and Fortran 77 compilers, an optional PLZ/ASM assembler for the Z8, a Z80 C compiler, and a Z80 assembler. To increase editing speed, Zilog includes a screen-oriented text editor in ZEUS. This editor uses a data base of CRT terminal control information, allowing it to be used with almost any cursor-addressable CRT terminal. This data base can be easily updated by the user to add new terminals. **Hardware.** The System 8000 hardware was designed to support the ZEUS software. The memory management architecture of System 8000 allows ZEUS to support, without changes, programs that run under the UNIX operating system. The memory architecture also makes it possible for user programs to have an address space of up to 8M bytes; future versions of ZEUS will take advantage of this large address space. System 8000 hardware is designed for performance, reliability, and future growth. Performance is based on the 6 MHz Z8001A CPU and high-performance Winchester disks. The 1M byte of error correcting memory that can be put in a system minimize the amount of swapping done, also contributing to the system's performance. Intelligent disk and tape controllers also aid performance by removing device handling chores from the CPU. Hardware reliability comes from the exclusive use of error correcting memories and Winchester disks. The Z-BUS Backplane Interconnect (ZBITM) and the modular system packaging allow for system growth. The ZBI makes it # General Description (Continued) possible to add memory and controllers to the system. The modular packaging permits the economical addition of peripherals to the system while allowing it to keep the same appearance. **32-Bit Future.** System 8000 was designed to be upgraded to the next generation of microprocessors. The ZBI is a 32-bit bus, the memory can handle 32-bit data transfers, and the peripheral controllers work with 16- and 32-bit CPUs. In addition, ZEUS will continue to be the operating system. This is possible because the UNIX operating system, of which ZEUS is an enhancement, has already been transported to several 32-bit computers. #### Software The ZEUS operating system is an enhancement of the seventh edition of the UNIX operating system and will also incorporate UNIX System III features. ZEUS is a transported operating system; it was not rewritten. This transporation was possible because the operating system was written in C, a highlevel systems implementation language. Any program that runs under the UNIX operating system and is written in C, Fortran 77, or Pascal can also be transported to run on System 8000. ZEUS is more than an operating system. It includes an extensive set of programs that comprise the system utilities and development tools of the ZEUS programming environment (Figure 3). The system utilities listed in Table 1 are commands that provide user access, command processing, file management capabilities, status information, and communication with other devices or systems. Certain system utilities are used for maintenance and can be run only by a local system administrator. The development tools listed in Table 2 are commands that provide control of running programs, programming support, languages, text processing, and text formatting. The ZEUS operating system occupies approximately 80K bytes of memory. This memory is completely separate from the user address space. User programs can have the same maximum address space found in large, 16-bit minicomputers: 128K bytes of memory, consisting of 64K bytes of code and 64K bytes of data. A future release of ZEUS will expand the user address space up to 8M bytes. The remainder of this section describes the two most frequently used parts of ZEUS: the file system and the command language. **The File System.** The file system is probably the most important feature of ZEUS. It supports three types of files: ordinary files, directories, and special files. Ordinary Files. Ordinary files contain whatever information the user stores in them. No distinguished file types are provided by the system. A file of text simply contains a string of characters; lines are terminated by the newline character. Binary programs are sequences of words as they appear in memory. Any programs that require a particular file structure, such as a loader, must depend upon cooperating programs to control the structure. Ordinary files can be up to one billion bytes long; there is no predetermined file size limit. Directories. Directories structure the file system by providing a mapping between names of files and the files themselves. Each user starts with a single directory for his or her own files. The user can then create subdirectories of files that can be conveniently treated together. Directories are like ordinary files, except they contain information about other files. Anyone with access permission can read a directory just like any other file. The directory structure is that of a rooted tree. A file name may be specified to the system in the form of a path name; this is a sequence of directory names separated by slashes (/) and ending in a file name. File names are sequences of no more than 14 characters. If a path name begins with a slash, the search begins at the root directory. Thus, the path name /project/user/fn tells the system to search the root directory for project, then to search project for the directory user, and finally to find the file fn in the directory user. The file fn may be an ordinary file, a directory, or a special file. When a path name does not start with a slash, the user's current directory is searched. Therefore, the command *user/fn* specifies the file named *fn* in the subdirectory *user* of the current directory. Inputting just *fn* tells the system to search for the file in the current directory. It is possible for a nondirectory file to appear in several directories and even with different names. This is called linking, and all links to a file have equal status. This differs from other systems because files exist independently of any directory entry, although a file disappears when the last link to it is removed. Special Files. Special files provide access to physical devices as though they were ordinary files. These files are, of course, protected from indiscriminate access. There are three benefits of treating I/O devices this way: file and device I/O are as similar as possible; programs expecting a file name as a parameter can be passed a device name as well because file and device names have the same syntax; and special files can be protected by the same mechanism as ordinary files. Software (Continued) Protection. The access control scheme of ZEUS is simple and effective. Each user is assigned an identification number. When a file is created, it is marked with the identification number of its creator or owner. Read, write, and execute permission for the owner, for members of the same group, and for all other users can be set when the file is created or by command at a later time. In the standard UNIX operating system, there is nothing to prevent two users from simultaneously modifying a file, resulting in one user invalidating the other's changes. The ZEUS operating system augments the three standard UNIX file opening modes (Read, Write, or both Read and Write) with a mechanism for locking portions of a file. Both Read-Only and Exclusive Use locks are provided. Command Language. Most users use the command interpreter called the shell to communicate with the System 8000. The shell is usually the first program run when a user logs on. It is possible to specify other command interpreters or, in fact, any program to be run when a user logs on. Consequently, some users could be in the editor as soon as they log on, while programmers on the same system would be in the shell. The simplest form of command line is a command name followed by a list of arguments to the command, all separated by spaces: cmd argl arg2 ... argn Given this command line, the shell searches for a file with the name cmd, where cmd may be a full path name. If cmd is found and is executable, it is loaded into memory and run. The arguments entered on the command line are accessible to the command. When the command is finished, control is returned to the shell, which prompts the user for the next command. If cmd is not a full path name, the shell automatically starts searching for cmd using a user-specified or default search path. Standard I/O. Programs executed by the shell start off with three open files. File 0 is initially open for reading. Programs that need to read from the user's terminal can read from this file; it is the standard input device. File 1 is open for writing and represents the standard output file. This file is initially the user's terminal. File 2 is the standard error file, also initially assigned to the terminal. The user can order the shell to change the standard assignments of these files from the terminal. If one of the arguments to a command is prefixed by ">", file descriptor 1 will refer to the file named after the ">" for the duration of the command. For example, ls ordinarily lists the names of the files in the current directory on the terminal. The command ls > catalog creates a file called *catalog* and puts the listing there. On the input side, mail fred enters the *mail* program, which normally accepts input from the terminal and in this case sends it to the user fred. The command mail fred < message causes *mail* to take its input from the file *message* instead of from the terminal. The "<" and ">" symbols tell the shell to redirect the I/O to the specified files. The command simply uses file descriptors 0 and 1 where appropriate and needs no special coding to handle the redirection. File descriptor 2 is for diagnostic messages normally associated with the terminal output. When an output redirection using ">" takes place, file 2 is still attached to the terminal, so commands produce diagnostic messages to the user. Pipes and Filters. The output of one command can be directed to the input of another with an extension of the standard I/O concept. When a sequence of commands separated by vertical bars (|) is entered, the shell executes all the commands simultaneously and connects the standard output of each command to be delivered to the standard input of the next command in the sequence. Thus, the command line sort data5 | pr | lpr sorts the file called data5 in the current directory and passes the sorted output to pr, which adds an identifying header line and page breaks. Likewise, the output from pr is passed to Ipr, which prints the formatted listing on the line printer. This procedure could have been carried out much more clumsily by using I/O redirection and two temporary files. The vertical bar represents a "pipe" that connects the output of one program to the input of another. Programs that read standard input, process the data, and write to standard output are called filters. Many of the ZEUS utilities can be used as filters to perform functions such as pattern searching, sorting, text formatting, encryption, and decryption. Command Separators and Multitasking. The shell allows multiple commands to be entered on a single command line simply by separating them with a semicolon. A related feature #### Software (Continued) allows the user to start multiple tasks from a terminal. When a command is followed by an ampersand (&), the shell does not wait for the command to finish before prompting again; instead, it is ready to accept a new command immediately. For example, starts the C compiler compiling prog, with compilation messages sent to out; the shell returns to the user immediately, no matter how long the compiling process takes. The identification number of the process running a command is printed when the shell does not wait for the completion of a command. This number can be used to terminate a command or check for its completion. The "&" can be used several times on a command line. Thus, the command line #### cc prog >out & ls >fnames & both compiles *prog* and lists the files in the current directory. Output files other than the terminal were specified above; had this not been done, the output of the various commands would have been interminaled. Command Files. The shell itself is a command and can be called recursively. Suppose the following commands were entered at the terminal: cc -o testprog prog testprog >testout diff testout valid >result This sequence of commands compiles prog, giving the binary program the name testprog; runs testprog, sending the output to the file testout; executes diff, a file comparison program, to compare testout with the expected valid output; and places any differences in the file result. To do the program testing automatically, the above commands can be entered in a file. If the file were called validation, then the command #### sh < validation would cause the shell to execute a new copy of itself, taking the input from *validation*. If *validation* is made an executable file, it becomes a new command and can be invoked simply by entering its name in the command line. The shell has more advanced capabilities, including the ability to substitute parameters and to construct argument lists from a specified subset of the file names in a directory. It also provides general conditional and looping constructs. In fact, the shell is its own programming language. #### Hardware System 8000 is a modular, free-standing unit built for multi-station software development in an office or laboratory environment. It can be stacked up to six modules high. When the side panels are removed from an individual module, it can be mounted in a standard 19-inch rack. The modular design of System 8000 makes it easy to service. Each module is self-contained and can be unstacked without the use of any tools. To aid servicing, all module interconnect cables are located on the outside rear panel of each module. The System 8000 is available in two basic configurations, referred to as Model 20 and Model 30 (see Figures 4 and 5). Both models can be expanded to the same maximum configuration. The components of the systems are housed in two types of modules, a processor module and a peripheral module. Processor Module: Z8001A CPU Eight serial ports Printer interface Winchester disk controller Cartridge tape controller 256 KB of ECC memory Peripheral Module: 24 MB Winchester disk Cartridge tape drive Double Storage Compartment: Miscellaneous storage space Processor Module: Z8001A CPU Eight serial ports Printer interface Winchester disk controller Cartridge tape controller # 512 KB of ECC memory Peripheral Module: 24 MB Winchester disk Cartridge tape drive Peripheral Module: 24 MB Winchester disk Storage Compartment: Miscellaneous storage space Figure 4. System 8000 Z-LAB Model 20 Figure 5. System 8000 Z-LAB Model 30 Hardware (Continued) **Processor Module.** The processor module holds all of the printed circuit boards of System 8000, the card cage and backplane, power supplies for the module itself, and the key lock switch that enables the system reset and start switches. The card cage and backplane hold 10 printed circuit boards. The minimal System 8000 is made up of five boards: CPU, ECC memory controller, one 256K byte memory array, a Winchester disk controller, and a cartridge tape controller. The ZBI bus allows optional memory and controllers to be added to the system simply by plugging them into available slots. The ZBI provides increased flexibility by supporting 8-, 16-, and 32-bit data transfers. This assures that future 32-bit microprocessors can be used in the system. The CPU board is based on Zilog's 6 MHz Z8001A. It also includes three Z8010A MMUs. which allow the hardware to support user programs of up to 8M bytes. Eight RS-232C serial ports with modem control and programmable baud rates are standard on the CPU board. Each serial port contains the control logic necessary for connection to a modem. The baud rate on each serial port can be set by software to standard rates from 110 baud to 19,200 baud (default is 9,600 baud). Also standard is a printer interface that supports the Centronics parallel interface; it can be jumpered to support the Dataproducts interface. An 8K byte monitor in ROM holds the power-up diagnostics and bootstrap. To allow the use of lower-cost RAMs on the memory array board and to eliminate wait states, the system clock runs at 5.5 MHz. The ECC memory controller provides singlebit error correction and double-bit error detection on a 32-bit basis and logs correctable errors. It controls the refresh needed for the dynamic RAMs on up to 16 memory array cards. It also performs 8-, 16-, and 32-bit data transfers to the ZBI, which allows the memory to be used with future 32-bit microprocessors. The memory array card currently provides 256K bytes of dynamic RAM and holds the extra memory necessary for the ECC bits. If the remaining three slots in the backplane are used for memory, a System 8000 can have up to 1M byte of memory. Larger memory configurations are planned for future release. The Winchester disk controller is an intelligent disk controller based on Zilog's Z80B microprocessor. It supports up to four 8-inch Winchester disk drives and holds enough memory to buffer one disk track. This provides for high-performance, multisector reads and writes. The controller transfers data to and from the System 8000 memory under DMA control, which minimizes CPU overhead and increases the system's performance. The cartridge tape controller is also a Z80B-based intelligent controller. It supports up to four standard (not streamer) cartridge tape drives. DMA data transfers are performed by this controller, too. The system can be upgraded to support a total of 16 users. The upgrade includes an external panel for the additional ports, cables, and serial controller board. The board has eight serial ports that are RS-232C compatible and a printer interface, identical to those on the CPU board. Peripheral Module. The peripheral module holds a Winchester disk drive, a cartridge tape drive, and the necessary power supply. The Winchester disk drive is a high-performance, 8-inch drive with an average access time of 48 ms. The peripheral module can house one drive; more drives can be added by connecting more peripheral modules to the system. The standard disk holds 24M bytes when unformatted and 22M bytes when formatted. A cartridge tape drive can be housed in the same peripheral module as a Winchester disk. One standard cartridge tape drive (not streamer) is provided with System 8000, allowing selective file backup and recovery. All software for the system is provided on a cartridge tape. The standard cartridge holds 17M bytes when unformatted and approximately 14M bytes when formatted. **System Diagnostics.** To help verify system integrity, two distinct diagnostic routines are standard with System 8000. Power-on diagnostics reside in the bootstrap ROM and are initialized when the system is powered on or the *RESET* and *START* buttons are pushed. They provide a limited measure of hardware integrity. The following tests are performed: Z8000 instruction test, MMU test, memory test, ECC controller test, Winchester disk controller test, and cartridge tape controller test. If no errors are detected, the system acknowledges that the test is over and boots the operating system. If an error is found, an explicit error message is displayed on the console. Stand-alone diagnostics are executed by the diagnostics monitor and provide a thorough testing of all standard and optional hardware. The diagnostic monitor lets the user select various options, construct a list of tests to be executed with options, or execute a test directly. Results and optional decisions are handled via the console. The tests provided are CPU test (which covers communications, the MMU, on-board RAM and ROM, and interrupt handling), stand-alone memory test, Winchester disk test, and cartridge tape test. #### User Access login Allows a user to sign on to the Changes working group (project). newgrp system. Verifies password to protect against □ Verifies password and unauthorized changes to projects. acknowledges user's individual passwd Sets or changes the password for a and group (project) identity gpasswd user or a group. Passwords are kept ☐ Adapts to terminal characteristics encrypted for security. ☐ Establishes working directory Substitute user. Verifies password to su ☐ Announces presence of mail ensure that present user can tem-(from mail) porarily operate under a different ☐ Publishes message of the day user name. ☐ Executes user-specified profile ☐ Starts command interpreter or other initial program Command Processing csh Processes commands and command letting them run asynline arguments. Provides all the chronously as directed general capabilities of the shell sh, by the user. ☐ Supports I/O redirection. as well as the following features: ☐ Has a C-like syntax for expres-☐ Connects processes with pipes. sions and conditionals. This ☐ Supports environment variables feature gives the C shell for each user that specify the home directory, prompt, mail its name. file, and search path for ☐ Supports aliases for commands. ☐ Supports history substitutions executable commands. involving previous commands. □ Can read, interpret, and execute a command file called a Supports more sophisticated shell script, substituting argument processing involving head or tail of a path name and arguments as directed. root or suffix of a file name. For command sequencing control, recognizes "if...then...", □ Can pass a shell script to the case switches, while loops, for shell sh for processing. sh loops over lists, break, and exit. Processes commands and command line arguments, and is the standard ☐ Supports execution of a shell seventh edition UNIX shell. Provides script at log-in. ☐ Constructs argument lists from the following features: ☐ Initiates tasks, either file name patterns used as waiting for completion or arguments. File Management Identifies the common lines in two Builds, adds to, or retrieves from an comm ar files. archive (library). Concatenates one or more files onto Copies one file to another, or a set cat cp standard output. Particularly useful of files to a directory. Works on any for simple printing. Works on any file regardless of content. file, regardless of content. dd Copies one file to another with concdChanges working directory. Built trol over other details such as the into the shells sh and csh. block size for files on tape. chkdiff Zilog source control (ZSC) comdiff Reports the changes, additions, and chkin mands. Report differences in verdeletions necessary to make two files chkout sions of a source file, check files in identical. chkwhat or out, and report on file status. Displays a file so that the user can doa chmod Changes read, write, or execute examine the information one full permissions on one or more files. screen at a time. Executable only by the file owner. find Searches the directory hierarchy for Compares two files and reports cmp every file that meets specified whether they are identical. Very criteria. Search criteria include: useful for comparing executable binary files. Table 1. System Utilities □ Name matches a given pattern □ Creation date in a given range | Table 1. | File Mar | nagement (Continued) | | | |---------------------------------|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|---------|-----------------------------------------------------------------------------------------------------------------------| | System | find | □ Date of last use in given range | mkdir | Makes a new directory. | | <b>Utilities</b><br>(Continued) | (cont) | <ul> <li>□ Given permissions</li> <li>□ Given special file</li> <li>characteristics</li> <li>□ A boolean combination of the</li> <li>above</li> </ul> | more | Displays a file so that a user can examine the information in full or partial screenfuls, moving forward or backward. | | | | Can start searching from any directory. Performs a specified command on each file found. | mv | Moves a file or files. Used for<br>renaming a single file or moving a<br>number of files to a different<br>directory. | | | head<br>ln | Displays a specified number of lines from the beginning of a file. Links another name (establishes an | pr | Prints files with date, page number and file name on every page. Can | | | _ | alias) to an existing file. | | produce column output and paralle column merge of several files. | | | lpr<br>lpr2 | Spools files to the line printer or the second line printer. | rm | Removes a file. Only the name is removed if any other names are | | | ls | Lists the names of one, several, or<br>all files in one or more directories.<br>Can display names in a single col- | | links to the file. Can delete entire<br>directory hierarchies interactively c<br>automatically. | | | | umn, multiple columns, or comma- | rmdir | Removes a directory. | | | | separated list. Names can be sorted<br>alphabetically, in ascending or<br>descending sequence, or by | tail | Retrieves a specified number of lines from the end of a file. | | | | modification date. Can display size, owner, group, date last modified, | tar | Creates a tape archive and retrieve from it. | | | | and permissions to read, write or execute. | touch | Changes the modification date of a file without changing the file. | | | Status In | formation | | | | | date | Prints current date and time. | pstat | Prints detailed status from internal system tables. | | | daytime<br>du | Gives day and time display. Prints a summary of the total space occupied by all files in a directory | pwd | Prints the name of the user's working directory. | | | | and all subdirectories. | setenv | Sets environment variables for the shell. Changes terminal type for | | | file | Attempts to determine what kind of information is in a file by looking at the file system index and by reading | | screen editor vi. Built into the st | | | printenv | the file itself. | stty | Reports or changes the terminal characteristics. | | | <b>P</b> | such as the terminal type known to vi. | tty | Prints the name of the user's terminal. | | | ps | Reports on active processes for one or all users. Tells what commands | who | Prints who is on the system, with port assignments and time of log-in | | | | are being executed. | whoami | Prints the current user name. | | | Commun | | | | | | cu | Provides dial-out capability to<br>another machine. Intended for use<br>with the VENTEL 212+ modem, | | 8000 emulator, or Z8000 target hard<br>ware. Uses the Tektronix hex com-<br>munication protocol. | | | | which can automatically originate phone calls. | local | Reverses the effect of remote by returning the user to the local | | | getfile | Provides upload of files from a local MCZ-1, ZDS or System 8000 to a remote System 8000. | putfile | system. Provides download of files from a remote System 8000 to a local | | | LOAD | Provides download of Z8000 code<br>from System 8000 to Z8000 Develop- | remote | MCZ-1, ZDS or System 8000. | | | | ment Module, Z-SCAN 8000 or EMS | remote | Establishes communication by direction link to another System 8000. | | | | | | | | Table 1. | Commun | nication (Continued) | | | |------------------------------|----------------|----------------------------------------------------------------------------------------------------------------------------------------|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------| | System Utilities (Continued) | SEND | Z8000 DM, Z-SCAN 8000, EMS 8000, or target hardware to System 8000. | | Enables communication between ZEUS and another ZEUS system, or between ZEUS and another UNIX system. | | | SYS | Enables code downloaded with <i>LOAD</i> to access files on the System 8000. | | | | | System 1 | Maintenance | | | | | ac | Prints a cumulative connect time report by user or by day for all or for selected users. | mknod | Makes a new file system entry for a special file that is a device. | | | accton | Initiates collection of system accounting information for sa. | mount | Attaches a device containing a file system to the tree of directories. | | | adduser | Adds a new user name to the system. | ncheck | For <i>icheck</i> or <i>dcheck</i> problems, displays correspondence of i-node numbers and file names. | | | chown<br>chgrp | Changes owner of one or more files, group (project) to which files | guot | Prints a summary of file space usage by user. | | | chog<br>chmog | belong, both the owner and group,<br>or the access privileges as well as<br>owner and group. | rc | Brings the system up automatically<br>after performing a file system con-<br>sistency check and setting the | | | clri | Clears one or more i-nodes. | | date/time information. | | | dcheck | Checks the integrity of the directory structure. | restor | Restores a dumped file system, or retrieves parts selectively. | | | df | Reports the amount of free space on file system devices. | rmuser | Removes a user name from the system. | | | down | Brings the system down smoothly, after broadcasting to all users at intervals. | sa | Prints an accounting report of com-<br>mand usage, including the number<br>of times each command was used,<br>total system time, total user time, | | | dump | Dumps the file system on the specified device either selectively, by date, or in total. | | and elapsed real time, with optional averages and percentages. | | | fsck | Performs file system consistency check and makes repairs, if | sync | Writes out super blocks to preserve file system changes. | | | | necesary. | sysgen | Defines a new system configuration. | | | icheck | Checks the integrity of the i-nodes<br>on the file system by reporting<br>assignment of blocks either to files<br>or to the free list. | umount | Removes a device containing a file system from the tree of directories. Protects against removing a busy device. | | | mkfs | Makes a new file system on a device. | wall | Writes a broadcast message to all users. | | Table 2. | Running | Programs | | | | Develop- | at | Schedules a command to be run at | kill | Terminates named processes. | | ment Tools | basename | an arbitrary time. Prints name after removal of | nice | Runs a command at low (or high) priority. Built into the shell <i>csh</i> . | | | echo | preceding path information. Prints remainder of the command | sleep | Suspends execution for a specified time. | | | echo2 | line. Useful for prompts or diagnostics in shell programs and in make files. Built into the shell csh. | tee | Passes data between processes and diverts a copy into one or more files. | | | expr | Performs integer arithmetic and pattern-matching string computation for calculating command arguments. | test | Supplies returned status codes as values for shell scripts. | | | gets | Gets string from the terminal. Used in shell scripts. | true<br>false | Supplies truth values for shell scripts. | | Table 2. | Running | Programs (Continued) | | | | | | |-------------------------------|-----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------|------------------------------------------------------------------------------------------------------------------|--|--|--| | Development Tools (Continued) | upkeep | Maintains a record of directory contents and can report modifications of contents. | wait | Waits for termination of asynchronously running processes. Buil into the shells <i>sh</i> and <i>csh</i> . | | | | | (Commueu) | Programi | ning Support | | | | | | | | apropos<br>getNAME | Locates and prints descriptive information from manual entries for | | Mail can be disposed of, saved in a file, or forwarded. | | | | | | whatıs | utilities. | make | Controls the creation of large pro- | | | | | | calendar | Automatic reminder service selects events due same day and next day, according to the user's calendar. | | grams. Uses a control file specifying<br>source file dependencies to make<br>new versions; uses time last change | | | | | | code | Prints characters and associated hexadecimal values. | | to deduce minimum amount of work<br>necessary. Has built-in knowledge<br>file extensions for source, assem- | | | | | | error | Disperses compiler error messages through program listing. | | bler, and object files. | | | | | | hd | Dumps any file in hexadecimal | mesg | Inhibits receipt of messages from other users. | | | | | | od | or octal. Output options include | nm | Prints the symbol table of an object | | | | | | ld<br>sld | display in decimal or ASCII. The Z8000 linker for nonsegmented or segmented code. It combines relocatable object files and inserts required routines from specified | | or executable program. Provides control over types of names and the order of names that are printed. | | | | | | | | prof | Constructs a profile of time spent | | | | | | learn | libraries. Runs computer-aided instruction | | per routine from statistics gathered<br>by time-sampling the execution of a<br>new program. | | | | | | | (CAI) scripts so that users can learn | prom | Transmits executable code to a | | | | | | (library<br>routines) | | prom | PROM programmer. Intended for use with the Data I/O Model 19 with translation option. | | | | | | | software. They include: □ Buffered, character-by- character I/O □ Formatted input and output conversion | size | Reports the memory requirements of one or more executable files, including code, data, and stack sections. | | | | | | | <ul><li>☐ Storage allocation</li><li>☐ Time conversions</li></ul> | str<br>strprint | Collects software trouble reports an produces listing sent to Zilog. | | | | | | | <ul> <li>□ Number conversions</li> <li>□ Password encryption</li> <li>□ Quicksort</li> <li>□ Random number generator</li> <li>□ Mathematical function library, including trigonometric functions and inverses,</li> </ul> | strip | Removes the relocation and symbol table information from an executabl file to save storage space. | | | | | | | | time | Runs a command and reports timing information on it. Built into the shell csh. | | | | | | | exponential, logarithm, square root, and bessel functions. | write<br>talk | Creates a direct terminal connectio<br>to another user, transmitting entire<br>lines or characters. | | | | | | man | Prints a specified section of the ZEUS reference manual at the terminal. | whereis | Locates binary code and manual entry for a utility. | | | | | | maıl | Mails a message to one or more user, or reads mail sent to the user. | xget<br>xsend<br>enroll | Receives or sends secret mail or establishes password for secret mail | | | | | | Languages | | | | | | | | | adb | Interactive Z8000 debugging tool. Provides breakpoint debugging with the debugger as a separate process, | as | The Z8000 PLZ/ASM assembler for nonsegmented or segmented Z8000 code. | | | | | | | as well as supporting symbolic reference to global variables, a stack trace for C programs, patching, and postmortem dumping. | bc | A C-like interactive interface to the desk calculator $dc$ . It includes arrays and recursive functions. | | | | | Table 2. | Langua | ges (Continued) | | | | |-------------------------------|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | Development Tools (Continued) | cb<br>cc<br>scc | A beautifier for C programs; it does proper indentation and placement of braces. Compiles programs written in the C language. cc generates non-segmented Z8000 code, and scc | lex | Generates lexical analyzers. Arbitrary C functions can be called upon isolation of each lexical token. It supports full regular expressions, plus left and right context dependence. Resulting lexical analyzers interface cleanly with | | | | | generates segmented Z8000 code.<br>The ZEUS operating system and the | | yacc parsers. | | | | | C compiler itself are written in C. The major features of C are: General-purpose language designed for structured | lint | Verifies C programs and reports any<br>machine-dependent constructs. It<br>does full cross-module checking of<br>separately compiled programs. | | | | | programming. Data types include character, integer, float, and double, pointers to all types, functions returning those types, arrays of all types, structures and unions of all types. Operations intended to give | m4 | A general-purpose macroprocessor that is stream-oriented and recognizes macros anywhere in the text. Its syntax fits with the functional syntax of most higher-level languages. It can evaluate integer arithmetic expressions. | | | | | machine-independent control. Macro-preprocessor for parameterized code and inclusion of standard files. | pascal | Compiles programs written in the Pascal language and produces nonsegmented Z8000 code. (Pascal is an option on System 8000.) | | | | | <ul> <li>☐ All procedures can be recursive, with parameters passed by value.</li> <li>☐ Machine-independent pointer manipulation.</li> <li>☐ Object code uses full addressing</li> </ul> | plz | Compiles programs written in Zilog's PLZ/SYS language and produces nonsegmented or segmented Z8000 code. | | | | | capability of the Z8000. Run-time library gives access to all system facilities. Definable data types. Block-structured language. | rmcobol<br>runcobol | Generates an intermediate code and<br>then interpretively executes pro-<br>grams written in the COBOL<br>language. (COBOL is an option on<br>System 8000.) | | | | ctags | gs Maintains tags file for use in editing large C or Fortran programs. | yacc | An LR(1)-based compiler writing system. During execution of resulting parsers, arbitrary C fund | | | | cxref | | | tions can be called to do code<br>generation or semantic actions. Syn- | | | | dc | | | tax specifications are in BNF and it takes precedence relations. It accepts formally ambiguous grammars with non-BNF resolution rules. | | | | (00 | decimal arithmetic, and reverse Polish operators. | z8as | Assembles code for the Zilog Z8 microcomputer. (Z8 assembler is an | | | | f77 | Compiles programs written in the Fortran 77 language and produces either nonsegmented or segmented Z8000 code. (Fortran is an option on System 8000.) | z80as<br>z80cc | option on System 8000.) Assembles code for the Zilog Z80 microprocessor, or compiles C programs to produce Z80 code. (Both are options on System 8000.) | | | | Text Pro | ocessing | | | | | | awk | A pattern scanning program and processing language. Searches input for patterns and performs appropriate actions. | | ☐ Find lines by number or pattern. Patterns may include specified characters, don't care characters, choices among characters, | | | | crypt | Encrypts and decrypts files for security. | | repetitions of these constructs, beginning of line and end of line. | | | | ed | Interactive, line-oriented context<br>editor providing random access to<br>all lines in a file. It lets the user: | | <ul><li>☐ Add, delete, change, copy, move or join lines.</li><li>☐ Permute or split contents of a line.</li></ul> | | | Table 2. | Text Pro | cessing (Continued) | | | |---------------------------|------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Develop-<br>ment<br>Tools | ed<br>(Cont) | ☐ Replace one or all instances of a pattern with a line. | | add to the systems' spelling dictionary. | | (Continued) | | ☐ Combine or split files. ☐ Escape to the shell during editing. | uniq | Collapses successive duplicate line of a file to a single line. | | | ex<br>edit | Line-oriented editors that are supersets of ed and contain many of the commands found in vi. | vi<br>view | Visual CRT-oriented text editor. Works with almost any addressable cursor CRT terminal. Features of vinclude: | | | grep<br>egrep<br>fgrep | Prints all lines in a file that satisfy a pattern, including line numbers if requested. | | <ul> <li>Cursor movement on character,<br/>word, line, sentence, paragraph<br/>section, or page basis.</li> </ul> | | | look | Searches for words in a sorted file that begin with a specified prefix. | | <ul> <li>Cut and paste.</li> <li>Optional automatic indentation</li> </ul> | | | sed | Stream-oriented version of ed. Performs a sequence of editing operations on an input stream of unrestricted length. | | for entry of programs in a block structured language. Full-screen display of current te in file. User-specified margin for | | | sort | Sorts or merges ASCII files line by<br>line. Sorts alphabetically or by<br>numeric key. Multiple keys are<br>located by delimiters or by position.<br>Sorts in ascending or descending<br>order. | | <ul> <li>automatic return when typing text.</li> <li>Escape to the shell while editing</li> <li>A line-oriented mode compatible with ed.</li> <li>A user modifiable data base of</li> </ul> | | | spell<br>spellin<br>spellout | Looks for spelling errors by comparing each word in a document against a 25,000-word dictionary that includes proper names. It handles common prefixes and suffixes. It also can collect words to | wc | CRT terminal control information □ For important files, a read-only version named view. Counts the lines, words, and characters in a file. | | | | inces. It also can conect words to | | | | | Text For | matting Checks validity of eqn constructs. | | □ Automatically numbered | | | col | Arrange files with reverse line feeds for one-pass printing. | | subheads. □ Footnotes. □ Single- or double-column outpu | | | deroff | Removes all <i>nroff, troff, eqn,</i> and <i>tbl</i> commands from input. | | ☐ Paragraphing, display, and indentation. | | | eqn | A mathematical typesetting preprocessor for <i>troff</i> . Translates | neqn | A version of eqn for nroff; it accept the same input language. | | | | formulas that are easily read into detailed typesetting instructions. | nroff<br>troff | Advanced text formatting. <i>nroff</i> drives ASCII terminals or printers | | | expand<br>(man | Expands tabs to spaces for printing. A standardized document layout | | all types, and <i>troff</i> drives a Graphi<br>Systems phototypesetter or | | | macros) | package that does formatting for en- | | equivalent. | | | | tries in the ZEUS Programmer's Manual. For use with nroff or troff. | tabs | Sets the tabs on a variety of terminals for printing. | | | (ms<br>macros) | A standardized manuscript layout package for use with <i>nroff</i> and <i>troff</i> . It includes macros that do: □ Page numbers and draft dates. | tbl | A preprocessor for <i>nroff</i> and <i>troff</i> that translates simple descriptions table layouts and contents into detailed typesetting instructions. | | System | Model 20/30 Physical — | | |-----------|------------------------|-----------------------------------| | Charac- | Height - | 84 cm (33 in.) | | teristics | Width | 48 cm (19 in.) | | | Depth | 61 cm (24 in.) | | | Weight (Model 20) | 60 kg (132 pounds) | | | | approximate | | | Weight (Model 30) | 70 kg (154 pounds)<br>approximate | # Model 20/30 Electrical Domestic | Domestic | | |---------------------|---------------| | Voltage | 117 ac ± 10% | | Phase | single | | Frequency | 60 Hz | | Current (sustained) | 3.5 A maximum | | Current (surge) | 4.5 A maxımum | | International | | | Voltage | 220 ac ± 10% | | Phase | single | | Frequency | 50 Hz | | Current (sustained) | 1.9 A maximum | | Current (surge) | 2.5 A maximum | | | | Tracks Recording Density | Model 20/30 Environmento | Model 20/30 Environmental | | | | | | |--------------------------|---------------------------|--|--|--|--|--| | Operating Temperature | 10° C | | | | | | | | (50° F) min. | | | | | | | | 40° C | | | | | | | | (104° F) max. | | | | | | | Relative Humidity | 80% | | | | | | | | (Noncondensing) | | | | | | | Disk Performance | | | | | | | | Rotation Speed | 3,600 RPM | | | | | | | Power ON to Ready | 60 seconds | | | | | | | Time | | | | | | | | Average Positioning | 43 ms | | | | | | | Time | | | | | | | | Number of Surfaces | 3 | | | | | | | Tracks per Surface | 600 | | | | | | | Sectors per Track | 24 | | | | | | | Bytes per Sector | 512 | | | | | | | Data Transfer Rate | 801K bytes/s | | | | | | | Tape Drive Performance — | | | | | | | | Speed Read/Write | 30 ips (90 ips) | | | | | | | (rewind/search) | • • • • | | | | | | 6400 BPI 00 2143 02 ## EMS 8000 Emulator Subsystem ## Product Brief #### June 1982 #### Features - Modular architecture can be easily expanded to support emulation of future Zilog microprocessors. - A unique "snapshot" feature permits partitioning of a large real-time trace module into many small trace memories. - Three parallel trigger comparators are provided. - Logic-state analysis is provided for target CPU address, data, status, control and external probe bits. - Up to 126K bytes of high-speed, static - mappable memory can be accessed by the target system. - A pulse output feature permits use of a high-end logic analyzer. - Network debugging is supported. - Full access is permitted to the target microprocessor's registers, memory and I/O space. - A "transparent" mode allows the same terminal to be used for host and EMS user interface. #### Description EMS 8000 is a high-end, emulation management system. The EMS 8000, together with Zilog's UNIX\*-based System 8000<sup>TM</sup> Z-LAB<sup>TM</sup>, provides the developer of Z8000 microprocessor-based products with a complete set of tools for speeding up the product development cycle. The emulator provides the link between the application software developed on a host system and the target system. It also aids in the integration of the software into the target system. Emulator to target system hookup is simple and immediate. A CPU pod/cable assembly directly replaces the target CPU. The emulator preserves the full capability of the target microprocessor. The emulator can start or stop program execution or it can perform # **Description** (Continued) single-step execution. Individual registers or memory can be examined and modified upon demand. Newly developed programs may be loaded into the development (target) hardware and executed in a real-time environment. EMS 8000 Network. Up to 8 emulator systems can be configured into a network that permits emulation of up to 8 distinct Z8000 microprocessors to begin and end simultaneously. This type of emulation capability enables message passing in a communications system to be monitored from source to destination. Individual emulator systems can be defined as being either in or out of a "break group." Those systems out of a "break group" can function as independent emulators with all the capabilities of EMS 8000 and the full use of the host resources, while those in the break group are debugging multiple processor systems. Mappable Memory. The emulator permits the user to access up to 126K bytes of mappable memory. This memory may be substituted anywhere in the target microprocessor's memory space and can be mapped with 2K byte resolution. Mapped memory can be declared as unprotected, write-protected, data memory only, or nonexistent. Mapping is also provided for systems using separate code/data/stack memory spaces for both System and Normal modes. #### Hardware Description A fully configured EMS 8000 emulation system (see Figure 1) contains the following units: - The EMS 8000 unit itself. - A CPU Pod/Cable Assembly. The CPU Pod contains the processor chip to be emulated plus required interface circuitry. Pods are available for the Z8001 and Z8002. ■ The EMS 8000 requires a host computer and a user CRT terminal. All EMS 8000 software is downloaded to the target system at the beginning of the debugging session. Application software developed on the host computer can also be downloaded to the target system via the EMS 8000. Figure 1. Hardware Configuration #### Software The EMS 8000 interfaces with Zilog computer systems. This capability allows the user access to all of the powerful development tools and cross-software of either the ZEUS or RIO operating system. The EMS 8000 software provides a friendly, self-prompting interface for the user. Interface With UNIX-Based Host System. When the System 8000 Z-LAB is the host computer, the EMS 8000 can make use of ZEUS, \*UNIX is a trademark of Bell Laboratories. Zilog's enhanced UNIX\* operating system. This system provides a sophisticated hierarchial file structure, C, PLZ/SYS, a Z8000 assembler, a compiler-writing system, and a general purpose macroprocessor. **EMS 8000 Monitor Software.** EMS 8000 monitor software is downloaded from the host during powerup; therefore, it can be easily modified and upgraded to improve both its effectiveness and its applicability. ## Z8000™ Emulator Z-SCAN 8000 # Product Description June 1982 - Provides Real Time Emulation up to 4 MHz of the Z8001 and Z8002 CPUs - Two RS-232C Serial Ports Make It a Peripheral Usable with Most Standard CRTs and Software Hosts. - Transparent Operation Permits Direct Communication Between CRT and Host without Physical Disconnect. - Highly Interactive, Screen-Oriented User Interface Makes Z-SCAN Easy To Use. - Shadow Monitor Removes All Restrictions on Target System Memory Space, Making It Fully Available To the User. - High-Speed Mappable Memory (no wait states) Is Available to Simulate Target System RAM/ROM. #### **OVERVIEW** The Z-SCAN 8000 Emulator is an incircuit emulator that has been designed as a peripheral unit for Zilog's Z8001 and Z8002 16-bit microprocessors. Interfacing via two RS-232C Serial ports to host and CRT terminal, Z-SCAN 8000 can work with Zilog's family of development hosts. Because it employs a standard serial interface, Z-SCAN 8000 can also be used with virtually any software host system that runs a cross assembler or cross compiler capable of generating Z8000 code. Communication between the host system and Z-SCAN 8000 is with a standard serial format requiring only a simple upload and download utility to operate. For PROM-based target systems, Z-SCAN can operate stand-alone with a CRT terminal because the monitor and debug software is EPROM-resident. In keeping with Zilog's design philosophy of separating a development system into two identifiable units (the software host and an emulation peripheral), Z-SCAN 8000 fits into three scenarios, making it a highly versatile unit: As a peripheral to Zilog's PDS 8000 and ZDS-1 Series of development systems, Z-SCAN 8000 completes the development support package for the Z8001 and Z8002 microprocessors available from Zilog. - As a peripheral to any development host with the capability of compiling or assembling Z8000 code, Z-SCAN 8000 allows a low-cost emulation capability which precludes substantial reinvestment in a software host system. - As a stand-alone in-circuit emulator that can operate with most CRT terminals, Z-SCAN 8000 provides simple testing and debugging capability for PROM-based target systems. #### SYSTEM FEATURES User Interface. Z-SCAN 8000 incorporates the use of a two-dimensional screen-oriented user interface which makes it easy to use. Because it is general-purpose in nature, the user interface does not require a customized CRT terminal to operate. The only requirements are that the CRT terminal have screen erase, line erase, and cursor addressing capability. The objective of the user interface is to provide a screen format with a menu-like approach, which directs the user through the operation of the emulator. The user is aware at all times of where he/she is in the debug process because Z-SCAN 8000 provides the CRT information about system parameters, system resources, current execution, and error messages. When the system is turned on, a bootstrap routine produces a display informing the user of the unit's configuration and requesting the user to define set-up parameters. A menu of display choices shows the user the different capabilities of the system: - The Memory/I/O command display shows the various memory and I/O manipulation commands which access the target system. - The Resources display presents the user with the full complement of arguments applicable to emulation of the target system. - The Execution display shows all the commands and parameters necessary to cause emulation to take place. At all times, execution of specific Monitor commands is possible, and information on other relevant system parameters and resources is always displayed. This highly interactive user interface makes it possible to use Z-SCAN 8000 without frequent reference to the operating manual. **Shadow Memory.** Z-SCAN 8000 is a single, CPU-based system that can be configured to emulate either the Z8001 or Z8002 by simply exchanging the CPU, monitor EPROM, and the emulator cable. Although the system uses a single CPU for both monitor and emulation functions, no restrictions are placed on the target system memory size. This is because the entire monitor resides in shadow memory and, therefore, does not appear in the target system memory space. This feature also provides the benefit of making future system expansion possible without any hardware redesign. Figure 1. Hardware Trigger Implementation Hardware Trigger, Z-SCAN 8000 offers the capability of setting breakpoints in three different fields or in a combination of these fields. These are the Address/Data Field, the Segment Field, and the Control/Status Field, A Pass Counter can be set up to a maximum of 255 counts to allow multiple pass triggering. In addition, Z-SCAN 8000 may also be set to break on instruction fetches only (single-step execution), or, by using a Pass Counter, may be set up to a maximum of 247 counts to allow triggering on multiple instruction fetches (multi-step execution). With these two capabilities, a breakpoint argument can be set up which is on ORed condition allowing for either a break-on-field (or combination of fields) argument or for "n" instruction fetches, whichever occurs first. This ORed situation is convenient when tracing through a program in search of a specific occurrence. A pulse output, providing a trigger pulse on breakpoint match condition is available on the rear panel to trigger auxiliary test instrumentation. Mappable Memory. Z-SCAN 8000 offers a 4K work block of high-speed static RAM. This block is available to the user to simulate a target system memory block which would typically be ROM. No Wait states are required at 4 MHz. This block is mappable anywhere in the Z8001 and Z8002 address space and can be specified to be Normal Code, Normal Data, Normal Stack, System Code, System Data, System Stack, or Space Independent. Mapping must be done on 4K word boundaries only, and the entire block can be write protected against illegal writes to cause system emulation either to break on such occurrences or continue emulation. An error message appears on the CRT display informing the user of an illegal write. Software Trace. Z-SCAN 8000 offers a software trace feature which provides insight into target system activity and CPU resources. In the Trace Mode, the system displays the address of the instruction being executed and the contents of the CPU registers (both general-purpose and control) consecutively, covering one full screen format. For example, displaying the CPU registers associated with every instruction executed just prior to executing a Break is tremendously useful to the user during debug of target system activity. #### **SPECIFICATIONS** #### CPU Z8001 or Z8002 per configuration #### Clock Rate 500 kHz-4.0 MHz (external) #### I/O Two RS-232C Serial Ports for CRT and #### **Baud Rate** Automatically selected from 50 to 19.2K #### Breakpoint Address, Data, Segment and Address, Control, Address and Control, Data and Control, Segment and Address and Control, Instruction Fetch, OR combination of Instruction Fetch and any Field argument #### Mappable Memory $4096 \times 16$ Static RAM (no Wait states at 4 MHz while operating off User clock) #### Innute One standard LS-TTL load plus 30 pF #### Outputs Capable of driving one standard LS-TTL load plus 30 pF preload #### Rear Panel Output BNC connector for pulse output, standard L.S-TTL #### Front Panel Target/Monitor, Reset, and NMI toggle switches #### Power 110/220 Vac, 50/60 Hz switch selectable, 60 VA maximum #### Dimensions 4 in. (10.2 cm) (H) × 14½ in. (36.8 cm) (W) × 18 in. (45.7 cm) (D) #### **Emulator Cable** 12 inches #### **AC CHARACTERISTICS** | Number | | | Z80 | 01/2 | Z-S | CAN | |-------------|------------------------------|-------------------------------------------------------------------|-----------------------------|----------------|----------------|-------------| | Syn | nbol | Parameter | Min (ns) | Max (ns) | Min (ns) | Max (ns) | | 1 | TcC | Clock Cycle Time | 250 | 2000 | 250 | 2000 | | 2 | TwCh | Clock Width (High) | 105 | 2000 | 105 | 2000 | | 3 | TwCl | Clock Width (Low) | 105 | 2000 | 105 | 2000 | | 4 | TfC | Clock Fall Time | | 20 | | 20 | | 5- | - TrC | — Clock Rise Time — — — — — — — — — — — — — — — — — — — | | 20 | | 20 | | 6 | TdC(SNv) | Clock † to Segment Number Valid (50 pF load) | | 130 | | 175 | | 7 | TdC(SNn) | Clock † to Segment Number Not Valid | 20 | | 35 | | | 8 | TdC(Bz) | Clock † to Bus Float | | <b>6</b> 5 | | 165 | | 9 | TdC(A) | Clock † to Address Valid | | 100 | | 163 | | 10- | <ul><li>TdC(Az)———</li></ul> | | | <del> 65</del> | | <del></del> | | 11 | TdA(DI) | Address Valid to Data In Required Valid | 455 | | 383 | | | 12 | TsDI(C) | Data In to Clock Setup Time | 50 | | 76 | | | 13 | TdDS(A) | DS t to Address Active | 80 | | -4 | | | 14 | TdC(DO) | Clock † to Data Out Valid | | 100 | | 163 | | 15- | ThDI(DS)——— | — Data In to DS † Hold Time ————— | 0 | | 20 | | | 16 | TdDO(DS) | Data Out Valid to DS † Delay | 295 | | 269 | | | 17 | TdA(MR) | Address Valid to MREQ Delay | 55 | | 29 | | | 18 | TdC(MR) | Clock I to MREQ I Delay | | 80 | | 143 | | 19 <b>a</b> | TwMRh | MREQ Width (High) | 210 | | 193 | | | 19b- | TwMRh | <ul> <li>— MREQ Width (High) During Monitor Operation—</li> </ul> | | | 184 | | | 20 | TdMR(A) | MREQ + to Address Not Active | 70 | | 53 | | | 21 | TdDO(DSW) | Data Out Valid to DS (Write) Delay | 55 | | 59 | | | 22 | TdMR(DI) | MREQ to Data In Required Valid | 350 | | 287 | | | 23 | TdC(MR) | Clock MREQ Delay | | 80 | | 134 | | 24 – | - TdC(ASf) | — Clock ↑ to AS ↓ Delay ————— | | 80 | | 134 | | 25 | TdA(AS) | Address Valid to AS † Delay | 55 | | 29 | | | 26 | TdC(ASr) | Clock ↓ to AS ↑ Delay | | 90 | | 144 | | 27 | TdAS(DI) | AS † to Data In Required Valid | 340 | | 277 | | | 28 | TdDS(AS) | DS ↑ to AS ↓ Delay | 70 | | 53 | | | 29 - | -TwAS | - AS Width (Low) | <del> 7</del> 0 <del></del> | | <del></del> 53 | | | 30 | TdAS(A) | AS to Address Not Active Delay | 60 | | 43 | | | 31 | TdAz(DSR) | Address Float to DS (Read) Delay | 0 | | -41 | 4 | | | | CONTINUED ON NEXT DAGS | 7 | | | | -CONTINUED ON NEXT PAGE - #### **AC CHARACTERISTICS** ORDERING INFORMATION Description Includes Z8001 and Z8002 CPU s, emulator cables and serial inter- face cables. Part No. | Number | | | Z8001/2 | | Z-SCAN | | |--------|-------------|---------------------------------------------------------|---------------------------------------|-----------------|-----------------------------|-------------------------| | Syn | nbol | Parameter | Min (ns) | Max (ns) | Min (ns) | Max (ns) | | 32 | TdAS(DSR) | ĀS↑ to DS (Read) ↓ Delay | 70 | | 53 | | | 33 | TdDSR(DI) | DS (Read) 1 to Data In Required Valid | 185 | | 122 | | | 34 | TdC(DSr) | Clock I to DS 1 Delay | | 70 | | 65 | | 35 | TdDS(DO) | DS † to Data Out and STATUS Not Valid | 75 | | 58 | | | 36- | -TdA(DSR) | — Address Valid to <del>DS</del> (Read) ↓ Delay ———— | <del></del> 180 <del></del> | | <del></del> 154 | | | 37 | TdC(DSR) | Clock ↑ to DS (Read) ↓ Delay | | 120 | | 174 | | 38 | TwDSR | DS (Read) Width (Low) | 275 | | 258 | | | 39 | TdC(DSW) | Clock ↓ to DS (Write) ↓ Delay | | 95 | | 149 | | 40 | TwDSW | DS (Write) Width (Low) | 185 | | 168 | | | 41 - | TdDSI(DI)—— | — <del>DS</del> (Input) ↓ to Data In Required Valid———— | 320 | | <del></del> 266 | | | 42 | TdC(DSf) | Clock I to DS (I/O) I Delay | | 120 | | 174 | | 43 | TwDS | DS (I/O) Width (Low) | 410 | | 393 | | | 44 | TdAS(DSA) | AS 1 to DS (Acknowledge) Delay | 1065 | | 1048 | | | 45 | TdC(DSA) | Clock 1 to DS (Acknowledge) Delay | | 120 | | 174 | | 46- | TdDSA(DI) | — DS (Acknowledge) ↓ to Data In Required Delay — | <del></del> | | 381 | | | 47 | TdC(S) | Clock † to Status Valid Delay | | 110 | | 162 | | 48 | TdS(AS) | Status Valid to AS † Delay | 60 | | <b>4</b> 5 | | | 49 | TsR(C) | RESET to Clock † Setup Time | 180 | | 208 | | | 50 | ThR(C) | RESET to Clock † Hold Time | 0 | | 15 | | | 51- | TwNMI | - NMI Width (Low) | <del></del> 100 <del></del> | | <del></del> 116 <del></del> | | | 52 | TsNMI(C) | NMI to Clock † Setup Time | 140 | | 154 | | | 53 | TsVI(C) | VI, NVI to Clock † Setup Time | 110 | | 118 | | | 54 | ThVI(C) | VI, NVI to Clock † Hold Time | 0 | | 22 | | | 55 | TsSGT(C) | SEGT to Clock † Setup Time | 70 | | 78 | | | 56- | -ThSGT(C) | — SEGT to Clock † Hold Time— | 0 | | 22 | | | 57 | TsMI(C) | MI to Clock † Setup Time | 180 | | 188 | | | 58 | ThMI(C) | MI to Clock † Hold Time | 0 | | 22 | | | 59 | TdC(MO) | Clock † to $\overline{\text{MO}}$ Delay | | 120 | | 165 | | 60 | TsSTP(C) | STOP to Clock Setup Time | 140 | | 148 | | | 61 — | -ThSTP(C) | — STOP to Clock ↓ Hold Time | 0 <del></del> | | 22 | | | 62 | TsWT(C) | WAIT to Clock ↓ Setup Time | 50 | | 78 | | | 63 | ThWT(C) | WAIT to Clock Hold Time | 10 | | 25 | | | 64 | TsBRQ(C) | BUSREQ to Clock Setup Time | 90 | | 98 | | | 65 | ThBRQ(C) | BUSREQ to Clock † Hold Time | 10 | | 32 | | | 66 — | -TdC(BAKr) | - Clock † to BUSACK † Delay | · · · · · · · · · · · · · · · · · · · | 100 <del></del> | | <del></del> 145 <i></i> | | 67 | TdC(BAKf) | Clock ↑ to BUSACK ↓ Delay | | 100 | | 145 | | | | • | | | | | | 05-0100-00 | Z-SCAN 8000/1 Emulator<br>(Supports Z8001 Emula-<br>tion and Control) | ZDS-1 Series Development Systems<br>PDS 8000 Series Development<br>Systems | Z8000 SDP<br>Z8000 SDP | |------------|------------------------------------------------------------------------------|----------------------------------------------------------------------------|------------------------| | 05-0100-01 | Z-SCAN 8000/2 Emulator<br>(Supports Z8002 Emula-<br>tion and Control) | 2,200,00 | | | 05-0101-00 | Z8001 Field Support Kit<br>(Converts Z-SCAN<br>8000/2 into Z-SCAN<br>8000/1) | | | | 05-0102-00 | Z8002 Field Support Kit<br>(Converts Z-SCAN<br>8000/1 into Z-SCAN<br>8000/2) | | | | 05-0103-01 | Z-SCAN 8000 Emulator | | | Description Systems recommended: Prerequisites 596 # **Z8000™ Development Module** # Product Description June 1982 - Z8001/Z8002 CPU Evaluation and Debug Support - 16K Words Dynamic RAM (Expandable to 32K for User Code Execution and Debug - 32 Programmable I/O Lines - EPROM Monitor and Debugger - Transparent Operation Allows Software Development without Disconnection from CRT and Host System - RS-232C Standard Serial Interfaces Compatible with Most CRT Terminals and Development Hosts - Wire-wrap Area for Prototyping #### OVERVIEW The Z8000 Development Module is a complete, single-board microcomputer that is used as a tool for the evaluation and debug of Z8000-based microprocessor systems. The Development Module is used in the first stages of the design and development process, not only as a tool for evaluating Z8000 microprocessor capabilities, but also as an environment in which code can be executed and debugged. **Evaluation.** The Development Module provides a ready-made environment in which the user can execute software unique to his Z8000-based application, evaluate the CPU's performance, and then reach a realistic decision about its suitability for a specific application. Software Debug. In addition to use as an evaluation tool, the Z8000 Development Module can be used to debug and modify user code. For the software designer, the Development Module is a real Z8000 environment in which he can execute code and carry out fairly extensive debugging. For the hardware designer, the Development Module is an example of Z8000 hardware design which provides special hooks and wirewarp facilities to strap on additional logic. #### FUNCTIONAL DESCRIPTION Z8000 code developed on a software host may be downloaded serially to the Development Module RAM area via a serial port, and executed and debugged under EPROM monitor control. Once the system is connected, no further disconnection is necessary as the module has two serial ports (one connected to a host and the other connected to a CRT terminal). A simple software command makes the development process transparent in the serial path, thereby allowing direct communication between the host and terminal. The serial RS-232C interfaces allow virtually any software development host and CRT terminal to be used. For PROM-based code testing, the development module is self-contained and can operate stand-alone with a CRT terminal, since the host is only required for storage of user code on disk. A variety of jumper areas and switches permit the selection of clock rates ranging from 2.5 to 3.9 MHz; the use of 2708, 2716, or 2732 EPROMs; the use of 4K or 16K RAMS; serial interface to modem, terminal, or teletype; I/O port addressing; and baudrate selection from 110 to 19200 baud. **Hardware.** The Z8000 Development Module is available in two versions: one supports the segmented Z8001 microprocessor; the other supports the non-segmented Z8002 microprocessor. Z8001 Development Module. The Z8001 Development Module consists of a Z8001 CPU, 16K words of dynamic RAM (expandable to 32K words), 4K words of EPROM monitor (user-expandable to 8K words), a Z80A SIO providing dual serial ports, a Z80A CTC peripheral chip providing four counter/timer channels, two Z80A PIO devices providing 32 programmable I/O lines, and wire-wrap area for prototyping hardware. 28002 Development Module. The Z8002 Development Module consists of a Z8002 CPU, 16K words of dynamic RAM (expandable to 24K words), 2K words of EPROM monitor (user-expandable to 8K words), a Z80A SIO device providing dual serial ports, a Z80A CTC peripheral device providing four counter/timer channels, two Z80A PIO devices providing 32 programmable I/O lines, and wire-wrap area for prototyping. Figure 1. Monitor Block Diagram **Software.** The monitor software (Figure 1) contained in EPROM (4K words for the Z8001 and 2K words for the Z8002) provides debugging commands, I/O control and host interface. It consists of a terminal handler, command interpreter, debugger and upload/download handler. Terminal Handler. A Terminal Handler provides interface to the console device to facilitate output to a display or printing mechanism and input from a standard ASCII keyboard. Debugger. The Debugger provides a basic set of debug commands to allow the user to start and stop program execution, display and alter CPU registers, flags or memory, and trap instruction sequences. Command Interpreter. The Command Interpreter scans console inputs, ensures command validity and passes to other software modules in the monitor. Upload/Download Handler. The Upload/Download Handler provides an interface between the serial connection and the host computer, the command interpreter and the memory resources of the Z8002 Development Module. It formats and interprets asynchronous data streams to and from the host and provides error checking and recovery for the serial interface (see Figure 2). **Memory Organization.** Tables 1 and 2 show the memory maps for the two versions of the Development Module. The organization of ROM and RAM in both the segmented and nonsegmented modes is indicated. Figure 2. Serial Data Format | | | | Segment 0 | Segment 1 | | | |-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------|----------------------------------------|-------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|--| | Äddress (Hex) | Memory | Address | (Hex) Memory | Address (He | k) Memory | | | 0000<br>0FFF | | 000 <b>0</b><br>1 <b>FFF</b> | Monitor<br>EPROM | 0000<br>3FFF | Expansion RAM (User Installed) | | | 1000<br>3FFF | | 200 <b>0</b><br>3 <b>FFFF</b> | User EPROM<br>(User Installed) | 4000<br>FFFF | Unused | | | 4000<br>BFFF | | 4000<br>49FF | Monitor RAM<br>(Scratchpad Area) | | | | | C000<br>FFFF | | 4A00<br>BFFF | Standard RAM | | | | | | | C000<br>FFFF | Expansion RAM (User Installed) | | | | | Table 1. Z8002 Develop | ment Module Memory Map | | Table 2. Z8001 Developm | ent Module Me | emory Map | | | MONITOR COMMAN | D SUMMARY | | | | | | | The following notation is used in the command description: | | | GO | GO Begins program address containe PC; execution is | | | | < > Enclose descript<br>quantities to be en<br>not actually ente<br>command. | | | IOPORT < address > | was last interrupted. All registers are restored prior to execution. | | | | | entries in the com- | | [W B] | Allows direct communications from the console to a selected I/O port. A word (W) or a byte (B) may be read from the selected port and a word or byte may be sent to the selected port; default is byte. | | | | | g. W B denotes that<br>ay be used but not | | | | | | | - | the nonsegmented | | JUMP < address > | Unconditional branch to the spec<br>fied address. All registers are<br>restored prior to execution. | | | | Prompt sign for the segmented Z8001 monitor. The following commands apply when | | MOVE < address 1 > < address 2 > < n > | from source<br>to destination | | | | | the Z8001 monitor is us<br>mands listed remain th<br>those that permit refer-<br>mented addresses as fo<br><address> =</address> | e same except<br>ence to seg- | | NEXT[ <n>]</n> | Executes th | <pre>2&gt; for <n> bytes. e next <n> machine t. <n> may be from n is omitted, l is</n></n></n></pre> | | | [ <segment number:<br="">address&gt;<br/><segment number="">:<br/>"&lt;"<hex in<br="" number="">7-bit range&gt;"&gt;"</hex></segment></segment> | = | | PUNCH <address 1=""><br/><address 2=""></address></address> | address 1 to<br>tape on the<br>matically tu<br>null leader<br>Upload/Dov | copy of memory from<br>be address 2 on paper<br>console device. Auto-<br>irns on punch and a<br>is created.<br>wnload section<br>ne tape format used. | | | BREAK < address > Sets and clears a breakpoint at given memory address. The opt <n> allows specification of the number of occurrences, where the from 1 to 128. The default is one</n> | | option<br>the<br>re n is<br>one. | QUIT | Places serial channels into tran<br>parent mode. The Z8000 Develo-<br>ment Module must be connecte<br>both the Zilog host and the con-<br>device, and the Development | | | | COMPARE <address 1=""> <address 2=""><n> DISPLAY<address> <n>[L W B] And the distribution of the console device. And the console device. And the console device. And the console device. And the console device. And the console device. Bisplays and modifies memory for the console device. And the console device. And the console device. And the console device. And the console device. Bisplays and modifies memory for the console device. And the console device. And the console device. Bisplays and modifies memory for the console device. And the console device. Bisplays and modifies memory for the console device. And the console device. Bisplays and modifies memory for the console device. And the console device. Bisplays and modifies memory for device.</n></address></n></address></address> | | resses | REGISTER | Module acts as a message switcher. Allows examination and modification of Z8000 registers. 8-bit, 16-bi or 32-bit quantities may be selected by the appropriate | | | | | | | [ <register name="">]</register> | | | | | | | ytes.<br>ta to<br>or | TAPE | selected by the appropriate register-naming conventions. Loads memory from paper tape via the console device. The | | | | FILL < address 1 ><br>< address 2 > < word > | ess 1> Stores the <word> from memory</word> | | | Upload/Download section describes the tape format used. | | | #### SPECIFICATIONS Microprocessor Z8001 or Z8002 CPU Clock Rate: 2.5 MHZ or 3.9 MHz Memory ROM: 2K or 4K Words (Expandable to 8K Words) RAM: 16K Words (Expandable to 32K Words) Input/Output Parallel: 32 Lines (Two Z80A-PIOs) Serial: Dual RS-232C or RS-232C and Current Loop (Z80A-SIO) Note The user has access to all bus signals to allow custom system expansion into the wire-wrap area off-board Interrupts Maskable Vectored (256), Maskable Non-vectored, Non-maskable, Segmentation Trap Power +5 V, 3 A +12 V, 1 A -12 V, 0.2 A Physical Height 1.75 in. (4.5 cm) Inclusive of Standoffs Width 14.0 in. (35.6 cm) Depth 11.0 in. (27.9 cm) Weight Approx. 30 oz. (850 gm) #### ORDERING INFORMATION | Part No. | Description | |------------|--------------------------------------------------------------| | 05-6168-01 | Z8001 Development Module | | 05-6101-01 | Z8002 Development Module | | 05-6171-01 | Z8001 Conversion Kit (converts Z8002 Development Module into | | | Z8001 Development Module) | #### Systems recommended for use with the above: Description Prerequisite ZDS-1 Series Development Systems PDS 8000 Series Development Z8000 Software Development Package Z8000 Software Development Package Systems 00-1047-A ## **Z8000™** Cross-Software Package Version II ## Product Brief #### June 1982 #### Features - Runs on the UNIX\* Operating System. This enables multi-user access for more efficient software development and provides tools to aid documentation production. - Includes C, a high-level, machineindependent, systems implementation language, that generates efficient Z8000 code. C improves programmer productivity, shortens product time-to-market, and protects software investment. - Provides C run-time support environment for the Z8000 Development Module. This keeps product development on schedule by reducing dependency on prototype hardware. - C compiler produces Z8000 cross-assembler source code. Assembly language listing of C programs simplifies debugging in any target environment. #### Description In today's complex microprocessor-based products, software development costs typically exceed those of hardware development. The Z8000 Cross-Software Package, running on the UNIX operating system, reduces software development costs by improving programmer productivity and enabling software to be developed before prototype hardware is ready. This allows time for thorough product testing while still meeting development schedules. The result is a higher quality product delivered on schedule. The Z8000 Cross-Software Package (CSP) is a complete set of software tools for developing Z8000 programs. The package works on Digital Equipment Corporation's PDP-11/44, 11/45, and 11/70 systems with the Seventh Edition of the UNIX operating system. Programmers and related support personnel at a UNIX installation can easily transfer their knowledge of the Typical Z8000 Cross-Software Package Installation # **Description** (Continued) UNIX environment to the Z8000 development project. The result is that programmers become productive more quickly. And, there is a greater likelihood of the project finishing on schedule. The C language, like other high-level, machine-independent, systems implementation languages, improves programmer productivity and protects the software investment made in a product by assuring program transportability. In addition, C produces Z8000 code which is efficient both in terms of execution time and memory space used. The result is a lower cost, higher performance product. The development environment supported by the Z8000 CSP allows for multiple user software development on various Z8000 target systems (see figure below). The pass-through mode of the Z8000 Development Module enables any terminal connected to the host system to be a hardware and software evaluation station. In this mode, the terminal and the host system communicate directly as if the Z8000 Development Module were not present. Thus, each terminal on a host system can text edit and compile programs and then download them into a development module for testing. The pass-through mode of the development module offers a more effective means of debugging than software emulation because programs can be debugged in real-time on actual hardware, without requiring any host system resources. Zilog emulation products, such as Z-SCAN 8000 and EMS 8000, will continue to use the pass-through mode to communicate to the host system. Thus, a single host system with Zilog's development modules, emulation products, and the Z8000 CSP can support total product development. **Product Description.** The major pieces of software in the Z8000 CSP are the C compiler, C optimizer, Z8000 cross-assembler, Z8000 cross-linker, upload/download program for the Z8000 Development Module, and C run-time support environment for the Z8000 Development Module. The Z8000 C compiler is the portable PDP-11 C compiler from the Seventh Edition of the UNIX system modified to generate Z8000 code. This means that existing PDP-11 C programs can be compiled by the Z8000 C compiler and, if the programs are machine-independent, they will run on a Z8000 target system. The C compiler generates both segmented and non-segmented code. The C optimizer speed optimizes the code produced by the compiler and outputs Z8000 cross-assembler source code. This process yields an assembly language listing of the optimized code. The Z8000 cross-assembler accepts Zilog's standard mnemonics and uses the pseudo-operations familiar to UNIX assembly language programmers. It supports programs with combined or separate code and data spaces. The Z8000 cross-linker links cross-assembler and C program modules together. The upload/download program transfers programs and data between the Z8000 target system and the UNIX host using Tektronix hex format. The C run-time support environment provides the necessary facilities to run sophisticated C programs on the Z8000 Development Module. Because it includes routines for terminal and UNIX file access, significant software development can take place using C and the Z8000 Development Module. The Z8000 Cross-Software Package combines with the UNIX operating system to provide a complete development environment for Z8000 software. #### Ordering Information #### Prerequisites - License for the Seventh Edition of the UNIX operating system. - One of the following computers from Digital Equipment Corporation: PDP 11/44 PDP 11/45 PDP 11/70 #### License Requirement ■ A special license is required for Z8000 Cross-Software Package 00-1006-02 # **Z8000<sup>™</sup> Software Development Package** # Product Description June 1982 - Structured assembly language with high-level constructs. - Relocatable and absolute object code format. - Free format statements allow indentation and spacing for readability. - External symbol references. - Global symbol definitions. #### OVERVIEW The Z8000 Software Development Package consists of five utility programs which aid and simplify the development of Z8000 programs. PLZ/ASM from Zilog's PLZ family bring all the advantages of modular programming to the Z8000 software developer and ensure transportability to future processors. The Z8000 LINKER, IM-AGER, LOAD/SEND and ZPROG simplify the testing and production stages of new software. Each program facilitates a single step towards completing a segmented or nonsegmented program; together they guarantee a smooth, logical, and manageable software development process. #### **FEATURES** Assembler. The Z8000 PLZ/ASM Assembler assembles easy-to-read. free-format PLZ/ASM source programs directly to machine code, PLZ/ASM allows an efficient mix of powerful assembly language mnemonics with high-level control structures, such as IF . . . THEN . . . ELSE . . . FI and DO . . . OD loops. The PLZ/ASM programmer may map instructions and information into the Z8000's program and data memory space, and organize the data space with such data declarations as RECORDS and ARRAYS. The PLZ/ASM Assembler supports both segmented and nonsegmented programs and is fully supported by the RIOTM operating system. **ZLINK.** ZLINK links assembled modules into a single relocatable module and resolves any external references among separately assembled modules. It can also reorder and combine named sections found in the input assembly language modules. ZLINK accepts a symbolic specification of the program entry point in the command line and, on request, produces a detailed link map which gives the locations of global references and relocated modules and sections. Errors in the linking process are reported in the optional link map and at the system console. Imager. The IMAGER accepts multiple linked object files from ZLINK and translates them into absolute code. IMAGER can then either store the absolute code in a disk file or leave it in system memory. IMAGER supports segmented and non-segmenting code. Named sections found in the input object modules may be reordered and loaded anywhere in system memory. **Program Transfer.** LOAD/SEND downloads an absolute program file into the Z8000 Development Module for debugging, then sends it back to the disk for back-up and storage. **Prom Programming.** Z-PROG stores the perfected load module in PROM. | ORDERING INFORMATION | | | | | | | | |----------------------|--------------------------------------------------------------------------------------------------|------------|--------------------------------------------------------------------------------------------------------------------|------------|--------------------------------------------------------------------------------------|--|--| | | Prerequisites: | Part No. | Description | Part No. | Description | | | | | PDS 8000 Series<br>ZDS 1/40<br>MCZ-1 Series<br>RIO | 07-3306-01 | Z8000 Software Develop-<br>ment Package<br>Object Cartridge Disk<br>for Use with PDS | 07-3309-01 | Z8000 Software Develop-<br>ment System<br>Object Diskette for Use<br>with PDS 8000/5 | | | | Part No. | Description | | 8000/20 | 07-3310-01 | Z8000 Software Develop- | | | | 07-0085-01 | Z8000 Software Develop-<br>ment Package<br>Object Cartridge Disk<br>for Use with PDS<br>8000/20A | 07-3306-02 | Z8000 Software Develop-<br>ment Package<br>Object Diskette for Hard<br>Disk Systems with<br>Optional Floppy Drives | | ment System<br>Object Diskette for Use<br>with ZDS-1 Series | | | 00 1044 A # Z8000<sup>™</sup> PLZ/SYS # Product Brief #### June 1982 #### Features - High-level procedure-oriented language permits efficient writing of machineindependent modules and programs. - Structured format for fast and easy-tocompile programs. - Produces efficient code for economical memory usage and processing time. - Simplifies software production and maintenance. - Allows direct or interpretive execution of program modules. - Supports both segmented and nonsegmented Z8000 processors. ## Description Z8000 PLZ is a family of different programming languages designed to satisfy a wide range of microcomputer software development requirements. The two members of the PLZ family, PLZ/SYS and PLZ/ASM, produce object code-compatible modules and share common control structures and data definition facilities. Thus, selective portions of programs can be written in the most appropriate language for the specific application and still maintain a consistent structure between modules. PLZ/SYS is a high-level, procedure-oriented language that is syntactically similar to Pascal. It provides a medium for writing structured, machine-independent programs with a minimum of programming effort. PLZ/ASM, on the other hand, is a structured assembly language that permits access to the low-level capabilities of the processor by mixing assembly language and high-level control structures. **Compiler.** The Z8000 PLZ/SYS Compiler translates source code modules into an intermediate stage called Z-code. The Z-code modules can then be executed interpretively or processed by the code generator to produce a machine-code object module. The compiler provides support for both the segmented and non-segmented Z8000 processors. **Code Generator.** The Z8000 PLZCG Code Generator accepts a file of intermediate Z-code generated by PLZ/SYS and produces the corresponding Z8000 machine code as a relocatable object module. This file can be linked with other modules to form a complete executable load module. **Interpreter.** The intermediate Z-code modules produced by the Z8000 PLZ/SYS Compiler can be executed interpretively by ZINTERP. Linking ZINTERP with the other modules generated by the compiler produces an executable load module. **Linker.** The Linker, ZLINK, links Z-code, ZINTERP and/or machine code modules into a single relocatable load module, allowing the user to control the overall size and speed of the program. Although interpretive Z-code runs more slowly than machine code, the space savings over machine code is usually substantial for larger programs where the 3K bytes of ZINTERP is a small percentage of the entire program. By balancing the number of Z-code and machine code modules, the user can maximize the efficiency of a particular program. ZLINK resolves any external references between separately assembled modules, so that the load module produced is relocatable. It also allows the reordering and combining of named sections between modules and supports incremental linking. **Operating Environment.** Z8000 PLZ/SYS is supported on all Zilog development systems that have at least 64K bytes of memory. # ZRTS™8000 Zilog Real-Time Software for the Z8000 Microprocessor # Product Description Preliminary June 1982 #### ■ Real-time Multi-tasking Software Components - Synchronization of multiple tasks - Interrupt-driven priority scheduling - Real-time response - Dynamic memory allocation #### ■ Modular and Flexible Design - Efficient memory utilization - 4K byte PROMable kernel - Support for Z8001 and Z8002 16-bit microprocessors - Configurable via linkable modules #### Versatile Base for Z8000<sup>TM</sup> System Designs - Segmented/non-segmented tasks - System/normal mode tasks - Uses standard Zilog calling conventions #### ■ Easy-To-Use System Generator - High-level configuration language - Supports a wide variety of hardware configurations - Easily changed control parameters allow system optimization - Eliminates the requirement for intimate knowledge of system internal structure #### **OVERVIEW** Zilog's Real Time Software (ZRTS) provides of a set of modular software components that allows quick and easy implementation of customized operating systems for all members of the Z8000 16-bit microprocessor family. In effect, ZRTS extends the instruction set of the Z8000, adding easy-to-use commands that give the Z8000 the capability for managing real-time, multi-tasking applications. The ZRTS package consists of a small real-time, multi-tasking executive program, the Kernel, and a System Configurator. The Kernel provides sychronization and control of multiple events occurring in a real-time environment. All major real-time functions are available—task synchronization, interrupt-driven priority scheduling, intertask communication, real-time response, and dynamic memory allocation. The System Configurator is a language processor that allows the target operating system to be defined in high-level terms using the ZRTS Configuration Language (ZCL). These functions greatly simplify the tasks of the designer, allowing development efforts to be concentrated on the application, instead of on real-time coordination, task management problems, and complicated system generations. ZRTS provides a modular and flexible development tool that serves as a versatile base for Z8000 system designs. The Kernel requires only 4K bytes of either PROM or RAM memory, thus allowing configurations for a wide variety of target systems, while producing a memory-efficient, cost-effective end product. #### **FUNCTIONAL DESCRIPTION** The Concepts. ZRTS is both easy-tolearn and easy-to-use. Only a few simple concepts need to be understood before designing begins. Tasks. Tasks are the components comprising a real-time application. Each task is an independent program that shares the processor with the other tasks in the system. Tasks provide a mechanism that allows a complicated application to be subdivided into several independent, understandable, and manageable units. Semaphores. Semaphores provide a low overhead facility for allowing one task to signal another. Semaphores can be used for indicating the availability of a shared resource, timing pulses or event notification. Exchanges and Messages. Exchanges and Messages provide the mechanism for one task to send data to another. A Message is a buffer of data, while an Exchange serves as a mailbox at which tasks can wait for Messages and to which Messages are sent and held. The ZRTS Kernel. The Kernel is the basic building block of ZRTS and performs the management functions for tasks, semaphores, the real-time clock, memory and interrupts. The Kernel also provides for task-to-task communications via Exchanges and Messages. All requests for Kernel operations are made via system call instructions with parameters in registers, according to the standard Zilog calling conventions. Task Management. One of the main activities of the Kernel is to arbitrate the competition that results when several tasks each want to use the processor. Each task has a unique task descriptor that is managed by the Kernel. The data contained in the descriptor include the task name, priority, state and other pertinent status information. ZRTS supports any number of tasks, limited only by the memory available to accommodate the task descriptors and stacks. The Kernel maintains a queue of all active tasks on the system. Each task is scheduled for processor time based on its priority. The highest-priority task that's ready to run gains control of the CPU; other tasks are queued. Tasks can be prioritized up to 32767 levels, with round-robin scheduling among tasks with the same priority. Tasks can run either segmented or non-segmented code, in either normal or system mode. The numerous operations that may be performed on tasks are listed in Table 1. ## TABLE 1. TASK MANAGEMENT T\_Census T\_\_Create T Destroy T Lock T Reschodule T Resume T Suspend T Unlock T\_\_Wait Provides the status of tasks in the system Creates a task dynamically Removes a dynamically created task Allows a task to take exclusive control of the CPU Changes the priority of a task Activates a suspended task Suspends another task Releases exclusive control of the CPU for other tasks Suspends task execution #### SEMAPHORE MANAGEMENT Sem Clear Sem Create Sem\_Destroy Sem Signal Sem Test Sem Wait #### CLOCK MANAGEMENT Clk\_Delay\_Absolute Clk\_Delay\_Interval Clk Set Clk Time #### MEMORY MANAGEMENT Mem Census Alloc Release #### INTER-TASK COMMUNICATION M\_Acquire M Assian M\_Create M\_Destroy M\_Get\_Descriptor M\_\_Read M\_\_Receive M\_Receive\_Wait M Release M\_Reply M\_Send M\_Write X\_\_Create X\_Destroy Clears semaphore queue and reinitializes a semaphore Creates a semaphore dynamically. Removes a dynamically created semaphore. Signals a semaphore, increments the counter. Tests a semaphore for a signal. Causes a task to wait until a semaphore is signaled, decrements the counter Places a task on the clock queue waiting for absolute time Places a task on the clock queue waiting for passage of an interval of Sets the real-time clock Reads the clock Provides status of the memory resource. Dynamically allocates memory. Releases allocated memory Gets a message from an exchange pool and assigns a destination or a reply exchange to it. Assigns a new source and destination to an existing message. Creates a message dynamically Removes a dynamically created message Gets message's descriptor information Reads the message data. Receives a message from an exchange. Waits to receive a message from an exchange. Returns a message to the exchange Sends a message back to destination exchange Sends a message to an exchange. Changes message data. Dynamically creates an exchange with a pool of messages. Removes a dynamically created exchange. Semaphore Management. The Kernel provides semaphore management for synchronizing interacting tasks. A typical use of semaphores is to provide mutual exclusion of a shared resource. When a resource is to be used by only one task at a time, a semaphore with a counter of 1 controls the resource. Every task requiring the resource must first wait on that semaphore. Since the counter is 1, only one task will acquire the resource. The others will be queued on the semaphore and suspended until the semaphore is signaled that the resource is once again available. At that time, the first task on the semaphore queue will be made ready to run and can use the resource. After all tasks have acquired the resource and signaled the completion of their use, the semaphore returns to its original state with a counter of 1. Counters greater than one are useful when there are a number of similar resources, (i.e., three tape drives, four I/O buffers, etc.). In ZRTS, a semaphore can count up to 32676 signals. The commands provided by the Kernel to manage semaphores are listed in *Table 1*. Clock Management. ZRTS operates with a real-time clock that generates interrupts at a hardware-dependent rate. It is used for timed waits, timeouts, and round-robin scheduling. All times are given in number of ticks. The clock may be manipulated by the set of commands provided by the Kernel that are listed in Table 1. Memory Management. Storage for ZRTS data structures is allocated either statically at system generation time, or dynamically at run time. Dynamic allocation occurs via a system call that specifies the attributes of the structure to be created and returns a name that can be used to refer to the structure. Memory is allocated in 256-byte increments, and can be released using a system call. The storage allocator can also be called directly to obtain blocks of memory up to 64K bytes long, which can be used by the task for any purpose. Interrupt Management. Interrupthandling routines are provided for system calls, non-vectored interrupts and a hardware clock. The user must provide interrupt routines for whatever other vectored interrupts are included in the target system. ZRTS can switch control to a task waiting for an external event within 500-microseconds after the occurrence of the event. This is based on the worst case with a 4MHz Z8000. A more typical response time would be | | TABLE 2. | |----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | CONSTANTS | Specifies system constants. | | EXCHANGES | Defines the characteristics of application exchanges. | | FILES | Indicates additional files to be included in the configuration link. | | HARDWARE | Describes the target hardware configuration—Z8001, Z8002, or Development Module. | | INITIALIZATION | Specifies routines that are to execute prior to beginning execution of the first task. | | INTERRUPT | Associates an interrupt routine with an interrupt vector or trap and system call-handlers. Provides the facilities to specify a NVI interrupt-handler that will be called from the system NVI-handler routine. | | MEMORY | Specifies the memory configuration and identifies where sections are to be placed (i.e.,CODE,DATA,). | | SECTIONS | Allows modules to be placed in a specific section, overriding the standard assignment conventions. | 250-microseconds. Quicker service of interrupts is possible through the use of user-written routines. SEMAPHORES **SWITCHES** TASKS Inter-task Communication. The Kernel provides the capability for tasks to exchange information. This communication process occurs when one task sends a Message to an Exchange and another task receives the Message. A Message contains a length indicator, a buffer with a variable amount of data, and a code that identifies the Message type. The Exchange is a system data structure that consists of a queue for Messages sent but not yet received, a semaphore on which a task can wait for a Message, and an optional "pool" list from which Messages can be obtained quickly. ZRTS provides several commands for Defines the characteristics of applica- Allows flags that control the system Defines the characteristics of applica- generation operation to be set. tion semaphores. tion tasks. ZRTS provides several commands to inter-task communications. These are listed in *Table 1*. ZRTS Configuration Language (ZCL). Since ZRTS's modular design leads to so many different configurations, a simple facility for generating the target operating system is a critical part of the ZRTS package. The ZRTS Configuration Language (ZCL) provides an easy-to-use means for generating the target system. Using ZCL, the designer can specify hardware information, software parameters, linkage information, and system data structures in highlevel terms. Development Environment ZCL unburdens the user of the necessity to learn the details of the ZRTS internal structures. System data structures can be generated simply by specifying the appropriate parameters. The ZCL syntax is free-format with comments allowed to make the configuration commands more readable and maintainable. ZCL input is comprised of a number of descriptive sections, each containing the details of the target operating system. The functions of these sections are described in *Table 2*. A sample system generation using ZCL is illustrated in *Figure 1*. **Development Environment.** Application modules for ZRTS can be developed on any Zilog Z80 or Z8000-based development system and then down-loaded into a Zilog Development Module or a customized target system. Subroutine libraries are provided for making ZRTS systems calls from programs written in PLZ/SYS, PLZ/ASM and C. Register usage in the system calls is compatible with the Zilog standard. When using a Development Module, the Debugger can be used with the ZRTS modules for testing purposes. After the application is debugged, the system can be easily reconfigured for the final target hardware. ``` SWITCHES . APPLICATION HADDWADE. 28002 THUE DELIDES . CONSTANTS: MINIMUM SYSTEM STACK SIZE = 512; FILES: REAL TIME CLOCK; MEMORY . CODE = [%8000..%8FFF]; DATA = [%9000..%9FFF]; FREE_MEMORY = [%F000..%FFFF]; SECTIONS: INITIALIZATION: TASKS. input handler task = tim_dIsplay_task = egg_timer_task = alarm_task = [entry = INPUT HANDLER, priority = 10]; [entry = TIME DISPLAY, priority = 20]; [entry = EGG TIMER, priority = 20]; [entry = ALARM, priority = 20]; [entry = ONE SECOND_GENERATOR, priority = 30]; one_second_task SEMAPHORES . ONE SECOND SEMAPHORE; TIME DISPLAY ENABLE SEMAPHORE; EXCHANGES: INPUT_HANDLER_ETE_EXCHANGE = [number_of_messages = 1, message_size = 8]; EGG_TIMER_ENABLE_EXCHANGE = [number_of_messages = 0]; INPUT_HANDLER_A_EXCHANGE = [number_of_messages = 1] message size = 8]; = [number_of_messages = 0]; ALARM_EXCHANGE ``` Figure 1. ZCL Sample Input. #### ORDERING INFORMATION #### Description ZRTS/8001 Zılog Real Time Software for the Z8001 ZRTS/8002 Zilog Real Time Software for the Z8002 ## Prerequisites Zilog Development System MCZ/1, PDS, ZDS Series or System 8000 (Requires Software License) # PDS 8000<sup>™</sup> Development Systems # Product Brief #### June 1982 #### **Features** - Supports entire family of Zilog microprocessors—Z8, Z80, and Z8000. - Speeds program development with highlevel, structured assembler. - Extends system capability with an intelligent CRT console. - Optional screen-oriented text editor. #### Description **System Hardware.** The PDS 8000 Series consists of several models of single-user systems for the design, development, and debugging of Zilog microprocessor-based systems. The PDS 8000 is a Z80-based microcomputer system with 64K bytes of RAM, a disk controller, parallel printer interface, and an intelligent CRT console. Dual, floppy-disk drive with 600K bytes of hard-sectored storage capacity is standard with the PDS 8000. The floppy disk drive is interfaced to the microcomputer via the Z80 Memory Disk Controller (MDC), which provides the Z80 microcomputer with all the data formatting required for reading and writing onto the floppy disks from RAM storage. Disk read/write accuracy is ensured by 16-bit CRC-code circuitry. The MDC also provides 48K bytes of dynamic RAM memory for programs or data storage. **System Software.** The PDS 8000 System provides all the necessary software to handle software development tasks, from inputting source code to printing listings and creating EPROM's. RIO Operating System. The PDS 8000 utilizes Zilog's field-proven RIO Operating System for the creation, editing, assembly, and debugging of software. RIO, with relocatable modules and I/O management, is a general-purpose computing system with architecture designed to facilitate the development process. RIO provides straightforward linking to various system routines and enables expansion of system features to meet the particular needs of individual user. RIO is composed of the following elements which aid in the development process: Operating System Executive. The RIO Executive maps requests of operations on logical units to specific device-handling programs. Commands may be issued to the operating system from the system console or by an executing program. Any number of user-defined commands may be added to the system. Command sequences may be recorded in files and executed as a group. The Executive manages the allocation of memory blocks. **Description** (Continued) Relocating Macro Assembler. The Relocating Z80 Macro Assembler offers relocatable or absolute object code format with external symbol references and global symbol definitions, macros and conditional assembly. The Assembler pages the symbol table, permitting assembly of arbitrarily large programs in standard memory. It also includes a directive permitting additional files to be merged with the source at assembly time. **Linker.** The Linker assigns absolute addresses to program modules, resolves external references, permits overlays, and produces a load memory map with a global address table. Text Editor. A line-oriented text editor pages work space so that files of any size can be edited and also provides automatic file backup and access to other disk files during editing. String matching allows for locating and modifying lines within a file. Also available is an optional multi-window, screen-oriented text editor. **PROM Monitor.** The PROM Monitor bootstrap loads for easy system entry, supports a full machine-language debug package, and includes low-level device handlers for system console and disk. **Processor-Oriented Support.** To enhance the development capability of the PDS 8000 Series of systems, Zilog also provides specific software packages and development tools to aid the microprocessor system designer. To support the Z8 MCU, an assembler and development module are available. **Z8000 Support.** For Z8000-based system designs, the Z8000 Software Development Package (SDP) provides the necessary tools to aid in software development. Utilizing PLZ, Zilog's high-level language, the Z8000 SDP includes a Cross Assembler, Linker, and PROM programming utility. For a tried and tested environment to run Z8000 code, the Z8000 Development Module is available. Providing support for either the Z8001 or Z8002, the Development Module is a single-board computer with RAM, I/O and monitor/debug firmware. The Z8000 Development Module is a convenient tool to evaluate Z8000 CPU performance, as well as a first-level software debug tool for use early in the design process. For real-time emulation of either the Z8001 or Z8002, the Z-SCAN 8000 Emulator is available. Operable both stand-alone and with a host system, Z-SCAN 8000 makes possible software and hardware integration with real-time breakpoint, monitor/debug software, mappable memory, and an interactive user interface. Figure 1. PDS 8000 Development System # ORDERING INFORMATION Floppy Disk-Based Part No. Description 05-6102-01 PDS 8000/05 Develop- 06-6102-02 ment System (60 Hz). Includes Z80 Microcomputer, 64K bytes dynamic RAM, 3K monitor, printer interface, editing-type video terminal w/line-drawing capability, dual floppy disk and RIO Operating System. (115 VAC) PDS 8000/05 Development System (50 Hz). Same as 05-6102-01 except 230 VAC. # Floppy Disk-Based (Continued) Part No. | Part No. | Description | |------------|-------------------------------------------------------------------------------------------------------------------| | 05-6102-04 | PDS 8000/05-1 Develop-<br>ment System (60 Hz). In-<br>cludes Z80 Microcom-<br>puter, 64K bytes<br>dynamic RAM, 3K | | | monitor, printer inter- | | | face, serial interface,<br>dual floppy disk and<br>RIO Operating System. | | | (115 VAC) | | 05-6102-03 | PDS 8000/05-1 Development System (50 Hz).<br>Same as 05-6102-04 ex- | cept 230 VAC. ## Floppy Disk-Based (Continued) | Part No. | Description | |------------|--------------------------| | 05-6104-01 | PDS 8000/15 Develop- | | | ment System (60 Hz). In- | | | cludes Z80 Microcom- | | | puter, 64K bytes | | | dynamic RAM, 3K | | | monitor, printer inter- | | | face, editing-type video | | | ternınal w/lıne-drawıng | | | capabılıty, dual floppy | | | dısk, Z8000 Development | | | Module, Z8000 SDP Soft- | | | ware Development | | | Package, and RIO | | | Operating System. | | | (115 VAC) | | 05-6104-02 | PDS 8000/15 Develop- | | | ment System (50 Hz). | | | Same as 05-6104-01 ex- | | | cept 230 VAC. | | 07-3001-01 | PDS 8000/RIO | # ZDS-1/40 Development System # Product Description June 1982 - Full Development Support for the Z80® and Z80A Microprocessors - 64K Bytes of Memory to Support Large Programs - 600K Bytes Floppy Disk Storage - In-Circuit Emulation up to 4 MHz - Memory Mapping Allows Borrowing of System Memory Before Prototype Memory Is Built - ZAP Package Provides Interactive, Symbolic Debugging With Disassembly #### OVERVIEW The ZDS-1/40 Development System provides total development support for Z80 and Z80A CPU-based system designs. This support begins with a complete Z80-based microcomputer system that includes 64K bytes of RAM, dual single-sided, single density floppy disk drives and system software to assist in every phase of software development. Included with the powerful microcomputer is an in-circuit emulation subsystem which connects to the user's prototype to monitor the execution of the software, control the behavior of the microprocessor in the prototype, and minimize the problems encountered in integrating software with hardware. Interactive debug software—the ZAP package, provided with the emulation system—allows debugging of the prototype, full disassembly of memory data and trace information, the use of symbolic references, and the capability of placing all debug commands on disk for execution. ### **FUNCTIONAL DESCRIPTION** The ZDS-1/40 Development System in effect consists of two functional parts: a software development host and an incircuit emulation subsystem. **Software Development.** The software development host is a Z80-based general-purpose microcomputer with 3K bytes of EPROM, 64K bytes of dynamic RAM, a floppy disk controller, serial RS-232C console interface, and two single-sided, single density floppy disk drives. Included with the microcomputer system is Zilog's RIOTM Operating System and System Utilities. This set of tools provides the user with the full capability of carrying out the various development tasks from the inputting and assembly of source code to the printing of listings and the creation of EPROMs. The RIO operating system is designed to provide the user with the capability of tailoring commands and initialization routines to suit the needs of the specific application. The main features of RIO include a PROM-based monitor, OS executive, ZDOS II file manager, text editor, Z80 relocating macro assembler and linker. PROM-Based Monitor. 3K bytes of nonvolatile storage provide system primitives for communication with floppy disk and console devices, and contain the bootstrap routine for the system OS Executive. The executive is the focus of system activity and thus handles I/O requests, dynamically allocates system storage areas to active programs on an "as needed" basis and invokes programs in response to operator commands. ZDOS II File Manager. The file manager organizes, stores and retrieves data from the floppy disk units. A directory provides an index for the data, which is accessed using a "hierarchical linked list." All space on the disk is dynamically allocated on an "as needed" basis to prevent gaps in the storage space. Logical record lengths from 128 to 4096 bytes per record may be used. Also, all files may be assigned one or more attributes for protection and privacy. Text Editor. A line-oriented text editor can handle files or programs larger than the available memory space. All operations within a file are based on character string matching to allow quick and easy search and modification of text. The capability to access other files during an edit session saves the repetitive entry of commonly used routines and enables the user to build libraries of commonly used code. Automatic backup of an existing file prevents accidental destruction of valuable data. Z80 Relocating Macro Assembler. The relocating macro assembler provides a quick way to create Z80 code in a modular fashion. Its design supports absolute or relocatable object code formats, global definitions, external references, macros and conditional assembly. Optionally, a cross-reference and/or symbol table is limited only by available storage on the disk. All diagnostic messages are routed to the system console with pertinent line number, error and the statement itself so that there is no waiting for a listing to locate erroneous statements. Z80 Linker. The Z80 Linker provides a means to link various program modules together and resolve communication between global modules, described by external references. The result is the generation of a single, executable program with absolute addresses. The use of the linker allows individual modules to be built and debugged, then merged with others without performing a complete assembly. System Utilities. All of the software used to drive or control the various accessory boards available is included with the system. There is no need to write software to communicate with printers or PROM programmers because it is already completed. The source code for the utilities is included so that the user can supplement or custom-tailor the software. In-Circuit Emulation. The in-circuit emulation subsystem enables the software developed on the microcomputer to be debugged before the hardware prototype is completed and even while the prototype is nonexistent. Resourcelending capabilities enable the software to be tested in the prototype hardware before it is completed. After the hardware is complete, the emulation subsystem allows total integration and testing to occur in a real-time environment. The subsystem consists of a trigger or breakpoint module, a monitor module, a user pod controller, a user pod, and a Z80A emulator CPU. Hardware trigger capability enables searching for a specific condition while the software is executing in real time, and executing breaks when detected. The detection can also be used to generate a sync pulse to trigger other instruments, such as oscilloscopes or logic analyzers used in the debug process. Monitoring Functions. The emulation subsystem provides a means of monitoring the interaction of the microprocessor with the target design. A special high-speed trace memory records the microprocessor's bus activity, while running the software in real time. The contents of the memory may then be dumped on the console after emulation has been halted for subsequent debug. The output of the trace memory can be displayed in three available formats. The user may qualify the inputs to the trace memory to select the specific type of bus cycle to be recorded, such as a memory write or an I/O operation. Resource Sharing Functions. The ZDS-1/40 system allows the user to borrow memory resources so that testing can begin even before the hardware is complete. The system provides a memory mapping mechanism, whereby the user can describe the addressable memory space of the microprocessor. This memory space is divided into blocks, each containing 1024 bytes of contiguous memory addresses. These blocks may be described to exist in the user's prototype, in the development system memory, or not to exist at all. All commands executed to examine or modify memory are qualified by the mapping mechanism. The mapping mechanism also allows hardware write protection of any block. Any attempted write to a write-protected block will be reported as a write violation and will terminate program execution without causing overwrites to the block. The nonexistent memory feature enables the user to declare blocks of memory nonexistent. Any attempt to access these blocks will immediately terminate program execution with a nonexistent memory violation message. Emulation occurs by removing the Z80 or Z80A microprocessor from the prototype and replacing it with the Z80A Emulator CPU of the development system. This emulator is connected to and controlled by the emulation subsystem. Monitoring and resource lending capabilities provided by the emulation subsystem also simplify the development process. Emulation Functions. The emulation subsystem provides several functions extremely useful to software and hardware designers: 1) control of the microprocessor in the hardware prototype; 2) the ability to monitor the bus signals of the microprocessor and record them; and 3) the ability to lend development system resources to the user's hardware prototype. Control Function. The cable connection between the user's prototype and the development system allows start/ stop control of the Z80A CPU Emulator. This feature enables the user to execute the software in a normal run mode, single-step the software, or execute multiple instructions. When the emulator is idling or not running the user's software, it generates the necessary refresh timing signals to keep dynamic memory in the prototype alive. Control of the microprocessor also allows the user to examine or modify CPU registers, memory or I/O devices. #### **SPECIFICATIONS** #### SW HOST Z80 CPU and Z80A Emulator CPU 64K bytes (3K EPROM, 1K static RAM. 60K dynamic RAM) Word Size 8 bits (1 byte) Clock Rate 2.5 MHz crystal-controlled Interrupts Three modes including vectored. nonvectored and nonmaskable Option Card Slots Five (5) Floppy Disk Storage Capacity Type 300,000 bytes/drive Single-sided, single density, hard-sectored 600.000 bytes Maximum Capacity (dual drives) 260K b/s Transfer Rate Average Latency 83 ms Track-to-Track Seek 10 ms Average Access Time 250 ms Physical Sectors 32 sectors/track. 77 tracks #### IN-CIRCUIT EMULATOR Clock Rate 4 MHz Trigger Break on address Real-time trace $256 \times 36$ bits wide. high-speed static RAM module Emulation cable 6 ft (including pod) (1.82 m) **PHYSICAL** 10.0 in. (25.4 cm) System Height Width Depth Weight 10.0 in. 19.0 in. 16.0 in. 35.0 lbs. (25.4 cm)(48.3 cm) (40.6 cm) (15.9 kg) Disk Unit Height Width Weight Depth 16.0 in. (40.6 cm) 35.0 lbs. (15.9 kg) 19.0 in. (48.3 cm) POWER System Frequency Voltage Current 50 Hz 110 Vac 1.5 A 50 Hz 220 Vac 0.7 A 60 Hz 110 Vac 1.5 A Disk Unit Frequency Voltage Current 50 Hz 110 Vac 1.5 A 50 Hz 220 Vac 0.7 A 110 Vac **ENVIRONMENTAL** 60 Hz Operating Storage Temperature Temperature 0° to 40°C 0° to 85°C Relative Humidity 20 to 80% noncondensina 1.5 A #### ORDERING INFORMATION Part No. Description 05-6013-05 ZDS-1/40 Development System (60 Hz) 07-3002-01 ZDS-1/40 RIO Development System (50 Hz) ### ZILOG ANALYZER PACKAGE (ZAP) #### **EMULATION SOFTWARE** Product Overview. The Zilog Analyzer Program is a sophisticated software module used to operate the emulation hardware of the ZDS-1/40 Development System. ZAP provides full control over the emulation hardware for quick and easy debugging of Z80- and Z80Abased designs. This module allows the user to inspect the microprocessor and to interact with the prototype system. The registers, user or system memory, and I/O ports may be interrogated and controlled. Control of program execution, interrupt, and Direct Memory Access (DMA) activity is also provided. These features, combined with full symbolic debugging and disagembly capability, provide powerful debugging tools for the Z80 microprocessor. Functional Description. The Ziloa Analyzer Program is a disk-resident program used to control the Z80/Z80A emulation hardware of the ZDS-1/40 Development System. It provides an interface between a command source and the emulation hardware. Commands may therefore be supplied from the disk file system (command file), system console device or a control program. This provides flexibility in hardware debugging as well as testing applications. ZAP provides a complete spectrum of commands and data formats to enable prototype hardware and software to be guickly integrated and debugged. A simple command syntax, using abbreviated command words, provides visibility into the Z80's registers, user memory, system memory, user I/O ports, and CPU status. Microprocessor registers may be displayed and altered individually, or the complete register set may be displayed. Commands for accessing user or system memory include FILL, SET, DISPLAY, and ALTER. A block compare command is also provided for comparison of a given string with memory. All memory data may be disassembled to reflect the actual source code mnemonics and symbolic references if the symbol table for the code is available. Emulator Start/Stop Control. The use of ZAP and the ZDS-1/40 emulation hardware allows the user to control the start up and shut down of the Z80A Emulator CPU. Emulation is initiated by the GO command and continues until one of the following conditions - One of eight different software breakpoints is encountered - Hardware breakpoint compare - Operator intervention (manual break) - Bad clock detection (in target system) - Non-existent memory access - Write-protect violation The user may select single step or multi-step execution of the program under test. This enables the registers to be examined after each step operation. In multi-step mode a group of instructions may be executed in real time. Any group of up to 255 instructions may be multi-stepped before stopping the emulator. Memory Mapping. The memory mapping capabilities of the ZDS-1/40 Development System are easily manipulated by ZAP. Blocks of memory, each containing 1024 contiguous bytes, may be assigned to exist in the user's system, in the development system at the normal address, in the development system with a translated address, or not to exist at all. In addition, these blocks of memory may be hardware write-protected to assist in the debugging task and prevent accidental destruction of data. Disassembly Capability. User memory, system memory, and the trace memory of the development system may be displayed in the hexadecimal or disassembled format. In disassembled format. the instructions are displayed in both hexadecimal machine code and assembly language mnemonics. Symbolic Debugging Capability. Symbol tables for each program module may be loaded individually, or the entire symbol table for the program may be loaded. The user may define local symbols to assist in the debugging process. Symbols are loaded into development system memory and are automatically hardware write-protected to prevent accidental destruction. A maximum of 29K bytes of system memory may be used for the symbol table: this equals approximately 3000 symbols. Since development system memory may be shared with the user's prototype system, the maximum symbol table size is a function of the number of blocks allocated for use in the user's prototype hardware. The use of symbols in place of numeric values in the ZAP command syntax, teamed with disassembly, enables the user to have an electronic listing of the program under test. This allows the user to concentrate on the debugging task instead of having to struggle with the development system software. Command File Capability. The Zilog Analyzer Program is structured to accept command input from several sources: console, file, or program. This capability is important in the debugging process, the training process, and even the manufacturing test process. In the debugging process, commonly used commands for establishing the memory map, enabling interrupts, and loading program modules may be placed in a disk file and executed. This allows a series of necessary operations to be performed with a minimum number of keystrokes. It also insures that the system will be initialized the same way, no matter how many individuals are using the system. The same technique may be used for training new users of the ZAP command structures. Tutorial files can be created to execute the various system commands and illustrate the results. An example of this is ZAP TUTOR, a software training package included with ZAP to acquaint the user with the commands and their use. In a manufacturing test operation, the user may create software which formats command parameters for ZAP and pass these using a CALL to ZAP. The ZAP software will perform the requested operation and return the results to the calling program. This enables the user to diagnose designs using the emulation hardware controlled by applications software. # **Z80® PLZ** # Product Description June 1982 - High-Level Procedure-Oriented Language Permits Efficient Writing of Machine-Independent Modules and Programs. - Structured Format for Fast and Easy-to-Compile Programs. - Produces Efficient Code for Economical Memory Usage and Processing Time. - Simplifies Software Production and Maintenance. - Allows Direct or Interpretive Execution of Program Modules. #### **OVERVIEW** Z80 PLZ is a family of different programming languages designed to satisfy a wide range of microcomputer software development requirements. The two members of the PLZ family, PLZ/SYS and PLZ/ASM, produce object code-compatible modules and share common control structures and data definition facilities. Thus, selective portions of programs may be written in the most appropriate language for the specific application and still maintain a consistent structure between modules. PLZ/SYS is a high-level, procedureoriented language that is syntactically similar to PASCAL. It provides a medium for writing structured, machine-independent programs with a minimum of programming effort. PLZ/ASM, on the other hand, is a structured assembly language that permits access to the low-level capabilities of the processor by mixing assembly language and high-level control structures #### **FEATURES** Compiler. The Z80 PLZ/SYS Compiler translates source code modules into an intermediate stage called Z-code. The Z-code modules may then be executed interpretively or processed by the code generator to produce a machine-code object module. Code Generator. The Z80 PLZCG Code Generator accepts a file of intermediate Z-code generated by PLZ/SYS and produces the corresponding Z80 machine code as a relocatable object module. This file may be linked with other modules to form the complete executable load module. **Interpreter.** The intermediate Z-code modules produced by the Z80 PLZ/SYS Compiler can be executed interpretively by ZINTERP. Linking ZINTERP with the other modules generated by the compiler produces an executable load module. PLZ/ASM Translator. The PLZ FILTER translates a PLZ/ASM source module into a file of the corresponding Z80 Assembler source. This gives the Assembler the benefit of logical data structure, program flow control, and modular program design, in addition to its existing features. **PLZ Linker.** The PLZ Linker, PLINK, links Z-code, ZINTERP and/or machine code modules into a single relocatable load module, allowing the user to control the overall size and speed of the program. Although interpretive Z-code runs more slowly than machine code, the space savings over machine code is usually substantial for larger programs where the 3K bytes of ZINTERP is a small percentage of the entire program. By balancing the number of Z-code and machine code modules, the user can maximize the efficiency of a particular program. PLINK resolves any external references between separately assembled modules, so that the load module produced is relocatable. It also allows the reordering and combining of named sections between modules and supports incremental linking. #### ORDERING INFORMATION Part No. # Description 07-3301-01 Z80 PLZ Object Diskette for use with PDS 8000/05 and PDS 8000/15 07-3302-01 Z80 PLZ Object Diskette for use with ZDS-1 Series 07-3303-01 Z80 PLZ Object Cartridge Disk for use with PDS 8000/20 and PDS 8000/30 Figure 1. Z80 PLZ Language Modules. # RIO Electric Blackboard<sup>TM</sup> # Product Brief ### February 1982 #### **Features** - Full-screen text editor - Simple, easy-to-remember commands - Edits any size file - Provides automatic file backup - Easily reconfigured for any CRT - Multiple windows on screen: - ☐ Same file may be shared by two or more windows - □ Screen can be divided horizontally and vertically - □ Text may be moved between windows ### Description The RIO Electric Blackboard is a sophisticated multi-window, full-screen text editor. The Electric Blackboard allows the user to divide the CRT screen into horizontal and vertical "windows." Because all editing is done directly to the text on the screen, the results are seen immediately. Multiple Windows. A window acts as an in- dependent text editor – with its own tab settings, page sizes, cursor position (and so forth). The Electric Blackboard allows the screen to be divided into horizontal and vertical windows. Windows can be as narrow as one column and as thin as one line. As many as ten windows can be displayed on the screen at the same time. Figure 1. Three windows looking at three files: A program, a spec and a trouble report. <sup>\*</sup>Electric Blackboard is the trademark of Santa Cruz Software Services. **Description** (Continued) The same file may be shared by two or more windows. This is useful when two physically separate but logically connected pieces of text in the same file are to be edited or viewed simultaneously. Text can be moved or copied within or between windows allowing text and figures to be easily rearranged. **Find and Replace Strings.** The next or previous occurrence of characters can be found or replaced with another string. Strings can also be repeatedly found and selectively replaced. **Simple, Easy-to-Remember Commands.** The Electric Blackboard supports a command mode with English-list mnemonics. See Table 1 for available commands. **Saves Keystrokes.** At any time during an editing session the user can record the exact keystrokes that are being typed. Later the recorded keystrokes can be executed. Once keystrokes have been recorded they can also be saved as a file on disk for later use—thus libraries of prerecorded procedures can be built Edits Large Files. The length of a text file is limited only by the amount of space on the disk. The Electric Blackboard automatically manages memory for large files. As a window is moved through a file, those parts of the file that are needed are read in from the disk. **Automatic File Backup.** Each time a file is saved, the previous version of the file is saved as a back-up file. In addition, the original disk image of the file being edited is not modified until the file is saved. Easily Reconfigured for a Wide Range of CRTs. The Infoton 200, ADM 3, and ADM 31 CRTs are supported by Zilog. However, a different CRT may be used with the Electric Blackboard simply by making the appropriate changes to the configuration package. | Function | Command | Function | Command | |-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------| | Single Key Commands | | Escape Key Commands (continued) | | | Delete previous character Move cursor to next line Terminate execution Move cursor Move cursor to home position Move cursor to next tab stop Escape Key Commands | RUB Key RETURN Key BREAK Key † ↓ → ← Keys HOME Key TAB Key | Moving Text Move Marked Text Move Box Move Workspace Copy Marked Text Copy Box of Text Copy Workspace | MM<br>MB<br>MW<br>CM<br>CB | | Cursor Control Insert Character Delete Character Replace Character Insert Lines Delete Lines Replace Lines Set Margin Reset Margin Marking Text Insert Mark Begin Insert Mark End | IC<br>DC<br>RC<br>IL<br>DL<br>RL<br>SM<br>RM<br>IMB | Loading, Saving and Sharing Files Load File Save File Use File Use Option Use Window Finding and Replacing Strings Find Next Find Previous Replace Next Replace Previous Replace Repeat Next | LF<br>SF<br>UF<br>UO<br>UW<br>FN<br>FP<br>RN<br>RP<br>RRN | | Delete Marks Erasing Text Erase Workspace Erase Marked Text Erase Box Inserting and Deleting Windows Insert Window Insert Window Horizontally Insert Window Vertically | EW<br>EM<br>EB<br>IW<br>IH<br>IV | Replace Repeat Previous Managing Keystrokes Load Keystrokes Save Keystrokes Delete Keystroke workspace eXecute Keystroke workspace eXecute File | RRP<br>LK<br>SK<br>DK<br>XK<br>XF | Table 1. Electric Blackboard Commands # **Z8° Development Module** # Product Description June 1982 - Two Z8-02 Devices Offer Complete Configuration Choice for Any Application. - 2048 Bytes Static RAM for Convenient Execution and Debug of User Code. - On-board 2716 Socket to Test User Code in EPROM Without Additional Hardware. - As Many as 2048 Hardware Breakpoints on Address Compare Cover the Entire Internal ROM Space. - Versatile Monitor Software for Debugging, Register and Memory Manipulation, and File Upload and Download. - "Transparent' Operation Allows Software Development Without Disconnecting from CRT and Host. Industry-Standard Interface Compatible with Most CRT Terminals and Development Hosts. - Wire-Wrap Area for Prototyping. #### **OVERVIEW** The Z8 Development Module is a single-board microcomputer system specifically designed to assist in the development and evaluation of hardware and software designs based on the Z8 microcomputer. It allows system prototyping in hardware with the Z8-02 prototyping device, thereby developing code that will eventually be mask programmed into the Z8 on-chip ROM. Two Z8-02 devices on the Z8 Development Module provide flexibility: one serves as a controller while the other is totally user-definable. All user ports on the second Z8-02 are unconfigured and available to suit any application. To simulate the final mask-programmed version on which user code resides, 2048 bytes of high-speed static RAM are available for executing and debugging code. An on-board EPROM socket allows the user to substitute EPROM for static RAM. This enables the user to test PROM after software development and debug without building special hardware. The EPROM-resident monitor software offers debugging features, register and memory manipulation, as well as a convenient means to upload and download software between the host and user RAM space. The Development Module connects to the CRT terminal and host system via two on-board standard RS-232C serial ports and is physically located between the CRT and host. A simple command makes the Development Module transparent in the serial path to allow software development without disconnecting from the CRT and host. The Development Module can operate stand-alone for simple debugging operations or it can interface directly to a host development system such as the Zilog ZDS-1 or PDS 8000<sup>TM</sup> Series for software development and file storage. Twenty square inches of wire-wrap area with conveniently located 5 V and ground points are provided near the user Z8-02 for prototyping. #### FUNCTIONAL DESCRIPTION Hardware. Two Z8 microcomputer units designated the Monitor MCU and User MCU are at the heart of the Z8 Development Module. The Monitor MCU controls operation of the User MCU and the monitor/debug software. The monitor/debugger resides in 4K bytes of EPROM. Hardware breakpoint logic provides a maximum of 2048 breakpoints. Single stepping and software trace capabilities are also available. The User MCU is a Z8-02 controlled by the Monitor MCU via internal address/data and control lines brought out to external pins. This effectively leaves all ports on the User MCU unconfigured and available to the user. The 2K bytes of static RAM on the 'internal' bus are for user code that may be executed by the User MCU. Execution is in real time at full processor speed. Both MCUs utilize 7.4 MHz crystal oscillators, the outputs of which are divided internally to provide 3.7 MHz clocks. In addition to wire-wrap area, a 40-pin header (3M type 3495-1002) for the User Z8 can connect to a ribbon cable with a 40-pin plug that may plug into a target system. Bus driver logic may be added on the wire-wrap area for basic emulation capability. Two switches, 'Mode' and 'Reset', provide a means to re-enter the Monitor and reinitialize the system, respectively. Baud rate from 110 to 19200 may be selected with an on-board 4-element DIP switch **Software.** The monitor/debug program, residing in 4096 bytes of EPROM, includes debug, input/output, control and host interface commands. The commands are grouped into four major functional blocks: monitor, debug, manipulation and file commands. Z8 Development Module conveniently connects to both the CRT and PDS 8000 Development System. | Monitor Commands. This group of commands controls | |---------------------------------------------------------| | execution of the User MCU, monitors user interrupts and | | transfers controls from the monitor to the host system. | | execution of the User MC | U, monitors user interrupts and | |-----------------------------|---------------------------------| | transfers controls from the | monitor to the host system. | | GO < ADDRESS> | Causes User MCU to execute pro- | gram disallowing further debug until a BREAK or HALT command is encountered. HALT Halts program execution of the User MCÚ. QUIT Returns control to the host system and enters the 'transparent' mode. INTERRUPTS [E/D] Enables or disables all user generated interrupts. Note: All user interrupts are automatically disabled when a breakpoint is encountered. It is necessary to reenable such interrupts by this command. **Debug Commands.** This group of commands allows the user to debug code by tracing through code and setting breakpoints and jumps to specified locations within the 'internal' ROM space. BREAK < ADDRESS> Sets a breakpoint at the specified address. KILL [< ADDRESS>] Clears the breakpoint at the specified address. JUMP < ADDRESS> Allows the User MCU to jump to a specified address anywhere within the internal ROM space, by changing the value of the program counter. NEXT [<n>] Causes execution of n instructions of the User MCU and then halts the User MCU. TRACE Causes single step execution of the User MCU. Every instruction executed is output to the console. Z8 Development Module Block Diagram Manipulation Commands. The manipulation commands display and alter registers and memory. This group may be subdivided into two categories: register manipulation and memory manipulation. #### Register Manipulation REGISTER (< REG NUMBER>][<NEW REG VALUE>]] Allows examination and modification of the User MCU registers. WORKING REGISTERS Displays contents of the 16 working registers of the User MCU. PHILL < STARTING REGISTER> < NUMBER OF REGISTERS> (<DATA BYTES>) Stores the sequence of DATA BYTES into User MCU registers beginning at the STARTING REGISTER and is copied as many times as necessary for the NUMBER OF REGISTERS #### **Memory Manipulation** DISPLAY (< STARTING ADDRESS>[<n>]] SET < ADDRESS> < LENGTH> [<DATA BYTES>] FILL < STARTING ADDRESS> < LENGTH> (< DATA BYTES> ) Allows display and modification of user memory contents for n number of bytes. Allows a sequence of data bytes beginning at the ADDRESS specified to be written into user memory. Stores the sequence of DATA BYTES into user memory beginning at the starting ADDRESS and is copied as many times as necessary for the LENGTH specified. specified. MOVE < SOURCE ADDRESS> < DESTINATION ADDRESS > (< n > ) COMPARE < ADDRESS 1> <ADDRESS 2>[<n>] Moves contents of a user memory block from a source address to a destination address for a length of n bytes. Compares two blocks of user memory data, one beginning at ADDRESS 1 and the other at ADDRESS 2 for n bytes. File Commands. The File group enables the user to upload and download programs to and from the host system. LOAD < FILE NAME> Downloads a file to user memory starting at the low address of the file and continuing until the entire file is transferred. UPLOAD < FILE NAME> < ADDRESS 1> < NUMBER OF BYTES> [<ENTRY ADDRESS>] Creates a RIO file image of user memory, beginning at ADDRESS l, creating default length records, and imaging memory for the specified number of bytes. Note: The following notation is used in the command description. - <> Enclose descriptive names for the quantities to be entered, and are not actually entered as part of the command. - Denote optional entries in the com- $\Pi$ mand syntax. - Denotes "or." 1007.001 ### SPECIFICATIONS Central Processor Monitor MCU Z8-02 (64-pin package) User MCU. Z8-02 (64-pin package) Clock Rate 3.7 MHz Memory Monitor: 4K bytes of EPROM User: 2K bytes of static RAM User: Wired socket for EPROM to substitute for static RAM Input/Output Two RS-232C ports to CRT terminal and host system **Baud Rate** Switch selectable from 110 to 19200 baud Breakpoint 2048 max , valid for Address Compare, applicable to user 'internal' memory only Control Mode and Reset switches Power +5 V, 1.4 A Physical Wire Wrap 20 sq. in 0.036" dia. Area plated-through holes on 3/32 in. centers Height 1.75 in. (4.76 cm), | Including standoffs | Width | 14.5 in. (35.6 cm) | Depth | 11.0 in. (29.9 cm) #### ORDERING INFORMATION Part No. Description 05-6158-01 Z8 Development Module. Includes one serial interface ribbon cable and reference manual. #### Systems recommended for use with above: Description Prerequisites ZDS-1 Series Development Systems PDS-8000 Series Development Systems Z8 Software Development Package Z8 Software Development Package 00-1007 A # **Z8° Software Development Package** # Product Description June 1982 - Structured Assembly Language with High-Level Constructs. - Relocatable and Absolute Object Code Format. - Free Format Statements Allow Indentation and Spacing for Readability. - External Symbol References. - Global Symbol Definitions. #### **OVERVIEW** The Z8 Software Development Package consists of five utility programs which aid and simplify software development for Z8-based systems. Z8 PLZ/ASM, part of Zilog's PLZ family, brings all the advantages of modular programming to Z8 software development. The programming task can be broken into easily managed modules, giving more work assignment options to the engineering manager and a clearcut structure to the individual programmer. The Z8 linker completes the task by combining the modules and resolving any external references. ### FEATURES Assembler. The Z8 PLZ/ASM Assembler translates easy-to-read, free-format PLZ/ASM source programs to object code. Because the user may specify that either absolute or relocatable object code be produced, he may choose a memory location for the program or leave that responsibility to the Linker. The Z8 PLZ/ASM Assembler produces a listing file containing both the source and assembled code. Z8 PLZ/ASM allows an efficient mix of powerful assembly language mnemonics with high-level control structures such as IF . . . THEN . . . ELSE . . . FI and DO . . . OD loops. The PLZ/ASM programmer may map instructions and information into the Z8's register, program and data memory spaces, and organize the data space with such data declarations as RECORDS and ARRAYS. The PLZ/ASM Assembler supports external symbol references and global symbol definitions and is fully supported by the RIOTM operating system. **ZLINK.** ZLINK links assembled modules into a single relocatable module and resolves any external references among Description Part No. separately assembled modules. It can also reorder and combine named sections found in the input assembly language modules. ZLINK accepts a symbolic specification of the program entry point in the command line and, on request, produces a detailed link map which gives the locations of global references and relocated modules and sections. Errors in the linking process are reported in the optional link map and at the system console. Imager. IMAGER accepts multiple linked-object files from the linker and translates them into absolute code. IMAGER can then either store the absolute code in a disk file or leave it in system memory. Named sections found in the input object modules may be reordered and loaded anywhere in system memory. Program Transfer. LOAD/SEND downloads an absolute program file into the Z8 Development Module for debugging, then sends it back to the disk for back-up and storage. **Prom Programming.** Z-PROG stores the perfected load module in PROM. Description Part No. #### ORDERING INFORMATION ### Prerequisites: PDS 8000 Series ZDS 1/40 or 1/25 MCZ-1 Series RIO | 07-0086-01 | Z8 Software Develop-<br>ment Package<br>Object Cartridge Disk<br>for Use with PDS | 07-3362-01 | Z8 Software Develop-<br>ment Package<br>Object Diskette for Use<br>with ZDS-1 Series | |------------|---------------------------------------------------------------------------------------------------|------------|-----------------------------------------------------------------------------------------------------------------| | 07-3361-01 | 8000/20A Z8 Software Development Package Object Diskette for Use with PDS 8000/5 and PDS 8000/15 | 07-3363-01 | Z8 Software Develop-<br>ment Package<br>Object Cartridge Disk<br>for Use with PDS<br>8000/20 and PDS<br>8000/30 | 00-1042-A # **Zilog Technical Training** Time and money are precious commodities in the 1980's. At Zilog, our wide range of innovative components and systems helps you get the edge on your competitors by reducing both system design time and costs. Zilog's Training and Education Department can help you by saving on those costly hours spent getting up to speed. Zilog offers sophisticated microcomputer products in every form—microprocessor components, OEM Boards, development systems, powerful general purpose systems; and to give you the knowledge necessary to take full advantage of these products, we offer thorough training and programs geared to the needs of the individuals. Zilog offers you the path through the state of the art training courses via an informal, hands-on, interactive approach that takes you where you need to be, up to speed, in the quickest, most efficient way. Each course enhances your ability to use individual Zilog products effectively. You will get all the information you want and need. The Zilog Training and Education Department is offering an exceptionally wide range of courses in 1982. This catalog describes your path through the state of the art technical training in detail. #### Location # Zilog Training and Education General Information The Zilog Training Center is located at: 1315 Dell Avenue Building C Campbell, CA. 95008 Telephone: (408) 370-8000 Ask for the Training and Education Department. ## Registration Enrollment in any of the classes listed in the catalog may be accomplished by contacting the Training and Education Department at the above location. After the Training and Education Department has received your purchase order or advance payment, written confirmation of your registration will be provided, along with local hotel information and directions to the Training Center. The Training and Education Department requests you register well in advance of the course date, as Zilog classes are well attended and enrollment is limited. If the purchase order or payment has not been received at least two weeks before the start of the class, your reservations will not be guaranteed. Payment, in the form of a confirming purchase order, check or money order, must be received by the Training Department prior to being admitted into the class. This must be accomplished before the start of class on the first day. #### Discount The Training and Education Department offers a 10% discount to companies with three or more employees attending a regularly scheduled class. The Training and Education Department also offers a 10% discount to companies with an employee attending three or more consecutive regularly scheduled classes. #### On-Site Classes All classes described in this catalog can, by special arrangement, be presented at your facility. This on-site class is the same course provided in our regularly scheduled classes. The price for an on-site class is \$8000.00. It includes: Training for up to 15 employees. There will be an additional charge of \$100.00 for each additional employee. Training materials. One instructor. Equipment for hands-on training. These courses can also be tailored to meet your needs. These tailored on-site classes include the items listed for the standard on-site class. However, the price of a tailored course will depend on each company's requirements and objectives. For further information regarding on-site training, contact the Training and Education Department at the above location. # Training Material Instructional aids include student notebooks, appropriate Zilog manuals, course notes and worksheets. The training material is designed to aid in the retention of the material presented as well as provide a practical reference after the formal training is completed. ### Payment Payment for any regularly scheduled class, or an on-site class may be made by confirmed company purchase order, check or money order made payable to Zilog, Inc. Please indicate on the purchase order, and/or the enrollment form the name(s) of the individual(s) and the class(es) the documents pertain to. ## Cancellation Zilog reserves the right to cancel any class. If a class is cancelled, all persons registered for that class will be notified as soon as possible. Cancellation of enrollment received less than two weeks prior to the scheduled start of the class, will be subject to a cancellation fee equal to one-third of the tuition. If a registered student fails to appear for a scheduled class, a cancellation fee equal to the full tuition will be charged. A cancellation fee of one-third the cost of the on-site class will be charged if an on-site class is cancelled, by the customer, within 10 days prior to the scheduled start of the class. ### **Price** Zilog reserves the right to change prices at any time without notice. Confirmed registrations will be honored at the original price. Registrations confirmed by the receipt of a purchase order within 30 days of a price change will be honored at the original price. Your path through the State of the Art Technical Training for the '80s. # Microprocessors: A General Introduction This course introduces the world of microprocessors. In it you will learn basic microprocessor fundamentals and capabilities as well as the basics of microcomputer-based design. Some of the topics covered include: - ✓ What is a microprocessor? - ✓ Some fundamental concepts about microprocessors - Microprocessor organization - ✓ Instruction execution - ✓ Central processing units, memories, support chips - Overview of Zilog products A background in digital logic, binary and hex number systems is suggested as course prerequisite. # Z8 Component Family The Z8 is Zilog's powerful single-chip, 8-bit microcomputer. This seminar is designed for hardware and software development personnel who are familiar with microcomputer system design and who are interested in learning Z8 architecture, capabilities, and supporting systems. Some of the topics covered are: - Z8 architecture and timing - ✓ Z8 assembly language programming - Interfacing memory and peripheral devices - ✓ Z8 software development tools - ✓ Z8 Development Module and other supporting products Designers interested in using the Z8090 UPC Universal Peripheral Controller should also attend this seminar, since the architecture of the UPC is very similar to that of the Z8. A general microcomputer course or equivalent experience is suggested as a course prerequisite. Length: Three days Length: Three days Tuition: \$525 Tuition: \$525 Z80 Component Family This basic course on Z80 components is designed for hardware and software development personnel with a modest background in microprocessors and assembly language programming. This course should be taken by anyone interested in effectively using the Z80 family of products. Some topics covered are: - ✓ Z80 architecture and timing - Z80 assembly language programming - Z80 interrupt processing (interfacing non-Zilog peripherals) - ✓ Z80 PIO Parallel I/O Controller - ✓ Z80 CTC Counter/Timer Controller - ✓ Z80 DMA Direct Memory Access Controller This course offers a "hands-on" approach to learning by doing. As each chip is covered, students measure their progress by programming a single-board computer in the laboratory. A general microcomputer course or equivalent experience is suggested as a course prerequisite. # Z8000 Component Family Zilog's basic course on the Z8000 family of components is for hardware and software development personnel who are familiar with microprocessor system design. Anyone interested in effectively using the Z8000 family of products should take this course. Some of the topics covered include: - Z8000 architecture and timing - ✓ Z8000 assembly language programming - Z8010 MMU Memory Management Unit - Z-Bus peripheral interfacing - ✓ Z8000 peripheral devices (CIO, FIO, SCC, and UPC) - ✓ Z8000 software development tools - Z8000 Development Module and other support products A general microcomputer course or equivalent experience is suggested as a course prerequisite. Length: Four days Tuition: \$695 Tuition: \$695 Length: Four days ## ZDS-1/40 Development System This seminar describes Z80 emulation using the ZDS-1/40 development system. Description of the ZDS-1/40 emphasizes those aspects of the development system that affect the emulation process. Some of the topics covered include: Length: One day Tuition: \$175 - ✓ ZDS-1/40 hardware design - ✓ Z80 system design hints to aid the emulation process - ✓ The Zilog Analyzer Program (ZAP) - ✓ The RIO Hardware Emulation Driver (RHED) This course is recommended for designers of Z80 systems where the emulation process is used as a development tool, as well as for engineers who are directly involved in Z80 emulation. A Z80 component class or equivalent Z80 assembly language experience is suggested as a course prerequisite. # EMS 8000 Emulation System This seminar details the use of the EMS 8000 emulator during development and debugging of Z8000-based systems. The emulator commands and their operation are fully described. The EMS 8000 emulation system is a very powerful development tool for both the hardware and software engineer. Some of the topics covered include: - → EMS 8000 hardware design - ✓ Use of triggers as breakpoints or trace qualifiers - Mapping EMS memory to the target system - Performance measurements for benchmarking applications - ✓ Link EMS systems for multiprocessor emulations - → Building user-definable macros of EMS commands This course is recommended for all engineers interested in using the EMS 8000 Emulation System to analyze and debug Z8000-based systems. The Z8000 Components family course or equivalent experience is recommended as a prerequisite. ## MCZ1/ZDS The needs of both the new Zilog system user and the experienced designer are met in this Z80-based systems course. The full range of MCZ-1 and ZDS microcomputer systems is described. Emphasis is placed on RIO, the Zilog operating system. Some topics covered are: ✓ MCZ-1/ZDS hardware - ✓ Z80 assembler, linker, debugger, editor - Advanced debugging techniques (symbolic debugging ZBUG and NBUG) - ✓ Elements of RIO-the MCZ-1/ZDS operating system - → RIO structure-making system calls - RIO floppy disk driver-ZDOS - ✓ Device drivers-printers, consoles This course provides a "hands-on" approach to learning by doing. As each portion of the operating system is covered in lecture, students can measure their progress by writing their own programs in class. A Z80 component class or equivalent Z80 assembly language experience is suggested as a course prerequisite. MCZ-2 Systems This Z80A-based systems course introduces the systems user to MCZ-2 local network microcomputer systems architecture and operation. The full range of MCZ-2 systems is described, with emphasis placed on RIO/CP, Zilog's multi-tasking operating system. Some topics covered are: - RIO/CP (Concurrent Processing) multitasking operating system - MCZ-2 System Kernel-dispatcher for multitasking environment - ✓ RIO floppy disk driver-FFS - COBOL calls to the operating system. - Z-Net philosophy and local networking concepts A Z80 component class or equivalent Z80 assembly language experience is suggested as a course prerequisite. Length: Four days Tuition: \$695 Length: Four days Tuition: \$695 ### ZEUS/System 8000 Users The ZEUS/System 8000 operating system user course covers features of the powerful multiuser multitasking ZEUS Operating System. (Zilog's enhancement of UNIX\* Version VII). It is designed for persons with little or no knowledge about ZEUS. Some topics covered are: - Hierarchical file system - C shell command language and procedures - ✓ ZEUS source code control system - ✓ ZEUS screen editor - ✓ Text and document processing - ✓ Software development using ZEUS This course provides the student with lab exercises to supplement the lecture session. Some previous programming or systems experience is recommended but is not a prerequisite for this course. ## ZEUS/System 8000 System Administrator The ZEUS/System 8000 systems administrator course is designed for persons responsible for maintaining the ZEUS Operating System. Some of the topics covered are: - Role of the systems administrator - ✓ System organization - ✓ System startup - File system checking and repair - Adding users to the system - Commands available to the administrator A working knowledge of the ZEUS Operating System, or equivalent, is suggested as a course prerequisite. Length: Five days Tuition: \$875 Length: Two days Tuition: \$350 # Z80 Assembly Language This seminar is for programmers needing to learn the Z80 low level assembly programming language. The course includes class presentation and hands-on programming labs that allow the students to write their own assembly language programs. Some of the topics covered are: - ✓ Language structure and syntax - ✓ Z80 instruction set - ✓ Z80 CPU flag and register utilization - Macros - Subroutines - System calls to the RIO operating system It is suggested that attendees to this seminar have some previous programming experience. # PLZ/SYS Programming The PLZ programming seminar is for programmers who need language tools that permit methodical and well-organized programs. PLZ, Zilog's Pascal-like language, includes the PLZ/SYS (high level, user-oriented) and PLZ/ASM (a structured assembly language) elements. Some topics covered in this seminar are: - ✓ Program structure - ✓ Data types-simple and structured - Recursive programming - → Pointers and linked lists - ✓ System I/O calls - ✓ Comparison of programming languages - → Protocols for communicating with other languages - The PLZ symbolic Debugging Tool (PDT) # C Programming The C programming course is for programmers interested in learning C, a high-level systems programming language. Tuition: \$695 The course includes class presentation and hands-on programming labs that allow students to write their own C programs on an System 8000 system. Some topics covered are: - ✓ Program structure - ✓ Data types, data structures, and pointers - Program flow control - ✓ Program development on the System 8000 system - ✓ System calls to the ZEUS Operating System Some high-level language programming experience is suggested as a course prerequisite. | | - | | | | |--|---|---|--|------| | | | • | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | <br> | # Zilog Sales Offices and Technical Centers #### West Sales & Technical Center Zilog, Incorporated 1315 Deli Avenue Campbell, CA 95008 Phops: (408) 370-8120 TWX: 910-338-7621 Sales & Technical Center Zilog, Incorporated // 18023 Sky Park Circle Suite J Irvine, CA 32714 Phone: (714) 549-2891 TWX: 910-595-2803 Sales & Technical Center Zilog, Incorporated 15643 Sherman Way Suite 430 Van Nuys, CA 91406 Phone: (213) 989-7485 TWX: 910-495-1765 Sales & Technical Center Z) log, Incorporated 1/50 112th Ave N.E. Suite D161 Bellevue, WA 98004 Phone: (206) 454-5597 #### Midwest Sales & Technical Center Zilog, Incorporated 890 East Higgins Road Suite 147 Schaumburg, IL 60195 Phone: (312) 565-8080 TWX: 910-291-1064 Sales & Technical Center Zilog, Incorporated 28349 Chagrin Blvd. Suite 109 Woodmere, OH 44122 Phone: (216) 831-7040 FAX: 216-831-2957 #### South Sales & Technical Center Zilog, Incorporated 4851 Keller Springs Road, Suite 211 Dailas, TX 75248 Phone: (214) 931-9090 TWX: 910-860-5850 Zilog: Incorporated 7113 Burnet Rd. Suite 207 Austin, TX 78757 Phone: (512) 453-3216 #### East Sales & Technical Center Zilog, Incorporated Corporate Place 99 South Bedford St. Eurlington, MA 01803 Phone: (617) 273-4222 TWX: 710-332-1726 Technical Center Zilog, Incorporated 110 Gibraltar Road Horsham, PA 19044 Phone: (215) 441-8282 TWX: 510-665-7077 Sales & Technical Center Zilog, Incorporated 240 Cedar Knolls Rd. Cedar Knolls, NJ 07927 Phone: (201) 540-1671 Technical Center Zilog, Incorporated 3300 Buckeye Rd. Suite 401 Atlanta, GA 30341 Phone: (404) 451-8425 Sales & Technical Center Zilog, Incorporated 1442 U.S. Hwy 19 South Suite 135 Clearwater, FL 33516 Phone: (813) 535-5571 ## **United Kingdom** Zilog (U.K.) Limited Zilog House 43-53 Moorbridge Foad Maidenhead SL6 8P Berkshire, United Kingdom Phone: 0628-39200 Telex: 848609 #### France Zilog, Incorporated Tour Europe Cedex 7 92080 Paris La Defense France Phone: (1) 778-14-34 TWX: 611445F ## **West Germany** Zilog GmbH Zugspitzstrasse 2a D-8011 Vaterstetten Munich, West Germany Phone: 08106 4035 Telex: 529110 Zilog d. ### Japan Zilog, Japan K.K. Konparu Bldg. 5F 2-8, Akasaka 4-Chome Minato-Ku, Tokyo 107 Japan Phone: (03) 587-0528 Telex: ESSOEAST J2284 # Zilog an affiliate of EXON Corporation 1315 Dell Drive Campbell, Calif. 95008 Phone: (408) 370-8000 TWX: 910-338-7621 00-2034-02 Printed in U.S.A