# SUPER SIX S-100 Single Board Computer Technical Manual USA OFFICE 5432 PRODUCTION DRIVE HUNTINGTON BEACH, CA 92649 TELEPHONE: (714) 891-4004 TELEX: 183210 ADVANCED HTBH UNITED KINGDOM OFFICE 27 PRINCESS: STREET HANOVER SQUARE, LONDON W1R8NO UNITED KINGDOM 409-0077 / 409-3351 TLX 265840 FINEST # SUPER SIX<sup>TM</sup> S-100 Single Board Computer Technical Manual June 1, 1983 ADVANCED DIGITAL CORPORATION #### TABLE OF CONTENTS | SECTION | TITLE | PAGE | |---------------|------------------------------------------|-----------------------| | SECTION I - I | NTRODUCTION | i | | 1.1 | Purpose | 1 | | 1.2 | Equipment Overview | 1 | | 1.3 | Document Organization | 2 | | 1.4 | List of Acronyms | 2 | | 1.5 | Document Maintenance | 3 | | 1.6 | Theory of Operation | 3 | | SECTION II - | OPERATION | 4 | | 2.1 | Floppy Disk Controller | 4 | | 2.2 | 128K Dynamic RAM | 4 | | 2.3 | System Monitor EPROM | 5<br>5<br>5<br>5<br>7 | | 2.4 | Serial Ports | ) | | 2.5 | Parallel Ports | ) | | 2.6 | Real Time Interrupt Clock | ) | | 2.7 | S-100 Bus Interface | )<br>7 | | 2.8 | Baud Rate Jumper | 7. | | 2.9 | EPROM and Monitor Operations | 7 | | 2.9 | | 8 | | | 9.2 Monitor Sign-on 9.3 Monitor Commands | 8 | | | 9.4 Cold Start Program | 10 | | 2.10 | RAM Organization | ÎĬ | | 2.11 | Z80A DMA Features | 11 | | 2.12 | PSNET/I Operation | ÎÎ | | 2.13 | PSNET/PAR Operation | 12 | | 2.14 | Synchronous Operations | . 12 | | 2.15 | Power Consumption | 12 | | SECTION III ~ | INPUT/OUTPUT PORTS | 13 | | 3.1 | Input/Output Port Assignments | 13 | | 3.2 | Input/Output Descriptions | 14 | | | 2.1 Port 00 | 14 | | | 2.2 Port 01 | 14 | | 3.2 | 2.3 Port 02 | 14 | | | 2.4 Port 03 | 14 | | | 2.5 Port 04 | 14 | | | 2.6 Port 05 | 14 | | | 2.7 Port 06 | 14 | | | 2.8 Port 07 | 14 | | | 2.9 Port 08 | 14<br>15 | | | 2.10 Port 09 2.11 Port 0A | 15 | | | 2.11 Port 0A<br>2.12 Port 0B | 15 | | | 2.12 Port 05<br>2.13 Port 0C | 15 | | | 2.14 Port 0D | 15 | | | 2.15 Port 0E | 15 | | | 2.16 Port 0F | 15 | | | 2.17 Ports 10-13 | 15 | | | | • | All information contained in this document is the property of Advanced Digital Corporation. # TABLE OF CONTENTS (continued) | SECTION | | | TITLE | | PAGE | |---------|------------|-------------|-----------------------------|---|----------| | | 3.2.18 | Port 14 | | | 16 | | | 3.2. | 18.1 | Port 14 Read Operation | | 16 | | • | 3.2.19 | Port 15 | | | 17 | | | 3.2. | 19.1 | Port 15 Read Operation | | 17 | | | 3.2. | 19.2 | Port 15 Write Operation | | 17 | | | 3.2.20 | Ports 16 | and 17 | | 17 | | | 3.2. | 20.1 | Port 17 Write Operation | | 18 | | | 3.2. | 20.2 | Port 17 Write Operation | | 19 | | | 3.2.21 | Ports 18- | 18 | | 21 | | SECTION | IV - JUMPI | ER CONNE | ECTIONS | | 22 | | 4.1 | | per Definit | | | 22 | | 4.2 | | per Descrip | | | 23 | | | 4.2.1 | Jumper A | | | 23 | | | 4.2.2 | Jumper B | | | 23 | | | 4.2.3 | Jumper C | | | 23 | | | 4.2.4 | Jumper D | | | 24 | | | 4.2.5 | Jumper E | | | 24 | | | 4.2.6 | Jumper C | | | 24 | | | 4.2.7 | Jumpers | | | 24 | | | 4.2.8 | Jumper J | | • | 24 | | | 4.2.9 | Jumper R | | | 25 | | | 4.2.10 | Jumper J | | | 25 | | | 4.2.11 | | P, N, M, K, J, R, S, and F | | 25 | | 4.3 | | | EM Installed Jumpers | | 26 | | • | 4.3.1 | | oppy Disk Drive | | 26 | | | 4.3.2 | | SA800/801 Disk Drive | | 26 | | | 4.3.3 | | 350 Disk Drive | | 27 | | | 4.3.4 | | tel 700 Disk Drive | | 27 | | | 4.3.5 | | lim Line Disk Drive | | 27 | | | 4.3.6 | | del FD1160 Disk Drive | | 28 | | | 4.3.7 | | ata Track Disk Drive | • | 28 | | | 4.3.8 | | .25 Inch Disk Drive | • | 28 | | | 4.3.9 | | ni Model 2894 Disk Drive | | 28 | | | 4.3.10 | | ni Model 2896 Disk Drive | 1 | 28 | | | 4.3.11 | | SA 860 Disk Drive | | 28 | | | 4.3.14 | | FDD-100-8 Disk Drive | | 29 | | | 4.3.16 | | ak 592 5.25 Inch Disk Drive | | 29 | | | 4.3.17 | | r Disk Drives | | 29 | | SECTION | V - EXTER | NAL CON | NECTOR PINS | | 30 | | 5.1 | | nector S-10 | | | 30<br>30 | | 5.2 | | nector 3-10 | | | 31 | | 5.3 | | nector 32 | | | 32 | | 5.4 | | nector 34 | | | 33 | | 5.5 | | nector J5 | | | 33 . | # TABLE OF CONTENTS (continued) TITLE **SECTION** | APPENDIX B - APPENDIX C - APPENDIX E - APPENDIX F - APPENDIX G - APPENDIX H - APPENDIX I - S APPENDIX J - APPENDIX K - APPENDIX L - APPENDIX M - | Z80A/Z80B CTC<br>Z80A/Z80B CPU | | | |--------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|----------------------------| | | LIST OF FIGURES | | ٠ | | FIGURE NO. | TITLE | | PAGE | | 2-1<br>2-2 | SUPER SIX Interface To the S-100 Bus<br>SUPER SIX RAM Configuration | | 6<br>11 | | | LIST OF TABLES | | | | TABLE NO. | TITLE | | PAGE | | 1-1 | List Of Acronyms | | 2 | | 2-1<br>2-2 | SUPER SIX Baud Rate Jumper Settings<br>Monitor Commanas For the SUPER SIX | | 7<br>9 | | 3-1<br>3-2 | I/O Port Assignments For the SUPER SIX<br>SUPER SIX Port 18 Baud Rate Settings | | 13<br>21 | | 4-1 | SUPER SIX Jumpers and Abbreviated Functions | : | 22 | | 5-1<br>5-2<br>5-3<br>5-4<br>5-5 | SUPER SIX 31 Connector Pin Functions<br>SUPER SIX 32 Connector Pin Functions<br>SUPER SIX 33 Connector Pin Functions<br>SUPER SIX 34 Connector Pin Functions<br>SUPER SIX 35 Connector Pin Functions | | 30<br>31<br>32<br>33<br>33 | #### SECTION I #### INTRODUCTION #### I.I PURPOSE This Manual provides the technical information necessary to install, operate and maintain the SUPER SIX singleboard computer by Advanced Digital Corporation. #### 1.2 EQUIPMENT OVERVIEW SUPER SIX, produced by Advanced Digital Corporation, is the first single board computer for the S-100 bus running at 6MHz. Without the S-100 bus the SUPER SIX can also run as a standalone computer executing a single user CP/M 2.2 or 3.0, or a multiuser MP/M, OASIS, or TurboDOS operating system. SUPER SIX runs substantially faster than any other S-100 single board computer avialable in the market. The SUPER SIX contains the following set of capabilities: - 1. Z80B CPU operating at 6MHZ - 2. 128K of dynamic bank select RAM arranged in 16k banks - 3. Floppy Disk Controller which supports the 8-inch and 5.25-inch disk drives simultaniously - 4. 2/4 K of shadow EPROM (Monitor) - 2 serial I/O (RS-232) ports offering software or hardware selectable baud rate, Z80B DART - 6. 2 parallel ports (Z80B PIO) - 7. Real time clock (Z80B CTC) - 8. DMA controller (Z80 DMA) - 9. Extended addressing: A16-A23 - 10. Single 5 volt supply on board - 11. One-year warranty - 12. Free copy of CP/M 2.2 BIOS supplied. <sup>\*</sup> NOTE: Items 5 and 6 require external adaptation for RS-232 and Centronics. The adapter boards contain a DB-25 connector on a 2-inch by 2-inch board attached to the back panel of the S-100 system (MODEM and RS 422 Paddle cards are also available). #### 1.3 DOCUMENT ORGANIZATION This document is organized into 5 sections and 14 appendices. Section I serves as an introduction to the entire document, stating the purpose of the document and providing an introduction to the SUPER SIX single board computer. This section also provides a list of acronyms used in the document and provides a statement on the responsibilities of document maintenance. Section II provides a description of the operations of all components associated with the SUPER SIX single board computer. Section III lists all SUPER SIX input/output ports and defines the assignments and functions of each port. Section IV lists and defines all SUPER SIX jumper connections. This section includes the jumper assignments for factory (OEM) installed jumpers. Section V describes the external connector pins for SUPER SIX connectors J1 through J5. The appendices provide supplemental material to the body of the text and are referenced in the text at the associated points. #### 1.4 LIST OF ACRONYMS Table 1-1 provides a listing and description of the acronyms used within this text. | ACRONYM | DESCRIPTION | |---------|-----------------------------------------------------| | CPU | Central Processor Unit | | стс | Controller/Timer Circuit | | DART | Dual Asynchronous Receiver/Transmitter | | DMA | Direct Memory Access | | EPROM | Electrically Erasable Programmable Read-Only Memory | | FDC | Floppy Disk Controller | | IEEE | Institute of Electrical and Electronic Engineers | | MP/M | Multiuser Program For Microcomputers | | ОЕМ | Original Equipment Manufacturer | | PIO | Parallel Input/Output | | PROM | Programmable Read-Only Memory | Table 1-1. List of Acronyms Table 1-1. List of Acronyms (Continued) | ACRONYM | DESCRIPTION | | | | |----------|-----------------------------------------------------------------------------|--|--|--| | RAM | Random Access Memory | | | | | SIO | Serial Input/Output | | | | | TTL | Transistor-transistor Logic | | | | | TurboDOS | A Multiuser Networking Operating System used as software with the SUPER SIX | | | | #### 1.5 DOCUMENT MAINTENANCE This document is the property of Advanced Digital Corporation, who is responsible for its content. Any modifications made to this manual must be made with the express written approval of Advanced Digital Corporation. #### 1.6 THEORY OF OPERATION - START-UP PROCEDURE The SUPER SIX Single board computer is shipped configured for 19. baud rate. The installation procedure is as follows: - 1. Plug the PSNET/I to connector 35. Use caution; pin 1 is marked. - 2. Connect the CRT. Pins 2, 3, 5, 7, and 20 must be used; no parity must be specified, - 3. Apply power to the system. The monitor message shown in subsection 2.9.2 appears. Check the CRT baud rate; if 9600 baud is required, unplug jumper area J7, pin 7-8. - 4. Install the floppy disk cable, load the CP/M diskette, and bootstrap the system. Note: CP/M is shipped configured for 64K bytes of memory. The parallel port is configured as the default printer. 1024 bytes per sector read/writes are also supported (or DMA). The plus 8V and the plus/minus 16V on the S-100 bus must be verified prior to installing the SUPER SIX board. #### SECTION II OPERATION This section describes the operation of all SUPER SIX components. ## 2.1 FLOPPY DISK CONTROLLER The floppy disk controller can access up to four 8-inch or four 5.25-inch disk drives or any combination of the two. The controller can read and write IBM 3740 single density format and double density 1024 sector-size formats. Data transfer is performed via Direct Memory Access (DMA). Due to the simultanious operation capability of the SUPER SIX the format compatibility problems with 5.25-inch disks have been eliminated. The floppy disk controller used is the WD2793. The WD2793 has on-chip PLL data separators and on-chip write pre-compensation logic. Adjustments for PLL are factory set and write pre-compensation has been provided with the SUPER SIX. 50 Pin and 34 pin connectors are available for 8-inch and 5.25-inch disk drives respectively. NOTE: Customer adjustment of trim pots may result in cancellation of warranty. #### 2.2 THE 128K DYNAMIC RAM The 128K RAM array can be switched ON and OFF in 16K increments, (0-16K, 16K-32K, 32K-48K, 48K-64K for both banks) under software control. This feature allows the CPU to access bank switchable external memory on the S-100 bus. The memory has an access time of 150ns. A Refresh operation is performed during Z80 MI cycles and during WAIT and RESET states. The memory can be accessed by floppy disk via DMA, serial and parallel 1/O, or another DMA device on the S-100 bus. \*NOTE: Any external DMA device that is using continous mode DMA cycles must transfer data at an average rate of 15ms per byte or faster when holding the DMA request line for more than 1.5ms. The RAM row address is the low order address; therefore the entire RAM array is refreshed by DMA device every 128 contiguous memory cycles. Under CPM 2.2 or CPM 3.0 the additional 64K can be used as a disk buffer. The SUPER SIX is ideal when operating in the bank mode under CP/M 3.0, as 128K RAM is required. #### 2.3 SYSTEM MONITOR EPROM The system monitor EPROM is switched ON during reset. It can be disabled and enabled under software control. When enabled, the system monitor resides at locations F800-FFFF (hex) (refer to subsection 2.9.1.2) when using 2716 EPROM or at locations F000-FFFF (hex) when using the 2732 EPROM. The system monitor EPROM contains the cold-start loader for CP/M, MP/M and TurboDOS. In addition it can be used to perform LOAD, I/O READ and I/O WRITE operations. When the EPROM is disabled no system address space is used. #### 2.4 SERIAL PORTS A 6MHz Z80B DART is used for the two serial I/O ports; a Z80B S10 or Z80A DART can be used in it's place (if a 4MHz Z80A DART is used the CPU and all other devices must also be 4MHz). This allows asynchronous serial data communication plus a variety of interrupt modes. Modem control signals are available at each serial connector. There are software selectable baud rates as well as hardware selectable baud rates (mini-jumpers J7). \*NOTE: The serial ports are TTL and must be connected to PSNET/I (serial adapter interface) for RS-232 communications. The J4 connector is for the CRT; the J5 connector is for the serial printer or CRT. #### 2.5 PARALLEL PORTS A 6MHz Z80B PlO is used as the parallel port. The "A" channel of this chip is used to connect the parallel port connector (J2) to PlO. This port has an 8-bit bi-directional data line and two hand-shake lines. The "B" port can be split between the parallel port connector and the S-100 bus vectored interrupts lines by jumper options. This allows the port to be used as an additional parallel port, an interrupt controller, or both of the above. In the output mode the parallel ports can drive one TTL load. # 2.6 REAL TIME INTERRUPT CLOCK A 6MHz Z80B CTC is used for providing a real time system clock for MP/M or TurboDOS operating systems. Three channels of the CTC are available to the user for jumpering to synchronous baud rates or long clock times. # 2.7 S-100 BUS INTERFACE The S-100 bus interface provides the signals necessary for an 8-bit bus master as described by the IEEE-696 bus specification. Vectored interrupt lines VIO-VI7 are supported via jumper options (refer to section IV) and A16-A23 are also supported via an I/O port. The Phantom line is also implemented for the dynamic RAM array. The SUPER SIX interface with the S-100 bus is depicted in Figure 2-1. TurboDOS is the registered trademark of Software 2000, Inc. CP/M and MP/M are the registered trademarks of Digital Research, Inc. Figure 2-1. SUPER SIX Interface to the S-100 Bus Upon SUPER SIX initialization, the baud rate for the two serial channels can be hardware-selected independently by means of the baud rate jumper (J7). This 7-pole jumper is located between U70 and U68 and is divided into two sets of jumpers containing four and three pins for SIO channels A and B, respectively. Pins 7, 6, 5, and 4 set the baud rate for SIO channel A and are designated as A, B, C, and D, respectively; pins 3, 2, and I set the baud rate for SIO channel B and are designated as A, B, and C, respectively. Because this jumper comprises of only seven pin sets, SIO channel B has a hardware limitation of 1200 baud; by means of port 18 the software may be set to allow up to 19.2K baud for channel B. The baud rate settings, as determined by this jumper, are shown in Table 2-1, below. Once the SUPER SIX is initialized, I/O port 18 is used to modify the baud rate. Port 18 is described in subsection 3.2.21. | BIT | BIT | BIT | BIT | BAUD | |------------------------------------------------|-----------------------------------------|-------------------------------------------|-----------------------|-------------------------------------------------------------------------------------------------------| | D | C | B | A | RATE | | 0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>1<br>1 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | 0<br>0<br>1<br>0<br>0<br>1<br>1<br>0<br>0 | A 0 1 0 1 0 1 0 1 0 1 | 50<br>75<br>110<br>134.5<br>150<br>300<br>600<br>1200<br>1800<br>2000<br>2400<br>3600<br>4800<br>7200 | | <u>l</u> | I | l | 0 | 9600 | | | I | l | 1 | 19,200 | Table 2-1. SUPER SIX Baud Rate Jumper Settings ### 2.9 EPROM AND MONITOR OPERATION The on-board EPROM occupies addresses F000-FFFF (hex). This EPROM is switched ON automatically during RESET or POWER-ON. It contains the serial input/output (SIO) and floppy disk controller (FDC) initialization code along with a simple debugger and floppy disk cold-start loader. After the operating system is loaded the EPROM can be turned OFF to allow access to the RAM at address F000H-FFFFH. The EPROM can be enabled or disabled at any time to permit the calling of hardware dependant I/O routines. #### 2.9.1 EPROM Enable/Disable A listing of the program required to enable and disable the EPROM is provided below #### BAUD RATE JUMPERS #### ADVANCED DIGITAL CORPORATION SUPER SIX SUPPLEMENT #### Update for Page 7 With the Super Six component side facing you and the S-100 connector down there are 7 jumpters between U68 and U70 aligned vertically. There are assigned as follows: Bit D for SIO CH. B is not available as a jumper and must be set in software. Bit 7 of this input port (port 15) is instead used to sense double sided drives. Some software reads this bit and sends it to the SIO CH. B baud rate anyway. If you have double sided drives, this will make the bit a 0 thru creating baud rates from 50 to 1200. If you have single sided drives, this will make the bit a 1 and create baud rates from 1800 to 19.2K. If you experience a problem with this you can make a file under cpm to correctly assign the baud rate to SIO CH. B (used for serial printer and/or modem) as follows: | A <b>&gt;</b> ddt | • | |-------------------|------------------------------------------| | -a100 | | | 0100 | in 15 | | 0102 | ani 7f (for 50 to 1200 baud. for 1800 to | | | 19.2k type ori 80) | | 0104 | out 18 | | 0106 | jmp 0 | | 0109 | ∢CR> | | -g0 | | | | | A>save 1 setbaud.com A>setbaud #### COMMON BAUD RATE SETTINGS | Console = 19.2k<br>SIO CH. B = 300 | Console = 19.2k<br>SIO CH. B =1200 | Console = 9600 | Console = 12 | |------------------------------------|------------------------------------|----------------|--------------| | (ON ) | (ON ) | (off) | (ON ) | | (ON ) | (ON .) | (ON ) | (ON ) | | (ON ) | (ON ) | (ON ) | (ON) | | (ON ) | (ON ) | (ON ) | (off) | | (ON ) | (ON ) | | | | (off) | (ON ) | | | | (ON ) | (ON ) | | | 2.9.1.1 Enabling the EPROM: F033 3E4F MVI A,01001111B ;RESET POWER ON JUMP AND ENABLE MEMORY, EPROM ON F035 D316 OUT 16H ;WRITE TO CONTROL PORT 2.9.1.2 Disabling the EPROM: F033 3E4F MVI A,01101111B ;RESET POWER ON JUMP AND ENABLE MEMORY, EPROM OFF F035 D316 OUT 16H ;WRITE TO CONTROL PORT Jumper R25 configures the board to accept a 2716 or 2732 EPROM (as described in section IV). NOTE: The EPROM is always addressed at location F800 (hex) and can not be moved. Since the 2716 EPROM is 2K long it appears twice, at location F800-FC00 (hex) and at location FBFF-FFFF (hex). 2.9.2 Monitor Sign-on The monitor signs-on with the following messages: ADVANCED DIGITAL CORP. Monitor Version 3.6 April - 1983 Press "H" for help 2.9.3 Monitor Commands The monitor commands are shown in table 2-2. | COMMAND | FUNCTION | | | |------------------|----------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | В | Loads the disk-boot loader | | | | D ssss qqqq | Dumps memory in hex starting at user-specified address ssss and ending at user-specified address qqqq | | | | F ssss qqqq bb | Fills memory from user-specified address ssss to user-specified address qqqq with bb | | | | G AAAA | Goes to address AAAA | | | | I pp | Input to user-specified port pp | | | | L aaaa | Loads memory starting at user-specified address aaaa | | | | M ssss qqqq dddd | Moves the contents of user-specified starting address ssss through user-specified ending address qqqq to t user-specified starting address of dddd | | | | O pp dd | Output user-specified data dd to port pp | | | | ESC | Terminates any command | | | Table 2-2. Monitor Commands For the SUPER SIX The cold-start loader will select and home drive 0. Track 0 sector 1 will be read into memory at location 0. Single density is assumed for track 0. If an error occures an error code will be printed. The error code must be translated using the table in appendex G. # Cold Start Program The cold start program is listed below. 2.9.4 # READ TRACK 0 SECTION 1 INTO MEMORY | В | O | O | Ţ | 5: | |---|---|---|---|----| | | | | | | | | | BOOLS | • | |-------------|-----------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | MVI | A,018H | | | | OUT | WAIT | set double for 5 inch | | | ٠,٥. | ** * * * * | ,000 00000 100 0 10000 | | • | | воот | | | ELD COEOD | 4 4 3 4 T | | RESET FDC | | F4B5 3E0D | MVI | A,0DH | • | | F4B7 D30C | OUT | FDC | ISSUE COMMAND | | F4B9 00 | NOP | | | | | | | | | | | FDCWI | • | | F4BA DB0C | IN | FDC | CHECK BUSY | | F4BC OF | RRC | | , | | F4BD DABAF4 | JC | FDCWI | | | | | I DCW I | ;KILL TIME | | F4C0 00 | NOP - | | inill Hair | | F4C1 00 | NOP | | | | F4C2 00 | NOP | | • | | F4C3 00 | NOP | | | | F4C4 3E03 | MVI | A,3 | GET A RESTORE | | F4C6 D30C | OUT | FDC | ISSUE COMMAND | | F4C8 00 | NOP | | ,—— | | F4C9 DB14 | ·- | WAIT | :WAIT*FOR | | | IN | M WYY | | | F4CB 00 | NOP | | ;INTRQ | | | | <b></b> | <del>-</del> | | | | TKO: | | | F4CC DB0C | IN | FDC | | | F4CE E604 | ANI | 4 | CHECK TRACK 0 | | F4D0 CACCF4 | JZ | TK0 | | | F4D3 AF | XRA | Α | | | F4D4 6F | MOV | L,A | POINT AT LOC 0 | | F4D5 67 | MOV | • | , CAN I AN ECC O | | | | H,A | | | F4D6 3C | INR | A | | | F4D7 D30E | OUT | FDCSEC | SET SECTOR | | F4D9 3E8C | MVI | A,08CH | GET READ COMMAND | | F4DB D30C | OUT | FDC | ISSUE COMMAND | | F4DD 00 | NOP | | The state of s | | | | | | | | | FDCRE | ): | | F4DE DB14 | IN | WAIT | WAIT FOR INTRO | | F4E0 B7 | | | OR DRO | | | OR A | A | | | F4E1 F2EBF4 | JР | BOOTDN | EXIT IF INTRQ | | F4E4 DB0F | IN | | GET DATA | | F4E6 77 | MOV | M,A | ;STORE | | F4E7 23 | INX | H | POINT NEXT | | F4E8 C3DEF4 | JMP | FDCRD | | | | | | | #### **BOOTDN:** | F4EB DB0C | IN | FDC | CHECK STATUS | |-------------|------|---------|--------------| | F4ED B7 | OR A | Α | 0 = NO ERROR | | F4EE CA0000 | JZ | 0 - | OK, GO | | F4F1 F5 | PUSH | PSW | SAVE ERROR | | F4F2 210FF6 | LXI | H,BTERR | PRINT | | F4F5 CDE6F0 | CALL | MSG | DISK ERROR | | F4F8 F1 | POP | PSW | GET ERROR | | F4F9 CD21F1 | CALL | THXB | PRINT IT | #### 2.10 RAM ORGANIZATION The SUPER SIX 128K RAM is configured as shown in Figure 2-2. | U55 | U46 | U47 | |-----|-----|-----| | U57 | U48 | U56 | | U58 | U49 | U50 | | U60 | U51 | U59 | | U61 | U52 | U53 | | U63 | U54 | U62 | Figure 2-2. SUPER SIX RAM Configuration The first 64K bank of RAM comprises of U46, U47, U48, U49, U51, U52, U54, U53, and U50; U46 is the parity chip. #### 2.11 Z80A DMA FEATURES The Z80A DMA performs transfers, searches and search/transfers on a full-byte basis in burst or continuous modes. The cycle length and edge timing can be programmed to match the speed of any port. A bit maskable byte search can be performed either concurrently with transfers or as an operation itself. ### 2.12 PSNET/I OPERATION This paddle card converts TTL to RS232 levels. Pin 6 of the 14 pin connector on the card represents TXD; pin 7 is RTS\*; pin 8 is DTR\*; pin 5 is CTS\*; 1 is DCD\* (normally GND); 3 is RNG\* optional; 2 is DSR\*; 4 is RXD. Only pins 3, 5, 20, 2, and 1 are required for most printers or CRT's. Printers employing the BUSY line must be tied to pin 20 of the DB-25 connector on PSNET/1. A PSNET/1 schematic is provided in Appendix L. #### PSNET/PAR 2.13 This paddle card connects the SUPER SIX parallel I/O to a Centronics printer or any other device that requires buffered signals. Note that a DB-25 connector is used to simplify the connection for the back panel of the S-100 system. Thirteen wires are required between the DB-25 and the printer. A PSNET/PAR schematic is provided in Appendix M. ## 2.14 SYNCHRONOUS OPERATIONS If synchronous operation is required, the CTC channels (all four) are unused; the jumper option on H and T can be used to bring external clock into the SIO. The 14 pin connectors (J4 and J5), pins I and II, are not used and can be employed for RNG. SIO pins 13 and 14 are connected on the SUPER SIX board and must be cut for synchronous operation. # 2.15 POWER CONSUMPTION +8V 2.8 Amp typical +/-16V 250 ma # SECTION III INPUT/OUTPUT PORTS # INPUT/OUTPUT PORT ASSIGNMENTS Input/Output port assignments are shown in Table 3-1: 3.1 | ADDRESS | FUNCTION | |---------------|------------------------------------| | 00 Read/Write | SIO channel A Data port | | 01 Read/Write | • | | 02 Read/Write | | | 03 Read/Write | SIO channel B status/control port | | 04 Read/Write | | | 05 Write | PIO channel B Data port | | 06 Read/Write | PIO channel A control port | | 07 Write | PIO channel B control port | | 08 Read/Write | | | 09 Read/Write | | | OA Read/Write | | | 0B Read/Write | | | OC Read/Write | | | 0D Read/Write | | | OE Read/Write | | | 0F Read/Write | | | 10 Read/Write | | | II Read/Write | | | 12 Read/Write | | | 13 Read/Write | | | 14 Read/Write | | | 15 Write | S-100 bus extended address A16-A23 | | 15 Read | On-board Baud Rate jumpers | | 16 Write | On-board memory control port #0 | | 17 Write | On-board memory control port #1 | | 18 Write | Set Baud Rate | | 19 Write | Same as port 18 | | IA Write | Same as port 18 | | lB Write | Same as port 18 | Table 3-1. I/O Port Assignments for the SUPER SIX Board Note: All Address in table 3-1 are listed in Hex. The unused input/output ports are internally decoded and should not be used by external S-100 I/O boards. The individual ports are described in detail in the following subsection. #### 3.2 I/O PORT DESCRIPTIONS This subsection discribes the function of all SUPER SIX I/O ports. #### 3.2.1 Port 00 This read/write port acts as the serial input/output channal A data port and is described in detail in Appendix A. #### 3.2.2 Port 01 This read/write port acts as the serial input/output channel A status/control port and is discribed in Appendix A. #### 3.2.3 Port 02 This read/write port acts as the serial input/output channel B data port and is discribed in detail in Appendix A. #### 3.2.4 Port 03 This read/write port acts as the serial input/output channel B status/control port and is described in detail in Appendix $A_{\bullet}$ #### 3.2.5 Port 04 This read/write port acts as the parallel input/output channel A data port and is discribed in detail in Appendix B. #### 3.2.6 Port 05 This write-only port acts as the parallel input/output channel B data port and is described in detail in Appendix B. This port can be jumpered to the S-100 vectored intercept lines onto connector J2 (refer to Section IV). #### 3.2.7 Port 06 This read/write port acts as the parallel input/output channel A control is discribed in detail in Appendix B. #### 3.2.8 Port 07 This write-only port acts as the parallel input/output channel B control port and is described in detail in Appendix B. This port can be jumpered to the S-100 vectored interrupt lines onto connector J2 (refer to Section IV). #### 3.2.9 Port 08 This read/write port acts as the counter/timer circuit channel zero control port and is discribed in detail in Appendix C. 3.2.10 Port 09 This read/write port acts as the counter/timer circuit channel I control port and is discribed in detail in Appendix $C_{\bullet}$ 3.2.11 Port 0A This read/write port acts as the counter/timer circuit channel 2 control port and is discribed in detail in Appendix $C_{\bullet}$ 3.2.12 Port 0B This read/write port acts as the counter/timer circuit channel 3 control port and is described in detail in Appendix $C_{\bullet}$ 3.2.13 Port 0°C This read/write port acts as the floppy disk control command and status port and is described in detail in Appendix $F_{\bullet}$ 3.2.14 Port 0D This read/write port acts as the floppy disk control track register port and is discribed in detail in Appendix F. 3.2.15 Port 0E This read/write port acts as the floppy disk control sector register port and is discribed in detail in Appendix F. 3.2.16 Port 0F This read/write port acts as the floppy disk control data port and is described in detail in Appendix F. 3.2.17 Ports 10-13 These ports act as direct memory access (DMA) control ports. The Z80A DMA controller requires only one control/status port; ports 11, 12, and 13 (hex) are therefore identical to port 10 (hex). The floppy disk controller (FDC) data request line is tied to the Z80 DMA ready input and is active when the signal is high. The DMA controller can move data to and from the FDC and memory, any I/O channel and memory, or memory and memory, on or off the board. \*NOTE: All DMA other than FDC must be started by ready = low (e.g., FDC DRQ = low) and sycronized using the S-100 wait line, pin 72. The DMA interrupt output is connected to interrupt jumper J6. INT from the DMA is active when low. #### 3.2.18 Port 14 This read/write port acts as the floppy disk controller synchronization, drive identification, and density port. #### 3.2.18.1 Port 14, Write Operation The two low-order bits (D0 and D1) specify the disk drive (see table below). Bit D2 selects the disk head. Bit D3 specifies the disk density, where zero (0) specifies single density and I specifies double density. Bit D4 specifies the disk drive size, where zero (0) specifies 8-inch disk and I specifies 5.25-inch disk. The bit significance is shown below. The two low-order bits (D0 and D1) specify the selected disk drive, where: | DI | D0 | RESULT | |----|----|-----------------------| | 0 | 0 | Disk Drive 0 selected | | 0 | 1 | Disk Drive 1 selected | | l | 0 | Disk Drive 2 selected | | I | 1 | Disk Drive 3 selected | Two connectors are provided on the SUPER SIX for the floppy disk: J1 and J3. J1 drives the 5.25-inch floppy disk; pin 1 is clearly marked to this effect. J3 drives the 8 inch disk. #### 3.2.19 Port 15 #### 3.2.19.1 Port 15, Read Operation This port reads the on-board baud rate. The bit significance is shown below. Note: Jumper J7 specifies the hardware setting for the baud rate. Port 15 reads jumper J7 to determine the hardware specified rate. ## 3.2.19.2 Port 15, Write Operation This port controls the S-100 extended address lines. The bit significance is shown below: #### 3.2.20 Ports 16 and 17 These write-only ports act as the on-board memory control ports zero (0) and I respectively. These ports control the on-board memory management circuit, PROM enable and disable circuit, power-on jump reset circuit, and the parity check enable. Port zero (0) controls the first 64K bytes of memory; port I controls the second 64K of memory. #### 3.2.20.1 Port 16, Write Operation The four low-order bits (D0, D1, D2, and D3) switch the on-board memory ON and OFF in 16K banks. Relative addresses of these banks are as shown below, (in hex). | BANK | FROM | TO | |------|------|------| | D0 | 0000 | 3FFF | | D1 | 4000 | 7FFF | | D2 | 8000 | BFFF | | D3 | C000 | FFFF | Bit 5 of this port switches the on-board EPROM ON and OFF. This EPROM occupies addresses F000 through FFFF (Hex). After the operating system is loaded the EPROM can be set to OFF to enable accessing of the RAM addresses F000 through FFFF (hex); it is switched to ON Automatically during reset or power-on. This EPROM contains the SIO and FDC initialization code, a simple debugger, and the floppy disk cold-start loader. Bit D6 resets the power-on jump circuit; it must be reset high before RAM can be accessed upon completion of a reset or power-on operation. Bit D7 enables and disables the on-board memory parity check latch. On power-up or reset, this bit is set to low and disables the parity circuit. Prior to enabling the parity circuit, all memory must be written; this initializes the parity bit for each location. If a parity error occurs an on-board LED is turned ON. If interrupts are enabled and the board is jumpered for parity error interrupts, the location in error can be located by clearing bit D7 (to clear the error), resetting the bit, and then reading each location again; If no parity error is encountered it is likely that the error encountered was a soft read error. Parity error interrupts can be jumpered to create a non-maskable or counter/timer channel interrupt. The bit significance of this port is shown below. Bits D0, D1, D2, and D3 switch the second 64K set of on-board memory similarly to the corresponding bits for port 16. Bits D4, D5, and D6 control memory mapping of the second set of memory. The first set of 64K bytes is not affected by these settings. Five memory maps are available and are depicted below. Note that if any 16K segment from the first bank is selected to overlay a 16K segment from the second bank, only the first bank's 64K memory is selected. The bit significance of map 0 is shown below. No overlays may be performed on this bank. The bit significance of map 1 is shown below. Bank zero of the first memory set may overlay bank 7. The bit significance of map 2 is shown below. Bank I of the first memory set may overlay bank 6. The bit significance of $\underline{map \ 3}$ is shown below. Banks zero and 1 of the first memory set overlay banks 6 and 7, respectively. The bit significance of $\underline{map \ 4}$ is shown below. Bank 3 of the first memory set overlays bank 4. #### EXAMPLES OF BANKING: | 64K - | Bank | 0 | |-------|------|---| | 3 | | | | 2 | | | | 1 | | | | 0 | | | | K. | 7 | | | 64K | _ | Bank | |-----|---|------| | 7 | | | | 6 | | | | 5 | | | | 4 | | | | | | | - Bank 0 Controlled by Port 16 There are five maps possible in Bank 1. Bank 0 always overrides. Once a bit in Bank 0 is set, you will always get the corresponding memory in that Bank only. - Bank 1 Port 17. Depending on the map used. - Map 0 You will get the corresponding memory in Map 0, Bank 1 if you don't have the Bank 0 bit set. | MAP 0 | | |-------|------| | 3/7 | C000 | | 2/6 | 8000 | | 1/5 | 4000 | | 0/4 | 0 | | } | 1 | | , | MAP 1 | | |---|-------|--| | | 3 | | | | 2/6 | | | | 1/5 | | | | 0/4/7 | | | | | | | MAP 2 | | |-------|---| | 3/7 | 1 | | 2 | | | 1/5/6 | | | 0/4 | | | | 4 | | | MAP 3 | | |---|-------|--| | | 3 | | | - | 2 | | | | 1/5/7 | | | | 0/4/6 | | | i | | | | | 0/4 | 0 | 0/4/7 | 0/4 | | |-----|-------|---|-------|-----|--| | 734 | | | | | | | _ | MAP 3 | | MAP 4 | | | | | 3 | | 3/4/7 | | | | | 2 | | 2/6 | • | | | | 1/5/7 | | 1/5 | | | | | 0/4/6 | | 0 | | | | 1 | | | | | | This write-only port acts as the set-baud-rate port and allows the user to perform a software reset of the baud rate for SIO channels A and B. The bit significance of this port is shown below. The baud rates equated with bit settings A, B, C, and D are shown in Table 3-2. These are identical for both channel A and channel B. | BIT<br>D | BIT<br>C | BIT<br>B | BIT<br>A | BAUD<br>RATE | |-------------|-------------|-------------|-------------|---------------------------------| | 0<br>0<br>0 | 0<br>0<br>0 | 0<br>0<br>1 | 0<br>1<br>0 | 50<br>75<br>110<br>134.5 | | 0 0 | l<br>l | 0<br>0 | 0<br>1<br>0 | 150<br>300<br>600 | | 0 1 1 | 0 | 0 | 1<br>0<br>1 | 1200<br>1800<br>2000 | | 1 1 | 0<br>0<br>1 | 0 | 0<br>1<br>0 | 2400<br>3600<br>4800 | | l<br>I | I<br>L | l<br>l | 0 | 7200<br>9600<br>19 <b>,2</b> 00 | Table 3-2. SUPER SIX Port 18 Baud Rate Settings # SECTION IV JUMPER CONNECTIONS # 4.1 JUMPER DEFINITIONS Table 4-1 presents the available jumpers and abbreviates their assigned functions. Detailed descriptions of individual jumper functions are presented following this table. To facilitate jumper insertion, each three (or more) pin jumper is depicted in an illustration contained within the narrative for that jumper. | JUMPER | FUNCTION | | | |--------|-------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | А | Generates Wait States | | | | В | Selects between on-board Tri-state and S-100 bus buffering (MWRITE) | | | | С | Selects 6MHz or 4MHz operation | | | | D | Selects 6MHz or 4MHz operation For DMA ONLY (2-3) | | | | E | Selects between the S-100 bus interrupt (INT) and the vectored interrupt zero (VIO) | | | | F | Used in conjunction with jumpers P, N, M, K, R, S, and J, this jumper area selects between vectored interrupts and the parallel I/O second port | | | | G | Used in adjusting the floppy disk controller phase line level (PLL) | | | | нат | This jumper area selects synchronous or asynchronous serial I/O | | | | J | Used in conjunction with jumpers P, N, M, K, R, S, and F, this jumper area selects between vectored interrupts and the parallel I/O second port | | | | Ј6 | Used for interrupts of the CTC to 1.5 MHz, DMA or parity error, NMI or INTRQ | | | | 37 | Used to set the hardware baud rate | | | | K | Used in conjunction with jumpers P, N, M, J, R, S, and F, this jumper area selects between vectored interrupts and the parallel I/O second port | | | | M | Used in conjunction with jumpers P, N, J, K, R, S, and F, this jumper area selects between vectored interrupts and the parallel I/O second port | | | Table 4-1. SUPER SIX Jumpers and Abbreviated Functions | JUMPER | FUNCTION | |--------|-------------------------------------------------------------------------------------------------------------------------------------------------| | N | Used in conjunction with jumpers P, M, J, K, R, S, and F, this jumper area selects between vectored interrupts and the parallel I/O second port | | P | Used in conjunction with jumpers N, M, J, K, R, S, and F, this jumper area selects between vectored interrupts and the parallel I/O second port | | R | Used in conjunction with jumpers P, N, M, J, K, S, and F, this jumper area selects between vectored interrupts and the parallel I/O second port | | R25 | Used to select the 2716 or the 2732 EPROM | | S | Used in conjunction with jumpers P, N, M, J, K, R, and F, this jumper area selects between vectored interrupts and the parallel I/O second port | Table 4-1. SUPER SIX Jumpers and Abbreviated Functions (Continued) # 4.2 JUMPER DESCRIPTIONS # 4.2.1 Jumper A This two-pin jumper must be installed when running DMA. 4.2.2. Jumper B $$\begin{bmatrix} \mathsf{B} \end{bmatrix}_2^1$$ When installed this two-pin jumper causes buffering of the MWRITE signal to be performed through the on-board tri-state buffer. When not installed, buffering is performed through the S-100 bus. In most cases this jumper is installed. 4.2.3 Jumper C | 1 | 2 | - 3 | |---|---|-----| | L | | | When installed between 1 and 2, this jumper sets the board for 6MHz operation. When installed between 2 and 3, 4MHz operation is specified. Also see jumper D, below. 4.2.4 Jumper D | <br> | | |------|--| | 1 | | | 2 | | | 3 | | When installed between 1 and 2, this jumper sets the board for 6MHz operation. When installed between 2 and 3, 4MHz operation is specified. Also see jumper C, above. For DMA Operation plug between 2-3 always. 4.2.5 Jumper E | _ | | |---|---| | | 1 | | | 2 | | | 3 | This jumper determines whether the S-100 bus interrupt (INT) or the vectored interrupt zero (VIO) is to be used. When installed between pins 1 and 2, the VIO is tied to priority interrupt DAISY CHAIN. When installed between pins 2 and 3, the priority interrupt (S-100 pin 73) is tied to the interrupt DAISY CHAIN. #### 4.2.6 Jumper G This jumper adjusts the floppy disk controller phase-locked loop (PLL) and is not installed unless adjusting the PLL. #### 4.2.7 Jumpers H and T Jumper J6 | 1 | 2 | 3 | Н | |---|---|---|---| | 1 | 2 | 3 | ۲ | This jumper area specifies that serial 1/O is to be performed synchronously or asynchronously. When installed between pins 1 and 2 of jumpers H and T, synchronous operation is selected; when installed between pins 2 and 3, asynchronous operation is selected. Pins 1 and 11 of the 14 pin J4 and J5 connectors are not factory connected. These may be used in synchronous operations to bring the external clock or ring indicator into the SIO. #### 4.2.8 This jumper is for CTC external interrupts. Pin 14 is the 1.5MHz clock; Pin 12 is INTDMA; pin 10 is PERR (parity error); pin 9 is NMI; pin 8 is INTRQ. Jumper J6 internal interrupts are 7-6, 5-4, and 3-2. ## 4.2.9 Jumper R 25 This jumper allows selection between the 2716 and 2732 EPROMs. When installed between pins 1 and 2, the 2716 EPROM is addressed; when installed between pins 2 and 3, the 2732 EPROM is addressed. 4.2.10 Jumper J7 | GND | 8 | 7 | BDo | |-----|----|---|-----| | GND | 9 | 6 | BD5 | | GND | 10 | 5 | BD4 | | GND | 11 | 4 | BD3 | | GND | 12 | 3 | BD2 | | GND | 13 | 2 | BD1 | | GND | 14 | 1 | BD0 | This jumper sets the hardware baud rate. When the jumper is inserted an inverted ground condition exists (1); when not inserted a zero (0) value is assumed. This setting must agree with the Set Baud Rate Port (port 18 - refer to subsection 3.2.21) e.g., when 7, 6, 5, and 4 are installed, 19.2K baud is read. 4.2.11 Jumpers P, N, M, K, J, R, S, and F These jumpers select between vectored interrupts or the Parallel I/O second port. When installed between pins I and 2, the vectored interrupts zero (0) to 7, as selected, are enabled and connected to Parallel I/O port B. When jumpers are installed between pins 2 and 3, Parallel I/O port B is connected to the J2 connector. # FACTORY AND OEM INSTALLED JUMPERS # 4.3.1 8-Inch Floppy Disk Drive Install jumpers as indicated below. 4.3 | JUMPER | BETWEEN PINS | FUNCTION | |--------|-----------------|---------------------------------------------| | В | | Enables the S-100 bus memory write signal | | C | 1 - 2 | Set for 6MHz operation | | D | 2-3 | Set for 4MHZ DMA | | E | 1 - 2 | Vectored Interrupt zero | | Н | 2 ~ 3 | Specifies asynchronous SIO | | Τ | 2 - 3 | Specifies asynchronous SIO | | Ј6 | 1-14:7-8 | Between 1-14 Clock/TRG3 to TO2 of the CTC | | | 1-14,7-8<br>3-2 | Between 7-8 Clock/TRG2 to TO1 of the CTC | | | | Between 2 - 3: Clock TRGI to TO0 of the CTC | | 37 | 5, 6, 7, 8 | 19.2K baud rate | | P | 2 - 3 | Selects parallel port B, Bit D0 on J2-25 | | N | 2 - 3 | Selects parallel port B, Bit DI on J2-27 | | M | 2 - 3 | Selects parallel port B, Bit D2 on J2-29 | | K | 2 - 3 | Selects parallel port B, Bit D3 on J2-31 | | J | 2 - 3 | Selects parallel port B, Bit D4 on J2-33 | | R | 2 - 3 | Selects parallel port B, Bit D5 on J2-35 | | \$ | 2 - 3 | Selects parallel port B, Bit D6 on J2-37 | | F | 2 - <b>3</b> | Selects parallel port B, Bit D7 on J2-39 | # 4.3.2 Shugart SA 800/801 Disk Drive Remove all factory installed jumpers and install as follows: ``` Jumper C Jumper T2 Jumper DS1 (Drive Select 1) Jumper DS Jumper RR Jumper 800 Jumper A Jumper В Jumper Jumper T3, T4, T5, T6, for end of cable ``` # 4.3.3 Shugart 850 Disk Drive Install the terminator at the cable end. Remove all factory installed jumpers and install as follows: Jumper 25 Jumper C Jumper A Jumper B Jumper R Jumper I Jumper Y Jumper 850 Jumper S2 Jumper IT Jumper FS Jumper RM Jumper DS Jumper S Jumper M Jumper FM, MFM Jumper DSI (for drive I) Jumper DS2 (for drive 2) #### 4.3.4 MFE Model 700 Disk Drive Install jumpers as indicated below: Jumper J3 Jumper RHL Jumper J4 Jumper L-1 Jumper J3 Jumper WP1 Jumper J1-4, J1-8 Jumper J10 Jumper J7 Jumper SSI Jumper SE2 Jumper J11, HS1 #### 4.3.5 Tandon Slim Line Disk Drive Install the terminator at the cable end. Install jumpers as indicated below: Jumper DS1 (for drive 1) Jumper DS2 (for drive 2) #### 4.3.6 NEC Model FD1160 Disk Drive Install jumpers as indicated below: Jumper C Jumper N Jumper HLS Jumper M Jumper PRI Jumper DLD Jumper FU # 4.3.7 QUME Data Track 8 Disk Drive Install and cut jumpers as indicated below: 2S, S2 Jumper DS1 (for drive 1) Jumper DS2 (for drive 2) Jumper Y Jumper C Cut X Cut Z Cut L # 4.3.8 Tandon 5.25-inch Disk Drive (48TPI) Install jumpers on the DIP shunt as indicated below: Jumper pin 7 Jumper pin 8 Jumper pin 2 (for drive 1) Jumper pin 3 (for drive 2) #### 4.3.9 Mitsubishi Model 2894 Disk Drive Install and cut jumpers as indicated below: Jumper Y Jumper E Jumper off Jumper R Jumper DS (drive select) Jumper S2 Jumper D Jumper H Jumper I # 4.3.10 Mitsubishi Model 2896 Disk Drive Install jumpers as indicated below: | Jumper | JFG | Jumper | В | |--------|-------------------|--------|-----| | Jumper | PS | Jumper | RS | | Jumper | S1 next to SE | Jumper | HUD | | Jumper | S2 | Jumper | Z | | Jumper | M1 | Jumper | WP | | Jumper | C | Jumper | HY | | Jumper | I | | | | Jumper | R | | | | Jumper | It | | | | Jumper | DS (drive select) | | | | Jumper | RFa | | | | lumner | Λ . | | | # 4.3.11 Shugart SA 860 Disk Drive Install jumpers as indicated below: Jumper DS Jumper S2 Jumper SR Jumper TR # 4.3.12 Siemens FDD-100-8 Disk Drive Install jumpers as indicated below: | Jumper RR | Jumper SS | | |-----------|-------------------------------------------|---| | Jumper U | Jumper GND | | | Jumper H | Jumper SE | | | Jumper D | Jumper Cut jumper 32 and connect jumper C | 1 | | Jumper L | Jumper E | , | | Jumper L | Jumper 2 for radial step | | | · | Jumper Cut jumper G & connect H | | | | Jumper R1 | | Note: Jumper H is normally shipped as G. Jumper 0 is set for 8 or 16 sectors. # 4.3.13 Qume Trak 592 5.25-inch Disk Drive Install jumpers as indicated below: Jumper HS Jumper DS0 #### 4.3.14 All Other Disk Drives Refer to manufacturer-supplied technical manual for specific drive. Note: The last drive at the end of the cable must be terminated. # SECTION V EXTERNAL CONNECTOR PINS # 5.1 CONNECTOR S-100 This connector interfaces SUPER SIX to the S-100 bus. Pin numbers and names are shown in Table 5-1. | PIN | NAME | PIN | NAME | PIN | NAME | |-----|-------------|-------|-------------|-------|----------| | I | +8 <b>V</b> | 25 | PSTVAL* | 58 | SXTRQ* | | 2 | +16V | 26 | PHLDA | 59 | A19 | | 3 | XRDY | 27-28 | RFU | 60 | SIXTN* | | 4 | VI0* | 29-34 | A5,4,3, | 61-64 | A20-A23 | | 5 | VII* | | 15,12,9 | 65-66 | NDEF | | 6 | VI2* | 35 | DOI/DATAI | 67 | PHANTOM* | | 7 | VI3* | 36 | DO0/DATA0 | 68 | MRWT | | 8 | V14* | 37 | A10 | 69 | RFU | | 9 | VI5* | 38 | DO4 | 70 | GND | | 10 | VI6* | 39 | DO5 | 71 | RFU | | 11 | VI7* | 40-43 | DO6,12 | 72 | RDY | | 12 | NMI* | | 13,17 | 73 | INT* | | 13 | PWRFAIL* | 44 | SMI | 74 | HOLD* | | 14 | DMA3* | 45 | SOUT | 75 | RESET* | | 15 | A18 | 46 | SINP | 76 | PSYNCH | | 16 | A17 | 47 | SMEMR | 77 | PWR* | | 17 | A16 | 48 | SHLTA | 78 | PDBIN | | 18 | SDSB* | 49 | CLOCK | 79-87 | A0-A11 | | 19 | CDSB* | 50 | GND | 88-95 | DO2-DI0 | | 20 | GND | 51 | +8V | 96 | SINTA | | 21 | NDEF | 52 | -16V | 97 | SWO* | | 22 | ADSB* | 53 | GND | 98 | ERROR* | | 23 | DODSB* | 54 | SLAVE CLR* | 99 | POC* | | 24 | 0 | 55-57 | DMA0*-DMA2* | 100 | GND | Table 5-1. S-100 Connector Pins and Pin Functions This connector interfaces the SUPER SIX to the parallel port. Pin numbers, names, and functions are shown in Table 5-2. | PIN | NAME | FUNCTION | |--------------|----------------|------------------------------------| | 1 | ARDY | PIO Channel A Ready Signal | | 2 | ARDY RET | Ground | | 3 | ASTRB* | PIO Channel A Strobe | | 4 | ASTRB RET | | | 5 | PA0 | PIO Channel A Data Bit 0 | | 6 | PAO RET | Ground | | 7<br>8 | PAI<br>PAI RET | PIO Channel A Data Bit I | | 9. | i i | Ground PIO Channel A Data Bit 2 | | 10 | PA2<br>PA2 RET | Ground | | 11 | PA3 | PIO Channel A Data Bit 3 | | 12 | PA3 RET | Ground | | 13 | PA4 | PIO Channel A Data Bit 4 | | 14 | PA4 RET | Ground | | 15 | PA5 | PIO Channel A Data Bit 5 | | 16 | PA5 RET | Ground | | 17 | PA6 | PIO Channel A Data Bit 6 | | 18 | PA6 RET | Ground | | 19 | PA7 | PIO Channel A Data Bit 7 | | 20 | PA7 RET | Ground | | 21 | BRDY | PIO Channel B Ready Signal | | 22 | BRDY RET | Ground | | 23 | BSTRB* | PIO Channel B Strobe | | 24<br>25* | BSTRB RET | Ground | | 26 | PB0<br>PB0 RET | PIO Channel B Data Bit 0 | | 25* | PBI | Ground<br>PIO Channel B Data Bit I | | 27 | PBI RET | Ground | | 29* | PB2 | PIO Channel B Data Bit 2 | | 30 | PB2 RET | Ground | | 31* | PB3 | PIO Channel B Data Bit 3 | | 32 | PB3 RET | Ground | | 33* | PB4 | PIO Channel B Data Bit 4 | | 34 | PB4 RET | Ground | | 3 <i>5</i> * | PB5 | PIO Channel B Data Bit 5 | | 36 | PB5 RET | Ground | | 37* | PB6 | PIO Channel B Data Bit 6 | | 38 | PB6 RET | Ground | | 39* | PB7 | PIO Channel B Data Bit 7 | | 40 | +5 Volts | | $<sup>\</sup>star$ - Can be jumpered to the S-100 Bus. Table 5-2. SUPER SIX J2 Connector Pin Functions This connector interfaces the SUPER SIX to the floppy disk controller. Pin numbers and functions are shown in Table 5-3. | 8 INCH DISK<br>PIN | 5.25 INCH DISK<br>PIN | FUNCTION | |--------------------|-----------------------|-------------------| | l | | Ground | | 2 | , | Alternate Head 2* | | 2<br>3 | | Ground | | 4 | | N/C | | 5 | | Ground | | 6 | | N/C | | 7 | | Ground | | 8 | | , N/C | | 9 | | Ground | | 10 | | N/C | | 11 | | Ground | | 12 | | N/C | | 13 | | Ground | | 14 | | Head 2* | | 15 | | Ground | | 16 | | N/C | | 17 | 1 | Ground | | 18 | | Head Load* | | 19 | 3 | Ground | | 20 - | 8 | Index* | | 21 | 5 | Ground | | 22 | | Ready* | | 23 | 7 | Ground | | 24 | 8 | Above Track 43* | | 25 | 9 | ground | | 26 | 10 | Drive Select 0* | | 27 | 11 | Ground | | 28 | 12 | Drive Select 1* | | 29 | 13 | Ground | | 30 | 14 | Drive Select 2* | | 31 | 15 | Ground | | 32 | 6 | Drive Select 3* | | 33 | 17 | Ground | | 34 | 18 | Direction | | 35 | 19 | Ground | | 36 | 20 | Step* | | 37 | 21 | Ground | | 38 | 22 | Write Data* | | 39 | 23 | Ground | | 40. | 24 | Write Gate* | | 41 | 25 | Ground | | 42 | . 26 | Track 0* | | 43 | 27 | Ground | | 44 | 28 | Write Protect* | | 45 | 29 | Ground | | 46 | 30 | Read Data* | | 47 | 31 | Ground | | 48 | 16 | Motor ON* | | 49 | 33 | Ground | | 50 | 34 | N/C | Table 5-3. SUPER SIX J3 Connector Pin Functions ## 5.4 CONNECTOR J4 This connector interfaces the SUPER SIX to the serial port, channel A. Pin numbers, names, and functions are shown in Table 5-4. | PIN | NAME | FUNCTION | |-------------------------------------------------------------------|--------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------| | 1<br>2<br>3<br>4<br>5<br>6<br>7<br>8<br>9<br>10<br>11<br>12<br>13 | N/C DCDA* SYNCA* RxDA CTSA* TxDA RTSA* DTRA* Tx/RxCA* GND N/C +16 Volts -16 Volts +5 Volts | Data Carrier Detect, Channel A* Sync Detect Receive data Clear To Send Transmit Data Request To Send Data Terminal Ready Transmit/receive Clock Ground | Table 5-4. SUPER SIX J4 Connector Pin Functions # 5.5 CONNECTOR J5 This connector interfaces the SUPER SIX with serial port channel B. Pin numbers, names, and functions are shown in Table 5-5. | PIN | NAME | FUNCTION | |-------------------------------------------------------------------------|--------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------| | 1<br>2<br>3<br>4<br>5<br>6<br>7<br>8<br>9<br>10<br>11<br>12<br>13<br>14 | N/C DCDA* SYNCA* RxDA CTSA* TxDA RTSA* DTRA* Tx/RxCA* GND N/C +16 Volts -16 Volts +5 Volts | Data Carrier Detect, Channel A* Sync Detect Receive data Clear To Send Transmit Data Request To Send Data Terminal Ready Transmit/receive Clock Ground | Table 5-5. SUPER SIX J5 Connector Pin Functions # APPENDIX A # Z80A/Z80B SERIAL INPUT/OUTPUT (SIO) AND DUAL ASYNCHRONOUS RECEIVER/TRANSMITTER (DART) # Z8470 Z80° DART Dual Asynchronous Receiver/Transmitter # Product Specification #### March 1981 #### Features - Two independent full-duplex channels with separate modem controls. Modem status can be monitored. - Receiver data registers are quadruply buffered; the transmitter is doubly buffered. - Interrupt features include a programmable interrupt vector, a "status affects vector" mode for fast interrupt processing, and the standard Z-80 peripheral daisy-chain interrupt structure that provides automatic interrupt vectoring with no external logic. - 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. - Programmable options include 1, 1½ or 2 stop bits; even, odd or no parity; and x1, x16, x32 and x64 clock modes. - Break generation and detection as well as parity-, overrun- and framing-error detection are available. #### 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. 280 DART Pin Functions Figure 2. Pin Assignments #### Pin Description - **B/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 Z-80 DART. - **C/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. - ML. Machine Cycle One (input from Z-80 CPU, active Low). When MI and RD are both active, the Z-80 CPU is fetching an instruction from memory; when MI is active while IORQ is active, the Z-80 DART accepts MI and IORQ. - as an interrupt acknowledge if the Z-80 DART is the highest priority device that has interrupted the Z-80 CPU. - IORQ. Input/Output Request (input from CPU, active Low). IORQ is used in conjunction with B/Ā, C/D, CE and RD to transfer commands and data between the CPU and the Z-80 DART. When CE, RD and IORQ are all active, the channel selected by B/Ā transfers data to the CPU (a read operation). When CE and IORQ are active, but RD is inactive, the channel selected by B/Ā is written to by the CPU with either data or control information as specified by C/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. - $\overline{RD}$ . Read Cycle Status. (input from CPU, active Low). If $\overline{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 hand- shake capability. 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. A more detailed explanation of Z-80 DART operation can be found in the *Z-80 SIO Technical Manual* (Document Number 03-3033-01). Because this manual was written for the Z-80 SIO, it contains information about synchronous as well as asynchronous operation. 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. 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 framing error as a new start bit: a fram from 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}}$ ). 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 and from the CPU. The Block Transfer mode can be implemented under CPU or DMA control. Figure 3. Block Diagram Functional Description (Continued) POLLING. There are no interrupts in the Polled mode. Status registers RRO 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 RR0 for each channel; the RR0 status bits serve as an acknowledge to the Poll inquiry. The two RR0 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 RRI does not have to be read in a Polling sequence because the status bits in RRI are accompanied by a Receive Character Available status in RRO. 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, D<sub>2</sub>) 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 CTS, DCD and 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 W/RDY output in conjunction with the Wait/Ready bits of Write Register 1. The W/RDY 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 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. **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 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. Dáta 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 To program the Z-80 DART, the system pro-Programming gram 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 WRO, programming the write registers requires two bytes. The first byte contains three bits (D<sub>0</sub>-D<sub>2</sub>) 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. - WRI Transmit/Receive interrupt and data transfer mode definition. - WR2 Interrupt vector (Channel B only) - WR3 Receive parameters and control - Transmit/Receive miscellaneous parameters and modes - WR5 Transmit parameters and controls Read Registers. The Z-80 DART contains three registers (RRO-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 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 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** - RR0 Transmit/Receive buffer status, interrupt status and external status - RRI Special Receive Condition status - Modified interrupt vector (Channel B only) Z-80 DART Read and Write Registers # READ REGISTER 1 D<sub>2</sub> D<sub>6</sub> D<sub>5</sub> D<sub>4</sub> D<sub>2</sub> D<sub>2</sub> D<sub>1</sub> D<sub>0</sub> L ALL SENT NOT USED PARITY ERROR RX OVERBUN ERROR FRAMING ERROR NOT USED USED USED USED USED # APPENDIX B Z80A/Z80B PARALLEL INPUT/OUTPUT (PIO) # Z8420 Z80° PIO Parallel Input/Output Controller # Product Specification #### March 1981 #### 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 a cither 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 spolling peripheral status. 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 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 200 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-chainconfiguration 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 intercupt 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 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 routing 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 $\bar{Z}$ -80 peripherals, the PIO does not enable interrupts immediately after programming, It waits until $\bar{M}\bar{I}$ 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 RD, CE, C/D and IORQ signals generate the write input internally. Figure 5. Typical Port I/O Block Diagram #### 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 D<sub>5</sub>. 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_4$ must be set. When $D_4$ 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). 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/Ā.** 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<sub>0</sub> 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 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/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<sub>1</sub> 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<sub>0</sub> 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 $\overline{\text{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 CE, RD, and IORQ are active, the port addressed by B/A transfers data to the CPU (a read operation). Conversely, when CE and IORQ are active but RD is not, the port addressed by B/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) Mi. Machine Cycle (input from CPU, active Low). This signal is used as a sync pulse to control several internal PIO operations. When both the Mi and RD signals are active, the Z-80 CPU is fetching an instruction from memory. Conversely, when both Mi and IORQ are active, the CPU is acknowledging an interrupt. In addition, Mi has two other functions within the Z-80 PIO: it synchronizes the PIO interrupt logic; when $\overline{M1}$ occurs without an active $\overline{RD}$ or $\overline{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 TwA. The PIO does not receive a specific write signal; it internally generates its own from the lack of an active 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 TwA. **Qutput 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 Figure 14. Mode 0 Output Timing 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 I 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 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 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 peripheral 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 | | | _ | Min | PIO<br>Max | Min | Morx | Min | PiO(9)<br>Max | Comment | |--------|---------------|--------------------------------------------------------------------------|--------|------------------|-------------|--------|-----------------|---------------|------------| | Number | Symbol | Parameter | (na) | (206) | (26) | (ns) | (ms) | (DS) | Comment | | 1 | TcC | Clock Cycle Time | 400 | [1] | <b>25</b> 0 | [1] | 165 | [1] | | | 2 | TwCh | Clock Width (High) | 170 | 2000 | 105 | 2000 | <b>6</b> 5 | 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 | | <del> 30</del> | | 30- | | 20 | | | 6 | TsCS(RI) | CE, B/A, C/D to RD,<br>IORQ I Setup Time | 50 | | 50 | | 50 | | [6] | | 7 | Th | Any Hold Times for Specified<br>Setup Time | 0 | | 0 | | 0 | 0 | | | 8 | TsRI(C) | RD, TORQ to Clock 1 Setup<br>Time | 115 | | 115 | | 70 | | | | 9 | - TdRI(DO) | — RD, IORQ I to Data Out Delay— | | <del> 4</del> 30 | | — 380— | | — 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) | IORO I to Data Out Delay<br>(INTACK Cycle) | 340 | | 160 | | 120 | | [3] | | 13- | - TsM1(Cr) | - Mi ↓ to Clock ↑ Setup Time- | - 210- | | 90- | | <del> 7</del> 0 | | | | 14 | TsM1(Cf) | MI to Clock Setup Time<br>(MI Cycle) | U | | 0 | | 0 | | [8] | | 15 | TdM1(IEO) | Ml 1 to IEO 1 Delay (Interrupt<br>Immediately Preceding Ml 1) | | 300 | | 190 | | 100 | (5, 7) | | 16 | TsIEI(IO) | IEI to IORQ Setup Time<br>(INTACK Cycle) | 140 | | 140 | | 100 | | [7] | | 17 | - TdIEI(IEOf) | - IEI I to IEO I Delay | | 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 1 to Clock Setup Time<br>(To Activate READY on Next | | | 200 | | 100 | | | | | | Clock Cycle) | 220 | | 200 | | 170 | | | | 20 — | - TdC(RDYr)- | Clock I to READY I Delay | - 200- | | 190- | | 170 | | CL = 50 pF | | 21 | TdC(RDYf) | Clock I to READY Delay | 150 | | 140 | | 120 | | [5] | | 22 | TwSTB | STROBE Pulse Width | 150 | | 150 | | 120 | | [4] | | 23 | TsSTB(C) | STROBE 1 to Clock 1 Setup Time (To Activate READY on | | | | | | • | | | | | Next Clock Cycle) | 220 | | 220 | | 150 | | <b>(5)</b> | | 24 — | -TdIO(PD) | <ul> <li>TORQ 1 to PORT DATA Stable -</li> <li>Delay (Mode 0)</li> </ul> | | 200 | | 180 | | 160 | [5] | | 25 | TsPD(STB) | PORT DATA to STROBE 1<br>Setup Time (Mode 1) | 260 | | 230 | | 190 | | | | 26 | TdSTB(PD) | STROBE 1 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 I<br>Delay (Mode 3) | | 540 | | 490 | | 430 | | | 29 | TdSTB(INT) | STROBE 1 to INT 1 Delay | | 490 | | 440 | | 350 | | [6] TeCS(RI) may be reduced. However, the time subtracted from TeCS(RI) will be added to TdRI(DO). [7] 2.5 TcC > (N-2)TdIEI(IEO) + TdMI(IEO) + TaIEI(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. NOTES: [1] TcC = TwCh + TwCl + TrC + TfC. [2] Increase TdRI(DO) by 10 ns for each 50 pF increase in load up to 200 pF max. [3] Increase Td(D(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. | 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 standard test conditions, unless otherwise noted. All voltages are referenced to GND (0 V). Positive current flows into the referenced pin. Available operating temperature ranges are: ■ 0° to +70°C, +4.75 $V \le V_{CC} \le +5.25 V$ ■ -40°C to +85°C, +4.75 V $\leq$ V<sub>CC</sub> $\leq$ +5.25 V ■ -55° to +125°C, +4.75 V $\leq$ V<sub>CC</sub> $\leq$ +5.5 V The product number for each operating temperature range may be found in the Ordering Information section. 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_{iHC}$ | Clock Input High Voltage | $V_{\rm CC}$ -0.6 | +5.5 | V | | | $V_{IL}$ | Input Low Voltage | -0.3 | +0.8 | v | | | $v_{iH}$ | Input High Voltage | +2.0 | +5.5 | V | | | V <sub>OL</sub> | Output Low Voltage | | +0.4 | V | $I_{OL} = 2.0 \text{ mA}$ | | V <sub>OH</sub> | Output High Voltage | +2.4 | | V | $I_{OH} = -250 \mu A$ | | I <sub>LI</sub> | 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 | μΑ | $0 < V_{IN} < V_{CC}$ | | I <sub>CC</sub> | Power Supply Current | | 100.0 | mA | $V_{OH} = 1.5V$ | | I <sub>OHD</sub> | Darlington Drive Current | -1.5 | 3.8 | mA | $R_{EXT} = 390 \Omega$ | Over specified temperature and voltage range. ## Capacitance | Symbol | Parameter | Min | Max | Unit | Test Condition | |----------|--------------------|-----|-----|------|----------------------------| | С | Clock Capacitance | | 10 | рF | Unmeasured | | $C_{IN}$ | Input Capacitance | | 5 | pF | pins returned<br>to ground | | COUT | Output Capacitance | | 10 | рF | | Over specified temperature range; $f = 1MH_Z$ ## APPENDIX C Z80A/Z80B COUNTER/TIMER CIRCUIT (CTC) ## Z8430 Z80° CTC Counter/ Timer Circuit ### Product Specification #### March 1981 #### 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. - 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. 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-80Å) 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 mutiple 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 (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{MI}}$ 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<sub>16</sub>). If the device has a pending interrupt, it raises IEO (High) for one $\overline{\text{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 (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 0 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_0$ | | |---|---------|--------|--------|--| | | 0 | 0 | 0 | | | | 1 | 0 | 1 | | | | 2 - | l | 0 | | | | 3 | 1 | l | | 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<sub>6</sub> 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). D3 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 (T2) 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 D3 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 $(T_2)$ 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 D2 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 D2 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 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 0016 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 or 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 Do 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 tor 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. **CS<sub>0</sub>-CS<sub>1</sub>.** Channel Select (inputs active High). Two-bit binary address code selects one of the four CTC channels for an I/O write or read (usually connected to $A_0$ and $A_1$ ). **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-∞0 CPU is not servicing an interrupt from an 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 inactive. 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. Mi. Machine Cycle One (input from CPU, active Low). When MI and 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 (INT). **RD.** Read Cycle Status (input, active Low). Used in conjunction with IORQ and 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. #### 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 were written to the CTC during the programming 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{M}$ 1 and $\overline{IORQ}$ ). All channels are inhibited from changing their interrupt request status when $\overline{M}$ 1 is active—about two clock cycles earlier than $\overline{IORQ}$ . $\overline{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{IORQ}$ goes Low. Two wait states ( $T_{WA}$ ) 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 $ED_{16}$ is decoded. If the following opcode is $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 #### 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{RD}$ , $\overline{IORQ}$ , and $\overline{CE}$ . A 2-bit binary code at inputs $\overline{CS_1}$ and $\overline{CS_0}$ selects the channel to be read. $\overline{M1}$ 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{\rm RD})$ input is High during $T_1$ . During $T_2$ $\overline{\rm IORQ}$ and $\overline{\rm CE}$ inputs are Low. $\overline{\rm MI}$ must be High to distinguish a write cycle from an interrupt acknowledge. A 2-bit binary code at inputs CS1 and CS0 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 TwA. No additional wait states are allowed. 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. Th∋ 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. # APPENDIX D Z80A/Z80B CENTRAL PROCESSING UNIT (CPU) ## Z8400 Z80°CPU Central Processing Unit ## Product Specification #### March 1981 #### 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 cleaks 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 #### General Description 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 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-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. #### 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 I provides further information on these registers. Figure 4. CPU Registers | Z80 CPU | Reg | gister | Size (Bits) | Remarks | |--------------------------|------------------------------------|--------------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------| | Registers<br>(Continued) | A, A' | Accumulator | 8 | Stores an operand or the results of an operation. | | Continued) | F, F | Flage | 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 | Stores addresses or data temporarily. See Push or Pop in instruction set. | | | PC | Program Counter | 16 | Holds address of next instruction. | | | IFF <sub>1</sub> -IFF <sub>2</sub> | Interrupt Enable | Flip-Flops | Set or reset to indicate interrupt status (see Figure 4). | | | IMFa-IMFb | Interrupt Mode | Flip-Flops | Reflect Interrupt mode (see Figure 4). | #### Table 1. 280 CPU Registers #### 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 since it requires that interrupts be enabled in software in order to operate. Either $\overline{\text{NMI}}$ or $\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. - 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 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 routine. Maskable Interrupt (INT). Regardless of the interrupt mode set by the user, the Z80 response to a maskable interrupt input follows a common timing cycle. After the interrupt has been detected by the CPU (provided that interrupts are enabled and BUSREQ is not active) a special interrupt processing cycle begins. This is a special fetch (MI) cycle in which $\overline{\text{IORQ}}$ becomes active rather than $\overline{\text{IMREQ}}$ , as in a normal MI cycle. In addition, this special MI cycle is automatically extended by two 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, which is then acted on six times by the CPU. This is normally a Restart Instruction, which will initiate an unconditional jump 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 $\overline{\text{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 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 address vector on the data bus during the interrupt acknowledge cycle. The high-order byte of the interrupt service routine address is supplied by the I (Interrupt) register. This flexibility in selecting the interrupt service routine address allows the peripheral device to use several different types of service routines. These routines may be located at any available location in memory. Since the interrupting device supplies the low-order byte of the 2-byte vector, bit 0 (A<sub>0</sub>) must be a zero. Interrupt Priority (Daisy Chaining and Mested 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 hardwared 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 <sub>1</sub> | IFF <sub>1</sub> - IFF <sub>2</sub><br>(Maskable interrupt 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 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 - ☐ 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 | 8 | z | | Flag<br>H | | P/V | M | c | Opcode<br>78 543 210 | Hex | | No.of M<br>Cycles | | | Comments | - | |---|----------------------------------------|----------------------------------|-----|-----|-------------|-----------|-------------|-----|---|--------------|--------------------------------------------|----------|--------------|-------------------|--------------|--------------------------|------------------|---| | P | LD r, r'<br>LD r, n | r - r'<br>r - n | • | • | X | | X | • | ^ | 0 | 01 r r'<br>00 r 110 | | 1 2 | 1 2 | 4 7 | 000<br>000 | | | | | LD r, (HL)<br>LD r, (IX+d) | r - (HL)<br>r - (IX + d) | | • | X<br>X | • | X<br>X | 8 | • | 0 | 01 r 110<br>11 011 101<br>01 r 101 | DD | ì<br>3 | 5 | 7<br>19 | 010<br>011<br>100<br>101 | D<br>E<br>H<br>L | | | | LD r, $(IY + d)$ | r - (IY + d) | • | ۰ | X | • | х | | • | 0 | 11 111 101<br>01 r 110 | FD | 3 | 5 | 19 | 111 | | | | | LD (HL), r<br>LD (IX+d), r | (HL) - r $(IX + d) - r$ | . • | • | X | | X | | | • | 01 110 r<br>11 011 101<br>01 110 r | DD | 3 | <b>2</b><br>5 | 7<br>19 | | | | | | LD (IY + d), r | (IY+d)-r | • | ٠ | X | • | X | ٠ | • | ٠ | - d -<br>11 111 101<br>01 110 r<br>- d - | FD | 3 | 5 | 19 | | | | | | LD (HL), n | (HL) - n | • | . • | X | • | X | • | • | 0 | 00 110 110 | 36 | 2 . | 3 | 10 | | | | | | LD (IX + d), n | (IX + d) - n | | .• | x | Ŷ | X | ٠ | • | ۰ | - n -<br>11 011 101<br>00 110 110<br>- d - | | 4 | 5 | 19 | | | | | | LD (IY+d), n | (IY + d) - n | ٥ | • | X | • | X | đ | • | • <b>a</b> , | - n -<br>11 111 101<br>00 110 110<br>- d - | | .4 . | S | 19 | | | | | | LD A, (BC)<br>LD A, (DE)<br>LD A, (nn) | A ~ (BC)<br>A ~ (DE)<br>A ~ (nn) | | | X<br>X<br>X | • | X<br>X<br>X | 9 | | | 00 001 010<br>00 011 010<br>00 111 010 | 1A | 1<br>1<br>3. | 2<br>2<br>4 | 7<br>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 | | | o<br>o, | 00 000 010<br>00 010 010<br>00 110 010 | 12 | 1<br>1<br>3 | 2<br>2<br>4 | 7<br>7<br>13 | | | | | | LD A, I | A - 1 | | 1 | x | 0 | X | IFF | 0 | | - n -<br>11 101 101<br>01 010 111 | ED<br>57 | . 2 | 2 | 9 | | | | | | LD A, R | A - R | . 1 | | X | 0 | X | IFF | 0 | • | 11 101 101 | ED<br>5F | 2 | 2 | 9 | | | | | | LD I, A | I-A | . • | ۵ | X | 0 | X | | ٠ | • | 11 101-101<br>01 000 111 | ED | 2 | 2 | 9 | | | | | 2 | LD R. A. | R - A | • | ۵ | X | ٠ | X | n | ٠ | n | 11 101 101<br>01 001 111 | ED | 2 | 2 | 9 | | | | OTES: r, r' means any of the registers A, B, C, D, E, H, L. IFF the content of the interrupt enable (lip-flop, (IFF) is copied into the P-V flag. For an explanation of flag notation and symbols for mnemonic tables, see Symbolic Notation section | 6-Bit Load | Mnomonic | Symbolic<br>Operation | | B : | z | 7 | Tage<br>L | P/¥ | M | С | Орсоdе<br>78 843 210 Вех | No.of<br>Bytes | He of M<br>Cycles | No.of T<br>States | | Comments | <u> </u> | |---------------------------|------------------------|-------------------------------------------------------------------|----------------|------|-------|--------|-----------|------------|--------|-------|--------------------------------|----------------|-------------------|-------------------|-----------------|-----------------------------------------------------------------|----------| | iroup | LD dd, nn | dd - nn | , | , , | , X | • | X | • | • | ٠ | 00 dd0 00i | 3 | 3 | ιo | <u>dd</u><br>00 | Pair<br>BC | | | | | | - " | | | | | | | | - n - | | | | 01 | DE<br>HL | | | | LD IX, nn | IX - nn | • | | • Х | | X | • | • | ٠ | 11 011 101 DD<br>00 100 001 21 | 4 | • | 14 | 11 | SP | | | | | | | | | | | | | | - n -<br>- n - | | | | | | | | ŧ | LD IY, nn | IY — nn | • | • | - X | | X | • | • | | 11 111 10f FD<br>00 100 001 21 | 4 | . 4 | 14 | | | | | | | | | | | | | | | | - n - | | | | | | | | | LD HL, (nn) | H - (nn+1) | • | | | ( • | X | ٠ | • | • | 00 101 010 2A | 3 | 5 | 16 | | | | | | | L - (nn) | | | | _ | | | | | - n -<br>- n - | | | | | | | | | LD dd. (nn) | ddµ (nn + 1) | • | • | • } | ( " | X | • | • | • | 01 ddi 011 ED | 4 | , 6 | 20 | | | | | | | - | | | | | | | | | - n - | | | | | | | | | LD IX, (nn) | $\begin{array}{l} IX_{H} - (nn+1) \\ IX_{L} - (nn) \end{array}$ | | • | • . X | , | Х | • | 6 | • | 11 011 101 DD<br>00 101 010 2Ā | 4 | . 6 | 20 | | | | | | | rw[ - (m) | | 1 | | | | | | | - n - | | | | | | | | | LD IY, (nn) | 17 <sub>H</sub> - (nn+1) | ٠ | • | - ) | ( - | X | • | • | • | 11 111 101 FD | 4 | 6 | 20 | | | | | | | IYL — (nn) | | | | | | | | | 00 101 010 2A | | | | | | | | | LD (nn), HL | (nn + 1) - H | 4 | | . y | ( ^ | × x | •, | | | 00 100 010 22 | 3 | 5 | 16 | | | | | | | (nn) - L | | | | | | | | | - n - | | | | | en e | | | | LD (nn), dd | (nn+1) - ddy | | 6 | n ) | ( - | X | ٠ | • | • | 11 101 101 ED<br>01 dd0 011 | 4 | 6 | 20 | | 1. 1. 1. | | | | | (nn) - ddL | | | | | | | | | - n - | | | | | | | | • | LD (nn), IX | (nn+1) - 1XH | | ٠. | ۰ ) | ( • | х | • | | | - n<br>11 011 101 DD | 4 | 6 | 20 | | | | | | • | (nn) – IXL | | | | | | | | | 00 100 010 22 | | | | | | | | | LD (nn), IY | (nn+1) - IYH | | | . ) | , | . v | | | | - n -<br>11 111 101 FD | 4 | | 20 | | | | | | LL (1111), 11 | (nn) - IYL | - | | • | | ^ | | | | 00 100 010 22 | • | Ü | | | | | | | | | | | | | | | | | - n | | | | | | | | | LD SP, HL<br>LD SP, IX | SP - HL<br>SP - IX | | • | • ) | ( 4 | X | | • | • | 11 111 001 F9<br>11 011 101 DD | 2 | 1<br>2 | 10 | | | | | | LD SP, IY | SP - IY | | | • 1 | κ . | . x | • | 4 | • | 11 111 001 F9<br>11 111 101 FD | 2 | 2 | 10 | | | | | | PUSH qq | (SP - 2) - qqL | | | . ) | | - | | ٠. | ٠ | 11 111 001 F9<br>11 qq0 101 | 1 | 3 | 11 | 99. | Pair<br>BC | | | | r opudd | (SP - 1) - qqH | | • | . ' | | ^ | - | | | .1 990 101 | | | ** | 01 | DE | | | | PUSH IX | SP - SP - 2<br>(SP - 2) - IX <sub>L</sub> | | e | • ) | κ . | × | • | • | • | 11 011 101 DD | 2 | 4 | 15 | 10<br>11 | HL<br>AF | | | | • | (SP-1) - IXH<br>SP - SP - 2 | | , | | | | | | | 11 100 101 ES | | | | | | | | | PUSH IY | (SP-2) - IYL<br>(SP-1) - IYH | | • | • ) | ( , | X | • | ٠ | • . | 11 111 101 FD<br>11 100 101 E5 | 2 | 4 | 15 | | | | | | POP qq | SP - SP - 2 | | | . , | | × | | | | 11 qq0 001 | 1 | 3 | 10 | | | | | | ror qq | qqH - (SP+1) | | - | | • . | · ^ | | | | 11 440 001 | 1 | , | 10 | | | | | | POP IX | SP - SP +2<br>IXH - (SP+1) | | • | , ) | ( , | , X | ٠ | • | | 11 011 101 DD | 2 | 4 | 14 | | | | | | | $IX_L - (SP)$<br>SP - SP + 2 | | | | | | | | | 11 100 001 E1 | | | ٠, | ٠. ' | st in a | | | | POP IY | $IY_{H} \leftarrow (SP + 1)$ | | • | • ) | • | · X | ٠. | ď | • | 11 111 101 FD<br>11 100 001 E1 | 2 | 4 | 14 | | | | | | | IY <sub>L</sub> - (SP)<br>SP - SP + 2 | | | | | | | | | | | | | | <u> </u> | | | | NOTES: dd m ar | ny of the register pairs | BC, DE | . HL | , SP. | | | , | | | | | | | | | ٠. | | | (PAIR) | H. (PAIR) L refer to his<br>BCL = C. AFH = A | gh order | and | low o | rder e | eight i | oits of | ipo te | guter | pair respectively. | | | | | | | | | | N-40 | | | | - | | | | | | | <del></del> | | · | | | | Exchange, | EX DE, HL | DE - HL | | • | 9 | X | • 1 | K • | , • | 0 | 11 101 011 EB | 1 | 1. | 4 | | | | | Block | EX AF, AF<br>EXX | AF - AF<br>BC - BC | | 6 | | X | • | Κ • | | • | 00 001-000 08<br>11 011 001 D9 | 1 | 1 | 4 | | jister bank and | | | Transfer.<br>Block Search | | HL HL' | | ÷ ., | | | | | | | | | | | | uxiliary regilifer<br>eank exchange | | | | EX (SP), HL | H (SP+1)<br>L (SP) | | • | • | Х. | •. , | х • | | • | 11 100 011 E3 | 1. | 5 | . 19 | | | | | irane. | EX (SP), IX | IXH - (SP+1)<br>IXL - (SP) | | • | • . | X | • | х • | Ô | ٥ | 11 011 101 DE | | 6 | 23 | | | | | iroups | EX (SP), IY | [[U - (SF + I) | | • | | X | | x - | • | | 11 100 011 E3 | 2 | 6 | 23 | | | | | iroups. | E | IYL - (SP) | | | - 1 | 4 | | Œ | ) " | | 11 100 011 E3 | | | | | | | | eroups. | : | | | | | X | 0 | X i | . 0 | 1.00 | 11 101 101 ED<br>10 100 000 A0 | | 4 | 16 | | id (HL) into | | | Groups | LDI | (DE) - (HL) | | • | | | | | | | TO TOO DOD NO | | | | | | | | Groups | : | (DE) - (HL)<br>DE - DE + 1<br>HL - HL + 1 | | • | • | | | | | | | | | | . 1 | DE), increment<br>he pointers and | | | Groups | LDI | (DE) - (HL)<br>DE - DE+1<br>HL - HL+1<br>BC - BC-1 | . <del>.</del> | | | | | | | | | | | | | he pointers and<br>lecrement the byte<br>counter (BC) | | | Groups | : | (DE) - (HL)<br>DE - DE+1<br>HL - HL+1<br>BC - BC-1<br>(DE) - (HL) | . <del>-</del> | | • | x | 0 | <b>x</b> o | 0 | | 11 101 101 ED<br>10 110 000 B0 | . 2 | 5<br>4 | 21<br>16 | 14 J | he pointers and<br>lecrement the byte<br>counter (BC)<br>3C ≠ 0 | | | Groups | LDI | (DE) - (HL)<br>DE - DE+1<br>HL - HL+1<br>BC - BC-1 | , <b>.</b> | | • | x | o : | <b>x</b> o | 0 | | 11 101 101 ED | . 2 | | | 14 J | he pointers and<br>lecrement the byte<br>counter (BC) | | | ixchange. | Maemonic | Symb | olic<br>rtion | 8 | 2 | | Flage<br>K | P/W | M | C | Opcod<br>78 543 2 | | | No.of<br>Cycle | M No.e | | Comments | | |---------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------|---------------------------------------|-----------------------------------------|-----------------------------------------------------|---------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------|-----------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|----------------|--------------------------------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------| | ransier, | | | | | | | | 0 | | | | | | 11. | | | | | | lock Search | LDD | (DE) ~ (HL | ) | • | | X | о х | | 0 | • | 11 101 | 101 ED | 2 | 4 | 1 | 6 | | | | | | DE - DE - | 1 | | | | | | | | 10 101 | 8A 000 | | | | | | | | roups | 1 7 | HL ~ HL ~<br>BC ~ BC ~ | 1 | | | | | | | | | | | | | • | | | | Continued) | | | | | | | | | | | | | | | | | | | | | LDDR | (DE) - (HL | ) | | • | X | 0 > | ( 0 | 0 | • | 11 101 | 101 ED<br>000 B8 | 2 | 5 | | 6 | If BC ≠ 0<br>If BC = 0 | | | | | DE - DE -<br>HL - HL - | 1 | | ν. | | | | | | 10 111 | 000 00 | - | • | | • | 20 - 0 | | | | | BC - BC - | 1 | | | | | | | | | | | | | | | | | | | Repeat until | | | | | | | | | | | | | | | | | | | | DC ~ 0 | | | ②. | | | 0 | | | | | | | | | | | | | CPI | A - (HL) | | 1 | t | X | 1 ) | X I | 1 | • | 11 101 | 101 ED | 2 | 4 | . ! | 6 | | | | | | HL - HL+<br>BC - BC- | .1 | | | | | | | | 10 100 | OUI AI | | | | | | | | | | | • | | 2 | | | ① | | | | | | | | | | | | | CPIR | A - (HL) | | t | t | X | 1 2 | χı | 1 | • | 11 101 | 101 EC | 2 | 5 | | 21 | If BC ≠ 0 and<br>A ≠ (HL) | | | 4.7 | | HL - HL+ | 1 | | | | | | | | 10 110 | 001 B1 | 2 | 4 | | 16 | If BC = 0 or | | | | | BC - BC- | - <b>l</b> | | | | | | | | | | | . , | | | A = (HL) | | | | | Repeat unti | 1 | | | | | | | | | | | | | | | | | | | A = (HL) c $BC = 0$ | л | | _ | | | _ | | | | | | | | | | | | | | | | | 2 | | | . 0 | | | | | | | | | | | | · · · · · · · · · · · · · · · · · · · | CPD | A - (HL) | | 1 | 1 | X | 1 | X 1 | . 1 | • | 11 101 | 101 EI | 2 | . 4 | | 16 | | | | | | HL - HL-<br>BC - BC | - 1 | | _ | | | _ | | | 10 101 | 001 M | • | | | | | | | | | | - | | 2 | | | (1 | | | | | | | | | W.D.O. | | | | CPDR | A ~ (HL) | | t | 1 | X | t | ΧÌ | 1 | • | 11 101 | 101 E | 2 | 5 | | 21 | If BC ≠ 0 and<br>A ≠ (HL) | | | e kaling in the first | 4 | HL - HL | - 1 | | | | | | | | 10 111 | 001 B | 9 2 | 4 | | 16 | If BC = 0 or | | | | | BC - BC | | | | | | | | | | | | | | | A = (HL) | | | | | Repeat unt | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | NOTES: ① P/V | A = (HL) $BC = 0$ flag in 0 if the g in 1 if $A = 0$ | result of B | | | arwis | e P/V | # J. | | | | | | | | | | | | | ② 2 fla | BC = 0 flag in 0 if the grant 1 if $A = (1 + 1)$ | result of B | wise Z | : O. | х | 1 | x v | | 1 | 10 000 | | 1 | | 1 | 4 7 | r Reg. | | | Ārithmetic | ② Z fla | BC = 0<br>flag is 0 if the s<br>g is 1 if A = () | result of B | wise Z | · 0. | | 1 | - | | | 10 <b>000</b> | 110 | 1 2 | | 1<br>2 | 4 7 | r Reg. | | | Arithmetic<br>and Logical | ADD A, r | BC = 0 flag is 0 if the r g is 1 if $A = (1$ $A \leftarrow A + 1$ | result of B<br>HL), other | wise Z | i<br>1 | x<br>x | 1 : | x v<br>x v | 0 | 1. | 10 000<br>11 000<br>- n | 110 | Ż | | 2 | 7 | 000 B<br>001 C<br>010 D | | | Arithmetic<br>and Logical | ADD A, r ADD A, n ADD A, (HL) | BC = 0 flag is 0 if the s g is 1 if A = (i A - A + i A - A + i | result of B<br>HL), other<br>n | wise Z : | 1<br>1 | x<br>x | i i | x v<br>x v | 0 | 1. | 10 000<br>11 000<br>- n | 110 | i i | r | 2 | 7 | 000 B<br>001 C<br>010 D<br>011 E | | | Arithmetic<br>and Logical | ADD A, r | BC = 0 flag is 0 if the s g is 1 if A = (i A - A + i A - A + i | result of B<br>HL), other<br>n | wise Z : | i<br>1 | x<br>x | i i | x v<br>x v | 0 | 1, | 10 000<br>11 000<br>- n<br>10 000<br>11 011 | 1110<br><br>1110<br>101 1 | Ż | r | 2 | 7 | 000 B<br>001 C<br>010 D<br>011 E<br>100 H | | | Arithmetic<br>and Logical | ADD A, r ADD A, n ADD A, (HL) | BC = 0 flag is 0 if the s g is 1 if A = (i A - A + i A - A + i | result of B<br>HL), other<br>n | wise Z : | 1<br>1 | x<br>x | i i | x v<br>x v | 0 | 1. | 10 000<br>31 000<br>- n<br>10 000<br>11 011<br>10 000 | 1110<br><br>1110<br>101 1 | i i | r | 2 | 7 | 000 B<br>001 C<br>010 D<br>011 E<br>100 H<br>101 L | | | Arithmetic<br>and Logical | ADD A, r ADD A, n ADD A, (HL) ADD A, (IX+c | BC = 0 flag is 0 if the is $g$ is 1 if $A = (1 + 1)$ $A - A + 1$ $A - A + 1$ $A - A + 1$ | result of B<br>HL), other<br>n<br>(HL)<br>(IX + d) | t t | i t | x<br>x<br>x | i i | x v<br>x v<br>x v | 0 | 1 . 1 . 1 | 10 000<br>11 000<br>- n<br>10 000<br>11 011<br>10 000<br>- d | 1110<br><br>1110<br>101 1<br>1110 | i i | | 2 | 7 | 000 B<br>001 C<br>010 D<br>011 E<br>100 H | | | Arithmetic<br>and Logical | ADD A, r ADD A, n ADD A, (HL) | BC = 0 flag is 0 if the is $g$ is 1 if $A = (1 + 1)$ $A - A + 1$ $A - A + 1$ $A - A + 1$ | result of B<br>HL), other<br>n<br>(HL)<br>(IX + d) | wise Z : | i t | x<br>x<br>x | i i | x v<br>x v<br>x v | 0 0 0 | 1 . 1 . 1 | 10 000<br>31 000<br>- n<br>10 000<br>11 011<br>10 000 | 110<br>101<br>101<br>1110 | i<br>OD 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 | | | Arithmetic<br>and Logical | ADD A, r ADD A, n ADD A, (HL) ADD A, (IX+c | BC = 0 flag in 0 if the ing in 1 if A = (1) A = A + in i | result of B<br>HL), other<br>n<br>(HL)<br>(IX + d) | t t | i t | x<br>x<br>x | i i | x v<br>x v<br>x v | 0 0 0 | 1 . 1 . 1 | 10 0000 11 0000 - n 10 0000 11 011 10 0000 - d 11 111 10 00000 - d | 1110<br>101<br>101<br>1110<br>101 | i<br>OD 3 | | 2<br>2<br>5 | 7<br>7<br>19 | 000 B<br>001 C<br>010 D<br>071 E<br>100 H<br>101 L | | | Arithmetic<br>and Logical | ADD A, r ADD A, n ADD A, (HL) ADD A, (IX+c | BC = 0 flag in 0 if the in g in 1 if $A = (1)$ $A - A + i$ | result of B<br>HL), other<br>n<br>(HL)<br>(IX + d) | t t | i t | x<br>x<br>x<br>x | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | x v v x v x v x v | 0 0 0 | 1 | 10 0000 11 0000 n 10 0000 11 011 10 0000 d 11 111 10 0000 d | 110<br>101<br>101<br>110<br>101<br>101 | i<br>OD 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<br>111 A | | | Arithmetic<br>and Logical | ADD A, r ADD A, n ADD A, (HL) ADD A, (IX+c | BC = 0 flag in 0 if the ing in 1 if A = (1) A = A + in i | result of B<br>HL), other<br>n<br>(HL)<br>(IX + d) | t t | i t | x<br>x<br>x | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | x v<br>x v<br>x v | 0 0 0 | 1 . 1 . 1 | 10 0000 11 0000 11 011 10 0000 11 011 10 0000 11 010 10 0000 10 0000 10 0000 10 0000 10 0000 | 110<br>101<br>101<br>110<br>101<br>110 | i<br>OD 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 | | | Arithmetic<br>and Logical | ADD A, r ADD A, n ADD A, (HL) ADD A, (IX+c ADD A, (IY+c | BC = 0 flag in 0 if the in g in 1 if $A = (1)$ $A - A + i$ | result of B<br>HL), other<br>n<br>(HL)<br>(IX+d)<br>+CY | t t | i t | x<br>x<br>x<br>x | 1 f t | x v v x v x v x v | 0 0 0 | 1 | 10 0000 11 0000 n 10 0000 11 011 10 0000 d 11 111 10 0000 d | 110<br>101<br>101<br>110<br>101<br>110 | i<br>OD 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 instructive | on. | | Arithmetic<br>and Logical | ADD A, r ADD A, n ADD A, (HL) ADD A, (IX+c ADD A, (IY+c ADC A, s SUB s | BC = 0 flag in 0 if the in g in 1 if A = (1) A - A + in - A + in A - A - A - A - A - A - A - A - A - A | result of B HL), other (HL) (IX + d) +CY | t t | i t | x<br>x<br>x<br>x | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | x v x v x v x v x v | 0 0 0 | 1 | 10 0000 11 0000 11 011 10 0000 11 011 10 0000 11 010 10 0000 10 0000 10 0000 10 0000 10 0000 | 110<br>101 1<br>1110 | i<br>OD 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 instructs The indicated bit | 1 | | Arithmetic<br>and Logical | ADD A, r ADD A, n ADD A, (HL) ADD A, (IX+c ADD A, (IY+c ADD A, SUB a SBC A, a | BC = 0 flag in 0 if the in g in 1 if A = (i) $A - A + i$ $A - A + i$ $A - A + i$ $A - A + i$ $A - A - A + i$ $A - A - A - A + i$ $A - A - A - A - A - A - A - A - A - A -$ | result of B HL), other (HL) (IX + d) (IY + d) + CY - CY | t t | i t | x x x x x x x x | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | x v x v x v x v x v x v x v x v x v x v | 0 0 0 | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | 10 0000 11 0000 11 011 10 0000 11 011 10 0000 11 010 10 0000 10 010 10 0000 10 010 | 110<br>101<br>101<br>110<br>101<br>110 | i<br>OD 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 \$2000. | in | | Arithmetic<br>and Logical | ADD A, r ADD A, (HL) ADD A, (IX+c ADD A, (IY+c ADD A, a SUB a SBC A, a AND a | BC = 0 Hag in 0 if the in g in 1 if A = (i) A - A + i A - A + i ) A - A + i ) A - A + i A - A - A + i A - A - A - A - A - A - A - A - A - A | result of B HL), other (HL) (IX+d) (IY+d) +CY -CY - | t t | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | x<br>x<br>x<br>x | 1 | X | 0 0 0 0 1 1 0 0 | 1 t t t t t t t t t t t t t t t t t t t | 10 0000 11 0000 10 0000 11 011 10 0000 11 011 10 0000 10 001 10 0000 10 001 10 0000 10 001 | 110<br>101<br>101<br>110<br>101<br>110 | i<br>OD 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 instructs The indicated bit | in | | Arithmetic<br>and Logical | ADD A, (HL), ADD A, (IX+c ADD A, (IY+c ADD A, a SBC A, a AND s OR a | BC = 0 flag in 0 if the in g in 1 if A = (i) A - A + i A - A + i A - A + i A - A - a A - A - a A - A - A A - A - A | result of B HL), other (HL) (IX+d) (IY+d) +CY -CY - | t t | 1 t 1 t 1 t 1 t 1 t 1 t 1 t 1 t 1 t 1 t | x<br>x<br>x<br>x<br>x<br>x | 1 | X | 0 0 0 1 1 0 0 0 | 1 t t t t t t t t t t t t t t t t t t t | 10 0000 11 0000 10 0000 10 10000 11 011 10 0000 11 111 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 10 0000 | 110<br>101<br>101<br>110<br>101<br>110<br>110 | i<br>OD 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 \$2000. | in | | Arithmetic<br>and Logical | ADD A, r ADD A, n ADD A, (IX+c ADD A, (IX+c ADD A, (IY+c ADC A, s SUB s SBC A, a AND s OR s XOR s CP s | BC = 0 flag in 0 if the in g in 1 if A = (1) A - A + i A - A + i A - A + i A - A + i A - A - i A - A - a A - A - a A - A - a A - A - a A - A - a A - A - a | result of B HL), other (HL) (IX + d) (IY + d) + CY - CY - R | t t | 1 t 1 t 1 t 1 t 1 t 1 t 1 t 1 t 1 t 1 t | x x x x x x x x x x x x x x x x x x x | 1 | X V V X V X V X V X V X V X V X V X V X | 0 0 0 0 1 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | t t t t t t t t t t t t t t t t t t t | 10 0000 11 0000 10 0000 11 011 10 0000 - d 10 11 111 10 0000 - d 0000 0010 0010 10000 | 1110<br>101 1<br>1110<br>101 1<br>1110 | i<br>OD 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 \$2000. | in | | Arithmetic<br>and Logical | ADD A, r ADD A, n ADD A, (HL) ADD A, (IX+c ADD A, (IY+c ADD A, a SUB a SBC A, a AND s OR a CP a INC r | BC = 0 Hag in 0 if the in g in 1 if A = (1) A - A + in A - A + in A - A + in A - A + in A - A + in A - A - A - A - A - A - A - A - A - A | result of B HL), other (HL) (IX+d) (IY+d) -CY -CY | t t | 1 | x x x x x x x x x x x x x x x x x x x | 1 | X V V X V X V X X V X X V X X V X X V X X X X X X X X X X X X X X X X X X X X | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | 1 | 10 0000 11 0000 10 0000 11 011 10 0000 - d 10 111 10 0000 - d 0000 0000 0000 0000 0000 0000 | 110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 1110 111 | DD 3 | 1 | 2<br>2<br>5<br>5 | 7 19 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 \$2000. | in | | Arithmetic<br>and Logical | ADD A, r ADD A, (HL) ADD A, (IX+c ADD A, (IY+c ADD A, a SUB a SBC A, a AND s OR a XOR a CP a INC r INC (HL) | BC = 0 flag in 0 if the in g in 1 if A = (1) A - A + i A - A + i A - A + i A - A + i A - A - i A - A - a A - A - a A - A - a A - A - a A - A - a A - A - a | (HL), other (HL), other (HL) = (HIX+d) (YY+d) = (YY+d) (Y+d) = (YY+d) | t t | 1 t 1 t 1 t 1 t 1 t 1 t 1 t 1 t 1 t 1 t | x x x x x x x x x x x x x x x x x x x | 1 | X V V X V X V X X V X X V X X V X X V X X X X X X X X X X X X X X X X X X X X | 0 0 0 0 1 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | 1 t t t t t t t t t t t t t t t t t t t | 10 0000 11 0000 11 011 10 0000 11 011 10 0000 10 011 10 0000 10 011 10 0000 11 011 10 0000 10 011 10 0000 11 011 10 0000 11 011 10 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 00000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 0000 11 00 | 110<br>101<br>1110<br>101<br>1110<br>101<br>1110 | DD 3 | 1 | 2 5 5 5 | 7 19 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 \$2000. | in | | Arithmetic<br>and Logical | ADD A, r ADD A, n ADD A, (HL) ADD A, (IX+c ADD A, (IY+c ADD A, a SUB a SBC A, a AND s OR a CP a INC r | BC = 0 Hag in 0 if the in g in 1 if A = (i) A - A + + + + + + + + + + + + + + + + + | result of B HL), other I HL), other I HL) I (IY+d) CY R R | t t | 1 | x x x x x x x x x x x x x x x x x x x | 1 | X V V X V V X V V X V V X V V X V V X V V X V V X X V V X X V V X X V V X X V V X X V V X X V V X X V V X X V V X X V V X X V V X X V V X X V V X X V X X V X X X X X X X X X X X X X X X X X X X X | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | 1 t t t t t t t t t t t t t t t t t t t | 10 0000 11 0000 11 011 10 0000 11 111 10 0000 10 011 10 0000 10 011 10 0000 11 111 10 0000 10 011 11 011 00 011 11 011 00 110 11 011 00 110 | 110 101 110 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 1101 | DD 3 | | 2 2 5 5 5 5 1 3 3 | 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 instructive. The indicated bit replace the 0000 | in | | 8-Bit<br>Arithmetic<br>and Logical<br>Group | ADD A, r ADD A, (HL) ADD A, (IX+c ADD A, (IY+c ADD A, (IY+c ADD A, a SUB a SBC A, a AND a OR a XOR a CP a INC r INC (HL) INC (IX+d) | BC = 0 Hag in 0 if the ing in 1 if A = (i) A - A + i A - A + i A - A + i A - A + i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i | (IHL), other (IHL), other (IHL), other (IHL) (IY+d) -CY -CY -A A | t t t t t t t t t t t t t t t t t t t | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | х<br>х<br>х<br>х<br>х<br>х<br>х<br>х<br>х<br>х | 1 | X V V X V V X X V V X X V V X X Y V X X X Y V X X X Y Y X X X X | 0 0 0 0 1 1 1 0 0 0 0 7 1 0 7 0 0 7 0 | 1 t t t t t t t t t t t t t t t t t t t | 10 0000 11 0000 11 0000 11 011 10 0000 11 011 10 0000 11 011 10 0000 10 000 11 011 00 0 110 00 110 00 110 00 110 00 110 00 110 00 110 00 110 00 110 00 110 00 110 00 110 00 110 00 110 00 110 00 110 00 110 00 110 00 110 00 110 00 110 00 110 00 110 00 110 00 110 00 110 00 110 00 110 00 110 00 110 00 110 | 110 | DD S | 3 | 2<br>2<br>5<br>5<br>5<br>1<br>3<br>6 | 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 instructive. The indicated bit replace the 0000 | in | | Arithmetic<br>and Logical | ADD A, r ADD A, n ADD A, (IX+c ADD A, (IX+c ADD A, (IY+c ADD A, (IY+c ADD A, (IY+c ADD A, a SUB a SBC A, a AND a OR a XOR a CP a INC (IX+d) INC (IX+d) | BC = 0 Hag in 0 if the in g in 1 if A = (i) A - A + i A - A + i A - A + i A - A + i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i | (HL) other (HL) (IX+d) (YY+d) (YY+d) (YY+d) | t t | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | х<br>х<br>х<br>х<br>х<br>х<br>х<br>х<br>х<br>х | 1 | X V V X V V X V V X V V X V V X V V X V V X V V X X V V X X V V X X V V X X V V X X V V X X V V X X V V X X V V X X V V X X V V X X V V X X V V X X V X X V X X X X X X X X X X X X X X X X X X X X | 0 0 0 0 1 1 1 0 0 0 0 7 1 0 7 0 0 7 0 | 1 t t t t t t t t t t t t t t t t t t t | 10 0000 11 0000 11 0000 11 011 10 0000 11 11 111 10 0000 011 10 000 11 011 10 000 11 011 10 000 11 011 10 000 11 011 10 000 11 011 10 000 11 011 10 000 11 011 11 111 | 110 101 110 101 110 110 110 110 110 110 | DD S | | 2 2 5 5 5 5 1 3 3 | 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 instructive. The indicated bit replace the 0000 | in | | Arithmetic<br>and Logical | ADD A, r ADD A, n ADD A, (IX+c ADD A, (IX+c ADD A, (IY+c ADD A, (IY+c ADD A, (IY+c ADD A, a SUB a SBC A, a AND a OR a XOR a CP a INC (IX+d) INC (IX+d) | BC = 0 Hag in 0 if the ing in 1 if A = (i) A - A + i A - A + i A - A + i A - A + i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i | (HL) other (HL) (IX+d) (YY+d) (YY+d) (YY+d) | t t t t t t t t t t t t t t t t t t t | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | х<br>х<br>х<br>х<br>х<br>х<br>х<br>х<br>х<br>х | 1 | X V V X V V X X V V X X V V X X Y V X X X Y V X X X Y Y X X X X | 0 0 0 0 1 1 1 0 0 0 0 7 1 0 7 0 0 7 0 | 1 t t t t t t t t t t t t t t t t t t t | 10 0000 11 0000 11 011 101 10 0000 11 011 10 0000 10 011 10 000 11 011 10 000 11 011 10 00 110 11 011 11 00 110 11 011 11 00 110 | 110 | DD S | 3 | 2<br>2<br>5<br>5<br>5<br>1<br>3<br>6 | 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 instructive. The indicated bit replace the 0000 | in | | Arithmetic<br>and Logical | ADD A, r ADD A, (HL) ADD A, (IX+c ADD A, (IX+c ADD A, (IY+c ADD A, (IY+c ADD A, a SUB a SBC A, a AND a OR a XOR a CP a INC r INC (IX+d) INC (IX+d) | BC = 0 Hag in 0 if the ing in 1 if A = (i) A - A + i A - A + i A - A + i A - A + i A - A + i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i | result of B HL), other (HL), other (HL) (HX+d) +CY -CY -CY -A -A -A | t t t t t t t t t t t t t t t t t t t | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | х<br>х<br>х<br>х<br>х<br>х<br>х<br>х<br>х<br>х | 1 | X | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | 1 t t t t t t t t t t t t t t t t t t t | 10 0000 11 0000 11 0000 11 011 10 0000 11 11 111 10 0000 011 10 000 11 011 10 000 11 011 10 000 11 011 10 000 11 011 10 000 11 011 10 000 11 011 10 000 11 011 11 111 | 110 | DD S | 3 | 2<br>2<br>5<br>5<br>5<br>1<br>3<br>6 | 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 instructive. The indicated bit replace the 0000 | in | | Arithmetic<br>and Logical | ADD A, r ADD A, n ADD A, (IX+c ADD A, (IX+c ADD A, (IY+c ADD A, (IY+c ADD A, (IY+c ADD A, a SUB a SBC A, a AND a OR a XOR a CP a INC (IX+d) INC (IX+d) | BC = 0 Hag in 0 if the in g in 1 if A = (i) A - A + i A - A + i A - A + i A - A + i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i | result of B HL), other (HL), other (HL) (HX+d) +CY -CY -CY -A -A -A | t t t t t t t t t t t t t t t t t t t | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | х<br>х<br>х<br>х<br>х<br>х<br>х<br>х<br>х<br>х<br>х | 1 | X | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | 1 | 10 0000 11 0000 11 011 101 10 0000 11 011 10 0000 10 011 10 000 11 011 10 000 11 011 10 00 110 11 011 11 00 110 11 011 11 00 110 | 110 | DD S | 3 | 2<br>2<br>5<br>5<br>5<br>1<br>3<br>6 | 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 2000 the ADD set abov m is any of r, (HL) (IX+d), (IY+d) | in<br>e. | | Arithmetic<br>and Logical | ADD A, r ADD A, (HL) ADD A, (IX+c ADD A, (IX+c ADD A, (IY+c ADD A, (IY+c ADD A, a SUB a SBC A, a AND a OR a XOR a CP a INC r INC (IX+d) INC (IX+d) | BC = 0 Hag in 0 if the ing in 1 if A = (i) A - A + i A - A + i A - A + i A - A + i A - A + i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i | result of B HL), other (HL), other (HL) (HX+d) +CY -CY -CY -A -A -A | t t t t t t t t t t t t t t t t t t t | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | х<br>х<br>х<br>х<br>х<br>х<br>х<br>х<br>х<br>х<br>х | 1 | X | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | 1 | 10 0000 11 0000 11 011 101 10 0000 11 011 10 0000 10 011 10 000 11 011 10 000 11 011 10 00 110 11 011 11 00 110 11 011 11 00 110 | 110 | DD S | 3 | 2<br>2<br>5<br>5<br>5<br>1<br>3<br>6 | 7<br>7<br>19<br>19 | m is any of r, (HL) (IX + d). m is any of r, (HL) (IX + d). m is any of r, (HL) (IX + d). m is any of r, (HL) (IX + d). | in<br>in | | Arithmetic<br>and Logical | ADD A, r ADD A, (HL) ADD A, (IX+c ADD A, (IX+c ADD A, (IY+c ADD A, (IY+c ADD A, a SUB a SBC A, a AND a OR a XOR a CP a INC r INC (IX+d) INC (IX+d) | BC = 0 Hag in 0 if the ing in 1 if A = (i) A - A + i A - A + i A - A + i A - A + i A - A + i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i | result of B HL), other (HL), other (HL) (HX+d) +CY -CY -CY -A -A -A | t t t t t t t t t t t t t t t t t t t | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | х<br>х<br>х<br>х<br>х<br>х<br>х<br>х<br>х<br>х<br>х | 1 | X | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | 1 | 10 0000 11 0000 11 011 101 10 0000 11 011 10 0000 10 011 10 000 11 011 10 000 11 011 10 00 110 11 011 11 00 110 11 011 11 00 110 | 110 | DD S | 3 | 2<br>2<br>5<br>5<br>5<br>1<br>3<br>6 | 7<br>7<br>19<br>19 | m is any of r, (HL) (IX+d), (IY+d) as shown for RMD Expension of the ADD and t | in<br>in<br>ie. | | Arithmetic<br>and Logical | ADD A, r ADD A, (HL) ADD A, (IX+c ADD A, (IX+c ADD A, (IY+c ADD A, (IY+c ADD A, a SUB a SBC A, a AND a OR a XOR a CP a INC r INC (IX+d) INC (IX+d) | BC = 0 Hag in 0 if the ing in 1 if A = (i) A - A + i A - A + i A - A + i A - A + i A - A + i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i A - A - i | result of B HL), other (HL), other (HL) (HX+d) +CY -CY -CY -A -A -A | t t t t t t t t t t t t t t t t t t t | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | х<br>х<br>х<br>х<br>х<br>х<br>х<br>х<br>х<br>х<br>х | 1 | X | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | 1 | 10 0000 11 0000 11 011 101 10 0000 11 011 10 0000 10 011 10 000 11 011 10 000 11 011 10 00 110 11 011 11 00 110 11 011 11 00 110 | 110 | DD S | 3 | 2<br>2<br>5<br>5<br>5<br>1<br>3<br>6 | 7<br>7<br>19<br>19 | m is any of r, (HL) (IX + d). m is any of r, (HL) (IX + d). m is any of r, (HL) (IX + d). m is any of r, (HL) (IX + d). | in in in | | Purpose | Macarate | Symbolic<br>Operation | 8 | 2 | | Pla<br>H | | P/W | M | c | 78 M | ************************************** | Mex | Ho.ed<br>Dyses | He-ol M<br>Cyales | | Communic | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------|--------------------------------------------------------------------------------------------------------|-----------------------------------------|------|-----------------------|-----------------------------------------|-------------|-------------|-------------|---------------------------------------|----------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------|----------------|-------------------|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Arithmetic<br>and | DAA | Converts acc. content<br>into packed BCD<br>following add or | 1 | | X | ı | X | P | • | 1 | 00 10 | 0 111 | 27 | 1 | ı | 4 | Decimal adjust accumulator. | | CPU Control | | aubtract with packed<br>BCD operands. | | | | | | | | | | | | | | | | | iroups | CPL | A X | | 4 | X | 1 | X | • | 1 | • | 00 10 | 1111 | ХF | ì | 1 | 4 | Complement<br>accumulator (one's | | | NEG | A - 0 - A | t | 1 | X | t | X | ٧ | 1 | 1 | | 1 101 | | 2 | 2 | 8 | complement). Negate acc. (two's complement). | | | CCF | CY - <del>CY</del> | • | | X | X | X | | 0 | 1 | | 1 111 | | ì | 1 | 4 | Complement carry flag. | | | SCF<br>NOP | CY - 1<br>No operation | | 0 | X | 0 | X | • | 0 | ì | | 0 000 | | 1 | 1 | 4 | Set carry flag. | | | HALT | CPU helted | • | | X | • | X | • | • | ۰ | | 0 110 | | l<br>I | 1 | 4 | | | | DI ↔<br>El ∗ | IFF 0<br>IFF 1 | • | • | X | | X | • | e<br>é | | | 1 011<br>1 011 | | 1 | 1 | 4 | | | | DM 0 | Set interrupt | | | â | 6 | Â. | | á | | | 1 101 | | 2 | 2 | 4<br>B | | | | IM 1 | móde 0<br>Set interrupt | • | ٠ | x | ۵ | x | 6 | 4 | • | 01 00 | 1 101 | 46 | 2 | 2 | 8 | | | | IM 2 | mode 1<br>Set interrupt | ۰ | • | X | ۰ | x | • | • | ń | 11 10 | 0 110 | 56<br>ED | 2 | 2 | 8 | | | | NOTES: IFF in | mode 2<br>indicates the interrupt enable file | - 4- | | | | | | | | 01 01 | 1 110 | 5E | | | | | | | CY see | dicates the cerry flip-liop,<br>dicates interrupts are not sample | | | end o | d El c | r DI. | | | | | | | | | | | | 6-Bit | ADD HL, es | HL - HL+ss | | • | X | X | x | 4 | 0 | 1 | · · | 1 001 | | 1 | 3 | 11 | B | | lrithmetic | ADC HL, as | HL ~ HL+m+CY | | 1 | | | X | | 0 | | | ) 101 | | 2 | | 11 | se Reg.<br>00 BC | | Group | • | | • | | ^ | Α. | • | * | J | • | Q) ne | 1 010 | ) | * | 1 | 15 | 01 DE<br>10 HL<br>11 SP | | | SBC H(, ms | HL - HL - m - CY | 1 | | X | X | Х. | | | 1 | 01 a | )1 101<br>10 010 | ) | 2 | 4 | 15 | *** | | | ADD IX, pp | IX - IX + pp | • | • | X | X | X | • | 0 | 1 | | 1 101<br>51 00: | | 2 | 4 | 15 | pp Reg.<br>00 BC | | | | | | | | | | | | | | | | | | | 01 DE<br>10 IX | | | ADD IY, rr | 1Y - 1Y + 11 | | ٥ | x | x | x | • | 0 | ı | | 1 101 | | 2 | 4 | 15 | 11 SP<br>rr Reg. | | | | | | | | | | | | | 00 rs | 1 001 | | | | | 00 BC<br>01 DE | | | MC c | | | | •- | | | | | | | | | | | | 10 IY<br>11 SP | | And the second | INC se<br>INC IX | en ne + 1<br>1X 1X → 1 | 0 | • | X | 0 | X | | | • | 11 0 | 1 101 | DD | 1<br>2 | 2 | 6<br>10 | | | <i>i</i> . | INC IY | IY - IY + 1 | | | x | ۰ | x | 4 | • | • | 11 11 | 0 011 | FD | 2 | 2 | 10 | | | | DEC IX | ss ~ ss ~ }<br>IX ~ IX ~ I | 0 | | X | | X | | ۰ | | 00 m | 0 011<br>1 011<br>1 101 | | 1 | 1 | 6 | | | | DEC IY | IY - IY - I | | | X | | x | | | | 00 10 | 1 101<br>1 <b>0</b> 11<br>1 101 | 2B | 2 . | 2 | 10<br>10 | | | e de la companya l | NOTES: made | my of the register pairs BC, DE | | co. | | <u>.</u> | | | | | | 1 011 | | | | | · | | | pp n 4 | any of the register pairs BC, Dr<br>my of the register pairs BC, DF<br>my of the register pairs BC, DF | E. 1X | .SP. | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 1000000 | | | | | | | | | | | | | | | | | RLCA | CY 7 A | æ | • | X | 0 | x | | 0 | 1 | 00 00 | 0 111 | 07 | 1 | . 1 | . 4 | Rotate left circular accumulator. | | | | CY | 4 | • | x | 0 | x<br>x | • | 0 | 1 | | 0 111 | | 1 | 1 | . 4 | accumulator. | | | RICA | (m) (1, 1, 1) | ф<br>Ф | | | | | | | 1 1 | 00 0 | | 17 | | 1 | 4 | accumulator. Rotate left accumulator. Rotate right circular | | | RICA<br>RLA | (T) | ф<br>Ф | • | | 0 | X | • | o .<br>O | 1 1 | 00 0 | 0 111 | 17<br>OF | | | 4 | accumulator. Rotate left accumulator. | | | RLCA RLA RRCA RRA | | 6 | | x<br>x<br>x | o<br>o<br>o | x<br>x<br>x | | o<br>o<br>o | 1 | 00 01<br>00 00 | 0 111<br>1 111<br>1 111 | 17<br>0F<br>1F | 1 | 1 | 4 | accumulator. Rotate left accumulator. Rotate right circular accumulator. Rotate right accumulator. | | | RLCA RLA RRCA RRCA RRA | | • | | x<br>x<br>x | 0<br>0<br>0 | x<br>x<br>x | e<br>e<br>p | 0<br>0<br>0 | 1 | 00 01<br>00 00<br>00 01<br>11 00<br>00 00 | 0 111<br>1 111<br>1 111<br>1 011<br>0 r | 17<br>OF<br>1F<br>CB | 1 1 1 2 | 1 2 | 4<br>8 | accumulator. Rotate left accumulator. Rotate right circular accumulator. Rotate right accumulator. Rotate left circular regulator. | | | RLCA RLA RRCA RRA | | • | | x<br>x<br>x | o<br>o<br>o | x<br>x<br>x | e<br>e<br>p | o<br>o<br>o | 1 | 00 01<br>00 00<br>00 01<br>11 00<br>00 00 | 0 111 1 111 1 111 1 011 0 | 17<br>OF<br>1F<br>CB | 1 1 1 2 | 1 | 4 | accumulator. Rotate left accumulator. Rotate right circular accumulator. Rotate right accumulator. Rotate left circular register r. r. Reg. OOO B | | | RICA RICA RRCA RRCA RRC RIC (HL) RIC (IX+d) | | | ı | x<br>x<br>x | 0<br>0<br>0 | x<br>x<br>x | e<br>P | 0<br>0<br>0 | :<br>:<br>: | 00 00<br>00 00<br>00 00<br>11 00<br>00 00<br>11 01 | 0 111 1 111 1 111 1 011 0 | OF OF CB CB | 1 1 1 2 2 4 | 1 2 | 4<br>8 | accumulator. Rotate left accumulator. Rotate right circular accumulator. Rotate right accumulator. Rotate left circular register r. r. Reg. | | | RICA RICA RRCA RRCA RRC RIC (HL) RIC (IX+d) | | 6 6 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | ı | x<br>x<br>x<br>x | 0 0 0 | x<br>x<br>x | e<br>P | 0 0 0 | :<br>:<br>: | 00 01<br>00 00<br>11 00<br>00 00<br>11 00<br>00 00 | 0 111 1 111 1 111 1 011 0 | 17<br>OF<br>1F<br>CB<br>CB | 1 1 1 2 2 4 | 1 2 4 | 8 | accumulator. Rotate left accumulator. Rotate right circular accumulator. Rotate right accumulator. Rotate left circular register r. r. Reg. 000 B 001 C 010 D 011 E 100 H 101 L | | | RLCA RLA RRCA RRA RLC r. RLC (HL) RLC (IX+d) | | 1 | 1 | x<br>x<br>x<br>x<br>x | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | x<br>x<br>x | e P | 0 0 0 0 | 1 1 1 1 | 00 01<br>00 00<br>00 01<br>11 00<br>00 00<br>11 00<br>11 00<br>00 00 | 0 111 101 11 10 11 10 11 10 11 10 11 10 11 10 11 10 11 10 11 10 11 10 11 10 11 10 11 10 11 10 11 10 11 10 11 10 11 10 11 10 11 10 11 10 11 10 11 10 11 10 11 10 11 10 11 10 11 10 11 10 11 10 11 10 11 10 11 10 11 10 11 10 11 10 11 10 11 10 11 10 11 10 11 10 11 10 11 10 11 10 11 10 11 10 11 10 11 10 11 10 11 10 11 10 11 10 11 10 11 10 11 10 11 10 11 10 11 10 11 10 11 10 11 10 11 10 11 10 11 10 11 10 11 10 11 10 11 10 11 10 11 10 11 10 11 10 11 10 11 10 11 10 11 10 11 10 11 10 11 10 11 10 11 10 11 10 11 10 11 10 11 10 11 10 11 10 11 10 11 10 11 10 11 10 11 10 11 10 11 10 11 10 11 10 11 10 11 10 11 10 11 10 11 10 11 10 11 10 11 10 11 10 11 10 11 10 11 10 11 10 11 10 11 10 11 10 11 10 10 | OF OF CB | 1 1 2 2 4 | 1 2 4 6 | 8<br>15<br>23 | Rotate left accumulator. Rotate right circular accumulator. Rotate right accumulator. Rotate left circular regulater r. r. Reg. 000 B 001 C 010 D 011 E | | | RICA RICA RRCA RRCA RRC RIC (HL) RIC (IX+d) | | 1 | 1 | x<br>x<br>x<br>x | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | x<br>x<br>x | e P | 0 0 0 | 1 1 1 1 | 00 01<br>00 00<br>00 00<br>11 00<br>00 00<br>11 01<br>11 00<br>00 00 | 0 111 1 111 1 111 1 111 1 111 1 111 1 111 1 111 1 111 1 111 1 111 1 111 1 111 1 111 1 111 1 111 1 111 1 111 1 111 1 111 | OF OF CB CB CB CB CB FD | 1 1 2 2 4 | 1 2 4 | 8 | Rotate left accumulator. Rotate right circular accumulator. Rotate right accumulator. Rotate left circular regular r. r Reg. 000 B 001 C 010 D 011 E 100 H 101 L | | Rotate and<br>Shift Group | RICA RICA RRCA RRCA RRC RIC (HL) RIC (IX+d) RIC (IY+d) | | 1 | 1 | x | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | x<br>x<br>x | e PPPP | 0 0 0 0 0 | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | 00 01<br>00 00<br>00 01<br>11 00<br>00 00<br>11 01<br>11 00<br>00 00 | 0 111 10 111 10 110 110 110 110 110 110 | OF OF OB CB | 1 1 2 2 4 | 1 2 4 6 | 8<br>15<br>23 | Rotate left accumulator. Rotate right circular accumulator. Rotate right accumulator. Rotate left circular register r. r. Reg. 000 B 001 C 010 D 011 E 100 H 101 L 111 A | | | RLCA RLA RRCA RRA RLC r. RLC (HL) RLC (IX+d) RLC (IX+d) | CY 7 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | 1 | 1 | x | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | x<br>x<br>x | e PPPP | 0 0 0 0 | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | 00 01<br>00 00<br>00 00<br>11 00<br>00 00<br>11 01<br>11 00<br>00 00 | 0 111 10 111 10 110 110 110 110 110 110 | OF OF OB CB | 1 1 2 2 4 | 1 2 4 6 | 8<br>15<br>23 | Rotate left accumulator. Rotate right circular accumulator. Rotate right accumulator. Rotate left circular regular r. r. Reg. 000 B 001 C C 010 D D 011 E 100 H 101 L 111 A Instruction format and states are as shown for RLCs. To form new | | | RLCA RRCA RRCA RRCA RLC r. RLC (HL) RLC (HX+d) RLC (HY+d) | CY 7 0 CY A | 1 | 1 | x | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 | x x x x - | e e P P P | 0 0 0 0 0 | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | 00 01<br>00 00<br>00 01<br>11 00<br>00 00<br>11 01<br>11 00<br>00 00 | 0 111 111 11 11 11 11 11 11 11 11 11 11 | OF OF OB CB | 1 1 2 2 4 | 1 2 4 6 | 8<br>15<br>23 | Rotate left accumulator. Rotate right circular accumulator. Rotate right accumulator. Rotate left circular regular r. Reg. 100 B B 001 C C C C C C C C C C C C C C C C C C | | lotate and<br>Shift Group | Mnomonic | Symbolic<br>Operation | 8 | z | | Flo | gs | <b>P/</b> ¥ | N | c | 76<br>76 | pcode<br>543 21 | 0 | Hex | Ho.el<br>Bytes | | | Ho of 7<br>States | Commonts | · | |---------------------------|----------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------|-------|---------------------|--------|-------------|------|-----|----------|----------------------------------|------------|------------------------------|----------------------------|-----|-----------------------|-------------------------------|--------------------------------------------------------------------------------------------------------------|------------------------------------------| | Continued) | | 7 0 CV CV = r.(HL).(IX + d).(IY + d) | 1 | 1 | x | 0 | X. | P | 0 | t | ſ | oii | | | - | - | | | | | | | | CY 7-0-0<br>mr.(HL),(IX+d),(IY+d) | 1 | ı | x | 0 | X | P | 0 | 1 | . 1 | 100 | | | | | | | | | | | | CY (HL),(IX + d),(IY + d) | t | ı | X | 0 | X | P | 0 | 1 | . ! | 101 | | | | | | | | | | | | 7-0-CY<br>n=r,(HL),(IX+d),(IY+d) | 1 | t | X | 0 | X | P | 0 | t | | Ш | | | | | | | | | | | RLD [ | 7 - 4 3 - 0 7 - 4 3 - 0 (HL) | ı | t | x | 0 | x | . P | 0 | ۰ | | 101 I<br>101 I | | ED<br>6F | 2 | - 5 | | . 18 | Rotate digit left and<br>right between<br>the accumulator | | | | RRD ( | 7 - 4 3 - 0 - 7 - 4 2 - 0 (HL) | ,1 | 1 | X | Ö | X | Þ | 0 | • | | 101 1<br>100 1 | | ED<br>67 | 2 | 5 | | 18 | and location (HL). The content of the upper half of the accumulator is unaffected. | | | Bit Set, Reset | RIThr | $z - \overline{r}_b$ | × | | x | 1 | х | X | G | | 11 | 001 0 | 11 ( | CB | 2 | 2 | | 8 | r Reg: | 57005-700-0-0-0-0-0-0-0-0-0-0-0-0-0-0-0- | | and Test | | $Z \sim (\overline{HL})_b$ | | 1 | | 1 | | | 0 | | | ь<br>001 0 | | CB · | 2 | 3 | | 12 | 000 B<br>001 C | | | Group | BIT b, (HL) BIT b, (IX+d) | z - (IX+d)b | | | | 1 | | | 0 | • | 01 | ь 1<br>011-1 | 10<br>01 1 | DD | 4 | 5 | | 20 | 010 D<br>011 E | 1. | | | | | | | | | | | | | | р I | _ | CB | 21 | | | | 100 H<br>101 L<br>111 A | | | | BIT b (IY+d) | b 2 - (1Y+d)b | х. | | X- | 1 | x | X | 0 | ۰ | 11 | 111 1 | 01 | | 4 | . 5 | | 20 | D Bit Tested | | | | 2, (1, 1, 2, | , | | | | | | | | | _ | 9 1<br>001 0 | - | СВ | • | ' | | | 001 1<br>010 2<br>011 3 | | | | | | | | | | | | | | Ü | | 10 | | | | | | 100 4<br>101 5 | | | | | * * * * * * * * * * * * * * * * * * * * | | | | | | | | | | | • | | | | | | 110 6<br>111 7 | | | | SET b, r | r <sub>b</sub> - 1 | a | • | X | ۰ | X | | | • | Ш | | r | | 2 , | 2 | | .8 | | | | | SET b. (HL) | (HL) <sub>b</sub> ~ 1 | • | ٥ | X | ٠ | X | ۰ | • | | Ш | 001 (<br>Б | 10 | | 2 | 4 | | 15 | | | | | SET b, (IX+d | ) (IX+d) <sub>b</sub> - 1 | | ٥ | X | . • | X | | è | | 11 | 001 (<br>011 1 | 311 | CB<br>DD | 4 | . 6 | | 23 | • | | | | SET b. (IY+d | (IY + d) <sub>b</sub> - 1 | ۵ | •. | х | | x | a | • | 'n | 11 | b .<br>111 <br>001 ( | 101 | | 4 | 6 | | 23 | | | | | | | | | | | | | | - | П | ъ<br>В | | | | | | | | | | | RES b, m | m <sub>b</sub> - 0<br>m = r, (HL),<br>(IX + d), | ٩ | | X | ٠ | X | | ٠ | • | 10 | l | | | | | | | To form new opcode replace Till of SET b, s | | | * | | (1Y + d) | , | | | | | | | | | | | | | | | | with 10 Flags<br>and time states for | | | | | | | | | | | | | _ | <u> </u> | | | ·· | | - | | | SET instruction. | | | | NOTES: The | notation mb indicates bit b ( | 10 7 | orie | ocatr | on m | | | | | | <del>o</del> iko | | | | سبب | <u>.</u> | | | | | Jump<br>Group | JP nn | PC - nn | • | • | , | ( * | , , | | ٠ | • | 1 | - n | 011 | C3 | 3 | 3 | ) | 10 | cc Condition | | | C.Cup | IP cc, nn | If condition cc is<br>true PC - nn, | • | | , , | ( - | , | | | | 1 | - n.<br>l cc<br>- n | 010 | ) | 3. | 3 | 3 | 10 | 000 NZ non-zero.<br>001 Z zero | | | | | otherwise<br>continue | | | | | | | | | | - , n | . 7 | | | 4 | ; <del>.</del> | | Q10 NC non-carry<br>011 C carry | | | | | | | | | | i, | | | | | | | : . | | | | | 100 PO parity odd<br>101 PE parity even | | | | | *** | | | | | | | a. e | | | 0 011 | | | . 2 | | 3 | 12 | 110 P sign positive | | | | IR e | PC PC+e | | | ; | K 4 | , , | | | | | ~ ~ ~ | | | | | _ | | | | | | IR e<br>IR C, e | If C = 0,<br>continue | | | ; | K 4 | , , | κ . | | | | 0 UII | 000 | .38 | 2 | | | 7 | If condition not met. | | | | IR C, e | If C = 0, continue If C = 1, PC - PC+4 | | | , ; | K * | , ) | | • • | | · · | 00 III<br>e | 2 - | 388 | 2 | 1 | 3 | 12 | If condition is met. | | | | | If C = 0,<br>continue<br>If C = 1,<br>PC - PC+e<br>If C = 1. | | | • ; | к <sup>(</sup><br>х | )<br> | K · | | | | 0 111 | 000 | 3.38 | | 1 | | 2.5 | | | | | IR C, e | If C = 0,<br>continue<br>If C = 1,<br>PC - PC+e<br>If C = 1. | | | | к<br>х<br>х | | K · | a 6 | | | 00 111<br>- #-<br>10 110<br>- #- | 000 | 36 | 2 | | 3 | 12<br>7 | If condition is met. | | | | IR C, e | If C = 0, continue If C = 1, PC - PC+e If C = 1, continue If C = 0, PC - PC+e If Z = 0 continue If Z = 1, | | | | к<br>к<br>х_ | | K<br>X | | | | 00 111<br>- e-<br>10 110<br>- e- | 000 | 30 30 30 329 | 2 2 2 | | 3 | 12<br>7<br>12 | If condition is met. If condition not met. If condition is met. | | | | IR C, e | If C = 0, continue If C = 1, PC = PC+e If C = 1, continue If C = 0, PC = PC+e If Z = 0 continue If C = 0, If Z = 1, PC = PC+e If Z = 1, | | k d | | к<br>х<br>х | )<br>) | X | a a | | . ( | 00 111<br> | 000 | 0 36<br>0 36<br>0 28 | 2 2 2 2 | | 3<br>2<br>3 | 12<br>7<br>12<br>7 | If condition is met. If condition not met. If condition is met. If condition not met. | | | | JR C, a | If C = 0, continue If C = 1, PC - PC + e If C = 1, continue If C = 0, PC - PC + e If Z = 0 continue If Z = 1, PC - PC + e If Z = 1, continue If Z = 1, continue If Z = 1, continue If Z = 0, | 6 | b f | | X<br>X | n : | X | a 1 | | . ( | 00 111<br>- e-<br>10 110<br>- e- | 000 | 0 36<br>0 36<br>0 28 | 2<br>2<br>2<br>2<br>2 | | 3<br>2<br>3<br>2 | 12<br>7<br>12<br>7<br>12 | If condition is met. If condition is met. If condition is met. If condition is met. | | | | JR C, a | If C = 0, continue If C = 1, PC - PC+e If C = 1, Continue If C = 0, PC - PC+e If Z = 0 continue If Z = 1, PC - PC+e If Z = 1, Continue | | k fi | | K<br>K<br>X | n ) | K<br>K<br>K | A 0 | n ( | . ( | 00 111<br> | 000 | 0 38<br>0 30<br>0 28<br>0 20 | 2<br>2<br>2<br>2<br>2<br>2 | | 3<br>2<br>3<br>2<br>3 | 12<br>7<br>12<br>7<br>12<br>7 | If condition is met. If condition is met. If condition is met. If condition is met. If condition is met. | | | u <b>mp Group</b><br>(Continued) | Mnomenic | Symbolic<br>Operation | | x | | Fie | | P/¥ | × | c | 78 | 341 | 214<br>214 | Моп | Ho.el<br>Bytes | No.at M<br>Cycles | Ho.ef T<br>States | Comments | |----------------------------------|----------------|-----------------------------------------------------------------------------------------|-------------------|-------|------------|--------|------------|----------------|-------------|-----|------|------------|------------|----------|----------------|-------------------|-------------------|-------------------------------------------------------------------------------| | OOMANAGA, | JP (IY) | PC - IY | <b>a</b> . | ٠ | X | • | X | • | a | | | | 101<br>001 | | 2 | 2 | 8 | | | | DINZ, a | B B-1 | • | • | X | • | X | • | ۰ | ۰ | 00 | | 000 | | 2 | 2 | 8 | If B = 0. | | | | If B = 0,<br>continue | | | | | | | | | _ | <b>.</b> | A | | 2 | 3 | 13 | ив <b>•</b> 0. | | | | # B ≠ 0,<br>PC PC++ | | ٠ | | | | | | | | | | | 4 | .3 | 13 | др≠ 0. | | | NOTES: e repre | sents the extension in the re- | lative a | ddre | teing | mode | ٠. | | | | | | | | | | | | | | o-2 in | gned two's complement num<br>the opcode provides an effe<br>prior to the addition of a. | ber in<br>ctive a | the r | ange<br>ol | PC + e | 128, | 1.789<br>*C is | >.<br>Incre | men | nd . | | | | | | | | | | LIT A | proc to the addition of a | | | | | | | | | | ·········· | | | | | | | | Call and | CALL nn | (SP-1) - PCH | | | X | | X | • | 0 | • | | | | CD | 3 | 5 | 17 | | | Return Group | | (SP - 2) - PC1<br>PC - nn | | | | | | | | | _ | | - | | | | | 4.1 | | | CALL cc, na | If condition | | 0 | X | ۰ | X | 9 | ۵ | 6 | 11 | œ | | | 3 | 3 | 10 | If oc is false. | | | | cc is false<br>continue, | | | | | | | | | ~ | n<br>n | | | 3 | 5 | 17 | If cc in true. | | | | otherwise same as<br>CALL nn | | | | | | | | | | | | | | | | | | | RET | PCL - (SP) | | | X | | X. | | | | 11 | m | mı | C9 | 1 | 3 | 10 | | | | REI | PCH - (SP+1) | | | ^ | - | | | | - | ** | | | Ų. | • | | ,, | | | | RET cc | If condition | • | 0 | x | • | X | • | 6 | | 11 | cc | 000 | | 1 | 1 | 5 | If oc in false. | | | | cc is false<br>continue, | | | | | | | | | | | | | 1 | 3 | 11 | If oc is true. | | | | otherwise<br>same as | | | | | | | | | | | | | | | | oc Condition | | | | RET | | | ٠ | | | | | - | | | | | · | 4 4 | | 000 NZ non-zero<br>001 Z zero | | | RETI | Return from | • | • | X | 0 | x | ٠, | ٨ | • | | | | ED | 2 | 4 | 14 | 010 NC non-carry<br>011 C carry | | | RETN1 | interrupt<br>Return from | ø. | • | X | • | X | • | • | | 11 | 101 | 101 | 4D<br>ED | 2 | 4 | 14 | 100 PO parity odd<br>101 PE parity even | | | | non-maskable<br>interrupt | | | | | | | | | . 01 | 000 | 101 | 45 | | | | 110 P sign positive | | • | RST p | (SP-1) - PCH | | | x | | χ. | • | , | | | | . 111 | | i | 3 | 41 | 111 M sign negative | | | nor p | (SP-2) - PCL | | ٠. | ^ | | ^ | | | | | | *** | | , • | | | 000 00H | | | | PCH - 0<br>PCL - p | | | | | | | | | | į. | | | | · - | | 001 08H<br>010 10H | | | | | | | | | | | | | | | | | | | | 011 18H<br>100 20H | | | | • | | | | | | | | | | | | | | | | 101 29H<br>110 30H | | | | | | | | | | | | | | _ | | | | : | | 111 38H | | | NOTE: RETH | loads IFF <sub>2</sub> - IFF <sub>1</sub> | | | | | | | | | | | | | | | | | | Input and | IN A, (n) | Å — (n) | | 4 | X | ٥ | x | 9 | | | 1.1 | 011 | 1 01 | DB | 2 | 3 | 11 | n to Ao - A7 | | Output Group | | | | 4 | | ı | | P | 0 | | - | - <u>n</u> | | ED | 2 | 3 | 12 | Acc. to Ag ~ A <sub>15</sub> | | | In r, (C) | r (C) if r = 110 only the flags will be affected | Ţ, | | ^ | • | | × | Ü | • | | | 000 | | • | · . | | C to A <sub>0</sub> ~ A <sub>7</sub><br>B to A <sub>8</sub> ~ A <sub>15</sub> | | | INI | (RL) - (C) | | 0 | x | x | <b>x</b> . | x | ì | • | 1 | 1 10 | I 10 | 1 ED | 2 | 4 | 16 | C to A0 ~ A7 | | | | B - B-1<br>HL - HL + 1 | | | | | | | | | 10 | 10 | 0 01 | 0 A2 | | | | B to A8 ~ A15 | | | INIR | (HL) - (C) | X | 1 | X | X. | X | X | 1. | | | | | I ED | 2 | 5 | 21 | C to A0 - A7 | | | | B - B-1<br>HL - HL + 1 | | | | | | | | | 10 | וננט | o oi | 0 B2 | 2 | (Ii B≠0)<br>4 | 16 | B to Ag ~ A15. | | | | Repeat until<br>B = 0 | | _ | | | | | | | | | | | | (li B = 0 | ) | | | | IND | (HL) (C) | | Φ | ¥ | X | X | X | , | D | 1 | 1 10 | 1 10 | 1 ED | 2 | 4 | 16 | C to A <sub>0</sub> ~ A <sub>7</sub> | | | 10.7 Par | B B 1 | . • | | ~ | - | • | eA. | | | | | | O AA | • | | | B to Ag ~ A15 | | | INDR | HL - HL - I<br>(HL) - (C) | X | 1 | X | x | X | ·x | 1 | ٠ | | | | 1 ED | | 5 | 21 | C to Ao - A7 | | | | B - B - 1<br>HL - HL - 1 | | | | | | | | | 1 | 0 11 | 1 01 | O BA | . 2 | (If B≠0)<br>4 | 16 | B to Ag - A15 | | | | Repeat until<br>B = 0 | | | ٠. | | | | | | | | | | | (If B = 0) | ) | | | | OUT (n), Å | (n) — A | • | • | , <b>X</b> | • | X | ۰, | • | | | | | 1 D3 | 2 | .3 | 11 | n to Ao - A7 | | | OUT (C), r | (C) - r | | ٥ | , <b>x</b> | ٩ | X | ۵ | • | • | 1 | 1 10 | | I ED | 2 | 3 | 12 | Acc. to Ag - A15<br>C to A0 - A7 | | | | • | | 0 | | | | | | | | | - 00 | | | | | B to A8 ~ A15 | | | OUTI | (C) (HL)<br>B B-1 | X | 1 | . Х | , X | . X | X | 1 | • | | | | I ED | | 4, 1 | 16 | C to A <sub>0</sub> ~ A <sub>7</sub><br>B to A <sub>8</sub> ~ A <sub>15</sub> | | | OTIR | HL - HL + 1<br>(C) - (HL) | x | 1 | :<br>X | Ψ. | ý | х. | | | | | | ) ED | | 5 | 21 | C to A <sub>0</sub> ~ A <sub>7</sub> : | | | O I III | B - B-1 | : <b>-^</b> | | ^ | ^ | . ^ | Α. | ٠ | | 1 | ó ii | 0 0 | 1 B3 | | (If B≠0 | ). | B to Ag - A15 | | | | HL - HL + 1<br>Repeat until | "- , | | | | | | | | | | | | 2 | 4<br>(If B = 0 | 16<br>) | | | | | B = 0 | | 0 | | | | | | | | | | | | | | | | | OUTD | (C) - (HL)<br>B - B - I | X | Ĩ, | X | X | X | X | 1 | • | | | | DI ED | | 4 | 16 | C to A0 - A7 | | | | HL - HL - i | | | | | | | | | | ווייי | ע ע | 1. 45 | | | | B to Ag ~ A <sub>15</sub> | | Input and<br>Output Group | Mnemonic | Symbolic<br>Operation | | 8 | 2 | | FI4 | iger | P/ <b>W</b> | M C | Opcode<br>78 543 210 Hex | No.of<br>Bytes | No.of M<br>Cycles | | Comments | |---------------------------|-------------------------------------------------|-----------------------------------------------------|----------------|---------|-------------|------------------|-------------|-------------|-------------|----------------------------------------|----------------------------------------------------------------------|----------------|--------------------------------|--------------------|-------------------------------------------------------------------------------| | (Continued) | OTDR | (C) - (HL) B - B - 1 HL - HL - 1 Repeat until B = 0 | • | X | 1 | х | x | X. | X | 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<br>Flag | Instruction | | D <sub>7</sub> | z | | Ħ | | B/A | M | D <sub>B</sub> | Comments | | | | · | | Operation | AND a | A, n; CP n; NEG | 1 | t<br>t | X<br>X<br>X | 1<br>1<br>1 | X<br>X | 5 A A | 0 | 0} | 8-bit add or add wit<br>8-bit subtract, subtra<br>Logical operations | | carry, cor | праге ап | d negate accumulator. | | | OR s, XOR s INC s DEC s ADD DD, ss | 1 | 1 | 1 | X<br>X<br>X | 0<br>1<br>1<br>X | X<br>X<br>X | V<br>V | 0 0 1 0 | 0 | 8-bit increment.<br>8-bit decrement.<br>16-bit add. | | | | • | | | ADC HL, sa<br>SBC HL, sa<br>RLA, RLCA | , RRA; RRCA | 1 1 | 1 | X<br>X<br>X | X<br>V | X<br>X<br>X | ٧ | 0 | 1 | 16-bit add with carr<br>16-bit subtract with<br>Rotate accumulator. | carry. | | | | | | RL m; RLC n<br>RRC m; S<br>SRA m; S<br>RLD; RRD | LA m; | 1 | 4 | X. | 0 | x | P | 0 | 1 | Rotate and shift local | | | | | | | DAA<br>CPL<br>SCF | | 1 | 1 | X<br>X<br>X | 1 0 | X<br>X | P | 1 0 | 1 | Decimal adjust accum Complement accum Set carry. | mulator. | | | | | | CCF<br>IN r (C)<br>INI, IND, O | UTI; OUTD<br>OTIR; OTDR | r<br>X | .1<br>t | X<br>X<br>X | Х<br>Х<br>Х | X<br>X<br>X | P<br>X<br>X | 0 1 | :} | Complement carry. Input register indire Block input and out | | 0 ifB≠ | 0 otherw | ise $Z = 0$ . | | | LDI; LDD<br>LDIR; LDDF<br>CPI; CPIR; | 1 · · | X<br>X<br>X | X<br>X | X<br>X<br>X | 0<br>0<br>X | X<br>X<br>X | 0 | 0 | :} | Block search instruc | tions. Z | = 1 if A | | , otherwise $P/V = 0$ . otherwise $Z = 0$ . $P/V = 1$ | | | LD A. I. LD<br>BIT b. s | A, R | 1<br>X | 1 | X | 0 | X | IFF<br>X | 0 | • | if BC # 0, otherw<br>The content of the in<br>The state of bit b of | nterrupt | enable flip | | F) is copied into the P/V flag.<br>e Z flag. | | Symbolic | Symbol | | | Ope | rat | ion | | | | ,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,, | Symbol | · | | | Operation | | Notation | s" | Sign flag. S = | l if | the ! | MSI | B of | the | res | ult | is I. | 1 | The f | lag is a | ffected | according to the result of the | | | Z | Zero flag. Z = | | | | | | | | | | opera | | _ | | | | P/V | Parity or overfl | | | | | | | | | | | | | ged by the operation. | | | | (V) share the se | | | | | | | | | | | | | the operation. | | | | this flag with th | | | | | | | | | l<br>X | | lag is so | | ne operation. | | • | | arithmetic oper<br>overflow of the | | | | | | | | | | | | | cording to the overflow resul | | | | l if the result o | | | | | | | | | - | | opera | | cording to the overnous result | | | | result is .dd. If | | | | | | | | | | | | | cording to the parity result o | | | | the result he | | | | | | | | | | | peration | | | | | H | Half-car ag | | | | | | | | | r | | | | Jregisters A, B, C, D, E, H, L | | | ** | operation wood<br>bit 4 of the acc | uċec | dac | arry | | | | | | | Any | 8-bit loved for t | cation f<br>he par | or all the addressing modes ticular instruction. | | | N | tion was Subt | ract. | | | | | | | oper | | allow | ed for f | hat ins | for all the addressing modes truction. | | | H & N | | | | | | | | | th the | _ | | one of t<br>esh cour | | index registers IX or IY. | | | | | | | | | | | | erly c<br>ollowi | | | | | e < 0, 255 >. | | | | addition: sub | trac | tion | | | | | | | nn nn | | | | ge < 0, 65535 >. | | • | _ | packed . Ofc | | | | | | | | | | | | | • | | | C | Carry/Li flag | | | | | | | | | | | | | | | | | a carry fine th | e M | SB c | of th | e o | pera | and . | OT 1 | result | | | | | | #### 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<sub>0</sub>-D<sub>7</sub>.** Data Bus (input/output, active High, 3-state). D<sub>0</sub>-D<sub>7</sub> constitute an 8-bit bidirectional data bus, used for data 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. IORQ. Input/Output Request (output, active Low, 3-state). IORQ indicates that the lower half of the address bus holds a valid I/O address for an I/O read or write operation. IORQ is also generated concurrently with MI during an interrupt acknowledge cycle to indicate that an interrupt response vector can be placed on the data bus. MI. Machine Cycle One (output, active Low). MI, together with MREQ, indicates that the current machine cycle is the opcode fetch cycle of an instruction execution. MI, together with IORQ, indicates an interrupt acknowledge cycle. MREQ. Memory Request (output, active Low, 3-state). MREQ indicates that the address bus holds a valid address for a memory read or memory write operation. NMI. Non-Maskable Interrupt (input, active Low). 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. AD. Memory 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. walt. Wait (input, active Low). Walt 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 Walt periods can prevent the CPU from refreshing dynamic memory properly. WR. Memory 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. The falling edge of MREQ can be used directly as a Chip Enable to dynamic memories. When active, RD indicates that the memory data can be enabled onto the CPU 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. data bus. The CPU samples the WAIT input with the rising edge of clock state T3. During clock states T3 and T4 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: 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 (MI) cycle. The MREQ and RD signals function exactly as in the fetch cycle. In a memory write cycle, MREQ also becomes active when the address bus is stable, so that it can be used directly as a Chip Enable for dynamic memories. The $\overline{WR}$ line is active when the data bus is stable, so that it can be used directly as an $R/\overline{W}$ pulse to most semiconductor memories. Figure 6. Memory Read or Write Cycles **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 and the port address lines. NOTE: Tw\* = 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 MI cycle, IORQ becomes active (instead of 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<sub>L</sub> = Last state of previous instruction. 2) Two Wait cycles automatically inserted by $CPU(^{\circ})$ . Figure 8. Interrupt Request/Acknowledge Cycle 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{NM1}$ is an asynchronous input, to quarantee its being recognized on the following machine cycle, $\overline{NM1}$ 's falling edge must occur no later : preceding TLAST. the rising edge of the clock cycle Figure 9. Non-Maskable Interrupt Request Op 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 spedance state with the rising edge of the nesselock pulse. At that time, any external devices an take control of these lines, usually to transier data between memory and I/O devices. ion NOTE: TL = Last state of any M cycle. Tx = An arbitrary clock cycle used by requesting device. Figure 10. Bus Request/Acknowledge Cycle Halt Acknowledge Cycle. When the CPU receives a HALT instruction, it executes NOP states until either an INT or NMI input is received. When in the Halt state, the HALT output is active and remains so until an interrupt is processed (Figure 11). NOTE: INT will also force a Halt exit. \*See note, Figure 9. Figure 11. Halt Acknowledge Cycle Reset Cycle. RESET must be active for at least three clock cycles for the CPU to properly accept it. As long as RESET remains active, the address and data buses float, and the control outputs are inactive. Once RESET goes inactive, 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 | Number | Symbol | Parameter | Z90<br>Min<br>(ns) | CPU<br>Max<br>(ns) | Z80A<br>Min<br>(ns) | CPU<br>Max<br>(ns) | Z80B<br>Min<br>(ns) | CPU<br>Max<br>(ns) | |--------|-------------|---------------------------------------------------------------------------------------------------------------------------------|--------------------|--------------------|---------------------|--------------------|---------------------|--------------------| | 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 | <del>; -</del> 1 | 30. | _ | 30 | _ | 20 | | 5 | -TrC | Clock Rise Time | | 30 | | <del> 30</del> | · | 20 | | 6 | TdCr(A) | Clock † to Address Valid Delay | <u> </u> | 145 | _ | 110 | _ | 90 | | 7 | TdA(MREQf) | Address Valid to MREQ 1 Delay | 125* | | 65* | | 35* | | | 8 | TdCf(MREQf) | Clock I to MREQ I Delay | <del>-</del> . | 100 | _ | 85 | · <u> </u> | 70 | | 9 | TdCr(MREQr) | Clock 1 to MREQ 1 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 I to MREQ 1 Delay | _ : | 100 | _ | 85 | | 70 | | 13 | TdCf(RDf) | Clock I to RD I Delay | <u></u> | 130 | | 95 | _ | 80 | | 14 | TdCr(RDr) | Clock 1 to RD 1 Delay | | 100 | ****** | 85 | | 70 | | 15 | -TsD(Cr) | - Data Setup Time to Clock † | 50 | | 35 - | | 30 - | | | 16 | ThD(RDr) | Data Hold Time to $\overline{RD}$ t | | 0 | _ | 0 | | . ( | | 17 | TsWAIT(Cf) | WAIT Setup Time to Clock I | 70 | _ | 70 | | 60 | _ | | 18 | ThWAIT(Cf) | WAIT Hold Time after Clock I | | 0 | - | 0 | | C | | 19 | TdCr(M1f) | Clock ↑ to MI ↓ Delay | | 130 | _ | 100 | _ | 80 | | 20 | -TdCr(Mlr) | Clock 1 to MI 1 Delay | | 130 | | 100 | · | 80 | | 21 | TdCr(RFSHf) | Clock t to RFSH 1 Delay | | 180 | _ | 130 | - | 110 | | 22 | TdCr(RFSHr) | Clock 1 to RFSH 1 Delay | _ | 150 | - | 120 | | 100 | | 23 | TdCf(RDr) | Clock I to RD 1 Delay | _ | 110 | | 85 | | 70 | | 24 | TdCr(RDf) | Clock 1 to RD 1 Delay | · — | 100 | _ | 85 | - | 70 | | 25 — | - TsD(Cf) | <ul> <li>Data Setup to Clock 1 during —</li> <li>M<sub>2</sub>, M<sub>3</sub>, M<sub>4</sub> or M<sub>5</sub> Cycles</li> </ul> | 60 | | 50 | | 40 | · | | 26 | TdA(IORQf) | Address Stable prior to $\overline{\text{IORQ}}$ 1 | 320* | | 180* | | 110* | . — | | 27 | TdCr(IORQf) | Clock ↑ to IORQ ↓ Delay | | 90 | | 75 | _ | 6 | | 28 | TdCf(IORQr) | Clock I to IORQ Delay | _ | 110 | - | 85 | | 7 | | 29 | TdD(WRf) | Data Stable prior to WR I | 1901 | <u> </u> | 80* | _ | 25* | _ | | 30 | - TdCf(WRf) | Clock ! to WR ! Delay | | 90 - | | 80 | | <del></del> 7 | | 31 | TwWR | WR Pulse Width | 360 | · _ | 220* | | 135* | _ | | 32 | TdCf(WRr) | Clock 1 to WR 1 Delay | - | 100 | _ | 80 | _ | 7 | | 33 | TdD(WRf) | Data Stable prior to WR 1 | 201 | ` · · — | -10* | · | -55 | ` | | 34 | TdCr(WRf) | Clock 1 to WR Delay | _ | 80 | | 65 | | 6 | | 35 | TdWRr(D) | – Data Stable from WR † – – – | <del></del> 120 | * | 60* | | —— 30° | - | | 36 | TdCf(HALT) | Clock to HALT for I | | 300 | · | 300 | | 26 | | 37 | TwNMI | NMI Pulse Width | 80 | | 80 | | 70 | | | 38 | TsBUSREQ(Cr | ) BUSREQ Setup Time to Clock 1 | 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. AC Characteristics | AC<br>Charac- | | | | Z80 (<br>Min | Max | Z80A<br>Min | Max | Z80B<br>Min | CPU<br>Max | |---------------|--------|------------------|-----------------------------------------------------------------------|-------------------|------|-------------|------|------------------|----------------| | teristics | Number | Symbol | Parameter | (ns) | (ns) | (ns) | (ns) | (ns) | (ns) | | (Continued) | 39 | ThBUSREQ(Cr) | BUSREQ Hold Time after Clock 1 | 0 | _ | O O | _ | 0 | | | | 40 | -TdCr(BUSACKi) | -Clock 1 to BUSACK Delay | | 120 | | 100 | · | <del></del> 90 | | | 41 | TdCf(BUSACKr) | Clock I to BUSACK 1 Delay | | 110 | _ | 100 | _ | 90 | | | 42 | TdCr(Dz) | Clock 1 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 1 to Address Float Delay | | 110 | _ | 90 | . — | 80 | | | 45 — | -TdCTr(A) | - Address Stable after MREQ 1, | <del></del> 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 1 Setup Time | 80 | _ | 80 | | 70 | | | | 49 | ThINTr(Cr) | INT to Clock † Hold Time | _ | 0 | | 0 | _ | 0 | | | 50 — | - TdM1f(IORQf) — | - MI I to IORQ I Delay | <b>-</b> 920* | | 565* | | <del></del> 365* | | | | 51 . | TdCf(IORQf) | Clock ↓ to IORQ ↓ Delay | _ | 110 | _ | 85 | | 70 | | | 52 | TdCf(IORQr) | Clock 1 to IORQ 1 Delay | _ | 100 | | 85 | · | 70 | | | 53 | TdCf(D) | Clock I 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 = TiC = 20 ns. #### Footnotes to AC Characteristics | Number | Symbol | 280 | Z80A | Z80B | |--------|--------------|--------------------------------------------------------------------------------|--------------------------------------------------------------------------------|--------------------------------------------------------------------------------| | 1 | TcC | TwCh + TwCl + TrC + TfC | TwCh + TwCl + TrC + TfC | TwCh + TwCl + TrC + TfC | | 2 | TwCh | Although static by design,<br>TwCh of greater than 200 μs<br>is not guaranteed | Although static by design,<br>TwCh of greater than 200 µs<br>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) | TwC1 + TrC - 180 | TwC1 + TrC - 140 | TwC1 + TrC - 140 | | 35 | TdWRr(D) | TwC1 + TrC - 80 | TwCl + TrC - 70 | TwC1 + 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: VIH = 2.0 V VIL = 0.8 V VIHC = VCC -0.6 V VILC = 0.45 V V<sub>OH</sub> = 2.0 V V<sub>OL</sub> = 0.8 V FLOAT = ±0.5 V ## APPENDIX E Z80 DIRECT MEMORY ADDRESS (DMA) ## 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 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. CPU +5V INT RDY IEI ZCITO CTC ZCITO2 INT IEO RECA INT TRCA IEO RACB TXCB WIRDVA WIRDVA WIRDVB SHO DMA 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 certair 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 2 M 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 10K 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 M1 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{M1}$ are both active simultaneously, an interrupt acknowledge is indicated. MI. 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, MI is active as each opcode byte is fetched. An interrupt acknowledge is indicated when both $\overline{\text{MT}}$ and $\overline{\text{IORQ}}$ 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 CE/WAIT 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: WRO-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 WRO 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 Status byte RRO RR6 #### **Read Registers** 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) 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 WRO (bits DO, DI and D7), and also contains I'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 Read Register 0 0, D<sub>4</sub> D<sub>5</sub> D<sub>4</sub> D<sub>5</sub> D<sub>2</sub> D<sub>1</sub> D<sub>5</sub> | X | X | X | STATUS BYTE | 1 = DMA OPERATION HAS OCCURRED | 0 = READY ACTIVE | 0 = INTERRUPT PENDING | 0 = MATCH FOUND | 0 = END OF BLOCK | Read Register 1 | BYTE COUNTER (LOW BYTE) 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. | Reco | d Re | gist | er 2 | | | |--------|------|------|---------|--------|------------------------------------| | | I | I | | $\Box$ | BYTE COUNTER (HIGH BYTE) | | Rea | d Re | gist | er 3 | | | | | I | I | Ш | ПТ | PORT A ADDRESS COUNTER (LOW BYTE) | | Reco | i Re | glet | er 4 | | | | П | I | L | П | Ш | PORT A ADDRESS COUNTER (HIGH BYTE) | | Rea | l Re | glet | er 5 | | | | | I | L | $\prod$ | | PORT B ADDRESS COUNTER (LOW BYTE) | | Rea | i Re | gist | er 6 | | | | $\Box$ | I | I | П | П | PORT B ADDRESS COUNTER (HIGH BYTE) | Figure 9. Sample DMA Program | Comments | 6 | å | Ds | ۲۵ | చ | Ž | á | å | нех | |---------------------------------------------------------------|--------------|----------------------------------------|--------------------------|----------------------------------------------|---------------------------------------|------------------------------------|--------------------------|----------------|-------------| | C. C | c | - | | - | - | 0 | 0 | 1 | 79 | | block length, Port A start- | > | Block Length | Block Length | Port A | Port A | B A A | - | | | | ing address and temporarily sets Port B as source. | | Follows | Follows | Address | Address | lor | Transfer, No Search | Jo Search | | | | | | | SMOIDL | S S S S S S S S S S S S S S S S S S S | Address | | | | | Port A address (lower) | 0 | - | 0 | - | 0 | 0 | 0 | 0 | 50 | | Port A address (upper) | 0 | o | 0 | - | 0 | 0 | 0 | 0 | 10 | | Block length (lower) | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 8 | | Block length (upper) | 0 | ٥ | 0 | - | 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 | †<br>Address<br>Increments | 0<br>Port is<br>Memory | - | 0 | 0 | 14 | | WR2 defines Port B as peripheral with fixed address. | 0 | 0<br>No Timing<br>Follows | 1<br>Fixed<br>Address | 0 | Port is | 0 | + | 0 | 28 | | WR4 sets mode to Burst, sets DMA to expect Port B address. | <del>-</del> | 1<br>Burst | Durst Mode | 0<br>No interrupt<br>Control Byte<br>Follows | 0<br>No Upper<br>Address | Port B Lower<br>Address<br>Follows | 0 | _ | | | Port B address (lower) | 0 | 0 | 0 | 0 | 0 | 1 | 0 | - | <b>\$</b> 0 | | WR5 sets Ready active High. | - | 0 | 0<br>No Auto<br>Restart | 0<br>No Wait<br>States | 1<br>RDY<br>Active High | 0 | - | 0 | 8 <b>A</b> | | WR6 loads Port B address<br>and resets block counter. | - | - | 0 | 0 | 1 | - | . 1 | - | ç | | WR0 sets Port A as source.* | 0 | 0 | 0<br>No Addres<br>Length | 0 0<br>No Address or Block<br>Length Bytes | 0 | A 🔻 B | 0<br>Transfer, No Search | 1<br>40 Search | 55 | | WR6 loads Port A address<br>and resets block counter. | - | - | 0 | 0 | - | - | - | - | Ç | | WR6 enables DMA to start operation. | - | 0 | 0 | 0 | 0 | * | ₩. | - | 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. 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) **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<sub>3</sub> 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 inserted wait cycle between $T_2$ and $T_3$ . If the $\overline{\text{CE/WAIT}}$ line is programmed to act as a $\overline{\text{WAIT}}$ 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 $\overline{\text{CE/WAIT}}$ is Low during this time another T-cycle is added, during which the $\overline{\text{CE/WAIT}}$ 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 Active State Timing (DMA as Bus Controller) (Continued) 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. Figure 14. Variable-Cycle and Edge Timing 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 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 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 BAT 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) # APPENDIX F FLOPPY DISK CONTROLLER (FDC) ### WESTERN DIGITAL ### WD279X-02 Floppy Disk Formatter/Controller Family #### **FEATURES** - · ON-CHIP PLL DATA SEPARATOR - · ON-CHIP WRITE PRECOMPENSATION LOGIC - SINGLE +5V SUPPLY - ACCOMMODATES SINGLE AND DOUBLE DENSITY FORMATS IBM 3740 (FM) IBM 34 (MFM) - AUTOMATIC SEEK WITH VERIFY - MULTIPLE SECTOR READ/WRITE - TTL COMPATIBLE - PROGRAMMABLE CONTROL SELECTABLE TRACK-TO-TRACK ACCESS HEAD LOAD TIMING - SOFTWARE COMPATIBLE WITH THE FD179X SERIES - SOFT SECTOR FORMAT COMPATIBILITY #### **APPLICATIONS** 8" FLOPPY AND 51/4" MINI FLOPPY CONTROLLER SINGLE OR DOUBLE DENSITY CONTROLLER/FORMATTER The WD279X Family are MOS/LSI devices which perform the functions of a Floppy Disk Controller/Formatter. Software compatible with its predecessor, the FD179X, the device also contains a high performance Phase-Lock-Loop Data Separator as well as Write Precompensation Logic. When operating in Double Density mode, Write Precompensation is automatically engaged to a value programmed via an external potentiometer. An on-chip VCO and phase comparator allows adjustable frequency range for 51/4 " or 8" Floppy Disk interfacing. The WD279X is fabricated in NMOS silicon gate technology and available in a 40 pin dual-in-line ceramic or plastic package. | FEATURES | 2791 | 2793 | 2795 | 2797 | |----------------------|------|------|------|------| | Single Density (FM) | Х | x | X | Х | | Double Density (MFM) | Х | Х | Х | x | | True Data Bus | 1 | Х | 1 | x | | Inverted Data Bus | Х | | X | | | Side Select Out | ļ | | X | X | | Internal CLK Divide | Х | X | | | Figure 1. #### PIN OUTS | PIN<br>NUMBER | PIN NAME | SYMBOL | FUNCTION | |---------------|-----------------------|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 1 | ENABLE PRECOMP | ENP | A Logic high on this input enables write precompensation to be performed on the Write Data output. | | 19 | MASTER RESET | MR | A logic low (50 microseconds min.) on this input resets the device and loads HEX 03 into the command register. The Not Ready (Status Bit 7) is reset during MR ACTIVE. When MR is brought to a logic high a RESTORE Command is executed, regardless of the state of the Ready signal from the drive. Also, HEX 01 is loaded into sector register. | | 20 | POWER SUPPLIES | VSS | Ground | | 21 | | VCC | +5V ±5% | | COMPUTER IN | <br> TERFACE: | | | | 2 | WRITE ENABLE | WE | A logic low on this input gates data on the DAL into the selected register when $\overline{\text{CS}}$ is low. | | 3 | CHIP SELECT | <u>CS</u> | A logic low on this input selects the chip and enables computer communication with the device. | | 4 | READ ENABLE | RE | A logic low on this input controls the placement of data from a selected register on the DAL when $\overline{\text{CS}}$ is low. | | 5, 6 | REGISTER SELECT LINES | A0, A1 | These inputs select the register to receive/transfer data on the DAL lines under RE and WE control: | | | | | CS | | 7-14 | DATA ACCESS LINES | DAL0-DAL7 | Eight bit bi-directional bus used for transfer of commands, status, and data. These lines are inverted (active low) on WD2791 and WD2795. | | 24 | CLOCK | CLK | This input requires a free-running 50% duty cycle square wave clock for internal timing reference, 2 MHz ± 1% for 8" drives, 1 MHz ± 1% for minifloppies. | | 38 | DATA REQUEST | DRQ | This output indicates that the Data Register contains assembled data in Read operations, or the DR is empty in Write operations. This signal is reset when serviced by the computer through reading or loading the DR. | | . 39 | INTERRUPT REQUEST | INTRQ | This output is set at the completion of any command and is reset when the Status register is read or the Command register is written to. | | FLOPPY DISK | INTERFACE: | | | | 15 | STEP | STEP | The step output contains a pulse for each step. | | 16 | DIRECTION | DIRC | Direction Output is active high when stepping in active low when stepping out. | | 17 | 51/4," 8" SELECT | 5/8 | This input selects the internal VCO frequency for use with 51/4" drives or 8" drives. | | 18 | READ PULSE WIDTH | RPW | An external potentiometer tied to this input controls the phase comparator within the data separator. | | PIN | | | | |--------|------------------------------------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | NUMBER | PIN NAME | SYMBOL | FUNCTION | | 22 | TEST | TEST | A logic low on this input allows adjustment of exter-<br>nal resistors by enabling internal signals to appear on<br>selected pins. | | 23 | PUMP | PUMP | High-Impedance output signal which is forced high or low to increase/decrease the VCO frequency. | | 25 | ENABLE MINI-FLOPPY<br>(2791, 2793) | ENMF | A logic low on this input enables an internal +2 of the Master Clock when 5/8 is also at a logic 0. This allows both 51/4" and 8" drive operation with a single 2 MHz clock. For a 1 MHz clock on Pin 24, this line must be left open or tied to a Logic 1. | | 25 | SIDE SELECT OUTPUT<br>(2795, 2797) | sso | The logic level of the Side Select Output is directly controlled by the 'S' flag in Type II or III commands. When U = 1, SSO is set to a logic 1. When U = 0, SSO is set to a logic 0. The SSO is compared with the side information in the Sector I.D. Field. If they do not compare Status Bit 4 (RNF) is set. The Side Select Output is only updated at the beginning of a Type II or III command. It is forced to a logic 0 upon a MASTER RESET condition. | | 26 | VOLTAGE-CONTROLLED<br>OSCILLATOR | VCO | An external capacitor tied to this pin adjusts the VCO center frequency. | | 27 | RAW READ | RAW READ | The data input signal directly from the drive. This input shall be a negative pulse for each recorded flux transition. | | 28 | HEAD LOAD | HLD | The HLD output controls the loading of the Read-<br>Write head against the media. | | 29 | TRACK GREATER<br>THAN 43 | TG43 | This output informs the drive that the Read/Write head is positioned between tracks 44-76. This output is valid only during Read and Write Commands. | | 30 | WRITE GATE | WG | This output is made valid before writing is to be performed on the diskette. | | 31 | WRITE DATA | WD | A 250ns (MFM) or 500 ns (FM) output pulse per flux transition. WD contains the unique Address marks as well as data and clock in both FM and MFM formats. | | 32 | READY | READY | This input indicates disk readiness and is sampled for a logic high before Read or Write commands are performed. If Ready is low the Read or Write operation is not performed and an interrupt is generated. Type I operations are performed regardless of the state of Ready. The Ready input appears in inverted format as Status Register bit 7. | | 33 | WRITE PRECOMP<br>WIDTH | WPW | An external potentiometer tied to this input controls the amount of delay in Write precompensation mode. | | 34 | TRACK 00 | TROO | This input informs the WD279X that the Read/Write head is positioned over Track 00. | | 35 | INDEX PULSE | ĪP | This input informs the WD279X when the index hole is encountered on the diskette. | | PIN NUMBER | PIN NAME | SYMBOL | FUNCTION | |------------|------------------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 36 | WRITE PROTECT | WPRT | This input is sampled whenever a Write Command is received. A logic low terminates the command and sets the Write Protect Status bit. | | 37 | DOUBLE DENSITY | DDEN | This input pin selects either single or double density operation. When $\overline{\text{DDEN}} = 0$ , double density is selected. When $\overline{\text{DDEN}} = 1$ , single density is selected. | | 40 | HEAD LOAD TIMING | HLT | When a logic high is found on the HLT input the head is assumed to be engaged. It is typically derived from a 1 shot triggered by HLD. | #### **GENERAL DESCRIPTION** The WD279X are N-Channel Silicon Gate MOS LSI devices which perform the functions of a Floppy Disk Formatter/Controller in a single chip implementation. The WD279X, which can be considered the end result of both the FD1771 and FD179X designs, is IBM 3740 compatible in single density mode (FM) and System 34 compatible in Double Density Mode (MFM). The WD279X contains all the features of its predecessor the FD179X plus a high performance Phase-Lock-Loop Data Separator as well as Write Precompensation Logic. In Double Density mode, Write Precompensation is automatically engaged to a value programmed via an external potentiometer. In order to maintain compatibility, the FD1771, FD179X and WD279X designs were made as close as possible with the computer interface, instruction set, and I/O registers being identical. Also, head load control is identical. In each case, the actual pin assignments vary by only a few pins from any one to another. The processor interface consists of an 8-bit bi-directional bus for data, status, and control word transfers. The WD279X is set up to operate on a multiplexed bus with other bus-oriented devices. The WD279X is TTL compatible on all inputs and outputs. The outputs will drive one TTL load or three LS loads. The 2793 is identical to the 2791 except the DAL lines are TRUE for systems that utilize true data busses. The 2795/7 has a side select output for controlling double sided drives. #### **ORGANIZATION** The Floppy Disk Formatter block diagram is illustrated on page 5. The primary sections include the parallel processor interface and the Floppy Disk interface. Data Shift Register — This 8-bit register assembles serial data from the Read Data input (RAW READ) during Read operations and transfers serial data to the Write Data output during Write operations. Data Register — This 8-bit register is used as a holding register during Disk Read and Write operations in Disk Read operations the assembled data byte is transferred in parallel to the Data Register from the Data Shift Register. In Disk Write operations information is transferred in parallel from the Data Register to the Data Shift Register. When executing the Seek command the Data Register holds the address of the desired Track position, This register is loaded from the DAL and gated onto the DAL under processor control. Track Register — This 8-bit register holds the track number of the current Read/Write head position. It is incremented by one every time the head is stepped in (towards track 76) and decremented by one when the head is stepped out (towards track 00). The contents of the register are compared with the recorded track number in the ID field during disk Read, Write and Verify operations. The Track Register can be loaded from or transferred to the DAL. This Register should not be loaded when the device is busy. Sector Register (SR) — This 8-bit register holds the address of the desired sector position. The contents of the register are compared with the recorded sector number in the ID field during disk Read or Write operations. The Sector Register contents can be loaded from or transferred to the DAL. This register should not be loaded when the device is busy. Command Register (CR) — This 8-bit register holds the command presently being executed. This register should not be loaded when the device is busy unless the new command is a force interrupt. The command register can be loaded from the DAL, but not read onto the DAL. Status Register (STR) — This 8-bit register holds device Status information. The meaning of the Status bits is a function of the type of command previously executed. This register can be read onto the DAL, but not loaded from the DAL. **CRC Logic** — This logic is used to check or to generate the 16-bit Cyclic Redundancy Check (CRC). The polynomial is: $G(x) = x^{16} + x^{12} + x^5 + 1$ . The CRC includes all information starting with the address mark and up to the CRC characters. The CRC register is preset to ones prior to data being shifted through the circuit Arithmetic/Logic Unit (ALU) — The ALU is a serial comparator, incrementer, and decrementer and is used for register modification and comparisons with the disk recorded ID field **Timing and Control** — All computer and Floppy Disk interface controls are generated through this logic. The internal device timing is generated from an external crystal clock. AM Detector — The address mark detector detects ID, data and index address marks during read and write operations. Write Precompensation — enables write precompensation to be performed on the Write Data output. WD279X BLOCK DIAGRAM Data Separator — a high performance Phase-Lock-Loop Data Separator with on-chip VCO and phase comparator allows adjustable frequency range for 51/4" or 8" Floppy Disk interfacing. #### PROCESSOR INTERFACE The interface to the processor is accomplished through the eight Data Access Lines (DAL) and associated control signals. The DAL are used to transfer Data, Status, and Control words out of, or into the WD279X. The DAL are three state buffers that are enabled as output drivers when Chip Select ( $\overline{CS}$ ) and Read Enable ( $\overline{RE}$ ) are active (low logic state) or act as input receivers when $\overline{CS}$ and Write Enable ( $\overline{WE}$ ) are active. When transfer of data with the Floppy Disk Controller is required by the host processor, the device address is decoded and $\overline{\text{CS}}$ is made low. The address bits A1 and A0, combined with the signals $\overline{\text{RE}}$ during a Read operation or $\overline{\text{WE}}$ during a Write operation are interpreted as selecting the following registers: | A1_ | - A0 | READ (RE) | WRITE (WE) | |-----|------|-----------------|------------------| | 0 | 0 | Status Register | Command Register | | 0 | 1 | Track Register | Track Register | | 1 | 0 | Sector Register | Sector Register | | 1 | 1 | Data Register | Data Register | During Direct Memory Access (DMA) types of data transfers between the Data Register of the WD279X and the processor, the Data Request (DRQ) output is used in Data Transfer control. This signal also appears as status bit 1 during Read and Write operations. On Disk Read operations the Data Request is activated (set high) when an assembled serial input byte is transferred in parallel to the Data Register. This bit is cleared when the Data Register is read by the processor. If the Data Register is read after one or more characters are lost, by having new data transferred into the register prior to processor readout, the Lost Data bit is set in the Status Register. The Read operation continues until the end of sector is reached. On Disk Write operations the data Request is activated when the Data Register transfers its contents to the Data Shift Register, and requires a new data byte. It is reset when the Data Register is loaded with new data by the processor. If new data is not loaded at the time the next serial byte is required by the Floppy Disk, a byte of zeroes is written on the diskette and the Lost Data bit is set in the Status Register. At the completion of every command an INTRQ is generated. INTRQ is reset by either reading the status register or by loading the command register with a new command. In addition, INTRQ is generated if a Force Interrupt command condition is met. The 279X has two modes of operation according to the state of $\overline{\text{DDEN}}$ (Pin 37). When $\overline{\text{DDEN}} = 1$ , Single Density (FM) is selected. When $\overline{\text{DDEN}} = 0$ , Double Density (MFM) is selected. In either case, the CLK input (Pin 24) is set at 2 MHz for 8" drives or 1 MHz for 51/4" drives. On the 2791/2793, the $\overline{\text{ENMF}}$ input (Pin 25) can be used for controlling both 51/4" and 8" drives with a single 2 MHz clock. When $\overline{\text{ENMF}}=0$ , an internal $\div$ 2 of the CLK is performed. When $\overline{\text{ENMF}}=1$ , no divide takes place. This allows the use of a 2 MHz clock for both 51/4" and 8" configurations. The internal VCO frequency must also be set to the proper value. The $\overline{5}/8$ input (Pin 17) is used to select data separator operation by internally dividing the Read Clock. When $\overline{5}/8 = 0$ , 51/4 " data separation is selected; when 5/8 = 1, 8" drive data separation is selected. | CLOCK (24) | ENMF (25) | 5/8 (17) | DRIVE | |------------|-----------|----------|-------| | 2 MHz | 1 | 1 | 8″ | | 2 MHz | 0 | 0 | 51/4" | | 1 MHz | 1 | 0 | 51/4" | Note: All other conditions invalid. #### **FUNCTIONAL DESCRIPTION** The WD279X-02 is software compatible with the FD179X-02 series of Floppy Disk Controllers. Commands, status, and data transfers are performed in the same way. Software generated for the 179X can be transferred to a 279X system without modification. In addition to the 179X, the 279X contains an internal Data Separator and Write precompensation circuit. The TEST (Pin 22) line is used to adjust both data separator and precompensation. When TEST = 0, the WD (Pin 31) line is internally connected to the output of the write precompone-shot. Adjustment of the WPW (Pin 33) line can then be accomplished. A second one-shot tracks the precomp setting at approximately 3:1 to insure adequate Write Data pulse widths to meet drive specifications. Similarly, Data separation is also adjusted with $\overline{\text{TEST}}=0$ . The TG43 (Pin 29) line is internally connected to the output of the read data one-shot, which is adjusted via the RPW (Pin 18) line. The DIRC (Pin 16) line contains the Read Clock output (.5 MHz for 8" drives). The VCO Trimming capacitor (Pin 26) is adjusted for center frequency. Internal timing signals are used to generate pulses during the adjustment mode so that these adjustments can be made while the device is in-circuit. The TEST line also contains a pull-up resistor, so adjustments can be performed simply by grounding the TEST pin, overriding the pull-up. The TEST pin cannot be used to disable stepping rates during operation as its function is quite different from the 179X. Other pins on the device also include pull-up resistors and may be left open to satisfy a Logic 1 condition. These are: ENP, 5/8, ENMF, WPRT, and DDEN. #### **GENERAL DISK READ OPERATIONS** Sector lengths of 128, 256, 512 or 1024 are obtainable in either FM or MFM formats. For FM, DDEN should be placed to logical "1." For MFM formats, DDEN should be | Sector L | ength Table* | |------------------------------|-------------------------------------| | Sector Length<br>Field (hex) | Number of Bytes in Sector (decimal) | | 00 | 128 | | 01. | 256 | | 02 | 512 | | 03 | 1024 | <sup>\* 2795/97</sup> may vary — see command summary. placed to a logical "0." Sector lengths are determined at format time by the fourth byte in the "ID" field. The number of sectors per track as far as the 279X is concerned can be from 1 to 255 sectors. The number of tracks as far as the 279X is concerned is from 0 to 255 tracks. For IBM 3740 compatibility, sector lengths are 128 bytes with 26 sectors per track. For System 34 compatibility (MFM), sector lengths are 256 bytes/sector with 26 sectors/track; or lengths of 1024 bytes/sector with 8 sectors/track. #### **GENERAL DISK WRITE OPERATION** When writing is to take place on the diskette the Write Gate (WG) output is activated, allowing current to flow into the Read/Write head. As a precaution to erroneous writing the first data byte must be loaded into the Data Register in response to a Data Request from the 279X before the Write Gate signal can be activated. Writing is inhibited when the Write Protect input is a logic low, in which case any Write command is immediately terminated, an interrupt is generated and the Write Protect status bit is set For write operations, the 279X provides Write Gate (Pin 30) and Write Data (Pin 31) outputs. Write data consists of a series of pulses set to a width approximately three times greater than the precomp adjustment. Write Data provides the unique address marks in both formats. #### READY Whenever a Read or Write command (Type II or III) is received the 297X samples the Ready input. If this input is logic low the command is not executed and an interrupt is generated. All Type I commands are performed regardless of the state of the Ready input. Also, whenever a Type II or III command is received, the TG43 signal output is updated. TG43 may be tied to ENP to enable write precompensation on tracks 44-76. #### COMMAND DESCRIPTION The WD279X will accept eleven commands. Command words should only be loaded in the Command Register when the Busy status bit is off (Status bit 0). The one exception is the Force Interrupt command. Whenever a command is being executed, the Busy status bit is set. When a command is completed, an interrupt is generated and the Busy status bit is reset. The Status Register indicates whether the completed command encountered an error or was fault free. For ease of discussion, commands are divided into four types. Commands and types are summarized in Table 1. #### TABLE 1. COMMAND SUMMARY | Α | Commands for | or Models: | 2791, 2793 | |------|--------------|--------------|------------| | /··. | Committanta | // (VICUCIS. | 2101,2100 | | A. Co | ommands for Models: | 2791, 279 | 33 | | | | | | | B. Co | omma | nas to | r Moa | eis: 2/ | 95, 27 | 9/ | | |-------|---------------------|-----------|----|---|----|-----|----|----------------|----------------|-------|------|--------|-------|---------|--------|----------------|----------------| | | | | | | Bi | its | | | | | | | 8 | its | | | | | Туре | Command | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | ı | Restore | 0 | 0 | 0 | 0 | h | ٧ | r <sub>1</sub> | ro · | 0 | 0 | 0 | 0 | h | ٧ | r <sub>1</sub> | ro | | 1 | Seek | 0 | 0 | 0 | 1 | h | ٧ | r <sub>1</sub> | ro | 0 | 0 | 0 | 1 | h | ٧ | ۲1 | r <sub>0</sub> | | - 1 | Step | 0 | 0 | 1 | T | h | V | Γį | r0 | 0 | 0 | 1 | Т | h | ٧ | ۲1 | r0 | | 1 | Step-in | 0 | 1 | 0 | T | ń | ٧ | <b>[</b> 1 | ro | 0 | 1 | 0 | T | h | ٧ | r <sub>1</sub> | rO | | ı | Step-out | 0 | 1 | 1 | T | h | ٧ | r <sub>1</sub> | LO | 0 | 1 | 1 | T | h | ٧ | ٢1 | LO. | | Ш | Read Sector | 1 | 0 | 0 | m | S | Ε | С | 0 | 1 | 0 | 0 | m | L | Ε | U | 0 | | II. | Write Sector | · 1 | 0 | 1 | m | S | Ε | С | a <sub>0</sub> | 1 | 0 | 1 | m | L | E | U | a <sub>0</sub> | | 111 | Read Address | 1 | 1 | 0 | 0 | 0 | Ε | 0 | 0 | 1 | 1 | 0 | 0 | 0 | Ε | U | 0 | | 111 | Read Track | 1 | 1 | 1 | 0 | 0 | Ε | 0 | 0 | 1 | 1 | 1 | 0 | 0 | Ε | U | 0 | | H | Write Track | 1 | 1 | 1 | 1 | 0 | Ε | 0 | 0 | 1 | 1 | 1 | 1 | 0 | Ε | U | 0 | | IV | Force Interrupt | 1 | 1 | 0 | 1 | lз | 12 | 11 | Ю | 1 | 1 | 0 | 1 | lз | 12 | 11 | 10 | #### FLAG SUMMARY #### TABLE 2. FLAG SUMMARY | 1 | Command | Bit | | Description | |---|------------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------| | | Туре | No(s) | | Description | | | <b>1</b> · | 0, 1 | r1 r0 = Stepping Motor Rate<br>See Table 3 for Rate Summary | | | | 1 | 2 | V = Track Number Verify Flag | V = 0, No verify $V = 1$ , Verify on destination track | | | l | 3 | h = Head Load Flag | h = 0, Unload head at beginning<br>h = 1, Load head at beginning | | | l . | 4 | T = Track Update Flag | T = 0, No update T = 1, Update track register | | | 11 & 111 | 0 | a <sub>0</sub> = Data Address Mark | a <sub>0</sub> = 0, FB (DAM)<br>a <sub>0</sub> = 1, F8 (deleted DAM) | | | И | 1 | C = Side Compare Flag | C = 0, Disable side compare<br>C = 1, Enable side compare | | | 11 & 111 | 1 | U = Update SSO | U = 0, Update SSO to 0<br>U = 1, Update SSO to 1 | | ٠ | II & III | 2 | E = 15 MS Delay | E = 0, No. 15 MS delay<br>E = 1, 15 MS delay (30 MS for 1 MHz) | | | II | 3 | S = Side Compare Flag | S = 0, Compare for side 0<br>S = 1, Compare for side 1 | | | ., | | | LSB's Sector Length in ID Field | | | 11 | 3 | L = Sector Length Flag | 00 01 10 11 | | | • | | • | L = 0 256 512 1024 128 | | | , | | | L = 1 128 256 512 1024 | | | 11 | 4 | m = Multiple Record Flag | m = 0, Single record<br>m = 1, Multiple records | | | IV | 0-3 | Ix = Interrupt Condition F I0 = 1 Not Ready To Read I1 = 1 Ready To Not Read I2 = 1 Index Pulse I3 = 1 Immediate Interrup I3-IC = 0 Terminate With No | ly Transition<br>ly Transition<br>ot, Requires A Reset* | <sup>\*</sup>NOTE: See Type IV Command Description for further information. #### Write Precompensation When operating in Double Density mode (DDEN = 0), the 279X has the capability of providing a user-defined precompensation value for Write Data. An external potentiometer (10K) tied to the WPW signal (Pin 33) allows a setting of 100 to 300 ns from nominal. Setting the Write precomp value is accomplished by forcing the $\overline{\text{TEST}}$ line (Pin 22) to a Logic 0. A stream of pulses can then be seen on the Write Data (Pin 31) line. Adjust the WPW Potentiometer for the desired pulse width. This adjustment may be performed in-circuit since Write Gate (Pin 30) is inactive while $\overline{\text{TEST}} = 0$ . #### **Data Separation** The 279X can operate with either an external data separator or its own internal recovery circuits. The condition of the $\overline{\text{TEST}}$ line (Pin 22) in conjunction with $\overline{\text{MR}}$ (Pin 19) will select internal or external mode. To program the 279X for external VCO, a $\overline{\text{MR}}$ pulse must be applied while $\overline{\text{TEST}}=0$ . A clock equivalent to eight times the data rate (e.g., 4.0 MHz for 8" Double Density) is applied to the VCO input (Pin 26). The feedback reference voltage is available on the Pump output (Pin 23) for external integration to control the VCO. $\overline{\text{TEST}}$ is returned to a Logic 1 for normal operation. Note: To maintain this mode, $\overline{\text{TEST}}$ must be held low whenever $\overline{\text{MR}}$ is applied. For internal VCO operation, the $\overline{\text{TEST}}$ line must be high during the $\overline{\text{MR}}$ pulse, then set to a Logic 0 for the adjustment procedure. A 50K Potentiometer tied to the RPW input (Pin 18) is used to set the internal Read Data pulse for proper phasing. With a scope on Pin 29 (TG43), adjust the RPW pulse for 1/8 of the data rate (250 ns for 8" Double Density). An external variable capacitor of 5-60 pf is tied to the VCO input (Pin 26) for adjusting center frequency. With a frequency counter on Pin 16 (DIRC) adjust the trimmer cap to yield the appropriate Data Rate (500 KHz for 8" Double Density). The DDEN line must be low while the 5/8 line is held high or the adjustment times above will be doubled. After adjustments have been made, the TEST pin is returned to a Logic 1 and the device is ready for operation. Adjustments may be made in-circuit since the DIRC and TG43 lines may toggle without affecting the drive. The PUMP output (Pin 23) consists of positive and negative pulses, which their duration is equivalent to the phase difference of incoming Data vs. VCO frequency. This signal is internally connected to the VCO input, but a Filter is needed to connect these pulses to a slow moving DC voltage. The internal phase-detector is unsymmetrical for a random distribution of data pulses by a factor of two, in favor of a PUMP UP condition. Therefore, it is desirable to have a PUMP DOWN twice as responsive to prevent run-away during a lock attempt. A first order lag-lead filter can be used at the PUMP output (Pin 23). This filter controls the instantaneous response of the VCO to bit-shifted data (jitter) as well as the response to normal frequency shift, i.e., the lock-up time. A balance must be accomplished between the two conditions to inhibit over-responsiveness to jitter and to prevent an extremely wide lock-up response, leading to PUMP runaway. The filter affects these two reactions in mutually opposite directions. The Source Impedance for a PUMP UP/DOWN condition is 600/120 ohms, respectively, therefore the change in bias voltage for each pump can be approximated: $$dV = \begin{array}{c} \displaystyle \frac{dt \, \triangle \, V}{RC} \\ \end{array} \qquad \begin{array}{c} \displaystyle dt \, = \, \, 250 \, \text{ns. (set by RPW)} \\ \displaystyle C \, = \, \, 0.1 \mu f \\ \displaystyle R \, = \, \, RS \, + \, R \\ \displaystyle \triangle \, V \, = \, \, 2.6 \, V \, \text{for PUMP UP} \\ \displaystyle 0.9 V \, \text{for PUMP DOWN} \\ \end{array}$$ Look up response (TL) is the transient time for the Loop to lock from center frequency (FO) to maximum lock range: $$T_L = 10\% F_L \times K_O \times \triangle P$$ Where: KO = VCO Conversion Gain = 3.7KHz/mV F<sub>L</sub> = Lock Range = 4.00 MHz $\triangle P$ = Change in Bias for each Pump = 4 mV/PUMP $400 \text{ KHz} \times 3.7 \text{ KHz} \times 4 \text{ mV} = 27 \text{ pumps}$ 27 pumps = 54 µsec = 3.4 Byte times (8" Double Density) The following Filter Circuit is recommended for 8" FM/MFM: Since 51/4" Drives operate at exactly one-half the data rate (250 Kb/sec) the above capacitor should be doubled to .2 or .22uf. #### TYPE I COMMANDS The Type I Commands include the Restore, Seek, Step, Step-in, and Step-Out commands. Each of the Type I Commands contains a rate field (r<sub>0</sub> r<sub>1</sub>), which determines the stepping motor rate as defined in Table 3. A $2\mu s$ (MFM) or 4 $\mu s$ (FM) pulse is provided as an output to the drive. For every step pulse issued, the drive moves one track location in a direction determined by the direction output. The chip will step the drive in the same direction it last stepped unless the command changes the direction. The Direction signal is active high when stepping in and low when stepping out. The Direction signal is valid 12 $\mu$ s before the first stepping pulse is generated. The rates (shown in Table 3) can be applied to a Step-Direction Motor through the device interface. **TABLE 3. STEPPING RATES** | С | LK | 2 MHz | 1 MHz | |----|-----|----------|----------| | R1 | R0 | TEST = 1 | TEST = 1 | | 0 | 0 | 3 ms | 6 ms | | 0 | - 1 | 6 ms | 12 ms | | 1 | 0 | 10 ms | 20 ms | | 1 | 1 | 15 ms | . 30 ms | After the last directional step an additional 15 milliseconds of head settling time takes place if the Verify flag is set in Type I commands. Note that this time doubles to 30 ms for a 1 MHz clock. There is also a 15 ms head settling time if the E flag is set in any Type II or III command. When a Seek, Step or Restore command is executed an optional verification of Read-Write head position can be performed by setting bit 2 (V = 1) in the command word to a logic 1. The verification operation begins at the end of the 15 millisecond settling time after the head is loaded against the media. The track number from the first encountered ID Field is compared against the contents of the Track Register. If the track numbers compare and the ID Field Cyclic Redundancy Check (CRC) is correct, the verify operation is complete and an INTRQ is generated with no errors. If there is a match but not a valid CRC, the CRC error status bit is set (Status bit 3), and the next encountered ID field is read from the disk for the verification operation. The WD279X must find an 1D field with correct track number and correct CRC within 5 revolutions of the media; otherwise the seek error is set and an INTRQ is generated. If V=0, no verification is performed. The Head Load (HLD) output controls the movement of the read/write head against the media. HLD is activated at the beginning of a Type I command if the h flag is set (h = 1), at the end of the Type I command if the verify flag (V = 1), or upon receipt of any Type II or III command. Once HLD is active it remains active until either a Type I command is received with (h = 0 and V = 0); or if the 279X is in an idle state (non-busy) and 15 index pulses have occurred. Head Load timing (HLT) is an input to the 279X which is used for the head engage time. When HLT=1, the 279X assumes the head is completely engaged. The head engage time is typically 30 to 100 ms depending on drive. The low to high transition on HLD is typically used to fire a one shot. The output of the one shot is then used for HLT and supplied as an input to the 279X. **HEAD LOAD TIMING** When both HLD and HLT are true, the 279X will then read from or write to the media. The "and" of HLD and HLT appears as status Bit 5 in Type I status. In summary for the Type I commands: if h=0 and V=0, HLD is reset. If h=1 and V=0, HLD is set at the beginning of the command and HLT is not sampled nor is there an internal 15 ms delay. If h=0 and V=1, HLD is set near the end of the command, an internal 15 ms occurs, and the 279X waits for HLT to be true. If h=1 and V=1, HLD is set at the beginning of the command. Near the end of the command, after all the steps have been issued, an internal 15 ms delay occurs and the 279X then waits for HLT to occur. For Type II and III commands with E flag off, HLD is made active and HLT is sampled until true. With E flag on, HLD is made active, an internal 15 ms delay occurs and then HLT is sampled until true. #### RESTORE (SEEK TRACK 0) Upon receipt of this command the Track 00 (TR00) input is sampled. If TR00 is active low indicating the Read-Write head is positioned over track 0, the Track Register is loaded with zeroes and an interrupt is generated. If TR00 is not active low, stepping pulses (pins 15 to 16) at a rate specified by the f1f0 field are issued until the TR00 input is activated. At this time the Track Register is loaded with zeroes and an interrupt is generated. If the TR00 input does not go active low after 255 stepping pulses, the 279X terminates operation, interrupts, and sets the Seek error status bit. A verification operation takes place if the V flag is set. The h bit allows the head to be loaded at the start of command. Note that the Restore command is executed when MR goes from an active to an inactive state. #### SEEK This command assumes that the Track Register contains the track number of the current position of the Read-Write head and the Data Register contains the desired track number. The WD279X will update the Track register and issue stepping pulses in the appropriate direction until the TYPE I COMMAND FLOW TYPE I COMMAND FLOW contents of the Track register are equal to the contents of the Data Register (the desired track location). A verification operation takes place if the V flag is on. The h bit allows the head to be loaded at the start of the command. An interrupt is generated at the completion of the command. Note: When using multiple drives, the track register must be updated for the drive selected before seeks are issued. #### STEP Upon receipt of this command, the 279X issues one stepping pulse to the disk drive. The stepping motor direction is the same as in the previous step command. After a delay determined by the <sup>r170</sup> field, a verification takes place if the V flag is on. If the T flag is on, the Track Register is updated. The h bit allows the head to be loaded at the start of the command. An interrupt is generated at the completion of the command. #### STEP-IN Upon receipt of this command, the 279X issues one stepping pulse in the direction towards track 76. If the T flag is on, the Track Register is incremented by one. After a TYPE I COMMAND FLOW delay determined by the f1f0 field, a verification takes place if the V flag is on. The h bit allows the head to be loaded at the start of the command. An interrupt is generated at the completion of the command. #### STEP-OUT Upon receipt of this command, the 279X issues one stepping pulse in the direction towards track 0. If the T flag is on, the Track Register is decremented by one. After a delay determined by the F1F0 field, a verification takes place if the V flag is on. The h bit allows the head to be loaded at the start of the command. An interrupt is generated at the completion of the command. #### **EXCEPTIONS** On the 2795/7 devices, the SSO output is not affected during Type I commands, and an internal side compare does not take place when the (V) Verify Flag is on. #### TYPE II COMMANDS The Type II Commands are the Read Sector and Write Sector commands. Prior to loading the Type II Command into the Command Register, the computer must load the Sector Register with the desired sector number. Upon receipt of the Type II command, the busy status Bit is set. If the E flag = 1 (this is the normal case) HLD is made active and HLT is sampled after a 15 msec delay. If the E flag is 0, the head is loaded and HLT sampled with no 15 msec delay. When an ID field is located on the disk, the 279X compares the Track Number on the ID field with the Track Register. If there is not a match, the next encountered ID field is read and a comparison is again made. If there was a match, the Sector Number of the ID field is compared with the Sector Register. If there is not a Sector match, the next encountered ID field is read off the disk and comparisons again made. If the ID field CRC is correct, the data field is then located and will be either written into, or read from TYPE II COMMAND TYPE II COMMAND depending upon the command. The 279X must find an ID field with a Track number, Sector number, side number, and CRC within 5 revolutions of the disk; otherwise, the Record not found status bit is set (Status bit 4) and the command is terminated with an interrupt. Each of the Type II Commands contains an (m) flag which determines if multiple records (sectors) are to be read or written, depending upon the command. If m=0, a single sector is read or written and an interrupt is generated at the completion of the command. If m=1, multiple records are read or written with the sector register internally updated so that an address verification can occur on the next record. The 279X will continue to read or write multiple records and update the sector register in numerical ascending sequence until the sector register exceeds the number of sectors on the track or until the Force Interrupt command is loaded into the Command Register, which terminates the command and generates an interrupt. For example: If the 279X is instructed to read sector 27 and there are only 26 on the track, the sector register exceeds #### TYPE II COMMAND the number available. The 279X will search for 5 disk revolutions, interrupt out, reset busy, and set the record not found status bit. The Type II commands for 2791-93 also contain side select compare flags. When C=0 (Bit 1) no side comparison is made. When C=1, the LSB of the side number is read off the ID Field of the disk and compared with the contents of the (S) flag (Bit 3). If the S flag compares with the side number recorded in the ID field, the 279X continues with the ID search. If a comparison is not made within 5 index pulses, the interrupt line is made active and the Record-Not-Found status bit is set. The Type II and III commands for the 2795-97 contain a side select flag (Bit 1). When U=0, SSO is updated to 0. Similarly, U=1 updates SSO to 1. The chip compares the SSO to the ID field. If they do not compare within 5 revolutions the interrupt line is made active and the RNF status bit is set. The 2795/7 READ SECTOR and WRITE SECTOR com- #### TYPE II COMMAND mands include a 'L' flag. The 'L' flag, in conjunction with the sector length byte of the ID Field, allows different byte lengths to be implemented in each sector. For IBM compatibility, the 'L' flag should be set to a one. #### READ SECTOR Upon receipt of the Read Sector command, the head is loaded, the Busy status bit set, and when an ID field is encountered that has the correct track number, correct sector number, correct side number, and correct CRC, the data field is presented to the computer. The Data Address Mark of the data field must be found within 30 bytes in single density and 43 bytes in double density of the last ID field CRC byte; if not, the ID field search is repeated. When the first character or byte of the data field has been shifted through the DSR, it is transferred to the DR, and DRQ is generated. When the next byte is accumulated in the DSR, it is transferred to the DR and another DRQ is generated. If the Computer has not read the previous contents of the DR before a new character is transferred that character is lost and the Lost Data Status bit is set. This sequence continues until the complete data field has been inputted to the computer. If there is a CRC error at the end of the data field, the CRC error status bit is set, and the command is terminated (even if it is a multiple sector command). At the end of the Read operation, the type of Data Address Mark encountered in the data field is recorded in the Status Register (Bit 5) as shown: | STATUS<br>BIT 5 | | | |-----------------|-------------------|--| | 1 | Deleted Data Mark | | | 0 | Data Mark | | #### WRITE SECTOR Upon receipt of the Write Sector command, the head is loaded (HLD active) and the Busy status bit is set. When an ID field is encountered that has the correct track number, correct sector number, correct side number, and correct CRC, a DRQ is generated. The 279X counts off 11 bytes in single density and 22 bytes in double density from the CRC field and the Write Gate (WG) output is made active if the DRQ is serviced (i.e., the DR has been loaded by the computer). If DRQ has not been serviced, the command is terminated and the Lost Data status bit is set. If the DRQ has been serviced, the WG is made active and six bytes of zeroes in single density and 12 bytes in double density are then written on the disk. At this time the Data Address Mark is then written on the disk as determined by the <sup>a</sup>O field of the command as shown below: | a <sub>0</sub> | Data Address Mark (Bit 0) | | |----------------|---------------------------|--| | 1 | Deleted Data Mark | | | 0 | Data Mark | | The 279X then writes the data field and generates DRQ's to the computer. If the DRQ is not serviced in time for continuous writing the Lost Data Status Bit is set and a byte of zeroes is written on the disk. The command is not terminated. After the last data byte has been written on the disk, the two-byte CRC is computed internally and written on the disk followed by one bye of FE in FM or in MFM. The WG output is then deactivated. For a 2 MHz clock the INTRQ will set 8 to 12 $\mu \rm sec$ after the last CRC byte is written. For partial sector writing, the proper method is to write the data and fill the balance with zeroes. By letting the chip fill the zeroes, errors may be masked by the lost data status and improper CRC Bytes. #### TYPES III COMMANDS READ ADDRESS Upon receipt of the Read Address command, the head is loaded and the Busy Status Bit is set. The next encountered ID field is then read in from the disk, and the six data bytes of the ID field are assembled and transferred to the DR, and a DRQ is generated for each byte. The six bytes of the ID field are shown below: | TRACK | SIDE | SECTOR | SECTOR | CRC | CRC | |-------|--------|---------|--------|-----|-----| | ADDR | NUMBER | ADDRESS | LENGTH | 1 | 2 | | - 1 | 2 | 3 | 4 | 5 | 6 | Although the CRC characters are transferred to the #### TYPE III COMMAND WRITE TRACK computer, the 279X checks for validity and the CRC error status bit is set if there is a CRC error. The Track Address of the ID field is written into the sector register so that a comparison can be made by the host. At the end of the operation an interrupt is generated and the Busy Status is reset. #### **READ TRACK** Upon receipt of the READ track command, the head is loaded, and the Busy Status bit is set. Reading starts with the leading edge of the first encountered index pulse and continues until the next index pulse. All Gap, Header, and data bytes are assembled and transferred to the data register and DRQ's are generated for each byte. The ac- TYPE III COMMAND WRITE TRACK cumulation of bytes is synchronized to each address mark encountered. An interrupt is generated at the completion of the command This command has several characteristics which make it suitable for diagnostic purposes. They are: no CRC checking is performed; gap information is included in the data stream; the internal side compare is not performed; and the address mark detector is on for the duration of the command. Because the A.M. detector is always on, write splices or noise may cause the chip to look for an A.M. If an address mark does not appear on schedule with the Lost Data status flag being set. The ID A.M., ID field, ID CRC bytes, DAM, Data and Data CRC Bytes for each sector will be correct. The Gap Bytes may be read incorrectly during write-splice time because of synchronization. #### WRITE TRACK FORMATTING THE DISK (Refer to section on Type III commands for flow diagrams.) Formatting the disk is a relatively simple task when operating programmed I/O or when operating under DMA with a large amount of memory. Data and gap information must be provided at the computer interface. Formatting the disk is accomplished by positioning the R/W head over the desired track number and issuing the Write Track command. Upon receipt of the Write Track command, the head is loaded and the Busy Status bit is set. Writing starts with the leading edge of the first encountered index pulse and continues until the next index pulse, at which time the interrupt is activated. The Data Request is activated immediately upon receiving the command, but writing will not start until after the first byte has been loaded into the Data Register. If the DR has not been loaded by the time the index pulse is encountered the operation is terminated making the device Not Busy, the Lost Data Status Bit is set, and the interrupt is activated. If a byte is not present in the DR when needed, a byte of zeroes is substituted. This sequence continues from one index mark to the next index mark. Normally, whatever data pattern appears in the data register is written on the disk with a normal clock pattern. However, if the 279X detects a data pattern of F5 thru FE in the data register, this is interpreted as data address marks with missing clocks or CRC generation. The CRC generator is initialized when any data byte from F8 to FE is about to be transferred from the DR to the DSR #### CONTROL BYTES FOR INITIALIZATION | | | •• | |-----------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | DATA PATTERN<br>IN DR (HEX) | WD279X INTERPRETATION<br>IN FM (DDEN = 1) | WD279X INTERPRETATION<br>IN MFM (DDEN = 0) | | 00 thru F4 F5 F6 F7 F8 thru FB FC FD FE | Write 00 thru F4 with CLK = FF Not Allowed Not Allowed Generate 2 CRC bytes Write F8 thru FB, Clk = C7, Preset CRC Write FC with Clk = D7 Write FD with Clk = FF Write FE, Clk = C7, Preset CRC Write FF with Clk = FF | Write 00 thru F4, in MFM Write A1* In MFM, Preset CRC Write C2** in MFM Generate 2 CRC bytes Write F8 thru FB, in MFM Write FC in MFM Write FE in MFM Write FE in MFM Write FE in MFM Write FE in MFM | <sup>\*</sup> Missing clock transition between bits 4 and 5 <sup>\*\*</sup> Missing clock transition between bits 3 and 4 or by receipt of F5 in MFM. An F7 pattern will generate two CRC characters in FM or MFM. As a consequence, the patterns F5 thru FE must not appear in the gaps, data fields, or ID fields. Also, CRC's must be generated by an F7 pattern. Disks may be formatted in IBM 3740 or System 34 formats with sector lengths of 128, 256, 512, or 1024 bytes. #### **TYPE IV COMMANDS** The Forced Interrupt command is generally used to terminate a multiple sector read or write command or to insure Type I status in the status register. This command can be loaded into the command register at any time. If there is a current command under execution (busy status bit set) the command will be terminated and the busy status bit reset. The lower four bits of the command determine the conditional interrupt as follows: 0 = Not-Ready to Ready Transition 11 = Ready to Not-Ready Transition 12 = Every Index Pulse 13 = Immediate Interrupt The conditional interrupt is enabled when the corresponding bit positions of the command ( $^{1}3 \cdot ^{1}0$ ) are set to a 1. Then, when the condition for interrupt is met, the INTRQ line will go high signifying that the condition specified has occurred. If $^{1}3 \cdot ^{1}0$ are all set to zero (HEX D0), no interrupt will occur but any command presently under execution will be immediately terminated. When using the immediate interrupt condition ${}^{1}3 = 1$ ), an interrupt will be immediately generated and the current command terminated. Reading the status or writing to the command register will not automatically clear the interrupt. The HEX D0 is the only command that will enable the immediate interrupt (HEX D8) to clear on a subsequent load command register or read status register operation. Follow a HEX D8 with D0 command. Wait 8 micro sec (double density) or 16 micro sec (single density) before issuing a new command after issuing a forced interrupt (times double when clock = 1 MHz). Loading a new command sooner than this will nullify the forced interrupt. Forced interrupt stops any command at the end of an internal micro-instruction and generates INTRQ when the specified condition is met. Forced interrupt will wait until ALU operations in progress are complete (CRC calculations, compares, etc.) More than one condition may be set at a time. If for example, the READY TO NOT-READY condition ( $^{1}1 = 1$ ) and the Every Index Pulse ( $^{1}2 = 1$ ) are both set, the resultant command would be HEX "DA." The "OR" function is performed so that either a READY TO NOT-READY or the next Index Pulse will cause an interrupt condition. #### STATUS REGISTER Upon receipt of any command, except the Force Interrupt command, the Busy Status bit is set and the rest of the status bits are updated or cleared for the new command. If the Force Interrupt Command is received when there is a current command under execution, the Busy status bit is reset, and the rest of the status bits are unchanged. If the Force Interrupt command is received when there is not a current command under execution, the Busy Status bit is reset and the rest of the status bits are updated or cleared. In this case, Status reflects the Type I commands. The user has the option of reading the status register through program control or using the DRQ line with DMA or interrupt methods. When the Data register is read the DRQ bit in the status register and the DRQ line are automatically reset. A write to the Data register also causes both DRQ's to reset. The busy bit in the status may be monitored with a user program to determine when a command is complete, in lieu of using the INTRQ line. When using the INTRQ, a busy status check is not recommended because a read of the status register to determine the condition of busy will reset the INTRQ line. The format of the Status Register is shown below: | | | | (BI | TS) | | | | | | |----|----|----|-----|-----|----|----|----|--|--| | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | S7 | S6 | S5 | S4 | S3 | S2 | S1 | S0 | | | Status varies according to the type of command executed as shown in Table 4. Because of internal sync cycles, certain time delays must be observed when operating under programmed I/O. They are: (times double when clock = 1 MHz) | | | Delay Req'd. | | | |--------------------------|---------------------------------|--------------|------|--| | Operation | Next Operation | FM | MFM | | | Write to<br>Command Reg. | Read Busy Bit<br>(Status Bit 0) | 12µs | 6µs | | | Write to<br>Command Reg. | Read Status<br>Bits 1-7 | 28µs | 14µs | | | Write Any<br>Register | Read From Diff.<br>Register | 0 | 0 | | #### IBM 3740 FORMAT -- 128 BYTES/SECTOR Shown below is the IBM single-density format with 128 bytes/sector. In order to format a diskette, the user must issue the Write Track command, and load the data register with the following values. For every byte to be written, there is one Data Request. | NUMBER<br>OF BYTES | HEX VALUE OF<br>BYTE WRITTEN | | | | |--------------------|------------------------------|--|--|--| | 40 | FF (or 00)3 | | | | | 6 | 00 | | | | | 1 | FC (Index Mark) | | | | | 1 26 | FF (or 00) | | | | | 6 | 00 | | | | | 1 1 | FE (ID Address Mark) | | | | | 1 1 | Track Number | | | | | 1 | Side Number (00 or 01) | | | | | 1 | Sector Number (1 thru 1A) | | | | | 1 | 00 (Sector Length) | | | | | 1 1 | F7 (2 CRC's written) | | | | | 11 | FF (or 00) | | | | | 6 | 00 | | | | | 1 | FB (Data Address Mark) | | | | | 128 | Data (IBM uses E5) | | | | | 1 | F7 (2 CRC's written) | | | | | 27 | FF (or 00) | | | | | 2472 | FF (or 00) | | | | - Write bracketed field 26 times Continue writing until 279X interrupts out. Approx. 247 bytes. - 3. A '00' option is allowed on 2795/7 only. #### IBM SYSTEM 34 FORMAT-256 BYTES/SECTOR Shown below is the IBM dual-density format with 256 bytes/sector. In order for format a diskette the user must issue the Write Track command and load the data register with the following values. For every byte to be written, there is one data request. | NUMBER<br>OF BYTES | HEX VALUE OF<br>BYTE WRITTEN | |--------------------|------------------------------| | 80 | 4E | | 12 | 00 | | 3 | F6 (Writes C2) | | 1 | FC (Index Mark) | | * 50 | 4E | | 12 | 00 | | 3 | F5 (Writes A1) | | 1 1 | FE (ID Address Mark) | | 1 1 | Track Number (0 thru 4C) | | 1 | Side Number (0 or 1) | | 1 1 | Sector Number (1 thru 1A) | | 1 | 01 (Sector Length) | | 1 | F7 (2 CRCs written) | | 22 | 4E | | 12 | 00 . | | 3 | F5 (Writes A1) | | 1 1 | FB (Data Address Mark) | | 256 | ··DATA | | 1 | F7 (2 CRCs written) | | 54 | 4E | | 598** | 4E | - \*Write bracketed field 26 times - \*\* Continue writing until 279X interrupts out. Approx. 598 bytes. **IBM TRACK FORMAT** #### 1. NON-IBM FORMATS Variations in the IBM formats are possible to a limited extent if the following requirements are met: - 1) Sector size must be 128, 256, 512 of 1024 bytes. - 2) Gap 2 cannot be varied from the IBM format. - 3) 3 bytes of A1 must be used in MFM. In addition, the Index Address Mark is not required for operation by the 279X. Gap 1, 3, and 4 lengths can be as short as 2 bytes for 279X operation, however PLL lock up time, motor speed variation, write splice area, etc. will add more bytes to each gap to achieve proper operation. It is recommended that the IBM format be used for highest system reliability. | | FM | MFM | |-----------|---------------------------|-----------------------------------------| | Gap I | 16 bytes FF | 32 bytes 4E | | Gap II | 11 bytes FF | 22 bytes 4E | | * | 6 bytes 00 | 12 bytes 00<br>3 bytes A1 | | Gap III** | 10 bytes FF<br>4 bytes 00 | 24 bytes 4E<br>8 bytes 00<br>3 bytes A1 | | Gap IV | 16 bytes FF | 16 bytes 4E | - \* Byte counts must be exact. - \*\* Byte counts are minimum, except exactly 3 bytes of A1 must be written. #### **ELECTRICAL CHARACTERISTICS** Absolute Maximum Ratings Voltage to any input with respect to $V_{SS} = +15 \text{ to } -0.3V$ $C_{IN}$ & $C_{OUT} = 15 \ pF$ max with all pins grounded except one under test. Operating temperature = $0^{\circ}$ C to $70^{\circ}$ C Storage temperature = $-55^{\circ}$ C to $+125^{\circ}$ C NOTE: Maximum limits indicate where permanent device damage occurs. Continuous operation at these limits is not intended and should be limited to those conditions specified in the DC Electrical characteristics. #### **OPERATING CHARACTERISTICS (DC)** $T_A = 0$ °C to 70°C, $V_{SS} = 0$ V, $V_{CC} = +5M \pm .25$ V | SYMBOL | CHARACTERISTIC | MIN. | TYP. | MAX. | UNITS | CONDITIONS | |--------|---------------------|------|------|------|-------|----------------------| | 4L | Input Leakage | | | 10 | μА | VIN = VCC | | lOL | Output Leakage | | | 10 | μΑ | Vout = Vcc | | Viн | Input High Voltage | 2.0 | | ĺ | V | | | VIL | Input Low Voltage | | | 0.8 | V | | | Voн | Output High Voltage | 2.4 | | | V | $i_{O} = -100 \mu A$ | | VOL | Output Low Voltage | 1 | } | 0.45 | V | IO = 1.6 mA | | VOHP | Output High PUMP | 2.2 | | | V | lop = -1.0 mA | | VOLP | Output Low PUMP | | | 0.2 | l v | IOP = +1.0 mA | | PD | Power Dissipation | | | .75 | w | All Outputs Open | | RPU | Internal Pull-up* | 100 | | 1700 | μA | VIN = 0V | | ICC | Supply Current | 1 | 70 | 150 | mA | All Outputs Open | <sup>\*</sup> Internal Pull-up resistors on PINS 1, 17, 22, 25, 37, and 40. #### TIMING CHARACTERISTICS $T_A = 0$ °C to 70°C, $V_{SS} = 0$ V, $V_{CC} = +5$ V $\pm .25$ V #### READ ENABLE TIMING | SYMBOL | CHARACTERISTIC | MIN. | TYP. | MAX. | UNITS | CONDITIONS | |--------|------------------------|------|------|------|-------|-----------------------| | TSET | Setup ADDR & CS to RE | 50 | | | nsec | | | THLD | Hold ADDR & CS from RE | 10 | | 1 | nsec | | | TRE | RE Pulse Width | 200 | j | | nsec | $C_L = 50 \text{pf}$ | | TDRR | DRQ Reset from RE | ļ | 100 | 200 | nsec | | | TIRR | INTRQ Reset from RE | | 500 | 3000 | nsec | See Note | | TDACC | Data Valid from RE | | 100 | 200 | nsec | $C_L = 50 pf$ | | TDOH | Data Hold From RE | 20 | | 150 | nsec | $C_L = 50 pf$ | #### WRITE ENABLE TIMING | SYMBOL | CHARACTERISTIC | MIN. | TYP. | MAX. | UNITS | CONDITIONS | |--------|------------------------|------|------|------|-------|------------| | TSET | Setup ADDR & CS to WE | 50 | | | nsec | | | THLD | Hold ADDR & CS from WE | 10 | | | nsec | <u> </u> | | TWE | WE Pulse Width | 200 | | | nsec | | | TDRR | DRQ Reset from WE | | 100 | 200 | nsec | | | TIRR | INTRQ Reset from WE | | 500 | 3000 | nsec | See Note | | Tps | Data Setup to WE | 150 | | | nsec | | | TDH | Data Hold from WE | 50 | | i | nsec | | WRITE ENABLE TIMING #### INPUT DATA TIMING | SYMBOL | CHARACTERISTIC | MIN. | TYP. | MAX. | UNITS | CONDITIONS | |--------|----------------------|------|------|------|-------|------------| | TpW | Raw Read Pulse Width | 100 | 200 | · | nsec | | | TBC | Raw Read Cycle Time | 1500 | 2000 | | nsec | | #### WRITE DATA TIMING: (ALL TIMES DOUBLE WHEN CLK = 1 MHz) | SYMBOL | CHARACTERISTIC | MIN. | TYP. | MAX. | UNITS | CONDITIONS | |-----------------|--------------------------|------------|--------|-------------|--------------|------------| | T <sub>WP</sub> | Write Data Pulse Width | 400<br>240 | 500 | 600<br>1000 | nsec<br>nsec | FM<br>MFM | | Twg | Write Gate to Write Data | | 2 | | μsec<br>μsec | FM<br>MFM | | TWF | Write Gate off from WD | | 2<br>1 | | μsec<br>μsec | FM<br>MFM | #### MISCELLANEOUS TIMING: | TCD2 Clock I TSTP Step P TDIR Dir Set TMR Master TIP RPW Read W WPW Write I RPW Precor Read W | Duty (low) Duty (high) ulse Output up to Step Pelset Pulse Width Pulse Width Window Pulse Width Data Pulse Width Inp Adjust. Nindow Pulse Width Data Pulse Width | 230<br>230<br>2 or 4<br>50<br>10<br>120<br>240<br>300<br>100<br>120<br>240 | 250<br>250<br>12<br>500 | 700<br>1400<br>250<br>700<br>1400 | nsec nsec usec usec usec usec nsec nsec nsec nsec nsec nsec nsec | See Note ± CLK ERROR See Note Input 0-5V MFM FM ± 15% Input 0-5V MFM FM MFM Input 0-5V MFM Input 0-5V MFM | |-------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------|-------------------------|-----------------------------------|----------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------| | TSTP TDIR TDIR TMR TIP RPW WPW Write I RPW RPW RPW RPW RPW RPW Read V | ulse Output up to Step r Reset Pulse Width Pulse Width Window Pulse Width Data Pulse Width mp Adjust. Window Pulse Width | 2 or 4 50 10 120 240 300 100 120 240 | 12 | 700<br>1400<br>1000<br>250<br>700 | µsec<br>µsec<br>µsec<br>µsec<br>nsec<br>nsec<br>nsec<br>nsec<br>nsec | ± CLK ERROR See Note Input 0-5V MFM FM ± 15% Input 0-5V MFM FM MFM Input 0-5V MFM Input 0-5V MFM | | TDIR TMR TMR TIP RPW WPW Write I RPW Read V | rup to Step r Reset Pulse Width Pulse Width Window Pulse Width Data Pulse Width mp Adjust. Nindow Pulse Width | 50<br>10<br>120<br>240<br>300<br>100<br>120<br>240 | | 1400<br>1000<br>250<br>700 | µsec<br>µsec<br>µsec<br>nsec<br>nsec<br>nsec<br>nsec<br>nsec | ± CLK ERROR See Note Input 0-5V MFM FM ± 15% Input 0-5V MFM FM MFM Input 0-5V MFM Input 0-5V MFM | | TMR TIP RPW RPW Write I Precor RPW Read V | r Reset Pulse Width<br>Pulse Width<br>Vindow Pulse Width<br>Data Pulse Width<br>mp Adjust.<br>Vindow Pulse Width | 10<br>120<br>240<br>300<br>100<br>120<br>240 | | 1400<br>1000<br>250<br>700 | usec<br>usec<br>nsec<br>nsec<br>nsec<br>nsec<br>nsec<br>nsec | See Note Input 0-5V MFM FM ± 15% Input 0-5V MFM FM MFM Input 0-5V MFM Input 0-5V | | TIP RPW Index I Read V WPW Write I Precor RPW Read V | Pulse Width<br>Vindow Pulse Width<br>Data Pulse Width<br>mp Adjust.<br>Vindow Pulse Width | 10<br>120<br>240<br>300<br>100<br>120<br>240 | 500 | 1400<br>1000<br>250<br>700 | nsec<br>nsec<br>nsec<br>nsec<br>nsec<br>nsec | Input 0-5V MFM FM ± 15% Input 0-5V MFM FM MFM Input 0-5V MFM Input 0-5V | | RPW Read W Write I Precor RPW Read W | Vindow Pulse Width Data Pulse Width mp Adjust. Vindow Pulse Width | 120<br>240<br>300<br>100<br>120<br>240 | 500 | 1400<br>1000<br>250<br>700 | nsec<br>nsec<br>nsec<br>nsec<br>nsec | Input 0-5V MFM FM ± 15% Input 0-5V MFM FM MFM Input 0-5V MFM Input 0-5V | | WPW Write I<br>Precor<br>RPW Read V | Data Pulse Width<br>np Adjust.<br>Nindow Pulse Width | 240<br>300<br>100<br>120<br>240 | 500 | 1400<br>1000<br>250<br>700 | nsec<br>nsec<br>nsec<br>nsec | MFM FM ± 15% Input 0-5V MFM FM MFM Input 0-5V MFM | | Precor<br>RPW Read V | np Adjust.<br>Vindow Pulse Width | 240<br>300<br>100<br>120<br>240 | 500 | 1400<br>1000<br>250<br>700 | nsec<br>nsec<br>nsec<br>nsec | FM ± 15%<br>Input 0-5V<br>MFM<br>FM<br>MFM<br>Input 0-5V<br>MFM | | Precor<br>RPW Read V | np Adjust.<br>Vindow Pulse Width | 300<br>100<br>120<br>240 | 500 | 1000<br>250<br>700 | nsec<br>nsec<br>nsec | Input 0-5V<br>MFM<br>FM<br>MFM<br>Input 0-5V<br>MFM | | Precor<br>RPW Read V | np Adjust.<br>Vindow Pulse Width | 100<br>120<br>240 | 500 | 250<br>700 | nsec<br>nsec<br>nsec | MFM<br>FM<br>MFM<br>Input 0-5V<br>MFM | | RPW Read V | Nindow Pulse Width | 100<br>120<br>240 | 500 | 250<br>700 | nsec<br>nsec<br>nsec | FM<br>MFM<br>Input 0-5V<br>MFM | | RPW Read V | Nindow Pulse Width | 120<br>240 | 500 | 700 | nsec | MFM<br>Input 0-5V<br>MFM | | RPW Read V | Nindow Pulse Width | 120<br>240 | | 700 | nsec | Input 0-5V<br>MFM | | | | 240 | | | | MFM | | WPW Write [ | Oata Pulse Width | 240 | | | | | | WPW Write [ | Data Pulse Width | | | 1400 | nsec | ENA . 450/ | | WPW Write I | Data Pulse Width | | 1 | | | FM ± 15% | | | * | | 1 | | | Input 0-5V | | | | 300 | ł | 1000 | nsec | MFM | | · 1 | | 1 | 500 | | nsec | FM | | Precor | np Adjust. | 100 | | 250 | nsec | MFM | | VCO Free R | un Voltage Controlled | 6.0 | | | MHz | Ext. C = 0 | | Oscilla | ator. Adjustable by ext. | 1 | 4.0 | | MHz | Ext. C = 35 pf | | capaci | tor on Pin 26 | | | 1 | | , | | Pump | Up + 25% | 5.0 | ļ | j l | MHz | PU = 2.2V Cext | | | • | 1 | l | . i | | = 35 pf | | VCO Pump | Down - 25% | | ł | 3.0 | MHz | PD = 0.2V Cext | | | | 1 | | | | = 35 pf | | 5% Ch | ange V <sub>CC</sub> | 3.8 | ļ | 4.2 | MHz | Cext = 35 pf | | VCO TA = | | 3.5 | | | MHz | Cext = 35 pf | | | sary external capacitor | 10 | 35 | 80 | pf | VCO = 4.0MHz | | | | " | " | | " | nom | | RCLK Derive | d read clock | | 1 | 1 | l | VCO = 4.0MHz | | = VC | O ÷ 8, 16, 32 | | l . | 1 | | | | | , ·-, · | | 500 | li . | KHz | DDEN = 0 | | | | | } | | · · · · · · | 5/8 = 1 | | · | | | 250 | 1 ' | KHz | DDEN = 0 | | | | | | 1 | | 5/8 = 0 | | , | | Ì | 250 | 1. | KHz | DDEN = 1 | | | | 1 | | | I | 5/8 = 1 | | | | i | 125 | | KHz | DDEN = 1 | | | · | | | | | $\bar{5}/8 = 0$ | | PU/DON PU/PD | time on | 1 | 1 | 250 | ns | MFM | | | se width) | | | 500 | ns | FM | ## APPENDIX G FLOPPY DISK ERROR CODES **Table 4. STATUS REGISTER SUMMARY** | BIT | ALL TYPE I<br>COMMANDS | READ<br>ADDRESS | READ<br>SECTOR | READ<br>TRACK | WRITE<br>SECTOR | WRITE<br>TRACK | |------------|------------------------|-----------------|----------------|---------------|-----------------|----------------| | S7 | NOT READY | NOT READY | NOT READY | NOT READY | NOT READY | NOT READY | | S6 | WRITE | 0 | 0 | 0 | WRITE | WRITE | | | PROTECT | ! | | | PROTECT | PROTECT | | <b>S</b> 5 | HEAD LOADED | 0 | RECORD TYPE | 0 | 0 | 0 | | S4 | SEEK ERROR | RNF | RNF | 0 | RNF | 0 | | <b>S3</b> | CRC ERROR | CRC ERROR | CRC ERROR | 0 | CRC ERROR | 0 | | S2 | TRACK 0 | LOST DATA | LOST DATA | LOST DATA | LOST DATA | LOST DATA | | S1 | INDEX PULSE | DRQ | DRQ | DRQ | DRQ | DRQ | | S0 | BUSY | BUSY | BUSY | BUSY | BUSY | BUSY | #### STATUS FOR TYPE I COMMANDS | BIT NAME | MEANING | |---------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | S7 NOT READY (40) | This bit when set indicates the drive is not ready. When reset it indicates that the drive is ready. This bit is an inverted copy of the Ready input and logically 'ored' with MR. | | S6 PROTECTED (30 | When set, indicates Write Protect is activated. This bit is an inverted copy of WRPT input. | | S5 HEAD LOADED (20) | When set, it indicates the head is loaded and engaged. This bit is a logical "and" of HLD and HLT signals. | | S4 SEEK ERROR (10 | ) When set, the desired track was not verified. This bit is reset to 0 when updated. | | S3 CRC ERROR (4) | CRC encountered in ID field. | | S2 TRACK 00 (3) | When set, indicates Read/Write head is positioned to Track 0. This bit is an inverted copy of the TROO input. | | S1 INDEX (2) | When set, indicates index mark detected from drive. This bit is an inverted copy of the $\overline{\mathbb{P}}$ input. | | SO BUSY (1) | When set command is in progress. When reset no command is in progress: | In certain cases the SUPER SIX must be run at 4MHz. This is because timing on the S-100 bus is critical when interfacing with select other S-100 bus boards. For the users of Super Six computer board the following changes apply to any Super Six up to Rev. "M": - 1. Add a 1 K Resistor (pull up) to the BRQ output of U21 (D.M.A.). - Change the value of Rll and Rl6 from 1 K each to 2 K, for more V.C.O. range. - 3. Connect Phantom to U33 pin 1, for all memory to be turned OFF when active. And for Super Six users running at 6 MHZ with up to Rev. "M" board, using any other non Advanced Digital boards that has one or the two next characteristics. - An I/O board latches the incoming data on the falling edge of (pWR\*) during an I/O transfer of data. - A memory transfer where the signal (pSTVAL\*) is expected to fall inside of (PSYNC) active. Modify your Super Six, through all the rework instructions, else do only first three steps. #### Rework Instructions: - Locate U15 on the solder side, connect a 1 K resistor across from U15 pin 14 to U15 pin 9. - Remove Rll and Rl6 next to (L.E.D.1) both a 1 K and replace with a 2 K resistor for Rll and Rl6. - 3. Locate U33 on the solder side cut trace between U33 pin 1 and 2 and jumper from U33 pin 1 to U33 pin 10. - 4. Locate U71 on the solder side and between pin 1 and 20 cut trace to the feed through. Now install a 14 pin socket at U1 (spare ic) with pin 1 on 1 jumper pin 7 of the socket to hole number 8, for ground into the IC. Jumper U71 pin 8 to U1 pin 9. Locate U68 on solder side, jumper U68 pin 2 to U1 pins 12 and 13. Locate U6 and jumper pin 11 to U1 pin 11. Locate U6A and jumper pin 3 to U1 pin 10. Remove I.C. U6A (741S32) and lift pin 1, bend it so won't sort out. Jumper pin 1 to pin 4 on component side over I.C., install back I.C. on solder side jumper U6A pin 2 to U25 Pin 4. - 5. Locate U28 component side, lift I.C. and pull out pin 9 install back I.C. Locate U4 and U5 solder side. Jumper U4 pin 12 to U5 pin 13. Jumper U5 pin 12 to U1 pin 2 and 1. Jumper U4 pin 1% to U1 pin 5. Jumper U1 pin 3 to U2 pin 1. Locate U21 (D.M.A.) jumper U21 pin 12 to U1 pin 4. - 6. Install a 74874 in Ul socket. ### APPENDIX I WARRANTY LETTER #### WARRANTY #### NOTICE Advanced Digital Corporation now requires a Return Authorization Number for the return of any equipment for repair or credit. This number will be issued by the Customer Support Department. Any equipment received without the Return Authorization Number clearly marked on the outside of the package may be subject to significant delays in the repair process. Return Authorization Numbers are active for 30 days after they are issued. If the equipment specified in the Return Authorization is not received by Advanced Digital within this 30 day period significant delays in handling the repair may be incurred. If the equipment must be returned a second time, a new Return Authorization Number must be issued. Reuse of Return Authorization Numbers may result in delays in processing returns. Effective November 1, 1981, repair of all kit and nonwarranty boards will be \$70.00. This fee is subject to change without notice. Returns for credit will be subject to a 15% restocking charge. If material for credit was purchased through a dealer, Advanced Digital cannot issue a credit. Adjustment must be handled through the dealer. Other credit returns should have reference to the original invoice number. If you have any questions regarding special handling, packaging of the equipment, or procedures for returning equipment, please contact the Advanced Digital Corporation. The warranty on the super Six is one year from the date of purchase. ### SUPER SIX SINGLE BOARD COMPUTER PARTS LIST | ITEM | PART NO. | LOCATION | | QTY. | |-----------------------|-----------------------------------------------------------|-------------------------------------------------------------|----------|---------------------------------| | 1<br>2<br>3<br>4<br>5 | 74S 10<br>74LS00<br>74LS132<br>74LS04<br>74 S74<br>74LS32 | U2<br>U3, U11, U44<br>U4<br>U5, U68<br>U6, U28<br>U6-A, U40 | | 1<br>3<br>1<br>2<br>2<br>2<br>1 | | 7 | Z80B PIO | U7 | | ļ<br>ļ | | 8<br>9 | CD4098<br>74LS138 | U8<br>U9, U34 | | 2 | | 10 | 7438 | U10 | | 1 | | 11 | 74LS13 | U12, U33 | | 2 | | 12 | 74LS123 | UI3 | | į, | | 13 | 74LS14 | U14 | | l<br>2 | | 14<br>15 | 7407<br>16L8 | U15, U22<br>U16, U36 | | 2<br>2 | | 16 | 74LS174 | U17 | | Ī | | 17 | 74LS11 | UI8 | | 1 | | 18 | 74S04 | U19 | | 1 | | 19 | Z80B CTC | U20 | | l i | | 20 | Z80 DMA | U2I | | Į<br>L | | 21<br>22 | 74LS92<br>74LS393 | U23<br>U24 | | 1 | | 23 | 8T97 | U25 | | î | | 24 | 7406 | U26 | | 1 | | 25 | WD2793 | U27 | | 1 | | 26 | 2726 EPROM | U29 | | l. | | 27 | Z80B | U30 | | 1 | | 28<br>29 | BR1945<br>74LS109 | U31<br>U32 | | I. | | 30 | 74LS27 | U35 | | 1 . | | 31 | 745287 | U37 | | î | | 32 | Z80B DART | U38 | | 1 | | 33 | 74LS280 | U39 | Awar and | l . | | 35 | 8T98 | U43, U66 | | 2 | | 36<br>37 | TTLDM100 | U41<br>U42 | | 1 | | 38 | 74LS02<br>4164-15 | U46-U54 | | 18 | | 39 | 74LS244 | U65 | | 1 | | 40 | 74LS374 | U67 | | 1 | | 41 | 74LS240 | U70, U71, U77 | | 3 | | 42 | 74LS373 | U73 | | 1 | | 43 | 74LS245 | U74, U76 | | 2 | | 44<br>45 | 74LS273 | U78 | | 2 | | 4) | 74S240 | U80, U79 | | 4 | #### LIST OF DISCRETE COMPONENTS | ITEM | PART NO. | LOCATION | QTY. | |------|-----------------------|------------------------|------| | 46 | 40 PIN SOCKET | U7, U21, U27, U30, U38 | 5 | | 47 | 28 PIN SOCKET | U20 | l | | 48 | 24 PIN SOCKET | U29 | l | | 49 | 20 PIN SOCKET | | 15 | | 50 | <b>18 PIN SOCKET</b> | U31 | l | | 51 | 16 PIN SOCKET | | 28 | | 52 | 14 PIN SOCKET | | 27 | | 53 | 220/330 SIP | RM2 | l | | 54 | 10K SIP | RMI, RM4, RM5, RM3 | 4 | | 55 | 4.7K SIP | RM6, RM7 | 2 | | 56 | 33 OHM SIP<br>(8 PIN) | RM8, RM9, RM10 | 3 | #### CAPACITOR LIST FOR SUPER SIX | ITEM | PART NO. | LOCATION | QTY. | |------|-----------------|--------------------|------| | 57 | .1 MF CAP | | 30 | | 58 | 10 MR CAP | C14, C6 | 2 | | 59 | 4.7 MF CAP(25V) | C9, C10 | 2 | | 60 | 6.8 MF (10V) | C7, C8 | 2 | | 61 | 33 PF | C23 | l | | 62 | 47 PF | C35, C32, C31, C33 | 4 | | 63 | 5-50 PF CAP | C26 | l | ### • RESISTOR LIST FOR SUPER SIX (ALL RESISTORS ARE 1/4 WATT) | ITEM | PART NO. | LOCATION | QTY. | |------|----------------------------|-----------------------------------------------|----------| | 64 | IK RESISTOR | R7, 8, 11, 15, 16 | 8 | | 65 | 220 OHM | R12, 18, 22, 23, 24, 29, 21, 20<br>26, 27, 28 | 8 | | 66 | 4.7K | RÍ | . 1 | | 67 | 10K | R6, R10 | 2 | | 68 | 27K | R3 | ı | | 69 | 470K | R2 | l. | | 70 | 5.1 MEGA OHM | R5 | 1 | | 71 | 10 OHM | R17 | 1 | | 72 | 1.5K | R13 | l | | 73 | 560 OHM | R14 | l | | 74 | 33 OHM | R30, R31 | 2 | | 75 | 10K TRIM POT<br>(82PR10K) | , | l. | | 76 | 50K TRIM POT<br>(82PR 50K) | | <b>l</b> | ### **ACCESSORIES** | ITEM | PART NO. | LOCATION | QTY. | |------|-------------------------|-------------------|------| | 77 | 220MH CHOCK | L1, L2 | 2 | | 78 | 6104 TERMALOY | VRÍ | 1 | | 79 | 78H05 | | ì | | 81 | 40 PIN CONN | Ј2 | l | | 82 | 50 PIN CONN | J3 | l | | 83 | 34 PIN CONNEC | J1 | ŀ | | 84 | 14 PIN CONNEC | J4, J5, J6 | 3 | | 85 | 16 PIN CONNEC | RS (8 PIN DOUBLE) | l | | 86 | 8 PIN SINGLE | RS | 1 | | 87 | 3 PIN SINGLE | E, C, D, R | 4 | | 88 · | 2 PIN SINGLE | B, G | 2 | | 89 | DIALIGHT 5552222<br>LED | | 1 | | 90 | 2N3906 TRANS | Q2 | Ţ | | 91 | 2N2222 TRANS | QI | . 1 | | 92 | 24 MHZ XTAL | Υl | 1 | | 93 | 5.068 MHZ XTA | Y2 | . 1 | | 94 | 1N914 DIODE | CRI, CR@ | 2 | # $\begin{array}{c} \text{APPENDIX K} \\ \\ \text{PLL REALIGNMENT} \end{array}$ Following is the procedure for realigning the PLL on the SUPER SIX single board computer. - 1. Turn POWER switch to ON (insure test jumper is removed). - 2. Install Jumper G. - 3. Adjust trimmer Cap for 250KHz/on pin 16 of the FDC. - 4. Adjust 50KHz trimmer pot for a positive going pulse of 250ns on pin 29 of the FDC. - 5. Adjust 10KHz trimmer pot for a positive going pulse of about 125ns (100ns 300ns, depending on disk drive manufacturer) on pin 31 of the FDC. - 6. Remove jumper G. ## APPENDIX M PSNET/PAR SCHEMATIC PS NET/PAR 3-25-32 PS. NET/1 ADMINUED DIGITAL 13.1 ### APPENDIX N SUPER SIX SCHEMATICS