# Model Z-89/90 SERIES DIGITAL COMPUTERS 595-2690-03 # TABLE OF CONTENTS | NTRODUCTION 1-3 | REPLACEMENT PARTS LIST 9-1 | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | SPECIFICATIONS 2-1 | Power Supply 9-1 Video Circuit Board 9-1 | | SETUP AND TESTING 3-1 Power Line Considerations 3-1 Cabinet Removal 3-2 Testing 3-3 | Video Driver Circuit Board9-3Terminal Logic Circuit Board9-3CPU Logic Circuit Board9-4Chassis Parts9-5Serial Interface Circuit Board9-6 | | SYSTEM CONFIGURATION 4-1 ZDS System Configuration 4-1 Terminal Logic Circuit Board 4-1 CPU Logic Circuit Board 4-4 | SEMICONDUCTOR IDENTIFICATION | | Serial Interface 4-7 Memory Map 4-8 I/O Port Useage 4-8 | APPENDIX | | OPERATION | ZDS Escape Sequences11-10ZDS Escape Sequences Defined11-12ANSI Escape Sequences11-17ANSI Mode Summary11-19ANSI Escape Sequences Defined11-20The Functions of a Computer11-27Instruction Set11-31 | | READJUSTMENT 6-1 | Demonstration Programs | | TROUBLESHOOTING | Z80 CPU | | SERVICE INFORMATION 7-5 | | | CIRCUIT DESCRIPTION 8-1 | INDEX 14-1 | | Power Supply Circuit Board 8-2 Video Circuit Board 8-3 Video Driver Circuit Board 8-6 | CIRCUIT BOARD X-RAY VIEWS (Illustration Booklet, Page 10) | | Terminal Logic Circuit Board | SCHEMATIC Fold-in | # INTRODUCTION This Zenith Data Systems Digital Computer is a versatile, 8-bit microcomputer and a professional video terminal, both built into the same cabinet. The computing functions and terminal operations are both controlled by separate Z-80 microprocessors. The high quality keyboard, video display, state-of-the art logic circuitry, and plug-in accessories make this Computer outstanding. Note that, because this Operation Manual was designed to be used with more than one Computer system, your Computer may vary slightly in some respects with the descriptive material that is presented. Some features of the Computer are: - Up to 64k bytes of user-addressable memory. - Wired and tested CPU and terminal logic circuit boards. - An internal monitor that automatically sizes the memory and initializes the unit at power-up. The monitor resides in 2k or 4k bytes (depending on the exact configuration) of ROM which contains load and dump routines that eliminate the need for bootstrap and loader programs at turn-on. - A floppy disk drive unit and its interface circuit board (optional, depending on the configuration). - A multiport serial interface circuit board. The information is displayed on a 12" (diagonal), high-quality cathode-ray tube (CRT) that can display 2000 characters at one time (25 rows of 80 characters). The phosphor used in the CRT provides superb character definition. Upper-case characters are formed by a $5 \times 7$ dot matrix. Lower-case characters that have descenders use a $5 \times 9$ dot matrix. The Computer can also display 33 special graphic characters that can be arranged and grouped to form any number of graphic displays and effects. The graphic symbols are formed on an $8 \times 10$ dot matrix. Special keyboard and software-controllable escape sequences allow you to select and use many special functions. These include: - Using either ZDS or ANSI escape sequences. - Eight user-defined special function keys. - Alternate keypad output (for sending more user-defined special codes to your computer). - Shifted keypad (so you can obtain the shifted keypad functions without using SHIFT key). - Keyboard enable/disable. - Keyclick enable/disable. - Cursor-type select (underline or block). - Auto LF (line feed), auto CR (carriage return). - Hold screen mode (for scrolling lines and pages). - Cursor control (left, right, up, down, home). - Direct cursor addressing. - Access and use of 25th line. #### and you can also: - Transmit page. - Transmit 25th line. - Insert and delete characters and lines. - Enter and exit the graphics and reverse video modes. - Erase lines or page or text. - Modify baud rates. The highly reliable, standard-size electronic keyboard uses the universally accepted, standard typewriter format. Each key stroke is affirmed by an audible click. A 12-key keypad duplicates the numeric key in a calculator format. This lets you rapidly enter numbers in programs that call for just numbers. In addition, the shifted keypad functions allow you to insert and de- lete lines and characters, and move the cursor. Plus, an alternate mode allows you to interchange the shifted and unshifted functions and send special codes to your Computer. These features, along with the stylish molded cabinet, make this Zenith Data Systems Digital Computer a versatile and powerful computing center. #### WARNING This equipment generates, uses, and can radiate radio frequency energy and if not installed and used in accordance with the instructions manual, may cause interference to radio communications. As temporarily permitted by regulation it has not been tested for compliance with the limits for Class A computing devices pursuant to Subpart J of Part 15 of FCC Rules, which are designed to provide reasonable protection against such interference. Operation of this equipment in a residential area is likely to cause interference in which case the user at his own expense will be required to take whatever measures may be required to correct the interference. If this equipment does cause interference to radio or television reception, which can be determined by turning the equipment off and on, the user is encouraged to try to correct the interference by one or more of the following measures: - Move the computing device away from the receiver being interfered with. - Reorient the receiving antenna. - Plug the computing device into a different AC outlet so that the computing device and receiver are on different branch circuits. - Disconnect and remove any I/O cables that are not being used. (Unterminated I/O cables are a potential source of high RF emission levels). - Unplug and remove any serial I/O circuit board cards that are not being used. (Here again, unterminated cards can be a source otential interference). - Be certain that the computing devices are plugged into grounded outlet recepticals. (Avoid using A/C cheater plugs. Lifting of the power cord ground may increase RF emission levels but also presents a lethal shock hazard to the user). If additional help is needed, consult the dealer or ask for assistance from the manufacturer. Costomer service information may be found on the inside back cover of this manual or on an insert sheet supplied with this equipment. The user may also find the following booklet helpful: "How to Identify and Resolve Radio-TV Interference Problems." This booklet is available from the US Government Printing Office, Washington, D.C. 20402-Stock No. 004-000-00345-4. # **SPECIFICATIONS** #### CPU AND MEMORY Processor Z-80 Clock 2.048 MHz. Memory 48 k bytes user RAM (expandable to 64k), Z-89 series 64k bytes user RAM, Z-90 series 8k System for ROM and RAM. 8k reserved. #### **DISPLAY** 12" diagonal. 24 lines of 80 characters (with access to 25th line). 6.5'' high $\times$ 8.5'' wide. Display Size ..... 0.2'' high $\times$ 0.1'' wide (approximate). Character Size ..... $5 \times 7$ dot matrix (upper case); $5 \times 9$ dot matrix (lower case with descenders); 8 × 10 dot matrix (graphics). 84 keys (60 alphanumeric, 12 function/control) plus a Keyboard ..... 12-key numeric/control pad. Blinking, nondestructive, underline, block, or dis-abled (DIP switch selectable). Up, down, left, right, home, CR, LF, back space, and Cursor Controls ..... tab, and cursor off. Relative and direct. Cursor Addressing ..... Standard 8-column tab. Tab ..... 60 Hz at 60 Hz/50 Hz at 50 Hz line frequency. Refresh Rate ..... Insert and delete character or line. Edit Functions ..... Erase page, erase to end of line, and erase to end of page. Audible alarm on receipt of ASCII BEL. Bell ..... Normal and reverse by character. Video ..... #### **Serial Interface** Channels ..... 3 EIA RS-232C. Each channel provides serial data and primary RS-232C handshake. Output Levels ..... RS-232C. Input Levels ..... RS-232C compatible. 5, 6, 7, or 8 bits. Character Length ..... Even, odd, stick, or none. Parity ..... 1, 1-1/2, or 2. Stop Bits ..... All standard rates to 57,600 baud. Baud Rates ..... **GENERAL** Power Requirements ..... 115/230 volts at 90 watts max. 13" high $\times$ 17" wide $\times$ 20" deep. Size ..... $(33 \times 43.2 \times 50.8 \text{ cm}).$ 46 lbs. (20.7 kg) Weight ..... 10° to 35° Celsius. 0° to 50° Celsius. Zenith Data Systems reserves the right to discontinue products and to change specifications at any time without incurring any obligation to incorporate new features in products previously sold. # **SET-UP AND TESTING** #### **POWER LINE CONSIDERATIONS** If you need to change the position of the 115/230 switch (located on the bottom of the Computer), be sure you change rear panel fuse F1 to the proper value as follows: For 115 VAC, use a 1.5-ampere, 125 volt, slow-blow fuse. For 230 VAC, use a 1-ampere, 250 volt, slow-blow fuse. The plug on the power cord is for standard 115 VAC outlets. For 230 VAC operation in the U.S.A., cut off and replace in a manner such that your power connection conforms with section 210-21 (b) of the National Electric Code, which reads, in part: "Receptacles connected to circuits having different voltages, frequencies, or types of current (AC or DC) on the same premises shall be of such design that attachment plugs used on such circuits are not interchangeable." When you install the new plug, make sure it is connected according to your local electrical code. Units with three-wire line cords must always have the green wire connected to chassis ground. Be sure the NORM/LOW switch (on the bottom of the Computer) is set in its proper position to match your line voltage as follows: NORM range — 110 V to 130 V rms or 220 V to 260 V rms. LOW range — 100 V to 120 V rms or 200 V to 240 V rms. NOTE: If you do not know the value of the line voltage in your area, set the NORM/LOW switch to NORM. ### **CABINET REMOVAL** Whenever you need to remove the cabinet top: - Refer to the inset drawing on Pictorial 3-1, insert the blade of a small screwdriver into the notch in the latch plate, and then, as you lift upward on the front, slide the latch plate toward the front of the Computer about 1/4". - Likewise, open the latch plate on the other side of the cabinet top. - WARNING: When the line cord is connected to an AC outlet, hazardous voltages can be present inside your Computer. See Pictorial 3-1. - Carefully tilt the cabinet top back. - Unplug the fan. - When the top is tilted straight up, carefully lift the hinges out of the rear panel. Simply reverse this procedure to close and lock the cabinet top back on the Computer. #### **TESTING** The purpose of the "Testing" is to verify that your Computer is working properly. Therefore, it is not necessary, at this time, to have a working knowledge of your Computer. If, at any time during the "Testing," you fail to obtain the proper results, refer to Pictorials 4-1 (Page 4-2) and 4-2 (Illustration Booklet, Page 1) to make sure the circuit board switches are properly set. Then, if necessary, refer to the "Troubleshooting" section on Page 7-1. #### **INITIAL TESTS** WARNING: Never turn the Computer on and off in rapid succession. - ( ) Push the OFF LINE switch once or twice to be sure it is in the out (up) position. - ( ) Plug in the line cord and push the rear panel POWER switch to ON. The speaker should produce one or two "beeps." After a minute or so, the prompt (H:) should appear and the cursor (short line) should blink on and off at the upper left-hand corner of the screen. - ( ) Push the OFF LINE key to the down position. Then simultaneously push down the CTRL and G keys. Again, the speaker should "beep." - ( ) Press the G key. This time, you should hear only a "tick." (You should hear a tick each time you press a key.) Also, the letter "g" will appear on the screen. - ( ) Release the OFF LINE key to its out position. - ( ) Push the right-hand SHIFT and RESET keys. This clears the screen to "H:". #### **MEMORY TEST** This test will test the user RAM in your Computer. [All other memory is reserved and will not be tested. See the "Memory Map" (Page 4-8) under "ZDS System Configuration" on Page 4-1.] The routine will first load a number into each byte of RAM (example: 000 is loaded into each memory location first). Then it will go back and read the number at each location, check it to be sure it is correct, add 001 to the number, place the new number back into the memory location it just read from, and then go on to the next address. This procedure is repeated until all the user RAM is tested for all possibilities, and then starts over. The test routine first clears the CRT and then displays the memory test message, the last working address (LWA) in the user RAM area (16k = 137377, 32k = 237377, 48k = 337377, and <math>64k = 377377), and the pass value (current value stored and read out of RAM). #### Example: Dynamic RAM test LWA = 337377 (for 48k of user RAM) Pass = 015 (current value stored and read out of RAM) If the memory test detects an error before it reaches the end of the memory (LWA), the address where the error occurred and the actual contents that was read will be displayed. #### Example: Dynamic RAM test LWA = 337377 Pass = 015 ERROR @ 132241 = 017 This means that there is a problem with bit 1 (of 0-7) at address 132241. If the test is successful, the PASS number will reach 377 and then start over. This will take approximately 5, 10, or 15 minutes; depending on how much memory you have installed. ( ) To start the test, be sure that you have the "H:" prompt. (If not, simultaneously push down the right-hand SHIFT key and the RESET key. The Computer will reset.) Then type G7375® (shown as underlined below). [® means to push the RETURN (carriage return) key]. The Computer will automatically insert the "o" and spaces, so the entire entry will be: To stop the test, simultaneously push the right-hand SHIFT and RESET keys. Memory failures usually fall into two categories: data and address. A data failure constitutes a particular number or group of numbers from 000 to 377 that cannot be written into or recalled from memory. This type of failure may be due to a solder bridge or defective cells in a memory chip. Since there are eight memory IC's, one for each bit of a byte, it is possible to write a combination of bytes at the address where the test routine failed to determine which, if any, of the memory IC's are at fault. If the memory IC's are interchanged between bits, the difficulty should move with the faulty IC. Be careful when you interchange memory IC's since these IC's are MOS devices. The following chart will help you locate each memory IC. Address faults are the most difficult to isolate. They may be caused by solder bridges between address lines on the circuit board or by a faulty memory IC. When address lines are shorted together (held high or low), the CPU cannot access the memory locations requested. Often, more than one address will access the location. Therefore, recalling how the "Memory Test" functions, you can see that a given memory location will be incremented too often. The most practical approach for locating an address failure is to substitute memory IC's or address buffers (U513 and U514), one at a time, until you locate the problem. #### **COMPUTING TEST** This test will test the computing portion of your Computer. You will first enter a short program into the Computer and then run it. If you make a mistake entering a number, just start over. It is a very short program. - Simultaneously press down the right-hand SHIFT key and the RESET key. The Computer will reset and then give you the "H:" prompt. - ( ) Type S; the Computer will finish the word "Substitute." Type 040100 and push the RETURN key. The computer will respond with: 040100 XXX\_(Each X can be any digit 0-7). Enter 076 and push the SPACE bar. The new display should be: > 040100 XXX 076 040101 XXX\_\_ ( ) Enter 011 and push the SPACE bar. The new display should be: 040100 XXX 076 040101 XXX 011 040102 XXX\_\_ - ( ) Enter 315 and push the SPACE bar. - ( ) Continue by making the following entries. Push the SPACE bar only once after each entry. | 302 | (SPACE) | |-----|---------| | 003 | (SPACE) | | 074 | (SPACE) | | 376 | (SPACE) | | 155 | (SPACE) | | 312 | (SPACE) | | 100 | (SPACE) | | 040 | (SPACE) | | 303 | (SPACE) | | 102 | (SPACE) | | 040 | (SPACE) | - ( ) Push the RETURN key. The Computer will respond with the "H:" prompt. - ( ) Type P; the Computer will print the words "Program Counter." Enter 040100 and then push the RETURN key. Again the computer will respond the the "H:" prompt. In the next step, the Computer will print several symbols, the numbers 0 through 9, several more symbols, the alphabet in capitol letters, some more symbols, and part of the alphabet in lower case letters — all on one line. Then it will keep printing this line, and soon will rapidly scroll the top line of the page. (NOTE: The bottom line will be flashing.) To stop the program, again push the right-hand SHIFT and RESET keys. ( ) Type G; the computer will print the word "Go". Then push the RETURN key. # **ZDS SYSTEM CONFIGURATION** This section of the Manual shows you the normal switch and jumper positions. If you like, check them to be sure they are in their proper positions, or set them (as explained) for the operation that you desire. Your Computer communicates with your peripherals at RS-232C signal levels. 25-pin "D" connectors on the rear panel conform to RS-232C standards and mate with most equipment that conforms to this standard. Refer to the following sections that pertain to your Computer. # TERMINAL LOGIC CIRCUIT BOARD Carefully tilt back the cabinet top. See Pictorial 4-1. Be sure the POWER switch is off. Then remove the screws that hold the terminal logic circuit board (the rear circuit board). Remove the two screws that hold the top of the CPU logic circuit board. Disconnect the cables, as necessary, and lift the circuit boards up out of the Computer. # SWITCH S402 (Secondary power-up configuration) Push all of the switches on S402 up (0) as shown in Pictorial 4-1. If you ever want to change these switch positions, they are defined as follows: #### SWITCH SECTION DESCRIPTION - 0 0 = underscore cursor; 1 = block cursor - 0 = key click; 1 = no key click - 2 0 = discard past end of line; 1 = wrap around - 0 = no auto LF on CR; 1 = auto LF on CR - 4 0 = no auto CR on LF; 1 = auto CR on LF - 0 = ZDS mode; 1 = ANSI mode - 6 0 = keypad normal; 1 = keypad shifted - 0 = 60 Hz refresh; 1 = 50 Hz refresh This switch (located on the terminal logic circuit board) sets the following power-up and reset modes: | SWITCH<br>SECTION | DESCRIPTION | |-------------------|---------------------| | 0-3 | Baud Rate | | 4 | Parity Enable | | 5 | Odd/Even Parity | | 6 | Normal/Stick Parity | | 7 | Half/Full Duplex | The particular configuration that you select is initialized when you power-up the Computer or when you perform a Computer Reset. Pictorial 4-1 shows the location of switch S401. Remember that, as you look at switch S401 from the front of the Computer, you select the one (1) positions of the switch by pushing the switches down, and you select the zero (0) positions by pushing the switches up. #### ( ) Set switch S401 for: | MODE | | | S | W | ΙΊ | 'C | Н | S | EC | TIO | AC | 1 | | | | |----------------------------------------------------------------------|---|---|---|---|----|----|---|---|----|-----|----|---|---|---|---| | | 0 | | 1 | | 2 | | 3 | | 4 | 5 | 5 | 6 | | 7 | | | 9600 Baud<br>No Parity<br>Odd Parity<br>Normal Parity<br>Full Duplex | | 0 | | 0 | | 1 | | 1 | 0 | | C | ) | 0 | | 1 | When no parity is selected, you can set the even and normal parity switch sections to either position since they will be ignored. Each function of switch S401 is explained in the following text. #### **Baud Rate** When used as a Computer, the baud rate must be set to 9600. If you use your Computer as a terminal (see Page 5-18), you can reset the baud rate as explained below. You can select any of 12 different baud rates (110-9600). To do this, place sections 0, 1, 2, and 3 of switch S401 to the proper positions as shown below. The baud rate will be initialized (or updated) upon Reset or during power-up. | BAUD | SW | ITCH | I SEC | TION | | |--------|-----|------|-------|------|--| | RATE | . 0 | 1 | 2 | 3 | | | N/A | 0 | 0 | 0 | 0 | | | 110 | 1 | 0 | 0 | 0 | | | 150 | 0 | 1 | 0 | 0 | | | 300 | 1 | 1 | 0 | 0 | | | 600 | 0 | 0 | 1 | 0 | | | 1200 | 1 | 0 | 1 | 0 | | | 1800 | 0 | 1 | 1 | 0 | | | 2000 | 1 | 1 | 1 | 0 | | | 2400 | . 0 | 0 | 0 | 1 | | | 3600 | 1 | 0 | 0 | 1 | | | 4800 | 0 | 1 | 0 | 1 | | | 7200 | 1 | 1 | 0 | 1 | | | 9600 | 0 | 0 | 1 | 1 | | | 19200* | 1 | 0 | 1 | 1 | | #### **Parity** You can program the ACE (Asynchronous Communication Element) to either generate or eliminate the parity bit. Section 4 of switch S401 selects the parity bit. ZDS Software does not check parity. #### **Odd/Even Parity** If section 4 = 1, then section 5 of switch S401 selects odd or even parity. Down $$(1)$$ = Even Parity Up $(0)$ = Odd Parity #### **Normal/Stick Parity** If section 4 = 1, then section 6 of switch S401 sets the ACE to transmit and receive either stick or normal parity. Down $$(1)$$ = Stick Parity Up $(0)$ = Normal #### Half/Full Duplex Section 7 of switch S401 selects either full or half duplex communications between the computer and the terminal sections. ZDS Software supports full duplex operation. Set section 7 to 1 for full duplex operation. ( ) Replace the circuit boards and reconnect their cables. <sup>\*</sup> Not currently supported (may drop characters). #### CPU LOGIC CIRCUIT BOARD Refer to Pictorial 4-2 (Illustration Booklet, Page 1) for the following steps. ### Switch SW501 The functions that switch SW501 selects are determined by integrated circuit U518. #### CASSETTE I/O USAGE When you use the cassette I/O, part number 444-40 must be installed at U518. Set SW501 switch sections as directed in the next two steps. Then proceed directly to "Programming Jumpers." - ( ) Set section 5 for SW501 to "1." - ( ) Set the remaining seven sections of SW501 to "0" #### 5-1/4" HARD-SECTORED FLOPPY USAGE When you use a 5-1/4" hard-sectored floppy disk, integrated circuits part numbers 444-40, 444-62, or 444-84 must be installed at U518. Set SW501 switch sections as directed in the next two steps. Then proceed directly to "Programming Jumpers." - ) Set SW501 section 5 to "1." - ( ) Set the remaining seven SW501 sections to "0." #### 8" FLOPPY DISK (Z-47) USAGE When you use an 8" floppy disk (Z-47), integrated circuit part numbers 444-62 or 444-84 must be installed at U518. - When you boot-up from a 5-1/4" hardsectored floppy disk to enable your 8" floppy disk, set SW501 switch sections as directed the next two steps. Then proceed directly to "Programming Jumpers." - ( ) Set SW501 switch sections 2 and 5 to "1." - ( ) Set the remaining six SW501 sections to "0." - When you boot-up from the left hand 8" floppy disk drive, set SW501 switch sections as directed in the next two steps. Then proceed directly to "Programming Jumpers." - ( ) Set SW501 switch sections 2, 4, and 5 to "1." - ( ) Set the remaining five SW501 switch sections to "0." #### ALTERNATE I/O APPLICATIONS DIP switch SW501 is used to program the initial power-up configuration. Its setting definitions depend on, and vary with, the monitor ROM IC installed at CPU circuit board location U518. The following paragraphs define the sections of this switch for these selected ROM's. #### **Definition of SW501 with MTR-88 (#444-40)** When IC part number 444-40 is installed at U518, the following table describes the function of each SW501 switch section. Only the three most significant address bits, SW501 sections 5, 6, and 7, are defined. Set switch SW501 sections 0 through 4 to "0." SW501 switch 6 and 7 select the power-up baud rate used for communication with the terminal (which is usually the internal terminal logic circuit board). The four options for switch sections 6 and 7 are: | SECTION 7 | SECTION 6 | BAUD RATE | |-----------|-----------|-----------| | 0 | 0 | 9600 | | 0 | 1 | 19200 | | 1 | 0 | 38400 | | 1 | 1 | 57600 | The selected baud rate must match the baud rate set at S401 on the terminal logic circuit board. The terminal logic circuit board firmware supports only the 9600 baud at this time (19200 can be selected and used, but characters may be lost). Therefore, when you use your H-89/90-Series Computer, you should set SW501 sections 6 and 7 to "0." You can use SW501 section 5 to force a memory test on RESET or power-up. To force the test, set section 5 to "0." Since the test will not stop until the switch is reset, the switch must be set to "1" before you can use your Computer for normal operation. #### **Definitions of SW501 with MRT-89 (#444-62)** When IC part number 444-62 is installed at U518, the following table describes the functions of each SW501 switch section. | SWITCH | | DEGODIPETION | |----------|----------|----------------------------------------------------------------------------------| | SECTIONS | SETTING* | DESCRIPTION | | 1 and 0 | 00 | Port 174/177Q (7CH-7FH) has a 5-1/4" hard-sectored floppy disk (normal). | | | 01 | Port 174/177Q has a Z-47, 8" floppy. | | | 10 | Undefined. | | | 11 | Undefined. | | 3 and 2 | 00 | Port $170/173Q$ (78H-7BH) is not in use (normal with Z-47, 8" floppy disk). | | | 01 | Port 170/173Q has a 8" floppy disk (normal with Z-47). | | | 10 | Undefined. | | | 11 | Undefined. | | 4 | 0 | Boots from device at port 174/177Q (7CH-7FH) (5-1/4" hard-sectored floppy disk). | | | 1 | Boots from device at port 170/173Q (78H-7BH) (Z-47, 8" floppy disk). | | 5 | 0 | Performs memory test upon power-up or SHIFT-RESET. | | | 1 | Does not perform memory test (normal). | | 6 | 0 | Sets console to 9600 baud (normal). | | | 1 | Sets console to 19200 baud (not currently supported). | | 7 | 0 | Normal boot (normal). | | | 1 | Auto boot on power up or SHIFT-RESET (not recommended). | <sup>\*</sup>Right-hand value is for switch section 0 or 2, depending on respective Switch Section column. #### Definition of SW501 with MTR-90 (#444-84) When IC part number 444-84 is installed at U518, set the sections of SW501 as described in "Definition of SW501 with MTR-89, except for sections 0, 1, 2, and 3, which are defined as follows: | SWITCH<br>SECTIONS | SETTING* | DESCRIPTION | |--------------------|----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------| | 1 and 0 | 00<br>01<br>10<br>11 | Port 174/177Q (7CH-7FH) is 5-1/4" hard-sectored floppy disk. Port 174/177Q is Z-47, 8" floppy disk. Port 174/177Q is Z-67, 8" hard disk. Undefined. | | 3 and 2 | 00<br>01<br>10<br>11 | Port 170/173Q (78H-7BH) is Z-37 soft-sectored disk.<br>Port 170/173Q is Z-47, 8" floppy disk.<br>Port 170/173Q is Z-67, 8" hard disk.<br>Undefined. | ### **Programming Jumpers** The positions of jumpers JJ501, JJ502, and JJ503, are determined by the amount of memory installed in your Computer. Position these jumpers as directed in the following chart. This determines the addresses supplied to the memory decoder IC U517. | | | MEMORY | JJ503 | JJ502 | JJ501 | |---|---|-----------|----------|-------|-------| | | | 16k bytes | В | 0 | 0 | | | | 32k bytes | В | 0 | 1 | | ( | ) | 48k bytes | В | 1 | 0 | | ( | ) | 64k bytes | <b>B</b> | 1 | 1 | The position of programming jumpers JJ504 through JJ507 are determined by the types and locations of the system PROM's. These jumpers will be set correctly for the PROM(s) supplied with your Computer. Instructions for changing these jumpers will be supplied with any product which requires these changes. | JUMPER | LOCATION | |-----------|----------------------------------------------------------------------------------| | ( ) JJ504 | Voltage to U519 pin 22;<br>0 = -5V, $1 = +5V$ . | | ( ) JJ505 | Input to U514 and U519 pins 19; | | ( ) JJ506 | 0 = +12V, $1 = A10$ .<br>Input to U518 and U519 pins 20; $0 = A10$ , $1 = gnd$ . | | ( ) JJ507 | Chip select of U519: | | | A = Bit 1 of U516 decoder. | | | B = Bit 4 of U516 decoder. | <sup>\*</sup>Right-hand value is for switch section 0 or 2, depending on respective Switch Section column. # HARD-SECTORED 5-1/4" SINGLE-DENSITY FLOPPY DISK The single-density floppy disk interface circuit board is installed at P506 and P512 on the CPU circuit board. #### **SERIAL INTERFACE** ( ) Refer to Pictorial 4-3 (Illustration Booklet, Page 3) and set all three programming jumpers to OFF if this has not already been done. NOTE: These jumpers determine the interrupt priority of the ports. When a jumper is in the "OFF" position, no interrupt exists for that port. When you install the jumper at 3,4, or 5, an RST 3, an RST 4, or an RST 5 (respectively) instruction is executed when the interrupt for that port occurs. The first port on the circuit board is located at address 340/347Q (0E0H-0E7H) and is normally used as the line printer port. However, it is not restricted only to that use, as it is a standard RS-232C interface with a "DCE" connector. The second port on the circuit board is located at address 320/327Q (0D0H-0D7H) and is a general purpose port. It is a standard RS-232C interface with a "DCE" connector. The third port on the circuit board is located at address 330/337Q (0D8H-0DFH) and is a general purpose port. It is a standard RS-232C interface with a "DTE" connector, suitable for use with a MODEM. Assembly language programmers who wish to program the ACE may refer to Chapter 13, Page 13-4. ## **MEMORY MAP** The Memory Map (Illustration Booklet, Page 2) illustrates the use of the specified memory locations. ## I/O PORT USAGE | | PORT I | LOCATION | |--------------------------|--------|----------| | USE | HEX | OCTAL | | | | | | Not specified, available | 0-77 | 0-167 | | Cassette I/O (if used) | 78-79 | 170-171 | | Disk I/O #1 | 78-7B | 170-173 | | Disk I/O #2 | 7C-7F | 174-177 | | Not specified, reserved | 80-C7 | 200-317 | | DCE Serial I/O | D0-D7 | 320-327 | | DTE Serial I/O | D8-DF | 330-337 | | DCE Serial I/O | E0-E7 | 340-347 | | Console I/O | E8-EF | 350-357 | | NMI* | F0-F1 | 360-361 | | General purpose port | F2 | 362 | | NMI* | FA-FB | 372-373 | # GENERAL PURPOSE PORT (0F2H) BIT DEFINITIONS | BIT | <u>INPUT</u><br>(SW501 SWITCH SECTION) | BIT | OUTPUT | |-----|----------------------------------------|-----|-------------------------------------------| | | • | 0 | Hardware single step enable | | 0 | 0 | 1 | 2 mSec clock enable | | 1 | 1 | 2 | Latched bit at memory expansion connector | | 2 | 2 | 3 | Not used | | 3 | 3 | 4 | Latched bit at memory expansion connector | | 4 | 4 | 5 | Selects HDOS map or CP/M map | | 5 | 5 | 6 | Latched bit at I/O expansion connector | | 6 | 6 | 7 | Latched bit at I/O expansion connector | | 7 | 7 | | <u>-</u> | <sup>\*</sup>Ports labeled "NMI" are not used. Rather, an NMI is generated if the port is accessed for either input or output. This is done for compatibility with earlier computer products, specifically the Heathkit Model H-8. # **OPERATION** ### **COMMAND SUMMARY** CARE OF YOUR FLOPPY DISKETTE — Do not turn your Computer on or off when a floppy disk is installed in the disk drive with its door closed. Errant power signals can cause the disk head to bounce. If the drive door is closed, the drive head is engaged on the diskette and can possibly damage the diskette. This summary is a list of the commands that your computer will respond to and the responses that it will make. You may enter commands in either upper or lower case characters. In all cases, pushing the DELETE or RUBOUT key prior to pushing the RETURN key (which terminates the command) will cancel the current command and cause the Computer to respond with the prompt (H:) All byte entries are in octal, and all address entries are in split octal. NOTE: Split octal is two 3-bit bytes as shown in Figure 5-1. 1. Turn on the Computer power. Then wait a few seconds until the CRT becomes illuminated. #### 2. Boot: After you see the prompt (H:), enter "B". The Computer will complete the "Boot" message and then wait for a Carriage Return. Insert a diskette in the floppy disk drive and close the door. Now press the RETURN key and the system should begin booting up. If the system seems to stop after a second or two of disk activity, depress the space bar two or three times. (You may be directed to do this by a message on the screen, depending on the firmware installed). - 3. Go to the user routine: (G) or (G ADDR) - A. After the prompt, enter "G". The Computer will complete the "Go" message. - B. Enter either a Carriage Return or a new address and a Carriage Return. - C. If you did not enter a new address above (in Step B), control will be given to the routine at the address specified by the user program counter. However, if you entered a new address and a Carriage Return, control will be given to the address you specified. 4. Set the user Program Counter values: (P) or (P ADDR) After the prompt, enter "P". The Computer will complete the "Program Counter" message. Now you may enter a new program counter value (in split octal) and terminate it with a Carriage Return. If no new value is entered and you enter a Carriage Return, the current contents of the user Program Counter will be displayed. Again, a new value may be entered and terminated with a Carriage Return, or just entering a Carriage Return will cause a return to the prompt and the current value to be unaltered. 5. Substitute memory: (S) or (S ADDR) After the prompt, enter "S". The Computer will complete the "Substitute" message and wait for an address to be specified (in split octal notation) and ended with a Carriage Return. The address specified will then be displayed, followed by its contents. At this point, you can change the contents by entering the octal value to be placed into memory. If you do not want a change, or after you have entered the new value, there are three options. - A. To view the contents of the next address; enter a SPACE. - B. To view the contents of the previous address; enter the minus sign (-). - C. To exit the Substitute mode; enter a Carriage Return. #### **KEYBOARD OPERATION** Pictorial 5-1 (Illustration Booklet, Page 3) shows the keyboard of the Computer. The power ON/OFF switch is located on the right rear corner of the back panel. Whenever you turn on the Computer, allow the tube about 30 seconds to warm up. You should then see a flashing line (cursor) or block cursor (if it was selected) in the upper left-hand corner of the screen. The keyboard allows you to send data to the Computer or the screen. Most of the keys are the same as they are on most typewriters; they type the same alphanumeric characters. A clicking sound tells you that each keystroke has been processed. You cannot damage the Computer by typing on the keys. PICTORIAL 5-2 The screen contains 2000 normal character positions; 25 lines of 80 characters. Only one character can occupy a character position at any given time and it will remain there until it is erased or replaced. When the Computer is initially turned on, it clears the screen by placing spaces in all character positions. The cursor is the blinking horizontal line that appears at the home position. It underlines the character position where the next character will be written. (The block cursor will fill the character position.) As shown in Pictorial 5-2, you can use the Computer in any one of three different modes; full duplex, off line, or half duplex. (However, half duplex is not a normal ZDS mode.) When the Computer is on line, the keyboard can transmit any one of the 128<sub>10</sub> ASCII characters (see the "ASCII Characters" chart on Page 11-1) to the computer section. However, some of these characters will not be displayed if the Computer sends them back to the Terminal section. (See the chart.) In the off line mode, the terminal is effectively disconnected from the Computer and the keyboard controls the screen directly. This way, you can position the cursor $(\uparrow, \downarrow, \rightarrow, \leftarrow, \text{ and HOME})$ , insert or delete characters or lines (IC, DC, IL, and DL), or erase (ERASE), without sending the codes to the Computer—which could otherwise disrupt a program, etc. Another way of controlling the screen without sending code to the Computer is to use the CTRL key. Example: you want to erase the screen, but you do **not** want to transmit a code to the Computer. Press and hold the CTRL key and then type SHIFT ERASE. This tells the terminal section to erase the screen, but not to send the code to the Computer section. Again, you can use this procedure with the cursor keys $(\uparrow, \downarrow, \rightarrow, \leftarrow,$ and HOME), the Insert Line, Delete Line, and Insert Character, and Delete Character keys, and ERASE. Whenever you use the special escape codes to enter and exit the special modes, make sure you enter the lower-case and upper-case letters just as they are called for in this Manual. For instance, type ESC p (not ESC P) to enter the reverse video mode. See "Special Modes" on Page 5-7. The "ASCII Characters" and "Escape Sequences" (see the "Appendix," Page 11-1) show the commands and special escape sequences that the terminal section sends and responds to. Your computer **must** contain the proper software for it to respond to and generate the codes that use these special features. Different versions of software may support different features. The Computer has a 128 character input FIFO (first in, first out buffer) for receiving and holding characters until the terminal section can process them. In some cases (such as when the terminal section is operating at 9600 baud in the "insert character" mode), the FIFO can be filled faster than the terminal section can process the characters. In this case, the terminal section will send X OFF (control S) when the FIFO has received 112 characters. After the terminal section has processed enough characters so that only 96 characters remain in FIFO, it will send X ON (control Q) to the computer section to indicate that it is ready to accept more characters. When the terminal section sends X OFF, this is only an indication that the buffer is nearly full. Characters will not be lost until after the FIFO has received a full 128 characters. At this point more incoming characters will be lost and the bell will sound. Three BASIC demonstration programs are included in the "Appendix" to show you how some of the Computer features are implemented in BASIC. Enter and run them if you wish. #### NORMAL MODES AND KEYS The following descriptions are for switch S402 set to all zeros. For the operation of special functions, refer to "Special Modes and Keys" on Page 5-7. #### ALPHABETIC KEYS The Computer has the standard 26 letters of the alphabet. These keys can transmit either lower-case or upper-case codes as well as display them on the screen. You can either hold the SHIFT key down or you can push the CAPS LOCK key to obtain upper-case letters. #### NONALPHABETIC KEYS The nonalphabetic keys are those with double markings. These include the numbers 0 through 9, punctuation marks, and special characters. The lower marking is generated when both of the SHIFT keys are released, while the upper marking is generated when either (or both) SHIFT key is held down. The CAPS LOCK key will not shift these keys. #### **MISCELLANEOUS** The characteristics in the following description apply only to the terminal's internal key handling of the listed codes, which can be overridden by the software. RETURN — Moves the cursor to the first character position of the line that it is currently in. If the cursor is already at the first character position, it remains there. RETURN is a nondisplayable character. Normally, there is no automatic line feed. LINE FEED — Moves the cursor down one line. LINE FEED is a nondisplayable character. If the cursor is at the bottom line, a LINE FEED causes it to remain there, but all of the data on the screen moves up one line. Data on the top line is lost as it is scrolled up and off the screen. Normally, there is no CR. SPACE BAR — Causes the cursor to move one character position to the right. A Space is a nondisplayble character. If you type the Space Bar when the cursor is positioned below a displayed character, the character is replaced by a space and the cursor moves one character position to the right. If you type the Space Bar when the cursor is at the right end of a line, the cursor will remain there since neither a carriage return nor a line feed is generated. BACK SPACE — Moves the cursor one space to the left. If the cursor is at the start (left end) of a line, it will not move when you type a BACK SPACE. ZDS software uses this key to delete the last input character. DELETE (Rubout) — Transmits the ASCII code 177Q (7FH). It is a nondisplayable character. ZDS software uses this key to cancel the last character that was input. TAB — When typed on the keyboard, it transmits the ASCII code 011Q (09H). When received by the terminal, it moves the cursor to the next tab stop (eight character spaces) to the right. The tab stops are fixed at 9, 17, 25, 33, 41, 49, 57, 65, and 73 (columns are numbered 1 through 80). If the cursor is at character position 73 through 79, it will only move one character position to the right each time you type the TAB key. If the cursor is at character position 80, it will not move when you type the TAB key (unless the wraparound feature has been selected). ESC (Escape) — A non-displayable character that transmits the ASCII code 033Q (1BH). This key is used in combination with other keys to enter and exit special modes. See "Special Modes and Keys" on Page 5-7. For a complete listing of ZDS and ANSI codes using escape sequences and their definitions, refer to the Appendix (Pages 11-10 and 11-17). REPEAT — When you hold this key in, along with another key, it will repeat the function of the other key as long as both keys are held down. The repeat rate is approximately 8-characters per second. However, if the baud rate that has been selected is less than the repeat rate, the repeat function will opeate at the slower rate. SHIFT — When you use this key in conjunction with another key, the character printed on the upper portion of that key will be displayed. When you use the SHIFT keys in conjunction with the alphabetic keys, the upper-case character is displayed. CAPS LOCK — When this latching key is down, the terminal section will transmit the ASCII code for, and display, upper-case (capital) alphabetic letters. It does not shift the keys with the double markings. This is **not** a shift lock. OFF LINE — When this latching key is down, the terminal section is inhibited from transmitting or receiving data. However, any displayable characters that you type on the keyboard will appear on the screen and any local control codes will be responded to. BREAK — When you type this key, it generates a **continuous space** at the output of the terminal section. It is generally used to tell the computer that you wish to interrupt execution. RESET — Allows you to reset the Computer to its preset condition; it exits all escape modes and resets the baud rate to the rate selected by the switches on the logic circuit board. To use this key, you must press only the right-hand SHIFT key and the RESET key at the same time. This two-key combination prevents you from inadvertently resetting the Terminal. SCROLL — When this is used with ZDS software, when in the Hold Screen Mode, you can type the SCROLL key to instruct the Terminal to display another line of information onto the screen. You can simultaneously press the SHIFT and SCROLL keys to display another 24 lines of information onto the screen. SCROLL (line) SCROLL (page) SCROLL SHIFT/SCROLL #### CONTROL KEY The CTRL key is held down while you push one of the other keys to send the 32 ASCII control codes to the Computer. Refer to the "ASCII Characters" chart in the "Appendix" (Page 11-1) of this Manual for a listing of the control keys. These are non-displayable characters. The Terminal responds to only seven of the control characters from the keyboard or from the serial input port. These seven characters are: **BELL** (BEL or CTRL G) — Causes the Terminal to sound an audible tone through an internal speaker. **Back Space** (BS or CTRL H) — Duplicates the BACK SPACE key. **Horizontal Tab** (HT or CTRL I) — Duplicates the TAB key. **Carriage Return** (CR or CTRL M) — Duplicates the RETURN key. **Escape** (ESC or CTRL [) — Duplicates the ESC key. $\begin{cal}{ll} \textbf{Cancel} & (CTRL~X) --- Cancels the current escape sequence. \end{cal}$ #### SPECIAL MODES AND KEYS Many of the following functions refer to and affect the operation of the terminal section of the Computer only. Escape sequences allow you to use two or more keys together to provide a certain function or to get your unit to operate in a particular manner. This provides a maximum of operation with a minumum of keys. NOTE: The following descriptions give ZDS mode escape sequences. For ANSI escape sequences, refer to the "Appendix." Also, the operating system must be set to accept and transmit lower-case letters before the example programs will run properly. See Page 11-50. #### **CURSOR FUNCTIONS** **Cursor Home** — ESC H — [Shift 5 (HOME) of keypad] Moves the cursor to the first character position on the first line (home). **Cursor Forward** — ESC C — [Shift $6 \rightarrow$ of keypad] Moves the cursor one character position to the right. If the cursor is at the end of the line, it will remain there. **Cursor Backward** — ESC D — [Shift $4 \leftarrow$ ) of keypad] Moves the cursor one character position to the left (backspaces). If the cursor is at the start (left end) of a line, it will remain there. Cursor Down — ESC B — [Shift 2 (↑) of keypad] Moves the cursor down one line. If the cursor is at the bottom line, it will remain there; however, a scroll will not occur. **Cursor Up** — ESC A — [Shift 8 (↑) of keypad] Moves the cursor up one line. If the cursor is at the top line, it will remain there; however, a scroll will not occur. **Reverse Index** — ESC I — This is a reverse line feed. It causes the cursor to move upward one line. If the cursor is at the top line it will remain there. However, any text on the screen will be scrolled downward one line. **Cursor Position Report** — ESC n — Reports the position of the cursor in the form of ESC Y line# column#. The following BASIC program gives an example of its use. This is sent by the computer to interrogate the terminal; terminal responds with the ESC Y sequence. ``` 00010 PRINT "PRESS RETURN"; CHR$(27); "n" (send ESC sequence to interrogate terminal). 00020 LINE INPUT; A$ (get result — ESC Y — sequence from terminal). 00030 B$=LEFT$(A$,1) (get left-most character of ESC Y sequence). 00040 A$=RIGHT$(A$,LEN(A$)-1) (remove left-most character of returned string). 00050 PRINT ASC(B$), (print ASCII value). 00060 IF LEN(A$)>0 THEN 30 (loop until string is gone). 00070 END ``` When you run the program and push the RETURN key, the Computer will respond with the following decimal numbers: Here the 27 equals ESC, 89 equals Y, 55 is the line# (55-31=24), and 44 is the column# (44-31=13). (See "Direct Cursor Addressing" below.) Therefore, the reported cursor position is: Save Cursor Position — ESC j — The present cursor position is saved so the cursor can be returned there later on the "Set to previously saved position" command. "Demonstration Program #2" in the "Appendix" of this Manual gives an example of this feature in a BASIC program. **Set to Previously Saved Position** — ESC k — Returns the cursor to the position where it was when it received the last "Save cursor position" command. **Direct Cursor Addressing** — ESC Y — Allows the Computer to control the position of the cursor on the screen by entering the escape code, the ASCII character which represents the line number, and the ASCII character which represents the column number. The first line and the left column are both 32 (decimal) and increase from there. The number 32 (decimal) is used because it is the smallest value of the printing characters. All values less than 32 (decimal) are control codes, which can interfere with operating sequences of some Computers. Since the lines are numbered from 1 to 24 (from top to bottom) and the columns from 1 to 80 (from left to right), you must add the proper line and column numbers to 31 (decimal). Then convert these decimal numbers to their equivalent ASCII characters and enter them in the following order: For example, to place the cursor at line 20, column 40, you will first have to add 31 (decimal) to the line number to find the value of the line#. $$31 + 20 = 51$$ Then use the "ASCII Characters" chart (in the "Appendix") to find the ASCII character that corresponds to 51 (decimal). In this case, it is the number 3. Next, add 31 (decimal) to the column number to find the actual value of the column#. $$31 + 40 = 71$$ Again, use the ASCII chart to find the ASCII character that corresponds to 71 (decimal), which is the symbol G. To demonstrate this example, make sure the OFF LINE key is down. Then type ESC Y 3 G. The cursor should move to line 20, column 40. If you specify a line# that does not exist on the screen, the cursor will remain in the line it is presently in. If you specify a column# that does not exist on the screen, the cursor will move to the right-most column. "Demonstration Program #1" in the "Appendix" of this Manual shows you how this feature is used in a BASIC program. #### **ERASING AND EDITING** Clear Display (SHIFT ERASE) — ESC E — Erases all the information on the screen. The screen is filled with spaces and the cursor is placed in the home position. "Demonstration Program #1" in the "Appendix" of this Manual shows you how this feature is used in a BASIC program. Erase Beginning of Display — ESC b — Erases the display from the start of the screen to the cursor position, and includes the cursor position. Erase to End Of Page (ERASE Key) — ESC J — Erases all the information from the cursor (including the cursor position) to the end of the page. Erase Entire Line — ESC 1 — Erases the entire line, including the cursor position. **Erase Beginning Of Line** — ESC o — Erases from the beginning of the line to the cursor position, and **includes the cursor position**. **Erase To End Of Line** — ESC K — Erases from the cursor (including the cursor position) to the end of the line. Insert Line — ESC L — [Shift 1 (IL) of keypad] Inserts a new blank line by moving the line that the cursor is on, and all following lines, down one line. Then the cursor is moved to the beginning of the blank line. **Delete Line** — ESC M — [Shift 3 (DL) of keypad] Deletes the contents of the line that the cursor is on, places the cursor at the beginning of the line, moves all the following lines up one line, and adds a blank line at line 24. Delete character — ESC N — [Shift 9 (DC) of keypad] Deletes the character at the cursor position and shifts any existing text that is to the right of the cursor, and on the same line, one character position to the left. Enter Insert Character Mode — ESC @ — [Shift 7 (IC) of keypad] Lets you insert characters or words into text already displayed on the screen. The first time you type IC, the Terminal enters the Insert Character Mode. You can then use the cursor controls to place the cursor at the point where you want to insert characters. As you type in the desired characters, any existing text directly at and to the right of the cursor is shifted to the right. This feature lets you add letters or words to existing text without having to re-type the whole text. When you finish inserting characters, type IC again to exit the Insert Character Mode. The Terminal transmits an ESC @ to enter, and an ESC O to exit the Insert Character Mode. Exit Insert Character Mode — ESC O — Exits the Insert Character Mode. See "Enter Insert Character Mode" above. #### CONFIGURATION **Reset To Power-Up Configuration** — ESC z — Nullifies all previously set escape modes and returns to the power-up configuration set by switches S401 and S402 on the terminal logic circuit board. **Modify the Baud Rate** — ESC r — Initially, the baud rate is set by the switches on the terminal logic circuit board. However, you can change the baud rate from the keyboard. To do this, type ESC r followed by the appropriate letter given below: | A = 110 | G=2000 | |----------|----------| | B=150 | H = 2400 | | C=300 | I=3600 | | D=600 | J=4800 | | E=1200 | K=7200 | | F = 1800 | L = 9600 | | | M=19200* | The baud rate reverts back to the baud rate set by the switches on the circuit board when you RESET the Terminal (RESET and right-hand SHIFT keys) or when you turn the Terminal off and then back on. **Set Mode** — ESC x — Certain operating modes can be enabled and disabled from the keyboard. To enable the functions, type ESC x followed by the appropriate number given below: 1 = Enable 25th line. The 25th line is available as a line that is totally separate from the normally-used 24 lines. You might use this line, for example, to identify the user function keys with labels which correspond to the function that your Computer provides when it receives these function key escape codes. Or you might use it to display information concerning the status of your Computer while a program is running. The only way to place the cursor on the 25th line is to enable the 25th line and then use "Cursor Addressing." Once on the 25th line, the terminal acts like a 1-line terminal ("erase in display" commands only operate on the 25th line) until you use cursor addressing to place the cursor on one of the other 24 lines of the Computer. This is a good place to use the "Save Cursor Position" and the "Set Cursor To Previously Saved Position" routines. With these routines, the current cursor position can be saved, your routine can address the 25th line, write information on the 25th line, and return to the "remembered" cursor location without your program having to remember that location. "Demonstration Program #2" in the "Appendix" of this Manual gives an example of these features in a BASIC program. Also, when the cursor is on the 25th line, all erase functions affect only this line and a line feed will not cause a scroll. - 2 = No key click. This function turns off the key click. - 3 = Hold screen mode. See "Enter Hold Screen Mode" (Page 5-11) for a description of this function. <sup>\*</sup>This baud rate is not presently supported (it may drop characters). - 4 = Block cursor. Produces a cursor that fills the entire character position. This is a **reverse video** character position. - 5 = Cursor off. Turns off the cursor so there is no cursor at all. - 6 = Keypad shifted. See "Enter Keypad Shifted Mode" for a description of this function. - 7 = Alternate keypad mode. See "Enter Alternate Keypad Mode" for a description of this function. - 8 = Auto line feed on receipt of CR. A line feed is automatically performed (in addition to a CARRIAGE RETURN) when a CARRIAGE RETURN is received. - 9 = Auto CR on receipt of line feed. A CARRIAGE RETURN is automatically performed (in addition to a line feed) when a line feed is received. For example: If you want to turn off the cursor, press OFF LINE and type ESC x 5. These functions default back to their initial states (as set by switches S401 and S402 on the terminal logic circuit board) when the Computer is reset (RESET and right-hand SHIFT keys) or when you turn the Computer off and then back on again. You can also reset these functions using the Reset Mode escape codes (ESC y). See below. **Reset Mode** — ESC y — Resets the "Set Mode" functions to their power-up default states. To reset a function, type ESC y followed by the appropriate number given below. - 1 = Disable 25th line - 2 = Enable key click - 3 = Exit hold screen mode - 4 = Underscore cursor - 5 = Cursor on - 6 = Keypad unshifted - 7 = Exit alternate keypad mode - 8 = No auto line feed - 9 = No auto CR See "Set Modes" above. **Enter ANSI Mode** — ESC < — Enters the ANSI mode. See the "Appendix" in the rear of this Manual for the definition and descriptions of the ANSI mode escape codes. #### MODES OF OPERATION Enter Hold Screen Mode — ESC [ — The Hold Screen Mode allows you to control when new information is printed on the screen. This is especially useful when you are reading lists or looking for a particular part of a program. Push the OFF LINE key to its down position and then type ESC [ to enter the Hold Screen Mode. Then after you release the OFF LINE key, each time you type the SCROLL key a new line of text will appear on the bottom line and the top line of text will scroll up and off the screen. If you type SHIFT SCROLL, a whole new page (24 lines) of text will be scrolled onto the screen. Press the OFF LINE key to its down position and type ESC \ to exit the Hold Screen Mode. Remember, that when the cursor is at the start of a line of text, the Terminal is probably waiting for a scroll command when in this mode. This mode requires that the operating system respond to XON and XOFF. **Exit Hold Screen Mode** — ESC \ — Exits the Hold Screen Mode. See "Enter Hold Screen Mode" above. **Enter Reverse Video Mode** — ESC p — The characters displayed on the screen can also be displayed in reverse video, a black character on a white background. Type ESC p to enter the Reverse Video Mode, and ESC q to exit the Reverse Video Mode. The following BASIC program shows you how to send the escape codes to the terminal to enter and exit the reverse video mode. ``` 00010 REM Reverse Video Demonstration 00020 PRINT "This is a demonstration of the "; 00030 PRINT CHR$(27);"p"; 00040 PRINT "reverse video"; 00050 PRINT CHR$(27);"q"; 00060 PRINT " feature." ``` **Exit Reverse Video Mode** — ESC q — Exits the Reverse Video Mode. See "Enter Reverse Video Mode" above. Enter Graphics Mode — ESC F — The graphics mode lets you display 33 special symbols. Refer to the "Graphic Mode Symbols" in the "Appendix" of this Manual. Type ESC F to enter the Graphics Mode. Then type any of the 26 lower-case keys or the seven other symbol keys that correspond to the graphic symbols. Type ESC G to exit the Graphics Mode. You can place the terminal in the Reverse Video Mode while it is in the Graphics Mode to increase the number of graphic symbols. "Demonstration Program #1" in the "Appendix" of this Manual shows you how this feature is used in a BASIC program. **Exit Graphics Mode** — ESC G — Exits the Graphics Mode. See "Enter Graphics Mode" above. Enter Keypad Shifted Mode — ESC t — The shifted functions that the keypad transmits normally require you to press and hold the SHIFT key when you type one of the keys. You can type ESC t to enter the Shifted Keypad Mode so that you do not need to hold the SHIFT key to obtain the unshifted functions. However, if you place the terminal in the Shifted Keypad Mode and you need to use the unshifted functions (numbers), you will have to press and hold the SHIFT key to obtain them. Type ESC u to exit the Shifted Keypad Mode. **Exit Keypad Shifted Mode** — ESC u — Exits the Keypad Shifted Mode. See "Enter Keypad Shifted Mode" above. **Enter Alternate Keypad Mode** — ESC = — The codes sent to the Computer from the keypad normally include the numbers, period, ENTER, and (when shifted) some special cursor movement and editing functions. You can change these codes using the Alternate Keypad Mode to transmit specific escape codes that your software may respond to. Note that the program must recognize the escape sequence. Type ESC = to enter and ESC > to exit the Alternate Keypad Mode. The following chart lists the escape codes sent by the Terminal in the Alternate Keypad Mode. | KEY | ZDS<br>ESCAPE<br>CODE | ANSI<br>ESCAPE<br>CODE | |-------|-----------------------|------------------------| | 0 | ESC ? p | ESC O p | | 1 | ESC ? q | ESC O q | | 2 | ESC ? r | ESC O r | | 3 | ESC ? s | ESC O s | | 4 | ESC ? t | ESC O t | | 5 | ESC ? u | ESC O u | | 6 | ESC ? v | ESC O v | | 7 | ESC ? w | ESC O w | | 8 | ESC?x | ESC O x | | 9 | ESC ? y | ESC O y | | • . | ESC ? n | ESC O n | | ENTER | ESC ? M | ESC O M | **Exit Alternate Keypad Mode** — ESC > — Exits the Alternate Keypad Mode. See "Enter Alternate Keypad Mode" above. #### ADDITIONAL FUNCTIONS Keyboard Disabled — ESC } — Inhibits the output of the keyboard. WARNING: After this function is entered, the keyboard can only be turned back on by your program or a master reset. **Keyboard Enabled** — ESC { — A computer-sent code that enables the keyboard after it was inhibited by a "Keyboard Disabled" command. Wrap Around At End Of Line — ESC v — 81st character on a line is automatically placed in the first character position on the next line. The page scrolls up if necessary. **Discard At End Of Line** — ESC w — After the 80th character in a line, the characters overprint. Therefore, **only the last character received will be displayed in position 80.** Identify As VT52® (ESC/K) — ESCZ — The terminal responds to interrogation with ESC/K to indicate that it can perform as a VT52. This is sent by the Computer to interrogate the terminal. Transmit 25th Line — ESC ] — See "Transmit Page" below. #### Transmit Page — ESC # The transmit functions (Transmit 25th Line and Transmit Page) are the same except for the source of the data transmitted. Basically (assuming that the mode has not changed), the data is transmitted the same as it appears on the CRT. This includes all 1920 characters (24 lines of 80 characters), or the 80 characters of the 25th line. However, it is possible that the actual number of characters transmitted will be more than 1920. If graphic characters, reverse video characters, or both are encountered, the proper escape sequence for entering the respective modes will be transmitted. When one or both of these parameters no longer apply, the appropriate escape sequence will then be sent to exit the mode. The escape sequence which is sent is determined by whether the Computer is in the ZDS mode or the ANSI mode. The sequence will be the same as that which was sent to the terminal (or entered from the keyboard) to cause the Computer to enter and/or exit the reverse video and graphic character modes. Other than the above required escape sequences, the only characters sent are the displayed characters. Following the transmission of the last character, a CARRIAGE RETURN is sent and the bell will sound. If a transmit page is executed (ESC #), only lines 1 through 24 are transmitted. If you want to transmit the 25th line, you must ask for that specifically (ESC ]). This operates the same as the transmit page except that only the 80 characters of the 25th line (and any necessary escape sequences) are transmitted and followed by a CARRIAGE RETURN. In the event that the 25th line is not enabled, only a CARRIAGE RETURN will be transmitted. #### **Special Function Keys** The eight special function keys $(f_1, f_2, f_3, f_4, f_5, Blue, Red, and White)$ on the top row of the keyboard transmit two-character escape codes to the computer. You can define the meanings of each of these keys to suit your particular application (your software program must recognize the particular escape codes associated with the keys). See the "Appendix." #### SUMMARY OF KEYPAD FUNCTIONS The keypad can operate in any one of four modes: normal unshifted, normal shifted, alternate unshifted, and alternate shifted. Then, within each of these modes, you can use the SHIFT key shifted or unshifted as a toggle. (See "Enter Keypad Shifted Mode" and "Enter Alternate Keypad Mode.") Normal Unshifted — This is the normal operating mode. **TERMINAL** Example: **TYPE TRANSMITS** 3 3 SHIFT 3 DL (Delete Line) Normal Shifted — ESC t to enter; ESC u to exit — The normal functions are inverted. **TERMINAL TYPE** Example: **TRANSMITS** DL (Delete Line) 3 3 SHIFT 3 Alternate Unshifted — ESC = to enter; ESC > to exit — This is the normal alternate mode. **TYPE** TERMINAL Example: **TRANSMITS** ESC?s(ZDS escape code) 3 DL (Delete Line) SHIFT 3 Alternate Shifted — ESC t ESC = to enter; ESC u ESC > to exit — The normal alternate functions are now inverted. TERMINAL **TYPE** Example: **TRANSMITS** DL (Delete Line) 3 ESC?s(ZDS escape code) SHIFT 3 See the "Appendix" for actual codes sent and for ANSI codes. # **USE AS A TERMINAL** To use your Computer as a terminal, refer to Pictorial 5-3 (Illustration Booklet, Page 4) and: - ( ) Disconnect the cable from P404 on the back of the terminal logic circuit board. - ( ) Disconnect cable #134-1070 from plug P605 (the bottom one) on the serial interface circuit board. - ( ) Plug the cable into P404 on the back of the terminal logic circuit board (brown wire up). This connects the rear panel DTE input to the terminal ACE. Another approach found to be more satisfactory by most users is to obtain software which utilizes the Z-89/90 Series Computer and one of its serial ports to emulate an intelligent terminal. This provides all of the usual terminal functions, and also allows additional features such as file transfer between any attached storage devices and the remote Computer, and local printing of data from the remote Computer using a second serial port and printer. Such software is available from your Zenith Data Systems dealer. # READJUSTMENT This section contains several adjustments that you may need to make to properly maintain your Computer. You will have to remove or tilt back the cabinet top in order to reach the controls, coils, and adjustments called for in this section. To do this, refer to the inset drawing on Pictorial 3-1 (Page 3-2) and carefully remove the cabinet top back. ( ) On the terminal logic circuit board (see Pictorial 4-1 on Page 4-2), set section 2 of switch S402 down to its 1 position. This enables the wraparound. NOTE: When power is turned on, do not touch the flyback transformer, the high voltage lead, or the anode socket at the back of the CRT, as it is possible to receive an electrical shock from these areas. Also, to lessen the chances of an electrical shock while you are making adjustments, keep your other hand away from this unit and all other metallic objects. ( ) Plug in the line cord and set the POWER switch to ON. Refer to Pictorial 6-1 for the locations of controls on the video circuit board. - ( ) After a short warm-up time, a light raster should appear on the screen. If it does not, adjust G1 control R262 counterclockwise (as viewed from the left side), to cause the raster to appear. - ( ) If the display is slanted, loosen the yoke clamp screw slightly and slowly turn the yoke to properly line up the raster on the screen. See Pictorial 6-2 on Page 6-2. - ( ) Adjust VERT SIZE control R219 (on the video circuit board) so the raster is approximately 6" high. PICTORIAL 6-1 **PICTORIAL 6-2** - ( ) Refer to Pictorial 6-2 and rotate the ring magnets on the back of the yoke to center the display on the screen. - ( ) Adjust rear panel BRIGHTNESS control R1 until a blinking cursor (underline) appears at the top corner of the screen. - ( ) Set the OFF LINE and CAPS LOCK keys to their down positions. - ( ) Hold the "Z" key and the REPEAT key down and fill the screen with characters. - ( ) Adjust HORIZ CENTERING control R246 to center the display horizontally within the raster. - ( ) Adjust VERT LINEARITY control R223 so that the top and bottom rows of characters are of uniform size. NOTE: You should make the next adjustment in a darkened room. - Turn G1 control R262 clockwise (as viewed from the left) until the raster just disappears. - ( ) If the display width is not approximately 8-1/2", adjust WIDTH coil L203 to correct the width size. - ( ) Adjust BRIGHTNESS control R1 to obtain the brightness that is most suitable to you. - ( ) Adjust FOCUS control R264 for the best focus. - ( ) Recheck the display for proper alignment of the screen. If necessary, rotate the yoke a small amount. Then tighten the yoke clamp screw only enough to hold the yoke from turning. - ( ) Set the POWER switch to OFF and disconnect the line cord. - ( ) Set section 2 of switch S402 (on the terminal logic circuit board) up to its 0 position. - ( ) Resecure all parts in your Computer and replace the cabinet top. # **TROUBLESHOOTING** #### IMPORTANT NOTICE All ZDS Computer hardware and software products were designed to work together as a complete system. Proper operation can be assured only when the Computers are used with ZDS designed or approved accessories. ZDS does not assume the responsibility for improper operation resulting from custom interfacing, custom software, or the use of accessories not approved by Zenith Data Systems. All the Computer components have been wired and tested at ZDS. If you encounter any malfunction during the warranty period, return the complete Computer to your Zenith Data Systems dealer or authorized Zenith Data Systems repair facility. It will be promptly repaired and returned. **DO NOT** attempt to service this Computer yourself during the warranty period; to do so voids the warranty. For out-of-warranty products, you can have them repaired by your Zenith Data Systems dealer or authorized Zenith Data Systems repair facility, or you can purchase individual replacement parts to do your own service. The following section, titled "Troubleshooting Charts," lists problems or conditions that might occur. The "Possible Cause" column lists the components associated with the problem. This will help you relate a problem to the Schematic and Circuit Description. The components listed in the "Possible Cause" column are the most likely causes (but not necessarily the only cause) of a problem. But before you start, check the set-up switches on the logic circuit boards to be sure that they are in their proper positions. See Pictorial 4-1 (Page 4-2) and Pictorial 4-2 (Illustration Booklet, Page 1). Refer to the "Circuit Board X-Ray Views" (Illustration Booklet, Pages 8 through 13) for the physical location of parts on the circuit boards. Due to the complexity of the factory wired circuit boards and the closed loop configuration of the control and interface circuits, we recommend that you return these parts to your ZDS dealer or authorized repair facility for repair if necessary. # TROUBLESHOOTING CHARTS The following charts list conditions and possible causes of several specific malfunctions. If a particular part is mentioned (F1 for example) as a possible cause, check that part and other components connected to that part to see that they are in good working order. WARNING: Measure the anode voltage only with an approved high voltage probe. CAUTION: Never operate the Computer unless the short black ground wire coming from the corner of the video board is connected to the CRT ground. ## **POWER SUPPLY PROBLEMS** | CONDITION | POSSIBLE CAUSE | |-----------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Nothing happens at turn on. | <ol> <li>Not plugged in.</li> <li>Fuse F1 blown.</li> <li>Switch SW1 wiring.</li> <li>Fuseholder wiring.</li> <li>Capacitor C1.</li> </ol> | | Fuse blows. | <ol> <li>Check primary wiring.</li> <li>Short circuit on power supply circuit board.</li> <li>Short circuit across transformer secondary.</li> <li>Diodes D101-D112, and BR1.</li> <li>Capacitors C1, C102-C104.</li> <li>IC's U401-U405.</li> <li>Short between collector of transistor Q204 and video board heat sink.</li> <li>Incorrect fuse.</li> <li>Power transformer T1.</li> </ol> | | No output from 5 V supplies, or voltage(s) too high or too low. | <ol> <li>IC's U401, U402.</li> <li>Diodes D105-D107.</li> <li>Capacitor C103.</li> </ol> | | No +12 V, or is too high or too low. | <ol> <li>IC U403.</li> <li>Diodes D101-D104.</li> <li>Capacitor C102.</li> </ol> | | No −12 V, or is too high or too low. | IC U404. Diodes D101-D104. Capacitor C104. | | No $-5$ V, or is too high or too low. | <ol> <li>IC U405.</li> <li>IC U404 (-12 V source supplies -5 V regulator).</li> <li>Diodes D101-D104.</li> <li>Capacitor C104.</li> </ol> | | No +53 V, or is too high or too low. | <ol> <li>Transistors Q201, Q202, Q204.</li> <li>Diodes D201, D202.</li> </ol> | | No unregulated voltages (+65, +8.5, +/ $-$ 16) on power supply board. | Check appropriate secondary of T1, diode bridges or filter capacitor. | | No anode voltage when other voltages are OK. | <ol> <li>No sync pulses coming from terminal logic board.</li> <li>Transistors Q213, Q214.</li> <li>Deflection yoke.</li> <li>Coils L203, L204.</li> <li>Capacitors C228, C232.</li> <li>Diode D208.</li> <li>IC's U201, U202.</li> </ol> | | +500 V supply is too high or too low. | Diode D211. Capacitor C231. | | −90 V supply is too high or too low. | <ol> <li>Diode D207.</li> <li>Resistor R259.</li> <li>Capacitor C229.</li> </ol> | | -6 V supply is too high or too low. | <ol> <li>Diode D203.</li> <li>Resistor R212.</li> </ol> | | CONDITION | POSSIBLE CAUSE | |---------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | No video (blank screen). | <ol> <li>Brightness control (R1) turned down.</li> <li>Anode voltage incorrect.</li> <li>Grid voltages incorrect (G1, G2, G4).</li> <li>No cathode drive.</li> <li>Transistors Q901, Q902.</li> <li>No video signal coming from terminal logic board.</li> <li>IC U406.</li> <li>Video circuits on logic board.</li> <li>Diode D901.</li> <li>No sync pulses coming from logic board.</li> <li>Diode D209.</li> </ol> | | Screen all white (raster). | <ol> <li>Grid voltages.</li> <li>Transistors Q901, Q902.</li> <li>Video circuits on terminal logic board.</li> <li>Anode voltage incorrect.</li> </ol> | | Insufficient brightness. | <ol> <li>Transistors Q901, Q902.</li> <li>Diode D902.</li> <li>Capacitors C901-C905.</li> <li>Brightness control, R1, Resistors R901-R904, R214, R218, R219, R217.</li> <li>Grid voltages.</li> </ol> | | One bright horizontal line on screen. | <ol> <li>Vertical amplifier transistors Q207-Q212.</li> <li>Diode D205.</li> <li>Deflection yoke (vertical).</li> <li>Vertical sweep generator transistors Q205, Q206.</li> <li>Diode D204.</li> <li>No vertical sync pulses coming from logic board.</li> <li>IC U406.</li> </ol> | | Too much or too little height. | <ol> <li>Vertical amplifier or sweep generator.</li> <li>Capacitor C213.</li> <li>Resistor R242.</li> <li>Vertical size control R219.</li> <li>Capacitor C211.</li> </ol> | | Too much or too little width. | <ol> <li>Adjust width coil L203.</li> <li>Capacitors.</li> <li>Deflections yoke (horizontal).</li> <li>Coils L203, L204.</li> <li>+53 V supply not correct.</li> <li>Flyback transformer T202.</li> <li>Transistor Q214.</li> </ol> | | CONDITION | POSSIBLE CAUSE | |-------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Picture tube filament does not glow. | <ol> <li>No horizontal sync pulse coming from logic board.</li> <li>Filament winding of T202 (brown wires).</li> <li>Resistor R257.</li> </ol> | | Horizontal centering does not work. | <ol> <li>IC U201.</li> <li>Horizontal centering control R246.</li> <li>Capacitor C221.</li> </ol> | | No horizontal sweep, but sync pulses are present at P202-1. | <ol> <li>Diode D206.</li> <li>IC's U201, U202.</li> <li>Transistors Q213, Q214.</li> <li>Transformer T201.</li> <li>+6 V supply not correct.</li> <li>Capacitor C226.</li> <li>Diode D208.</li> <li>+53 supply not correct.</li> <li>Deflection yoke.</li> <li>Coils L203, L204.</li> </ol> | # **SERVICE INFORMATION** In an extreme case where you are unable to resolve a difficulty, you may want to take your Computer to your local Zenith Data Systems dealer or authorized Zenith Data Systems repair facility. If you can isolate the problem to a particular circuit board, take only that circuit board for repair. This will save service expense. IMPORTANT: Try to list the following information about your Computer. It will help your ZDS dealer to diagnose and repair your unit. - A. The problem you are having. - B. Name, the Model number, and the Series number of your Computer system. (Shown on the blue and white label.) - C. Baud rate. - D. System configuration. - E. Any additional information that will help describe your System. # CIRCUIT DESCRIPTION Refer to the Schematic Diagram (fold-in) and the Computer Block Diagram (Illustration Booklet, Page 7) while you read this "Circuit Description." To help you locate parts in the Computer or on the Schematic, the circuit component numbers (R1, C101, L301, etc.) for resistors, capacitors, coils, transistors, and integrated circuits are in the following groups. > 0-99 Parts mounted on the molded cabinet base or front panel. > 100-199 Parts mounted on the power supply circuit board. > 200-299 Parts mounted on the video circuit board. Parts mounted on the keyboard cir-300-399 cuit board. Parts mounted on the terminal logic 400-499 circuit board. Parts mounted on the CPU logic cir-500-599 cuit board. Parts mounted on the serial interface 600-699 circuit board. Parts mounted on the cassette inter-700-799 face circuit board. Parts mounted on the hard-sectored 800-899 floppy disk interface circuit board. Parts mounted on the video driver circuit board. 900-999 ## POWER SUPPLY CIRCUIT BOARD The primary circuit of the power supply consists of slow-blow fuse F1, ON/OFF switch SW3, 115/230-volt switch SW1, NORM/LOW line switch SW2, and the primary windings of transformer T1. The red secondary windings of transformer T1 supply AC to diode bridge rectifier D109-D112. The 65-volt rectified output of the bridge is filtered by capacitor C1. It is used to power the video circuits. The yellow secondary winding of T1 supplies AC to the diode bridge rectifier BR1. The rectified output of the bridge (approximately 9 VDC) is filtered by capacitors C101 and C103 and is used on the logic circuit board. The green secondary windings supply center-tapped 30 VAC to diode bridge rectifier D101-D104. The rectified outputs of the bridge ( $\pm$ 18 VDC) are filtered by capacitors C102 and C104. These outputs are used on the logic circuit board. #### INTERCONNECTION AND GROUNDING The three power supplies $(+65, +8.5, \text{ and } \pm 18)$ are not interconnected on the power supply circuit board. Instead, they pick up their appropriate grounds at the circuit boards they power. The +65-volt video supply connects to + and ground points on the video circuit board. The external conductive coating of the CRT and the CRT socket arc-ring both connect directly to the video circuit board ground. The +8.5-volt and $\pm 18$ -volt supplies connect directly to the logic circuit boards with no common grounds until they meet at the terminal logic circuit boards. This grounding method produces two independent operating systems that do not interact with each other except through the signal ground and sync/video inputs. In the event of a CRT arc, the arc discharge current is confined to the video circuit board and it does not induce transients into the logic circuits. The logic/video system is also floating with respect to the ground wire of the power cord. The protective ground input (pin 1) of the EIA RS-232 connector connects to the power cord ground, along with all the exposed metal surfaces. The signal ground input (pin 7) of the EIA RS-232 connector connects to the terminal logic circuit board ground. ## VIDEO CIRCUIT BOARD #### POWER SUPPLY The unregulated 65-volts DC from the power supply circuit board enters the video circuit board at plug P202, pins 2 and 3. Assume that the Computer has just been turned on and the output of the +53-volt regulator is at zero volts. The base current of Q201 is supplied through resistors R201, R202, and R203. The collector current of Q201 causes Q202 to turn on and supply current to the base of Q204. As the output voltage at the emitter of Q204 rises, D202 begins to supply current to zener diode D201 through resistor R202. D201 stabilizes at 12.8 volts and provides a reference for the output voltage. The divider formed by resistors R207 and R208 samples the output voltage as it continues to rise, and applies a fraction of the voltage to the emitter of Q201. When the emitter voltage of O201 reaches 12.15 volts (12.8-.65), its collector current is reduced to a value that keeps the output voltage stabilized at +53 volts. The current through R211, supplied to the load by Q204, generates a voltage that is applied through current limiting resistor R209 to the base of Q203. If the current thus developed exceeds about 1.1 amperes, Q203 turns on and shunts current from the base of Q202, which, in turn, prevents the output current from exceeding 1.1 amperes. D203 and R212 form another zener regulator that supplies 6.2 volts DC to the video driver circuit board and 6 volts DC to the horizontal section through R213. #### VERTICAL SECTION The vertical portion of the video circuit board consists of two sections, a sweep generator and an amplifier. The sweep (or ramp) generator consists of C208, C209, R221, and Q205. Capacitors C208 and C209 charge to +53 volts through resistor R221 to generate the ramp. This ramp voltage is applied to the anode of Q205, a programmable unijunction transistor. The gate of the unijunction is biased at a voltage determined by R215, R216, D204, and R217. When the anode voltage charges to the gate voltage, Q205 conducts and discharges C208 to ground through L201. As the discharge current decreases to zero, the unijunction stops conducting and the capacitors start to charge again through R221. The ramp voltage is applied to the base of Darlington voltage follower Q206. The emitter voltage of Q206 is fed back to the junction of C208 and C209 to linearize the exponential ramp. Resistor R222 and Vert Linearity control R223 determine the amount of correction applied to the ramp. The amplitude of the ramp is determined by R218 and the Vert Size control, R219. The free-running frequency of the oscillator is slightly less than 60 Hz, the normal sweep rate. Vertical sync pulses, which enter the circuit board at plug P202, pin 6, are coupled through C206 and D204 to the gate of transistor Q205. The negative-going pulse lowers the gate voltage below the anode voltage and Q205 immediately conducts, discharging C208 and C209 before the free-running trip point is reached. This increases the oscillator frequency to 60 Hz (or 50 Hz if you set section 7 of switch S402 to its "1" position). Each succeeding sync pulse keeps the oscillator synchronized with the vertical sync signal generated by the CRT controller on the logic circuit board. The amplifier portion of the vertical circuitry is composed of Q207, Q208, Q209, Q210, Q211, and Q212. Under steady-state conditions, with no ramp signal applied to the base of transistor Q208, the collector currents of Q207 and Q208 are determined by bias string R225, R226, R227, R228 and emitter resistors R229 and R231. The collector current of Q207 is nominally 3 milliamperes, and the collector current of Q208 is nominally 2 milliamperes. The difference (1) milliampere) between the two, supplies base current to driver transistor Q209, which drives output transistors Q211 and Q212. Diode D205 and resistor R237 bias transistors Q211 and Q212 so that there is enough idle current to eliminate crossover distortion. Transistor Q210 is a current source that provides base current for Q212 and the bias network, D205 and R237. The output voltage at the junction of R239 and R241 is fed back to the bias string through R234 to keep the output stable at about 25 volts. When the ramp signal is applied to the input of the amplifier through C211, the collector current of Q208 is varied as a function of the amplitude of the ramp voltage. The difference between the currents of Q207 and Q208 drives the outputs through Q209. The output voltage is fed through C216 to the vertical deflection yoke. Resistor R242, which is in series with the yoke, generates a voltage proportional to the yoke current. This voltage is fed back to the base of Q207 (negative feedback), which changes its collector current to keep the yoke current directly proportional to the input ramp voltage. #### HORIZONTAL SECTION The horizontal portion of the video circuit board consists of three sections: Time delay and pulse shaping. Horizontal deflection. High voltage supplies. The time delay and pulse shaping circuits are triggered by the horizontal sync pulses that come from the logic circuit board. They generate a time delay that provides horizontal centering and a pulse of the proper width to drive the horizontal sweep system. The horizontal deflection system transfers energy from the power supply to the yoke in order to sweep the beam across the face of the CRT. The high voltage supplies generate the anode and grid voltages that operates the CRT. #### TIME DELAY AND PULSE SHAPING The horizontal sync pulses enter the circuit board at plug P202, pin 1. These pulses are then coupled through R243, C217, and D206 to U201. The trailing edge of each pulse triggers U201, a timer used as a monostable multivibrator, causing the output (pin 3), to go high. The width of the output pulse is determined by C221, R247 and Horizontal Centering control R246. When the output pulse from U201 goes low, it triggers another timer used as a monostable multivibrator, U202. The 20 microsecond output pulse of U202 (pin 3) is determined by C223 and R249. This pulse drives horizontal driver transistor Q213. #### HORIZONTAL SWEEP AND HIGH VOLTAGE Transistor Q213 and driver transformer T201 drive horizontal output transistor Q214, which, in turn, drives the horizontal output transformer (flyback transformer) and the yoke. The positive-going pulse from U202 is coupled through the parallel combination of R251 and C224 to the base of Q213. During the time the pulse is high, the collector current of Q213 flows through the primary of T201. The phasing of the transformer is such that the secondary output voltage during this time is negative and keeps Q214 turned off. While Q213 is turned on and current flows through the primary, energy is stored in T201. When the output pulse from U202 returns to zero volts, Q213 turns off, its collector current decreases to zero, the secondary voltage of T201 goes positive, and Q214 starts to conduct. The energy stored in the transformer is converted to base current and keeps Q214 turned on for the rest of the cycle. The transformer inductance, R254, R255, C226, and L202 control the base current decay and insure the best efficiency of the output transistor. Transistor Q214 is a switch that controls the flow of energy through the deflection components. When Q214 is turned on, current flows from the power supply through the primary of horizontal output transformer T202 and through the horizontal yoke, L203, L204, and C232 to ground. During this time, the yoke current increases linearly and the beam is deflected to the right of the screen. When it reaches the right edge, driver transistor Q213 turns on and output transistor Q214 turns off. The energy that was stored in the yoke (along with the energy stored in the primary of T202) is transferred to C228 in the form of a half-wave voltage pulse with an amplitude of 550 volts. During this cycle, the current through the yoke goes to zero and the beam returns to the center of the screen. Capacitor C228 now discharges into the yoke, inducting a current in the opposite direction, deflecting the beam to the left side of the screen. As the voltage across C228 decreases to zero volts, the resonant circuit of C228, the yoke, and the primary of T202 tries to oscillate in a negative direction. The energy transferred to the yoke by C228 now provides the sweep current for the first half of the scan and charges C232 via damper diode, D208. Shortly before the beam reaches the center (before the yoke current reaches zero), transistor Q213 is turned off by U202 and Q214 is turned on. For a brief period, both D208 and Q214 are conducting in opposite directions. D208 is conducting the yoke current and Q214 is conducting the primary current of T202. Transistor Q214 turns on early to guarantee a smooth transition from negative to positive yoke current. The value of C232 is chosen to provide "S" shaping of the current waveform through the yoke. This compensates for stretching at the left and right edges of the screen. Since the deflected beam sweeps a wider area at the edges than it does at the center for a given deflection angle, the current is decreased slightly at the left and right edges. Width coil L203 is in series with the yoke and its reactance can be adjusted to change the total current through the yoke. If its reactance is high, the yoke current is slightly decreased and the scan width is reduced. If its reactance is low, the scan width is increased. Vertical linearity coil L204 is a nonlinear inductor that provides further linearity correction that cannot be provided by C232 alone. #### HIGH VOLTAGE SUPPLIES The flyback voltage pulse developed at the collector of Q214 during the horizontal retrace is rectified by D211 and C231 to provide approximately 500 volts DC. This voltage, which is filtered further by R266, C235, C236, and C237 is coupled through R909, on the driver circuit board, to the CRT grid 2 (G2). The same flyback pulse is transformer coupled to the secondary of T202 and rectified by D207 and C229 to generate a -100-volt DC supply. Resistor R265 and Focus control R264 form a voltage divider between the +500-volt and the -100-volt supplies to provide a bias voltage for grid 4 (the focus grid). This voltage is coupled through R267 and R908, on the driver board, to G4 on the CRT. Another voltage divider consisting of D209, R261, and G1 control R262, between the +55-volt and -100-volt supplies, provides a bias voltage for grid 1 of the CRT. The flyback pulse is also coupled to another secondary of transformer T202, the high voltage winding. The output pulse from this winding is about +15,000 volts. It is rectified by D1 (in the anode lead) and filtered by the internal capacitance of the CRT to provide the anode (or accelerator) voltage for the CRT. Occasionally, the voltage stored in the internal capacitance of the CRT arcs over to the other electrodes. An arc ring built into the tube socket, and C233 (a capacitor with a parallel spark gap), in conjunction with driver circuit board series resistors R904, R907, R908, and R909, limit the amount of the arc energy on the video circuit board to a safe value. Flyback transformer T202 also has a filament winding that supplies 6.3 volts AC at 450 milliamperes to power the CRT filament. # VIDEO DRIVER CIRCUIT BOARD The voltages for the CRT, except for the anode supply and deflection voltages, are either generated on or pass through the video driver circuit board. The CRT 6.3 VAC voltage originates on the video circuit board and passes directly through the video driver circuit board to the CRT. The filament voltage is RF-bypassed to ground on the driver board by capacitors C907 and C908. A common ground also is routed from the video board through the driver board, and forms an arc-ground to the cathode and grid circuits of the CRT. The video amplifier is a conventional cascade amplifier. The video signal is routed onto the board from rear panel Brightness control R1 and through resistor R905 to the base of transistor Q902. The base of transistor Q901 is biased by the 6.2-volt supply coming from the video circuit board. The signal at the collector of Q901 is coupled through resistor R904 to the cathode of the CRT. Choke L901, in series with collector load resistor R903, provides high frequency compensation. Grid voltages for the CRT are routed through three, series-connected, current-limiting resistors on the driver board, R907 to grid 1, R908 to grid 4, and R909 to grid 2. # TERMINAL LOGIC CIRCUIT BOARD | The terminal logic board consists of seven functional blocks: | U426, U427,<br>U429, U431, | Master clock and system logic. | | |----------------------------------------------------------------|----------------------------|---------------------------------------------------------------|--| | 1. Power supplies. | U434, U435,<br>U440-U442 | | | | 2. Keyboard encoder and configuration logic. | U413, U428, | Processor, ROM, RAM, pro- | | | 3. Processor/CPU. | U430, U432,<br>U433, | cessor control logic. | | | 4. Master clock and system logic. | U436-U439 | | | | 5. Communications. | U443-U450 | Keyboard encoder and configuration logic. | | | 6. CRT and memory control. | U452-U454 | Communications and | | | 7. Display memory, character generator, and | | I/O drivers. | | | video control logic. | U414-U418 | CRT and memory control. | | | The integrated circuits in each block are numbered as follows: | U406-U411,<br>U419-U425 | Display memory, character generator, and video control logic. | | | U401-U405 Power supplies. | | | | #### **POWER SUPPLIES** Integrated circuits U401 and U402 provide two regulated 5-volt supplies. U401 supplies 5-volts DC for the left half of the circuit board, while U402 supplies the right half of the circuit board. U403 supplies +12 volts DC, U404 supplies -12 volts DC, and U405 supplies -5.2 volts DC. These integrated circuits are internally protected against short circuits, overloads, and high temperatures. Capacitors C402, C404, C407, and C411 at the inputs of the regulators stabilize the supplies, while capacitors C403, C405, C408, C412, and C413 improve the transient response of the regulators. C412 serves as the input stability capacitor for U405 and as the output capacitor for U404. #### MASTER CLOCK AND SYSTEM LOGIC #### **Clock And Scalers** The master clock is a 12.288 MHz crystal-controlled oscillator. Crystal Y401, with C419, C421, and U426E form the oscillator. The series combination of C419 and C421 serve as the load capacitance for the crystal. U426E is the gain stage. Resistors R408 and R409 bias U426E into its linear region, while C418 bypasses any AC feedback through the two resistors. The output of the oscillator is buffered by U426D to prevent loading on the output from changing the oscillator frequency. This output is the "dot clock" and it is used by the shift register to shift dot information to the screen. The dot clock also drives divide-by-sixteen counter U427, which generates 1.536 MHz pulses. This is called the character clock. Each pulse corresponds to one character on the screen. U427 is a synchronous presettable counter that is loaded with a binary eight (1000). It counts dot clock pulses until its output reaches binary fifteen (1111). During the fifteenth count, the ripple carry output (pin 15) goes low. This pulse, which is inverted by U426F, puts a logic one on the load input (pin 9). The next positive-going clock cycle reloads a binary eight back into the counter and the cycle repeats. The Q<sub>c</sub> output (pin 12) generates a 1.536 MHz pulse that serves as the clock for (pin 21) CRT controller U417. It is inverted by U412D. These two signals are referred to on the Schematic as C and C. The $Q_B$ (pin 13) output generates a 3.072 MHz signal that drives the clock input (pin 16) of the ACE (U452). The dot clock also drives U429. U429 is a divide-by-six and divide-by-two scaler. The clock drives the B input (pin 1), and the $Q_D$ output (pin 8) generates a 2.048 MHz clock signal for CPU (U430). The $Q_D$ output (pin 8) also drives the A input (pin 14). The $Q_A$ output (pin 12) in turn drives the input of binary scaler U440. The output of U440 provides a 128 kHz clock (pin 6) for the keyboard encoder, U444 and a 1 kHz signal (pin 14) for the audible bell signal. #### **System Control Logic** The system control logic consists of I/O and memory decoding, power-up and manual reset circuits, and the bell and key clock circuits. I/O and memory decoding are accomplished by three-to-eight line decoders U442 and U435, respectively. U442 decodes address bits A5, A6, and A7, to generate eight I/O addresses: | 1. | Keyboard encoder | |----|------------------------------------------------| | 2. | Keyboard status240 $(A0_H)$ | | 3. | CRT controller140 $(60_H)$ | | 4. | Power-up configuration (primary)000 $(00_H)$ | | 5. | Power-up configuration (secondary)040 $(20_H)$ | | 6. | ACE (communications) | | 7. | Bell enable | | 8. | Key click enable | Decoder U442 is enabled only during an I/O read or write operation to eliminate the possibility of false decoding on a refresh address coming from the Z80. U435 decodes address bits 14 and 15 to generate three memory addresses: | 1. | Program ROM | |----|----------------| | 2. | Scratchpad RAM | | 3. | Display memory | Whenever the Z80 performs a read or a write operation it will either write to or read from one of these memory or I/O addresses. When the Computer is first turned on, the CPU, CRT controller, ACE, and keyboard control logic are cleared by the master reset signal. U431A, R412, C422, and D401 form the power-up reset circuit. When power is first turned on, C422 has no charge and temporarily holds pin 2 of U431A at logic zero. The output of U431 goes high and is inverted by U431B. The two outputs are the true and the complimented reset pulses. As C422 charges through R412, it pulls the input of U431 high, turning off the reset pulses. A manual reset can also be accomplished if you simultaneously press the Reset and right-hand Shift keys on the keyboard. U446E and U446B are connected to those keys and they drive the inputs of U431D. The output of U431D (pin 11) is coupled through R413 to pin 1 of U431A. R413 and C423 form a de-bounce circuit for the Shift and Reset keys. When the output of U431D goes low, the input of U431A is also pulled low. This generates a reset pulse. The CPU, under the control of the ROM program, can cause a bell tone or a key click to sound through the speaker. When the CPU addresses I/O port 340, pin 7 of U442 trigger one-half of monostable U441. Its output goes low for about 200 milliseconds, causing the output of U431C to go high. This logic 1 is NANDed in U434C with the 1000 Hz signal coming from U422. The output of U434C drives speaker SP1. Diode D402 keeps the output of U434C from being driven above 5-volts at turn-off by the inductive reactance of the speaker. When the CPU addresses I/O port 300, pin 9 of U442 triggers the other half of U441. Its output (pin 7) goes low for about six milliseconds and turns on the 1000 Hz tone. This short duration causes the tone to sound like a click. #### **PROCESSOR** The processor section of the Terminal consists of the Z80 processor (U430 the CPU, central processing unit), ROM (read only memory), RAM (random access memory), and processor control logic. #### Processor/CPU The heart of the terminal logic circuit board is the Z80 CPU. It acts as a scheduling or dispatching service for the data coming into or originating from the Terminal. It examines the data it receives and determines what, if anything, it should do with it. If the data comes from the ACE (U452), for example, the Z80 will compare the ASCII word with a set of conditions determined by the ROM program, and then write the word into the appropriate memory or I/O port. If the ASCII word is a bell signal, the CPU addresses I/O port 340, and the bell tone sounds through the speaker. If the word is the letter "B", the CPU performs a memory write to the current cursor position in the display memory. If the data from the ACE is a nonvalid character or a string of characters, the CPU simply ignores the data and does nothing. The ROM program that directs the CPU is rather long and complex, but the mechanics of the process are easy to follow. The 2.048 MHz clock signal drives the clock input (pin 6) of the CPU through U426A. This steps the CPU through an internal "Machine" cycle that starts with a fetch instruction. It executes the remainder of its instructions by stepping through a precise set of a few basic instructions. These include memory read, memory write, I/O read, I/O write, and interrupt acknowledge. The basic thing to remember is that the ROM program directs the Z80 to make decisions and move data from place to place within the circuit board. Without the CPU and ROM, the decisions and data movement would have to be accomplished with hard-wired logic packages. For a more detailed description of the Z80 processor, refer to Chapter 12 of this Manual, starting on Page 12-1. #### **ROM** The read only memory, U437, is a pair of $4K \times 8$ -bit (32768 bit) ROM. Its twelve address inputs connect to A0 through A11 of the address bus and its eight data outputs connect to D0 through D7 of the data bus. U413A, U413B, and U434D decode the ROM select line coming from memory decoder U435. #### **RAM** The random access memory for the Z80 scratchpad consists of U438 and U439, $256 \times 4$ -bit RAMs. This scratchpad RAM provides temporary data storage for the Z80. The address inputs to each IC connect to A0 through A7 on the address bus. The lower four bits of data (D0-D3) are provided by U438; the upper four bits (D4-D7) are provided by U439. The select signal comes from U435. #### **Processor Control Logic** The processor for the Terminal requires some additional circuitry to control the interrupt process, and to provide a wait cycle for keyboard encoder U444, which is slow in responding to a read cycle. U432C is a 2-input NOR gate that monitors the INTRPT output of the ACE (U452) and pin 6 of U447B (the keyboard INTRPT). When either INTRPT output goes high, the output of U432C goes low and signals the INT input (pin 16) of the Z80 that data is available from the ACE or keyboard. U433, U432A, and U432B form a counter that drives the WAIT input (pin 24) of the Z80. Whenever the Z80 performs an I/O read at the keyboard encoder, pin 11 of U442 drives the "reset to zero" inputs (pins 12 and 13) of U433. The $Q_4$ and $Q_B$ outputs (pins 9 and 5) of U433 drive the inputs of U432B, a 2-input NOR gate. The output of U432B holds the Z80 WAIT input low whenever the $Q_4$ or $Q_B$ outputs of the counter are high. This generates a total wait of four clock cycles (one wait cycle is automatically inserted by the Z80 on an I/O instruction) to allow the output buffer of U444 to turn on. When the $Q_{\it C}$ output (pin 4) of counter U433 goes high, it drives the input of U432A high. This forces the output low and turns off the A input (pin 10) of U433. The $Q_{\it A}$ and $Q_{\it B}$ outputs now go low and the wait signal is no longer present. The Z80 then finishes up the I/O read cycle (pin 11 of U442 goes high) and the counter is reset to zero and held there until the next keyboard read. U428 provides a nonmaskable-interrupt (NMI) that operates under the control of the ROM program. The NMI routine is used when the program wants to read something into the CRT Controller (or CRTC) during the vertical blanking period. The data input of U428A is driven by A2 of the address bus. The T. or clock. input is driven by the complemented CRT controller I/O select that comes from pin 12 of I/O decoder U442 through U412C, which provides the complement of the signal. When the program wants to write during vertical retrace, it addresses the CRT controller while holding A2 high. The Q output of U428A is clocked high and drives the reset input of U428B high. The vertical sync signal from U417 drives the T input of U428B and clocks the Q output low as soon as the sync signal begins. The NMI input of the Z80 goes low and the program immediately jumps to the "update CRTC" routine. Part of that routine will write a zero to the data input of U428A to clear the NMI signal. # KEYBOARD ENCODER AND CONFIGURATION LOGIC #### Keyboard Encoder The keyboard of the Terminal consists of single-pole, single-throw switches in a matrix that is scanned by keyboard encoder U444. Outputs X1 through X9 go high, in sequence, and drive one of the Y1 through Y10 inputs if one of the switches is depressed. The encoder uses the X and Y information to generate a unique binary code for each matrix intersection, and this code is latched internally when a key is depressed. The encoder generates a data strobe (DS), which comes from pin 13 of U444, for each key closure. DS clocks the T input (pin 3) of U448A and the $\overline{Q}$ output of U448A goes low. The $\overline{Q}$ output drives an input of U447B. The output of U447B, an $\overline{INT}$ signal, is coupled to Z80 pin 16. When the Z80 services the interrupt at I/O port 200, pin 11 of U442 clears U448A (through U447C and U446A) and the $\overline{INT}$ signal is removed. Pin 36 of U444 is also a binary data output and it is latched in U448B by the I/O read at 80H (200Q). The keyboard interrupt routine also checks the keyboard status in another I/O read operation. The keyboard status check reads the state of the following: - 1. Control key. - 2. Shift keys. - 3. Repeat key. - 4. Break key. - Off-line key. - 6. Caps Lock key. - 7. Data Strobe. - 8. Data bit latched in U448B. The ROM program uses this information in conjunction with the encoder data to determine the routing of the data within the Terminal. Pin 10 of I/O decoder U442 drives enable inputs (pin 19) of buffers U449 and U450 to put the status information on the bus. The Caps Lock, Break, Off Line, Control, Repeat, and Shift (left) keys are connected directly to the inputs of these buffers. The outputs of U448A and U448B are also connected to the inputs of the buffers. The binary data outputs of the keyboard encoder drive the address inputs (A0-A7) of ROM U445. U445 converts the binary data from the keyboard encoder to ASCII data. The data outputs of U445 drive the D0-D7 bits of the data bus. The chip select input (pin 18) of U445 is driven by pin 11 of U442 (the I/O decoder). When the Repeat key is held down, the input of U446D is low and its output is high. This enables the repeat rate oscillator, U447A, R437, C481, and Q402. The repeat frequency, approximately 15 Hz, is determined by R437 and C481. When the Repeat key is released, the output of U446D goes low, forcing the output of U447A high and disabling the repeat function. The two shift keys are NORed together in U447D. Its output drives the shift input (pin 21) of U444. When the Control key is typed, the output of U446F is forced high, which drives the control input (pin 19) of keyboard encoder U444. ### Configuration (Power-up) Logic When the system is first turned on, the ROM program must program the ACE (U452) for the baud rate and parity that you selected on switches S401 and S402. The program addresses I/O port 00H (000Q). Pin 15 of I/O decoder U442 drives enable inputs of U449 and U450 to put the information selected by the switches on the bus. The program then interprets the data and configures the ACE accordingly. I/O address 20H (040Q) is used in a similar manner. Pin 14 of the I/O decoder U442 enables buffer U443 and puts the data from S402 on the bus. ### **COMMUNICATIONS AND I/O DRIVERS** The Terminal talks to the outside world through an Asynchronous Communications Element (ACE) and EIA RS-232C compatible line drivers and receivers. The ACE (U452) converts parallel ASCII data to serial data and drives the communications line through line driver U453. The ACE also converts serial data coming from line receiver U454 into parallel ASCII data. The ACE puts this data on the bus when the ROM program requests it. #### ACE/UART U451 is an Asynchronous Communications Element that performs the following functions: - Converts data from parallel to serial and vice versa. - Divides a master clock frequency by a programmed divisor to generate a desired baud rate. - 3. Programs the data characteristics, parity, stop bits, and character length. The characteristics of the ACE must be programmed into the internal registers of U452 by the ROM program through the address and data busses. Bidirectional data bits (pins 1-8) of U452 connect to the system data bus. The address inputs (pins 28, 27, and 26) connect to the system address bits A0, A1, and A2. When the ROM program addresses I/O port 40H (100Q), pin 13 of I/O decoder U442 selects the CS2 input (pin 14) of the ACE. The Z80 can then read or write data by enabling the data input and data output strobes at pins 21 and 18 (DISTR and DOSTR) of U452. When the ACE receives a complete serial word from the EIA interface, it signals the Z80 that there is data available by pulling the Z80 $\overline{\text{INT}}$ input (pin 16) low. The Z80 then examines the internal status and data registers of the ACE, reads the data word, and routes it to the proper device within the Computer. For a more complete description of the ACE, refer to Chapter 13 in this Manual, starting on Page 13-1. #### I/O Drivers The standard EIA interface communicates by means of a serial stream of voltage levels that correspond to logic ones and zeros. A logic one (or mark) on the data lines is a voltage between -5 and -15 volts. A logic zero on the data lines is a voltage between +5 and +15 volts. On the control lines (DTR, RTS, RLSD, DSR, CTS), a voltage between +5 and +15 volts is considered to be ON, and a voltage between -5 and -15 volts is considered to be OFF. U453 is a standard EIA line driver. A logic one on the input of U453C drives the serial data outline to an EIA logic one, or "mark." A zero on the input forces the line to an EIA zero, or "space." U453B and U453D drive control lines DTR (Data Terminal Ready) and RTS (Ready to Send) in a similar manner. U454 is a standard EIA line receiver. The serial data in line drives the input of U454A, which converts the EIA voltages to TTL levels and drives the serial input of the ACE. Likewise, the RLSD, DSR, and CRS line signals drive the inputs of U454B, U454D, and U454C, respectively. The outputs drive the appropriate control inputs of the ACE. The I/O connector on the back panel of the Computer is a standard 25-pin D-type plug with the data and signal line connected as follows: - 1. Protective or chassis ground. - 2. Serial Data Out. - 3. Serial Data In. - 4. Request To Send (RTS). - 5. Clear To Send (CTS). - 6. Data Set Ready (DSR). - 7. Signal ground. - 8. Received Line Signal Detector In (RLSD). - 20. Data Terminal Ready (DTR). #### CRT AND DISPLAY MEMORY CONTROL The heart of the video logic system is the CRT controller. This device generates all of the sync and blanking signals and display memory addresses for the video system. The memory control is used to select either the address coming from the CRT controller or the address bus, and to synchronize read and write pulses. #### CRT Controller The CRT controller, U417, is a fully programmable device that is set up by the ROM program during power-up. Its bidirectional data bits (pins 33-26) connect to system data bits D0-D7. Its address or programming inputs come from the following four input pins: Pin 22. Read/Write $(R/\overline{W})$ – Determines whether the controller's internal register file is to be written to or read from. A write is a logic zero. - Pin 24. Register Select (RS) Selects either the address register (RS=0) or one of the data registers (RS=1) of the internal register file. - Pin 25. Chip Select (CS) A zero sets the CRT controller to read or write the internal memory file. - Pin 23. Enable (E) Enables the I/O buffers and clocks data to and from the CRT controller. Data is clocked on the falling edge of the enable signal. The internal registers are written to or from by means of the address register. The Z80 sets up the programmable registers by first writing a register number into the address register when the register select input is low. It then performs a write operation when the register select input goes high. Each of the CRT controller's registers is programmed at power-up with appropriate data to generate the SYNC, timing, and refresh signals. The memory address outputs (MA0-MA10) drive the address of the display RAM through multiplexers U414, U415, and U416. The scan row address outputs (RA0-RA3) drive the address inputs of character generator U420. The display enable output (DISPLAY) is a logic one whenever the CRT controller, U417, is addressing a port of the RAM during the time it should be displayed. This serves as a blanking output whenever it is a logic zero. The cursor output goes to a logic one when the RAM location being addressed is equal to the address stored in the cursor address registers. #### **Controller Read/Write Logic** The $\overline{\text{CS}}$ and E inputs of the CRT controller must be selected in a particular sequence to perform read and write operations to and from the controller. The enable input pulse (pin 23) must always be inside the CS pulse. When the I/O request for address 140 appears at pin 12 of U442, the clear input of U418A goes low, and the Q output immediately drives the CS input low. The $\overline{\text{Q}}$ output drives the data input of U418B to a logic one. At the same time, U412C puts the Clear input of U418B at a logic one. The next CPU clock pulse at pin 11 of U418B clocks the logic one at the data input through to the Q output. This delays the leading edge of the enable pulse until approximately one clock cycle after the leading edge of the $\overline{CS}$ pulse. When the I/O request at address 140 goes away (returns to logic one), the output of U412C immediately clears U418B. U418B's Q output (pin 9) drives the E input of the CRT controller to zero. The clear input of U418A goes high at the same time, but the Q output remains low until the next CPU clock pulse at U418A's clock (pin 3) clocks the logic one at the data input through to the output, terminating the $\overline{CS}$ . This delays the trailing edge of the $\overline{CS}$ pulse until after the trailing edge of the E pulse. #### **Display Memory Control** The display memory control consists of an address bus multiplexer, a bidirectional bus buffer, and some gates that control the display memory write enable (WE) and chip select $(\overline{CS})$ inputs. The address bus multiplexer consists of quad 2-input multiplexers U414, U415, and U416. Their select inputs are tied together and controlled by memory decoder U435. When no read or write operations are being performed on the display memory, the select inputs are at a logic one, and the memory addresses (MA0-MA9) generated by the CRT controller drive the address inputs (A0-A9) of RAMs U408-U411. Memory address MA10, generated by the CRT controller, is used to select either the upper or the lower 1k bank of video RAM. When the Z80 addresses the memory, pin 9 of U435 pulls the select input to a logic zero, CRT controller memory addresses MA0-MA9 are disconnected from the display RAM, and address bus bits A0-A9 are connected to the RAM address inputs. The Z80 can then read from or write into the display RAM. Bus buffer U407 isolates the main data bus from the secondary or refresh, bus. During the screen refresh period, the data outputs of the display RAM drive the data inputs of the character generator continuously. This would prevent the processor from having access to the bus except during retrace times. However, by isolating the refresh bus from the main bus, the Z80 can have continuous access to the main bus, and the display RAM and character generator can have continuous access to the secondary bus (refresh bus). When the Z80 needs access to the display RAM, it addresses the memory, which enables U407 through pin 9 of U435, and connects the main bus directly to the secondary bus. U412A and U412B provide the $\overline{\text{CS}}$ signals for the display RAMs. During the screen refresh cycle, pin 11 of U414 is driven by A10 and pins 1 and 4 of U412 are logic one. The output of U412A provides the $\overline{\text{CS}}$ for RAMs U408 and U409 and drives input pin 5 of U412B. The output of U412B is the complement of the $\overline{\text{CS}}$ signal and it drives the $\overline{\text{CS}}$ input of RAMs U410 and U411. During a display RAM read or write cycle, pins 1 and 4 of U412 are driven by the RD+WR signal coming (indirectly) from pin 3 of U434A. This eliminates the possibility of a contention problem on the secondary (refresh) bus between the display RAMs and buffer U407. The write (WE) inputs of the RAMs are connected together and they are controlled by U413C. The WE (pin 8 of U413C) cannot go low unless pin 9 of U435 is low (memory is selected), the signal is delayed slightly to avoid a timing race with memory selection, and the Z80 WR output is low. #### DISPLAY MEMORY, CHARACTER GENERATOR, AND VIDEO CONTROL LOGIC This section of the terminal logic circuit board essentially runs by itself (in conjunction with the CRT controller) after being programmed by the Z80. The CRT controller continually provides refresh addresses for the display RAM, while the output of the RAM continually provides data for the character generator and the video shift register. #### **Character Generator** Character generator U420 is a 2048 × 8 (16384 bit) read only memory (ROM) that converts the ASCII data stored in the display memory into dot information for the video shift register. Address inputs A0-A3 (pin 5-8) are driven by the scan row address outputs of the CRT controller (RA0-RA3) to select a particular row of dots within a character space. Address inputs A4-A10 connect to the secondary data bus through 8-bit latch U419. These inputs use ASCII data to address the dot data stored in the ROM. The data outputs (01-08) of U420 supply video dot data to the parallel inputs of video shift register U421. The inputs of 8-bit latch U419 connect to the secondary data bus. Data bits D0-D6 are latched into U419A-G and drive the character generator. Data bit D7 is the reverse video bit. It is latched in U419H and drives an input of U423A. Video shift register U421 latches parallel dot data from the character generator at inputs A-H and shifts it out of output $Q_H$ in synchronism with the dot clock (the dot clock drives the clock input, pin 7). The shift register is loaded (the dot data is latched) on a positive-going transition of the dot clock while the shift/load input is held low by the ripple carry coming from pin 12 of U426F. The dot data at input H appears immediately at output $Q_H$ . The next leading edge of the dot clock shifts the data that was latched at $Q_G$ . The next edge of the dot clock will shift the data that was latched in $Q_F$ , and so on. After the data from $Q_A$ is shifted to the $Q_H$ output, the load input goes low, and the next character cycle begins. ### Video Control Logic The video control logic consists of two sections: a series, or chain, of gates and latches associated with video, cursor, and reverse video data; and a chain of gates and latches associated with blanking data. The display enable (blanking) and cursor data from pins 18 and 19 of the CRT controller is coincident with MA0-MA10, which address the display RAM. The display enable bit is latched in U424F (after passing through AND gate U423C) by the complemented character clock pulse coming from pin 11 of U412D. The cursor bit is latched in U424F. This delays the two signals by one character time. They are delayed for one more character time by being latched in U424E and U424G, respectively. The two character delays are necessary to compensate for the delays in the display RAM/character generator "pipeline." When MA0-MA10 address the RAM, it takes approximately 450 nS for the data to be valid at the outputs. Once it settles down, the next character clock latches it in U419. The data at the output of U419 then addresses character generator U420. The data at the output takes another 450 nS to settle, and it is latched in the shift register by the following clock pulse. (Since the character clock pulses are 650 nS apart, the RAM and character generator outputs have plenty of time to settle). This two-character delay matches the delays for the cursor and display enable, so that everything is synchronized. The reverse video bit (D7) in the display RAM is latched first in U419, and then in U424H (after passing through AND gate U423A), so that it too arrives coincident with the video, blanking, and cursor data. The video dot data from pin 13 of video shift register U421 and the cursor data coming from pin 16 of U424G are exclusive-ORed in U425A. This causes the cursor dots to reverse when the cursor happens to be coincident with video information, and keeps the cursor from disappearing when it occupies the same space as a character. The video/cursor information coming from pin 3 of U425A is then exclusive-ORed in U425B with the reverse video data coming from pin 19 of U424H. When pin 19 is logic zero, the video/cursor data passes through U425B just as it is entered. If pin 19 of U424H is logic one, the data is reversed, and the character appears on the screen as black dots on a white background. The reverse video function can be disabled under the control of the ROM program when a logic zero is written into latch U422B via the address bus. Address bit A3 drives the data input of U422B, and its clock input is clocked when the CRT controller is addressed (I/O address 140). If the reverse video is to be ignored, the Q output (pin 9) of U422B puts pin 1 of AND gate U423A at a logic 0 and disables the reverse video bit coming from pin 19 of latch U424H. The video/cursor/reverse data coming from pin 6 of U425B is ANDed in U423D with the display enable data coming from pin 12 of U424E. If the display enable is logic 1, the video data goes to the video circuit board; if it is a logic zero, the video is blanked. When the Z80 performs a read or write operation on the display RAM, it disturbs the pipeline, and the data on the secondary (refresh) bus does not coincide with what should be written on the screen. Consequently, the video is blanked during a read or write. When pin 9 of memory decoder U435 goes low to select the display RAM, it also drives the clear input (pin 1) of U424. The Q output (pin 6) of U424C drives pin 9 of AND gate U423C to a logic zero and disables the display enable. At the same time, the Q output (pin 12) of U424E drives pin 12 of AND gate U423D to a logic zero, blanking the video information coming from the video chain. The screen will blank as long as the RAM is selected. When pin 9 of U435 goes high to deselect the RAM, U424 is no longer held cleared. The logic one at the D input of U424C is clocked through to its Q output on the next character clock pulse, and it is clocked through U424D and U424E on the next two pulses. This three-character delay gives the pipeline time to reload with valid information before the video is enabled. The propagation delays through the various gates and latches (U421, U425A, U425B, and U424) from the edge of the character and dot clocks to their various outputs is not always constant, so another delay is used. Latch U422A acts as a mini-pipeline, clocked at the dot rate. The data input to U422A is the composite video/cursor/reverse/blanking data, and its T input is clocked by the dot clock. This 80 nS delay lets all data settle to valid states before it is sent to the video circuit board. The sync and video signals are buffered before they leave the terminal logic circuit board. U406A inverts and buffers the video data. U406C inverts and buffers the vertical sync signal coming from pin 40 of the CRT controller. U406D buffers the horizontal sync signal coming from pin 39 of the CRT controller. ### CPU LOGIC CIRCUIT BOARD Refer to the CPU Logic Circuit Board Block Diagram (Illustration Booklet, Page 6) as you read the following material. #### SYSTEM CLOCK Crystal X501, in conjunction with U501A, form a crystal oscillator which operates at 12.288 MHz. Capacitors C501 and C503 provide the load for the crystal, while R501 and R502 force U501A to operate in its linear mode. C502 acts as a low-pass filter to insure that the crystal will determine the operating frequency of the circuit rather than the delay time of U501A. U502 operates both as a divide-by-6 scaler, resulting in a 2.048 MHz clock signal, and as a divide-by-two scaler acting on the 2.048 MHz signal to provide U503's clock . U503 operates as a divide-by-1024 scaler and provides the 2 mS clock signal. #### **POWER-UP AND RESET** When power is first applied, capacitor C507 is discharged. As the +5 V source becomes active, C507 begins to charge. Approximately 150 mS after the +5 V source reaches +5 volts, pin 6 of U508B goes low and pin 8 of U501D goes high and terminates the power-up reset operation. As long as the reset and shift keys are held down on the keyboard, pin 3 of U506A is held low and the display electronics are continuously reset. However, the Computer is not reset until the keys are released. This insures that the display will complete its reset function before the Computer resets; thus resulting in a proper indication on the display. The rising edge of the KBRST L signal toggles U506A and causes its Q output (pin 5) to go high. This signal is coupled to a 50 $\mu$ S one-shot (U507A) by U508A, and is the trigger signal for the one-shot. U507A's output is the reset signal used by the Computer and is coupled to the Computer by U508B and U501D. U508A and U508D form an R-S flip-flop which guarantees that a keyboard reset will occur only during the op code fetch portion of an M1 cycle. Therefore, the refresh for dynamic memories will not be disturbed and no information will be lost. #### **CENTRAL PROCESSING UNIT (CPU)** The CPU is a Z80 microprocessor which runs at 2.048 MHz. Pictorial 8-1 shows the timing during an M1 cycle (instruction fetch). Notice that signal M1 occurs prior to the refresh signal during the instruction fetch. Pictorial 8-2 shows the timing of a memory read and a memory write cycle, Pictorial 8-3 shows the timing during an I/O cycle, and Pictorial 8-4 (on Page 8-17) occurs only at the end of an instruction cycle and that both an M1 and an IORQ are generated. #### **CONTROL LOGIC** U509 is a non-inverting buffer, while U562D complements BM1 L to produce BM1 H. U515A OR's the I/O request and memory request signals to produce the latch address signal (LA L). U562A and U562B form a 100 nS delay for the memory request signal; thus DMERQ L is the delayed memory request. This delay occurs only on the leading edge and not the trailing edge of the signal. #### ADDRESS LATCH U510 and U511 are transparent latches. Any data at their inputs is transferred to their outputs when LA L is high. When LA L is low, the last data pattern to occur just before the LA L high-to-low transition is retained at their outputs. #### MEMORY MAP DECODER U517 and U516 are PROMs which decode the latched address lines and determine which memory chips are to be enabled. Specifically, U517 determines which of the eight 8k banks is to be enabled, and U516 determines which of the 1k pages within bank 0 is to be enabled. However, the address lines are not the only criteria used to determine memory selection. Jumpers IJ501, IJ502, and IJ503 select various memory configurations. That is, if only 48k of user RAM is installed, then JJ501 is jumpered for "0," JJ502 is jumpered for "1," and JJ503 is jumpered for "B." As a result, RAS0 L, RAS1 L, or RAS2 L, will be selected (coincident with the selected address being within banks 1 and 2, 3 and 4, or 5 and 6). In addition, NOMEM L will be asserted low whenever bank 7 is accessed. This results in U521 being enabled and all 0's being forced onto the data bus (required by some software memory sizing routines). If, however, 64k of user memory is installed, JJ501 and JJ502 will be jumpered for "1," and JJ503 is again a "B." Now, when bank 7 is addressed, RAS3 L will be asserted instead of NOMEM L. Access to 64k of RAM requires setting the CP/M ORGO latch in the software to configure bank 0 as RAM. PICTORIAL 8-1 $\overline{RD}$ The write enable line (WE L) will be asserted low whenever there is no read (BRD L is high), no refresh (BRSH L is high), memory is selected (DMERQ L is low), and the bank selected contains writeable memory. Thus, since NOMEM L contains no writeable memory, WE L cannot be asserted if NOMEM L is asserted. However, bank 0 contains both writeable and non-writeable memory. Therefore, WE L will be asserted for bank 0 if the first three conditions are met regardless of the fourth condition. It is up to U516 to either enable or not enable the page select lines (MC5001 L, MC5023 L, MC505 L, and MC5067 L), depending on whether the memory addressed is writeable or not. Write enable line 0 (WE 0 L) is used with the 1k of RAM associated with the floppy disk. It is only asserted when WE L is asserted, MC 505 L is asserted, and FMWEN H is asserted. It is controlled by bit 7 of I/O port 177. If the refresh line (BRFSH L) is asserted low, then WE L is not asserted. In addition, RAS0 L, RAS1 L, and RAS2 L will be asserted (consistent with the position of jumpers JJ501, JJ502, and JJ503) regardless of the bank address. This insures that all applicable dynamic RAM will be refreshed. #### DYNAMIC RAM MULTIPLEXER U513 and U514 multiplex the 14 address lines required for 16k of memory into the 7 lines available on the memory chips. U512A is used to clock the row and column addresses into the memory chips in the proper sequence and at the proper time. Assume that a memory cycle has just begun (DMERQ H is high). At this time, the row addresses are multiplexed onto the memory address lines (A0-6 L) and the applicable RAS line (RAS0-2 L) is asserted low; thus, latching the row address into the memory chips. One half clock cycle later, U512A is toggled. This causes the row addresses to be removed from the memory address lines (A0-6 L) and the column addresses (A7-13) to be multiplexed in. A short delay later (determined by R514 and C522), the CAS L line is asserted and the column address is latched into the memory. The multiplexer will be returned to its normal state (RAS address selected) when either a refresh cycle is initiated (clears U512A) or after the first clock cycle following the memory cycle (DMERQ H is low, causing the Q output of U512A to go low). #### SYSTEM ROM U518 is the system ROM which resides in the bottom 2 pages of memory (0, 1). An additional 2k of ROM can be added to the system at Pages 2 and 3 by installing jumper JJ507 at "A". Jumpers JJ504, JJ505, and JJ506 are used to switch between the 3-voltage EPROMs and the single voltage ROMs. When the jumpers are installed in their 0 locations, then the 3-voltage EPROMs are used. #### FLOPPY DISK ROM U520 is the floppy disk ROM which resides in the address map at Pages 6 and 7. It is restricted to a single voltage ROM. However, by moving jumper JJ507 to 'B', U519 will serve as the floppy ROM and a 3-voltage EPROM can be installed. It is now no longer possible to use 4k of system ROM. #### FLOPPY DISK RAM U523 and U525 are used by the floppy disk and reside in Page 5 of bank 0 of the memory map. They are organized as $1k \times 4$ static RAMs. Provisions are made for an additional 1k of static memory at Page 4. However, it cannot be write protected as the memory at Page 5 can. #### SYSTEM RAM The system RAM is organized as $16k \times 1$ dynamic RAMs and resides in banks 1, 2, 3, 4, 5, 6, and 7. U526 through U533 comprise banks 1 and 2, U534 through U541 comprise banks 3 and 4, and U542 through U549 comprise banks 5 and 6. Bank 7 is accessible when the memory expansion board is installed and JJ501 through JJ503 are properly positioned. #### INTERRUPT LOGIC U557 detects that an interrupt request has occurred. It transmits this information to the processor by the INT L line. The interrupt priority is also determined by U557, and is available on output pins 6, 7, and 9. This information is transmitted to the data bus during the interrupt acknowledge cycle by U558. The highest priority is interrupt level 5, while the lowest priority is the 2 mS clock at level 1. In processing the interrupt, the CPU is operating in the 8080 mode. Therefore, the data on the data bus at acknowledge time is an instruction (U558 encodes the data from priority encoder U557 such that the processor sees a restart instruction). This instruction directs the processor to execute the instruction at ROM address 10 for the 2 mS clock, at address 20 for the single step, at address 30 for the INT 3L, etc. #### I/O MAP DECODER U550 is a 256 $\times$ 8 PROM, and decodes the various I/O ports required by the Computer. I/O F2H (362Q) is the general purpose port and I/O 362L is its enable signal. I/O NMI L is generated by the system whenever accesses to ports 0F0H (360Q), 0F1H (361Q), 0FAH (372Q), 0FBH (373Q) occur. Interrupt acknowledge is generated by the Z80 via a simultaneous M1 L and IORQ L. The BM1 L is used to deselect U550 and terminate the interrupt request. This enables the system to run software previously developed for the H-8 Computer. That is, accesses to the H-8 front panel are rerouted to the system console. Since the interrupt acknowledge generates a BIORQL signal, this could cause an I/O request to I/O 362 or I/O NMI. The effect would be to either cancel the interrupt before it could be processed or to generate an NMI request. In either case, the Computer will get lost. Therefore, since the interrupt acknowledge also generates an M1 signal, M1 is used to deselect U550 during the interrupt acknowledge cycle. #### SINGLE STEP AND 2 mS CLOCK The 2 mS clock is controlled by U506B. It is enabled by writing a '1' on data line D1 H at I/O port 0F2H (362Q). Once enabled, the next positive transition of the 2 mS clock will trigger U506B and cause its output (pin 8) to go low; thus enabling interrupt level 1. The clock handler must, as part of its routine, disable the clock interrupt (clear U506). Otherwise, another interrupt will be generated as soon as an EI instruction is executed. This occurs because U506B is operating as a latch. It will be cleared whenever a write to I/O port 0F2H (362Q) occurs. If D1 H is low when this write occurs, then the 2 mS clock will be disabled. If D1 H is high when the write occurs, then U506B will only be cleared and the 2 mS clock will still be enabled; thus allowing another interrupt to occur at the end of the next 2 mS period. At power-up or keyboard reset, U506B is enabled. Consequently, a 2 mS clock interrupt will occur immediately after an EI instruction has been executed. The single step is enabled by D0 H and I/O port 0F2H (362Q). With bit 0 of port 0F2H (362Q) low, U555A and U555B are held in their initialized state. When bit 0 of port 0F2H (362Q) is high, the single step is enabled. U556A synchronizes the 2.048 MHz clock with the M1 cycle and valid data on the data lines. U515B and U554 decode the EI instruction for U555A. Thus, an EI instruction causes the D input of U555A (pin 2) to be asserted low. U555A is then toggled by U556A: thus, setting the T input of U555B (pin 11) low. At the end of the next M1 cycle, U555B is toggled, which latches its output (pin 0) low. Another M1 cycle is executed, which now toggles U556's output(pin 8) high. This generates the interrupt at level 2 (restart 2). The software sequence is: - 1. Enable single step - 2. Wait for keyboard - 3. EI instruction - 4. RTI instruction - 5. Execute single program instruction - 6. Interrupt out of program - 7. Disable single step - 8. Enable single step (step 7 and 8 are required to reinitialize single step logic) - 9. Wait for keyboard - 10. Etc. #### GENERAL PURPOSE PORT The general purpose port is located at I/O address 0F2H (362Q), and is comprised of U551, U552, U553B, and switch SW501. A read from this port puts the dip switch (SW501) status on the data lines. A write to this port controls the single step and 2mS interrupt logic. In addition, 4 other lines (MEM0 H, MEM1 H, IO0 H, and IO1 H) are available. These lines are routed to the accessory connectors on the CPU logic circuit board and are not presently used. BANK SEL H controls the selection of bank 7 on the 16k memory expansion board. #### **CONSOLE SERIAL PORT** This port, at I/O locations 0E0H-0E7H (350Q-357Q), is used to communicate with the console terminal. U559 and U560 convert the TTL levels from and to the ACE (U561) into standard EIA signals. U515D acts only as an inverter for the reset line, and Q1 provides both inversion and the WIRED-OR function for interrupt level 5 (restart 5). The clock for the ACE is supplied by logic inside U561, and is crystal controlled by X502. C525 and C526 provide the load for the crystal, and R515 and R516 provide the proper bias for the internal devices. The clock thus generated is routed to the I/O accessory connectors (through buffer U564D) for use by the Serial Interface Accessory circuit board. For a description of the ACE and how to program it, refer to Chapter 13 in this Manual, starting on Page 13-1. ### SERIAL INTERFACE CIRCUIT BOARD The first port on this circuit board is located at I/O 0E0H-0E7H (340Q-347Q) and is used as the line printer port. Its output is standard EIA with a DCE connector. The second port is located at I/O 0D8H-0DFH (330Q-337Q) and, again, is used as the standard EIA output. However, this port is terminated with a DTE connector for communication with a MODEM. The third port is located at I/O 0D0H-0D7H (320Q- 327Q) and is configured for EIA with a DCE connector. All three ports can be jumpered for interrupt levels, 3, 4, or 5 and use the 1.8432 MHz clock generated by the console serial port. The main logic device for each port is the 8250 ACE. For a description of this device and its programming instructions, refer to Chapter 13 in this Manual and starting on Page 13-1. # **REPLACEMENT PARTS LIST** # **POWER SUPPLY** | CIRCUIT<br>Comp. No. | HEATH<br>Part No. | DESCRIPTION | CIRCUIT<br>Comp. No. | HEATH<br>Part No. | DESCRIPTION | |-------------------------------------------------------|--------------------------------------------------------|-----------------------------------------------------------------------|------------------------------------------------------|-------------------------------------------------------------|-----------------------------------------------------------| | CAPACI | TORS, Ele | ctrolytic | Diodes | (cont'd.) | | | C101<br>C102<br>C103<br>C104<br>DIODES<br>BR1<br>D101 | 25-902<br>25-906<br>25-902<br>25-891<br>56-67<br>57-42 | 10,000 μF<br>4700μF<br>10,000 μF<br>470 μF<br>Bridge rectifier<br>3A1 | D102<br>D103<br>D104<br>D109<br>D110<br>D111<br>D112 | 57-42<br>57-42<br>57-42<br>57-27<br>57-27<br>57-27<br>57-27 | 3A1<br>3A1<br>3A1<br>1N2071<br>1N2071<br>1N2071<br>1N2071 | See "Semiconductor Identification." # **VIDEO CIRCUIT BOARD** | CIRCUIT<br>Comp. No | HEATH Part No. | DESCRIPTION | CIRCUIT<br>Comp. No. | Part No. | DESCRIPTION | |---------------------|----------------|---------------------------------------|----------------------|-----------------------------|-----------------------------------------| | RESIST | ORS | | Resistors | s (cont'd.) | | | NOTE: The wise spec | | istors are 5%. 1/2-watt unless other- | R212<br>R213<br>R214 | 3-57-5<br>6-470<br>Not used | 1500 $\Omega$ , 5-watt, 10% 47 $\Omega$ | | R201 | 6-105 | 1 ΜΩ | R215 | 6-152 | 1500 Ω | | R202 | 6-472 | 4700 Ω | R216 | 6-332 | 3300 Ω | | R203 | 6-102 | 1000 Ω | R217 | 6-104 | 100 kΩ | | R204 | 6-682 | 6800 Ω | R218 | 6-223 | 22 kΩ | | R205 | 6-472 | 4700 Ω | R219 | 10-390 | 20 kΩ control | | R206 | 6-101 | 100 Ω | R220 | Not used | | | R207 | 6-6491 | 6490 Ω, 1% | R221 | 6-224 | 220 kΩ | | R208 | 6-1871-12 | 1870 Ω, 1/4-watt, 1% | R222 | 6-273 | 27 kΩ | | R209 | 6-102 | 1000 Ω | R223 | 10-390 | 20 kΩ control | | R210 | Not used | | R224 | 6 <b>-8</b> 22 | 8200 Ω | | R211 | 3-6-2 | .51 Ω, 2-watt | R225 | 6-103 | 10 kΩ | | | | | R226 | 6-623 | 62 kΩ | | | | • | = | | | | CIRCUIT<br>Comp. No. | HEATH<br>Part No. | DESCRIPTION | |----------------------|-------------------|------------------------| | Resistors | s (cont'd.) | | | R227 | 6-473 | 47 k $\Omega$ | | R228 | 6-103 | 10 k $\Omega$ | | R229 | 6-122 | 1200 Ω | | R230 | Not used | | | R231 | 6-182 | 1800 Ω | | R232 | 6-101 | 100 Ω | | R233 | 6-105 | 1 M $\Omega$ | | R234 | 6-103 | 10 k $\Omega$ | | R235 | 6-273 | 27 k $\Omega$ | | R236 | 6-222 | 2200 Ω | | R237 | 6-150 | 15 Ω | | R238 | 6-471 | 470 $\Omega$ | | R239 | 6-279 | 2.7 Ω | | R240 | Not used | | | R241 | 6-279 | 2.7 Ω | | R242 | 6-479 | 4.7 Ω | | R243 | 6-102 | 1000 Ω | | R244 | 6-223 | 22 kΩ | | R245 | 6-273 | 27 kΩ | | R246 | 10-311 | 5000 $\Omega$ control | | R247 | 6-6491 | 6490 Ω, 1% | | R248 | 6-273 | 27 k $\Omega$ | | R249 | 6-392 | 3900 $\Omega$ | | R250 | Not used | | | R251 | 6-201 | 200 $\Omega$ | | R252 | 6-470 | 47 Ω | | R253 | 6-392 | 3900 Ω | | R254 | 3-22-2 | 1.2 $\Omega$ , 2-watt | | R255 | 6-101 | 100 Ω | | R256 | 3-22-2 | 1.2 $\Omega$ , 2-watt | | R257 | 3-22-2 | 1.2 $\Omega$ , 2-watt | | R258 | 6-104 | 100 k $\Omega$ | | R259 | 6-331 | 330 Ω | | R260 | Not used | | | R261 | 6-473 | 47 k $\Omega$ | | R262 | 10-941 | 100 k $\Omega$ control | | R263 | 6-823 | 82 kΩ | | R264 | 10-1049 | 2 M $\Omega$ control | | R265 | 6-394 | 390 kΩ | | R266 | 6-335 | 3.3 M $\Omega$ | | R267 | 6-335 | 3.3 M $\Omega$ | | R268 | 6-102 | 1000 Ω | | CIRCUIT<br>Comp. No. | HEATH<br>Part No. | DESCRIPTION | |----------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | CAPACIT | ORS | | | CAPACIT C201 C202 C203 C204 C205 C206 C207 C208 C209 C210 C211 C212 C213 C214 C215 C216 C217 C218 C219 C219 C220 C221 C222 C223 | 25-911<br>21-140<br>25-865<br>25-220<br>25-220<br>21-176<br>25-883<br>27-145<br>Not used<br>27-841<br>29-32<br>25-865<br>21-176<br>21-140<br>25-890<br>21-75<br>21-176<br>21-75<br>Not used<br>29-22<br>21-176<br>29-22 | 22 μF, 25 V<br>.001 μF ceramic<br>10 μF electrolytic<br>10 μF tantalum<br>10 μF tantalum<br>.01 μF ceramic<br>47 μF electrolytic<br>.22 μF Mylar<br>.22 μF Mylar<br>4.7 μF tantalum<br>.0068 μF polystyrene<br>10 μF electrolytic<br>.01 μF ceramic<br>.001 μF ceramic<br>.001 μF ceramic<br>100 μF ceramic<br>.00 μF ceramic<br>.00 μF ceramic<br>.00 μF ceramic<br>.00 μF ceramic<br>.00 μF ceramic<br>.00 μF ceramic<br>.0047 μF polystyrene<br>.01 μF ceramic<br>.0047 μF polystyrene | | C224<br>C225<br>C226<br>C227<br>C228<br>C229<br>C230<br>C231<br>C232<br>C233<br>C234<br>C235 | 27-73<br>25-882<br>25-220<br>25-882<br>29-56<br>25-299<br>Not used<br>29-57<br>27-206<br>21-193<br>25-913<br>21-122 | .047 $\mu$ F Mylar<br>22 $\mu$ F electrolytic<br>10 $\mu$ F tantalum<br>22 $\mu$ F electrolytic<br>.006 $\mu$ F polypropylene<br>1.5 $\mu$ F electrolytic<br>.22 $\mu$ F polypropylene<br>1 $\mu$ F polycarbonate<br>.005 $\mu$ F spark gap<br>.47 $\mu$ F electrolytic<br>.02 $\mu$ F ceramic | | C236<br>C237 | 21-122<br>21-122 | .02 $\mu$ F ceramic<br>.02 $\mu$ F ceramic | # ${\bf DIODES-TRANSISTORS-IC's}$ See "Semiconductor Identification." # INDUCTORS — CHOKES — TRANSFORMERS | L201 | 40-581 | 620 $\mu$ H inductor | |------|---------|----------------------| | L202 | 45-42 | $8.75~\mu H$ choke | | L203 | 40-2081 | 120 $\mu$ H inductor | | L204 | 40-1948 | 52 $\mu$ H inductor | | T201 | 51-197 | Driver transformer | | T202 | 51-200 | Flyback transformer | | " noitealit | oudirctor Iden. | ime2" ee2 | | DOOD 1011 | 001-0 | |--------------------------------------------|-----------------|-------------------|---------------------------------|--------------|-------------------| | | | | and a second | besu toM | C+60 | | STORS — IC's | SISNART — | DIODES | .01 µF glass capacitor | 21-761 | C428 | | .01 02020 | | 0_0.0 | | beau toM | C+28 | | 12.288 MHz crystal | 404-613 | <b>₩</b> | .01 µF glass capacitor | 197-12 | C491-C497 | | Dip switch | 129-09 | Z402 | | beau foM | C420 | | Dip switch | 129-09 | 107S | $^{'}$ $^{'}$ F glass capacitor | 197-12 | C438-C446 | | doting aid | 103 03 | 1070 | οίπετος Τη 10. | 21-185 | C436-C437 | | | | | .01 µF glass capacitor | 197-12 | C451-C432 | | | SUO3NA. | MISCELL | mulatnat 44, 0.1 | Z61-32 | C <del>1</del> 58 | | | | | imereceramic Tμ Γ. | 21-15 | C452 | | 125 pF ceramic | 21-758 | C491 | ims¹9⊃ ∃μ Γ. | 21-15 | C454 | | | besu toM | C490 | mulatnat 44 0.1 | 761-32 | C <del>1</del> 53 | | .01 µF glass capacitor | 197-12 | C <del>1</del> 88 | mulatnat 74 74 | 126-92 | C455 | | .01 µF glass capacitor | 197-12 | C488 | 150 pF mica | 20-103 | C451 | | .01 µF glass capacitor | 197-12 | C487 | 1500 pF ceramic | 21-745 | C450 | | .01 µF glass capacitor | 197-12 | C486 | 47 pF mica | 20-101 | C419 | | <ol> <li>101 µF glass capacitor</li> </ol> | 197-12 | C482 | οίπετοο Τ <sub>4</sub> Γο. | 21-185 | C418 | | oimaneo ∃4 to. | 21-185 | C484 | oimεreo 4μ f00. | 21-140 | C417 | | mulatnat 74 74 | 52-951 | C483 | 470 pF ceramic | 51-56 | C418 | | oimareo $\exists u$ 600. | 21-46 | C485 | oimaneo $\exists \mu$ fo. | 21-185 | C412 | | mulatnat 74, 01 | 52-550 | C <del>1</del> 81 | 39 pF ceramic | 21-167 | C414 | | | Not used | C <del>1</del> 80 | mulatnat A <sub>M</sub> 0.1 | 761-32 | C413 | | oims $\exists \mu$ 100. | 21-140 | 67 <b>4</b> 79 | 2.2 pF tantalum | 561-92 | C415 | | 470 pF ceramic | 51-56 | C475-C478 | mulstnst ∃4 7.4 | 25-276 | C411 | | | Not used | C474 | 1500 pF ceramic | 21-745 | C410 | | .01 µF glass capacitor | 197-12 | C471-C473 | oimsiso Ay 10. | 21-185 | C409 | | | Not used | C410 | mulatnat Au 0.1 | 761-32 | C408 | | .01 $\mu F$ glass capacitor | 197-12 | C461-C469 | muletnet 🗛 7.4 | 25-276 | C407 | | | s (cont'd.) | Capacitor | | rs (cont'd.) | Capacito | | | • | | | | • | | | Part No. | Comp. No. | - | Part No. | Comp. No. | | DESCRIPTION | HTA∃H | TIUDAID | DESCRIPTION | HTA∃H | TIUORIO | | | | | | | | # CPU LOGIC CIRCUIT BOARD | 101 µF glass capacitor | 194-12 | C251 | | | | |------------------------|------------|-----------|------------------------------|-----------------------|--------------| | | Not used | C250 | 75 IAI I | 71-001-0 | // (0) / | | 101 µF glass capacitor | 194-12 | C218 | Ω M 1 | 6-106-12 | 7138 | | 1.0 µF tantalum | 261-92 | C218 | Ω 0091 | 6-162-12 | 915A | | 2.2 µF tantalum | 52-551 | C217 | υ 00/4 | 21-274-8 | H515 | | mulainat Au 0.f | 261-92 | C516 | υ 091 | 6-151-12 | 412A | | 2.2 µF tantalum | 26-221 | C515 | υ 091 | 6-151-12 | F13H | | mulatrat 44 0.f | Z9-16L | C214 | ប 0001 | 6-102-12 | R512 | | Z.2 kF tantalum | 20195 | | $\Omega$ 0001 | 6-102-12 | F13A | | mulatinat 74 0.f | 26-19F | C213 | | besu toM | P510 | | Z.S µF tantalum | | C215 | 10 K 🖰 | 6-103-12 | 609님 | | muletact 3" S S | 52-195 | Cell | 180 K Ծ | 6-184-12 | 809님 | | mulainai 44 0.f | besu foV | C210 | 10 KU | 6-103-12 | 709日 | | | 761-32 | C209 | υ ozp | 21-17 <del>1-</del> 9 | 909H | | mulatriat 74 S.S | 25-221 | C208 | ប 000 ប | 6-102-12 | 909H | | 69 µF electrolytic | 52-950 | C207 | ប 0001 | 6-102-12 | ₽09H | | 680 pF mica | 20-184 | C206 | 330 T | 6-331-12 | E09H | | 390 pF mica | 20-106 | C202 | Ω 099 | 6-561-12 | H202 | | oimera⊓, r0. | 21-186 | C204 | υ 099 | 6-561-12 | F501 | | 47 pF mica | 101-02 | C203 | 0 302 | 0, ,02 0 | ,,,, | | .01 µF glass capacitor | 197-12 | C205 | o⁄ <b>C</b> ,11 <b>5W-</b> + | esistors are 1/ | NOTE: 3II 16 | | 150 pF mica | 20-103 | C201 | /03 #F V | , p one one to jee | II. 17TOM | | | | | | SH | RESISTO | | | SHO | TIDA9AD | | - | 0_0.0 | | | :011.110.1 | | | .011 112 1 | | | | Part No. | Comp. No. | | Part No. | Comp. No. | | DESCRIPTION | HTA∃H | TIUOAIO | DESCRIPTION | HTA∃H | TIUOAIO | Not used See "Semiconductor Identification." # VIDEO DRIVER CIRCUIT BOARD | | | | .01 µF ceramic | 971-12 | C903 | |--------------------|---------------|------------|-------------------------------|------------|-------------| | | | | oimareo ∃ų f0. | 21-176 | C905 | | | | | ol μF ceramic | 21-176 | C901 | | 4.65 µН сһоке | 66-34 | F901 | | SHO | TIDAGAD | | | | 7310110 | | | | | | | CHOKE | | Not used | F16A | | | | | | Not used | 016日 | | ".uoiteailitu | onductor Ide | oime2" ee2 | 47 k $\Omega$ , 1/2 watt, 10% | 1-25 | 606出 | | | | | 47 k $\Omega$ , 1/2 watt, 10% | 1-25 | 806日 | | SAOTSI | SNAAT - | DIODES - | 1000 Ω, 1/2 watt, 10% | 6-1 | 206日 | | | | | 22 Ω, 1/4 watt, 5% | 6-220-12 | 906님 | | от р. сегатіс | 941-12 | C908 | %3 ,1 <b>\4 wa</b> tt, 5% | 6-750-12 | 906님 | | Ju Foramic | 21-176 | 2060 | S20 $\Omega$ , 1/2 watt, 10% | 97-1 | ₩68 | | 390 pF mica | 20-106 | 9060 | 820 $\Omega$ , 2-watt | 1-50-2 | 606日 | | 22 µF electrolytic | <b>25-882</b> | C902 | 1000 Ω, 1/4 watt, 5% | 6-102-15 | F905 | | оіт р. Сегатіс | 21-176 | C904 | %3 ,116w 4/1 ,0M t | 6-105-12 | 106日 | | . (• | s (cont'd. | Capacito | | СЛ | OTSISER | | ` | P.44.00) O. | .o.țioono) | | 30 | OTSISE | | | ON UP | OOUD: MO: | | 'ONI 119 ' | COULD: IAO: | | | Part No. | Comp. No. | | Part No. | Comp. No. | | DESCRIPTION | HTA∃H | TIUORIO | DESCRIPTION | HTA3H | TIUORIO | | | | | • | | | # **TERMINAL LOGIC CIRCUIT BOARD** | | | | | | - | |---------------------------------|-------------------|---------------------|--------------|-------------------|--------------------| | | | | Ω 0001 | 6-102-12 | 9£4H | | Of MF ceramic | 21-185 | C409 | 10 KU | 6-103-12 | F433 | | mulatnat 44 0.f | 261-92 | C402 | i | besu toM | B430 | | 2.2 µF tantalum | 561-92 | C404 | 10 KU | 6-103-12 | R427-R435 | | mulatnat ∃4, 0.f | 261-92 | C403 | 10 KU | 6-103-12 | R418-R426 | | 2.2 µF tantalum | 55-195 | C405 | | Not used | <b>Ľ</b> ⁴50 | | oims as Ty 200. | 21-46 | C401 | Ω 01 | 6-100-12 | 71 <i>4</i> 8 | | .01 µF ceramic | 21-185 | C400 | 1000 T | 6-102-12 | 91#出 | | | 307 70 | 0075 | 550 KV | 6-224-12 | B415 | | | 0110 | | 10 KD | 6-103-12 | H414 | | | 280 | TIDA9AD | 1000 t | 6-102-12 | E413 | | NIOM3011 10301001 2211 2222 | | | 10 KU | 6-103-12 | H415 | | 220 kΩ resistor network | 86-6 | 임 | 330 U | 6-331-12 | F411 | | S20 k $\Omega$ resistor network | 86-6 | ŀЧЯ | 1 | Not used | ₽410 | | Ω 0001 | 6-102-12 | 734A | υ 099 | 6-561-12 | 60 <del>1</del> ∕⊟ | | Ω 001 | 6-101-12 | 99 <i>†</i> 8 | υ o99 | 6-561-12 | 80₺日 | | Ω 0001 | 6-102-12 | B455 | 1000 ប | 6-102-12 | <b>₹</b> 0₽ | | 10 KU | 6-103-12 | P451-R454 | 1000 ប | 6-102-12 | 90₺日 | | | besu toM | B420 | Ω 001 | 6-101-12 | ₽405 | | 10 KD | 6-103-12 | 9443-E44B | 2200 T | 6-222-12 | F404 | | 220 KD | 6-224-12 | F441 | Ω 001 | 6-101-12 | F403 | | | Not used | 0 <del>77</del> 40 | <b>υ 4</b> | 21-07 <i>4</i> -8 | E402 | | 10 KU | 6-103-12 | 6€ <del>1</del> 436 | 2200 T | 6-222-12 | F401 | | | Not used | R438 | | | | | Ω 0074 | 51-27 <i>4</i> -8 | ₹£ <del>1</del> 43 | /4-watt, 5%. | esistors are | NOTE: All ro | | | | | · | | | | | (cont'd.) | Resistors | | CH. | RESISTO | | | | | | 30 | 0131330 | | | | | | | | | | Part No. | Comp. No. | | Part No. | Comp. No. | | DESCRIPTION | HTA∃H | TIUDAID | DESCRIPTION | HTA∃H | TIUORIO | | | | | _ | | | | CIRCUIT<br>Comp. No. | HEATH<br>Part No. | DESCRIPTION | CIRCUIT<br>Comp. No. | HEATH<br>Part No. | DESCRIPTION | |-------------------------------------------|------------------------------------------|------------------------------------------------------------------------------------------------|----------------------------------------|-------------------------------------------|-------------------------------------------------------------------| | Capacito | rs (cont'd. | ) | MISCELL | .ANEOUS | | | C523<br>C524<br>C525<br>C526<br>C527-C598 | 20-77<br>21-761<br>21-3<br>21-5<br>21-76 | 24 pF mica .01 $\mu$ F glass capacitor 10 pF ceramic 20 pF ceramic .01 $\mu$ F glass capacitor | S501<br>Y501<br>Y502<br><b>DIODE</b> — | 60-621<br>404-613<br>404-608<br>- TRANSIS | 8-section switch 12.288 MHz crystal 1.843 MHz crystal TOR — IC's | # **CHASSIS PARTS** See "Semiconductor Identification." | CIRCUIT<br>Comp. No. | HEATH<br>Part No. | DESCRIPTION | |----------------------|-------------------|--------------------------------| | R1 | 10-1178 | 500 $\Omega$ control | | .C1 | 25-857 | 1500 µF electrolytic capacitor | | T1 | 54-969 | Power transformer | | T2 | 58-19 | Yoke | | SW1 | 60-54 | 115/230 switch | | SW2 | 60-608 | NORM/LOW switch | | SW3 | 61-49 | Power switch | | F1 | 421-23 | 1-ampere fuse | | F1 | 421-25 | 1.5-ampere fuse | | | 401-163 | Speaker | | V1 | 411-852 | Green anti-glare CRT | # SERIAL INTERFACE CIRCUIT BOARD | CIRCUIT<br>Comp. No | HEATH<br>. Part No. | DESCRIPTION | CIRCUIT<br>Comp. No. | HEATH<br>Part No. | DESCRIPTION | |----------------------------------------------------------------------|----------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------|--------------------------------------------------------|------------------------------------------------------------|---------------------------------------------------------------------------------| | RESIST | OR | | CAPACIT | ORS | | | R601<br>R602<br>R603<br>R604<br>R605<br>R606<br>R607<br>R608<br>R609 | 6-102-12<br>6-181-12<br>6-181-12<br>6-181-12<br>6-181-12<br>6-181-12<br>6-181-12 | 1000 $\Omega$ 180 $\Omega$ 180 $\Omega$ 180 $\Omega$ 180 $\Omega$ 180 $\Omega$ 180 $\Omega$ | C601<br>C602<br>C603<br>C604<br>COILS<br>(21) L601-L62 | 25-197<br>25-197<br>25-197<br>25-197<br>25-197<br>2145-614 | 1.0 μF tantalum 1.0 μF tantalum 1.0 μF tantalum 1.0 μF tantalum 1.0 μF tantalum | | R610<br>R611 | 6-181-12<br>Not used<br>6-181-12 | 180 Ω<br>180 Ω | | onductor Ide | | • . . . # SEMICONDUCTOR IDENTIFICATION This section is divided into two parts; "Component Number Index." and "Part Number Index." The first section provides a cross-reference between semiconductor component numbers and their respective Part Numbers. The component numbers are listed in numerical order. The second section provides a lead configuration detail (basing diagram) for each semiconductor Part Number. The Part Numbers in the second section are also listed in numerical order. # **COMPONENT NUMBER INDEX** This index shows the Part Number of each semiconductor in the Computer. ### POWER SUPPLY CIRCUIT BOARD | CIRCUIT | HEATH | |---------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------| | COMPONENT | PART | | NUMBER | NUMBER | | BR1<br>D101<br>D102<br>D103<br>D104<br>D109<br>D110<br>D111<br>D112<br>U101<br>U102<br>U103 | 57-67<br>57-42<br>57-42<br>57-42<br>57-27<br>57-27<br>57-27<br>57-27<br>442-651<br>442-30 | ## **VIDEO CIRCUIT BOARD** ### **Diodes** | CIRCUIT | HEATH | |-----------|--------| | COMPONENT | PART | | NUMBER | NUMBER | | D201 | 56-94 | | D202 | 56-56 | | D203 | 56-58 | | D204 | 56-56 | | D205 | 56-73 | | D206 | 56-56 | | D207 | 57-27 | | D208 | 57-614 | | D209 | 57-27 | | D210 | 57-27 | | D211 | 57-64 | ## **Transistors** | CIRCUIT | HEATH | |-----------|---------| | COMPONENT | PART | | NUMBER | NUMBER | | Q201 | 417-811 | | Q202 | 417-924 | | Q203 | 417-874 | | Q204 | 417-282 | | Q205 | 417-823 | | Q206 | 417-885 | | Q207 | 417-822 | | Q208 | 417-821 | | Q209 | 417-926 | | Q210 | 417-926 | | Q211 | 417-264 | | Q211 | 417-263 | | Q212 | 417-195 | | Q213 | 417-923 | # **Integrated Circuits** | CIRCUIT | HEATH | |-----------|--------| | COMPONENT | PART | | NUMBER | NUMBER | | U201 | 442-53 | | U202 | 442-53 | # VIDEO DRIVER CIRCUIT BOARD ## Diodes | CIRCUIT | HEATH | |-----------|--------| | COMPONENT | PART | | NUMBER | NUMBER | | D901 | 57-27 | | D902 | 56-93 | ### Transistor | CIRCUIT | HEATH | |-----------|------------------| | COMPONENT | PART | | NUMBER | NUMBER | | Q901 | 417- <b>834</b> | | Q902 | 417- <b>8</b> 75 | ## TERMINAL LOGIC CIRCUIT BOARD ### **Diodes** | CIRCUIT | HEATH | |-----------|--------| | COMPONENT | PART | | NUMBER | NUMBER | | D401 | 56-56 | | D402 | 56-56 | ## **Transistors** | CIRCUIT | HEATH | |-----------|---------| | COMPONENT | PART | | NUMBER | NUMBER | | Q401 | 417-937 | | Q402 | 417-937 | # **Integrated Circuits (Cont'd)** | CIRCUIT<br>COMPONENT<br>NUMBER | HEATH<br>PART<br>NUMBER | | |------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------|--| | COMPONENT | PART | | | U431<br>U432<br>U433<br>U434<br>U435<br>U436<br>U437<br>U438<br>U439<br>U440 | 443-792<br>443-779<br>443-733<br>443-728<br>443-877<br>Not used<br>444-46<br>443-721<br>443-721<br>443-760 | | | U441 U442 U443 U444 U445 U446 U447 U448 U449 U450 U451 U452 U453 U454 | 443-727<br>443-877<br>443-913<br>444-37<br>443-78<br>443-792<br>443-791<br>443-791<br>443-791<br>443-795<br>443-795 | | ## **Resistor Packs** | CIRCUIT | HEATH | |-----------|--------| | COMPONENT | PART | | NUMBER | NUMBER | | RP1 | 9-98 | | RP2 | 9-98 | # CPU LOGIC CIRCUIT BOARD ### Diode | CIRCUIT | HEATH | |-----------|--------| | COMPONENT | PART | | NUMBER | NUMBER | | D501 | 56-56 | # Transistor | CIRCUIT | HEATH | |-----------|---------| | COMPONENT | PART | | NUMBER | NUMBER | | Q501 | 417-937 | # SERIAL INTERFACE CIRCUIT BOARD # **Integrated Circuits** | CIRCUIT<br>COMPONENT<br>NUMBER | HEATH<br>PART<br>NUMBER | |--------------------------------|-------------------------| | U601 | 443-818 | | U602 | 443-952 | | U603 | 443-952 | | U604 | 443-952 | | U605 | 443-795 | | U606 | 443-794 | | U607 | 443-795 | | , U608 | 443-794 | | U609 | 443-795 | | U610 | 443-730 | | U611 | 443-794 | ## **Integrated Circuits** | ntegrated Circuits | | | | |--------------------------------|-------------------------|--|--| | CIRCUIT<br>COMPONENT<br>NUMBER | HEATH<br>PART<br>NUMBER | | | | U501 | 443-18 | | | | U502 | 443-34 | | | | U503 | 443-760 | | | | U504 | 443-881 | | | | U506 | 443-730 | | | | U507<br>U508 | 443-727<br>443-792 | | | | U509 | 443-792 | | | | U510 | 443-837 | | | | U511 | 443-837 | | | | U512 | 443-730 | | | | U513 | 443-824 | | | | U514<br>U515 | 443-824<br>443-779 | | | | U516 | 444-41 | | | | 55.15 | (in Z-89) or | | | | | 444-83 <sup>°</sup> | | | | | (in Z-90) | | | | U517 | 444-66 | | | | U518 | 444-62<br>(in Z-89) or | | | | | (III 2-89) 01<br>444-84 | | | | | (in Z-90) | | | | U519 | Notused | | | | U520 | 444-19 | | | | U521 | 443-754 | | | | U522 | Not used | | | | U523<br>U524 | 443-764<br>Not used | | | | U525 | 443-764 | | | | U526-U548 | 443-904 | | | | U549 | 443-904 | | | | | (IC not used | | | | U550 | in Z-90)<br>444-61 | | | | U551 | 443-791 | | | | U552 | 443-805 | | | | U553 | 443-875 | | | | U554 | 443-732 | | | | U555 | 443-730 | | | | U556<br>U557 | 443-730<br>443-912 | | | | 0337 | (IC not used | | | | | in Z-90) | | | | U558 | 443-754 | | | | | (IC not used | | | | LIEEO | in Z-90) | | | | U559<br>U560 | 443-794<br>443-795 | | | | U561 | 443-795<br>443-952 | | | | U562 | 443-901 | | | | U563 | 443-730 | | | | U564 | 443-18 | | | | U565 | 442-664 | | | | U566<br>U567 | 442-665<br>442-674 | | | | U568 | 442-674<br>442-674 | | | | U569 | 442-665 | | | | | · · | | | # PART NUMBER INDEX This index shows a lead configuration detail (basing diagram) of each semiconductor part number. # **RESISTOR PACK** | HEATH<br>PART<br>NUMBER | MAY BE<br>REPLACED<br>WITH | DESCRIPTION | LEAD CONFIGURATION (TOP VIEW) | |-------------------------|----------------------------|----------------------------|-------------------------------| | 9-98 | | 220 kΩ<br>resistor network | DOT<br>OR<br>1 | # **DIODES** | HEATH<br>PART<br>NUMBER | MAY BE<br>REPLACED<br>WITH | DESCRIPTION | LEAD CONFIGURATION (TOP VIEW) | |-------------------------|----------------------------|-------------------------|------------------------------------------------------| | 56-56 | 1N4149 | 10 mA, 75 V | | | 56-58 | 1N709A | Zener, 6.2 V, 25 mA | | | 56-73 | MZ2360 | Compensation | NOTE: HEATH PART NUMBERS ARE STAMPED ON MOST DIODES. | | 56-93 | FD333 | 225 mA, 125 V | OR | | 56-94 | | Zener, 12.8 V, 12 mA | OR | | 57-27 | 1N2071 | SI Rect<br>1 A, 600 V | OR OR | | 57-42 | 3 <b>A</b> 1 | SI rect<br>3A, 100 V | OR | | 57-64 | DRS-110 | SI Rect<br>1A, 1000 V | OR | | 57-65 | 1N4002 | SI Rect<br>1A, 100 V | | | 57-614 | MR-508 | SI Rect<br>3A, 800 V | | | 57-67 | 10 <b>A2</b> 0 | Diode<br>Bridge | | | 412-640 | | Light-emitting<br>Diode | ANODE | ## **TRANSISTORS** | HEATH<br>PART<br>NUMBER | MAY BE<br>REPLACED<br>WITH | BASING<br>DIAGRAM | | |-------------------------|----------------------------|-------------------|------------------| | 417-195 | MJE340 | А | METALLIC<br>SIDE | | 417-282 | MJ2841 | E | A | | 417-811 | MPSL01 | В | BCE | | 417-821 | MPSA06 | В | <b>B</b> | | 417-822 | MPSA56 | В | E B C | | 417-823 | MPU131 | С | | | 417-834 | MPSU10 | D | C | | 417-874 | 2N3906 | В | C A | | 417-875 | 2N3904 | В | OR | | 417-885 | MPSA65 | В | D D | | 417-923 | BU500 | E | E B C | | 417-924 | MJE172 | Α | B | | 417-926 | MPSU06 | D | WIDE SPACE | | 417-927 | MPSA93 | В | | | 417-932 | MJE182 | A | | | 417-937 | MPS2369 | В | | # **INTEGRATED CIRCUITS** | HEATH<br>PART<br>NUMBER | MAY BE<br>REPLACED<br>WITH | DESCRIPTION | LEAD CONFIGURATION<br>(TOP VIEW) | |-------------------------|----------------------------|----------------------------------|------------------------------------------------------------------------------------------------------------------| | 442-30 | μΑ309Κ<br>LM309 | 5-volt<br>Regulator | WIDE SPACE CASE (C) | | 442-53 | 555 | Timer | GND 1 8 VCC TRIGGER 2 COMP 7 DISCHARGE OUT PUT 3 OUTPUT COMP 6 THRESHOLD RESET 4 FLIP-FLOP 5 CONTROL VOLTAGE | | 442-54 | 7805 | +5 V<br>Regulator | OR OUT | | 442-616 | LM3302N,<br>LM2901, or | Quad<br>Operational<br>Amplifier | GND<br>14 13 12 11 10 9 8<br>C + 1 2 3 4 5 6 7 | | HEATH<br>PART<br>NUMBER | MAY BE<br>REPLACED<br>WITH | DESCRIPTION | LEAD CONFIGURATION<br>(TOP VIEW) | |-------------------------|----------------------------|------------------------|----------------------------------| | 442-630 | 7905.2 | −5.2 V<br>Regulator | GND OR OND ONT OUT | | 442-650 | 78H12 | +12 V. 5A<br>Regulator | WIDE SPACE COMMON (3) | | 442-663 | 78M12CKC | +12 V<br>Regulator | OR OR OR OUT | | 442-664 | 79M12CKC | −12 V<br>Regulator | GND OR OND IN OUT | | 442-665 | 79L05AC | −5 V<br>Regulator | GND | | HEATH<br>PART<br>NUMBER | MAY BE<br>REPLACED<br>WITH | DESCRIPTION | LEAD CONFIGURATION<br>(TOP VIEW) | |-------------------------|----------------------------|------------------------------|----------------------------------------------------------------------------| | 442-674 | UA7812 | +12 V<br>Regulator | I N G N D O U T | | 442-683 | 79 <b>M</b> 05 | −5 V<br>Regulator | GND | | 443-18 | 7404 | Hex Inverter | V <sub>CC</sub> 14 13 12 11 10 9 8 F B C GND | | 443-22 | 74121 | Monostable<br>Multivibrator | Rext/ VCC NC NC Cext Cext Rint NC 14 13 12 11 10 9 8 Q NC A1 A2 B Q GND | | 443-34 | 7492 | Divide-By-<br>Twelve Counter | INPUT NC NC NC V <sub>CC</sub> R <sub>O(1)</sub> R <sub>O(2)</sub> | | HEATH<br>PART<br>NUMBER | MAY BE<br>REPLACED<br>WITH | DESCRIPTION | LEAD CONFIGURATION<br>(TOP VIEW) | |-------------------------|----------------------------|------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------| | 443-73 | 7416 | Line Driver | V <sub>CC</sub> 14 13 12 11 10 9 8 F E GND | | <b>443-77</b> | 7438 | Quadruple<br>2-Input<br>Positive-NAND<br>Buffers With<br>Open-collector<br>Outputs | V <sub>C</sub> C<br>14 13 12 11 10 9 8<br>A B B 1 Y 2 A 2 B 2 Y GND | | 443-721 | 2112-2 | 256 × 4 RAM | V <sub>CC</sub> A4 R/W CE 1/0 <sub>4</sub> 1/0 <sub>3</sub> 1/0 <sub>2</sub> 1/0 <sub>1</sub> 16 15 14 13 12 11 10 9 1 A3 A2 A1 A0 A5 A6 A7 GND | | 443-727 | 96L02 | Dual<br>Monostable | V <sub>CC</sub> 16 15 14 13 12 11 10 9 2 | | 443-728 | 74LS00 | Quad 2-input<br>NAND | V <sub>CC</sub> 14 13 12 11 10 9 8 A B GND | | HEATH<br>PART<br>NUMBER | MAY BE<br>REPLACED<br>WITH | DESCRIPTION | LEAD CONFIGURATION<br>(TOP VIEW) | |-------------------------|----------------------------|----------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 443-730 | 74LS74 | Dual D<br>Flip-flop | VCC CLR 2D 2CK 2PR 2Q 2Q 14 13 12 11 10 9 8 PR Q CK B | | 443-731 | SN74LS290 | BCD<br>Counter | VCC R0(2) R0(1) B A QA QD R0(2) R0(1) B A QA R9(1) QC QB R9(1) NC R9(2) QC QB NC GND OUTPUTS | | 443-732 | SN74LS30 | 8-input<br>NAND | V <sub>C</sub> C<br>14 13 12 11 10 9 8<br>1 1 2 3 4 5 6 7<br>GND | | 443-733 | 74LS293 | 4-Bit<br>Binary<br>Counter | V <sub>CC</sub> R <sub>0(2)</sub> R <sub>0(1)</sub> B A QA QD R <sub>0(2)</sub> R <sub>0(1)</sub> B A QA QD Q <sub>C</sub> Q <sub>B</sub> Q <sub>C</sub> Q <sub>B</sub> OUTPUTS | | HEATH<br>PART<br>NUMBER | MAY BE<br>REPLACED<br>WITH | DESCRIPTION | LEAD CONFIGURATION<br>(TOP VIEW) | |--------------------------|----------------------------|----------------------------------|---------------------------------------------------------------------------------------------------------------------------------| | 443-754<br>. (Z-89 only) | 74LS240 | Octal buffer,<br>3-state outputs | V <sub>CC</sub> 20 19 18 17 16 15 14 13 12 11 10 10 10 10 10 10 10 10 10 10 10 10 10 1 | | 443-755 | 74LS04 | Hex Buffer | V <sub>CC</sub> 14 13 12 11 10 9 8 E C GND | | 443-757 | 74LS161 | 4-Bit<br>Binary<br>Counter | RIPPLE CARRY VCC OUTPUT QA QB QC QD T LOAD RIPPLE QA QB QC QD ENABLE TOUTPUT LOAD CLEAR CLOCK A B C D ENABLE GND DATA INPUTS | | 443-760 | 4040 | 12 <b>-B</b> it<br>Binary | BUFFERED OUT VDD Q11 Q10 Q8 Q9 RESET CLOCK Q1 16 15 14 13 12 11 10 9 Q12 Q6 Q5 Q7 Q4 Q3 Q2 VSS BUFFERED OUT | | HEATH<br>PART<br>NUMBER | MAY BE<br>REPLACED<br>WITH | DESCRIPTION | LEAD CONFIGURATION<br>(TOP VIEW) | |-------------------------|----------------------------|-----------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 443-764 | 2114 | 1k × 4 RAM | A 6 1 | | 443-776 | 8251 | USART | D2 1 28 D1 D3 2 RxD 3 26 V <sub>CC</sub> GND 4 25 RxC D4 5 23 RTS D6 7 22 DSR D7 8 21 RESET TxC 9 20 CLK WR 10 19 TxD CS 11 18 TxEMPTY C/D 12 17 CTS RD 13 16 SYNDET RxRDY 14 15 TxRDY | | 443-778 | 4093 | Quad 2-input<br>NAND SCHMITT<br>Trigger | V <sub>D</sub> D 13 12 11 10 9 8 | | HEATH<br>PART<br>NUMBER | MAY BE<br>REPLACED<br>WITH | DESCRIPTION | LEAD CONFIGURATION<br>(TOP VIEW) | |-------------------------|----------------------------|------------------------------------------------------|-------------------------------------------------------------| | 443-779 | 74LS02 | Quad 2-input<br>Positive-NOR<br>gates | D | | 443-780 | 74LS08 | Quad 2-input<br>Positive-AND<br>Gates | V <sub>CC</sub> 14 13 12 11 10 9 8 D B GND | | 443-791 | 74LS244 | Noninverting<br>3-state output<br>octal buffers | VCC 20 19 18 17 16 15 14 13 12 11 1 | | 443-792 | 74LS132 | Quad 2-input<br>Positive-NAND<br>Schmitt<br>Triggers | VCC 14 13 12 11 10 9 8 D D D D D D D D D D D D D D D D D D | | 443-79 <del>4</del> | 75188<br>or<br>1488 | EIA Driver | +12V<br>14 13 12 11 10 9 8<br>D B B GND | | HEATH<br>PART<br>NUMBER | MAY BE<br>REPLACED<br>WITH | DESCRIPTION | LEAD CONFIGURATION (TOP VIEW) | |-------------------------|----------------------------|------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 443-795 | 75189<br>or<br>1489 | EIA<br>Receiver | VCC 14 13 12 11 10 9 8 | | 443-797 | 74LS10 | Triple 3-input<br>Positive-NAND<br>Gate | V <sub>CC</sub> 14 13 12 11 10 9 8 C B 1 2 3 4 5 6 7 7 GND | | 443-799 | 74LS157 | Quad 2-line-<br>to-1-line<br>Multipliers | VCC STROBE 4A 4B 4Y 3A 3B 3Y Ib 15 14 13 12 11 10 9 G 4A 4B 4Y 3A 3B 3Y IA 1B 1Y 2A 2B 2Y SELECT 1A 1B 1Y 2A 2B 2Y GND INPUTS OUTPUT INPUTS OUTPUT INPUTS OUTPUT INPUTS | | 443-805 | 7 <b>4</b> LS273 | Octal D<br>Flip-flop<br>with clear | VCC 8Q 8D 7D 7Q 6Q 6D 5D 5Q CLOCK 20 19 18 17 16 15 14 13 12 11 OHD CCK CK CK CCK CLEAR CK | | HEATH<br>PART<br>NUMBER | MAY BE<br>REPLACED<br>WITH | DESCRIPTION | LEAD CONFIGURATION<br>(TOP VIEW) | |-------------------------|----------------------------|----------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------| | 443-807 | 74LS42 | BCD-to-Decimal<br>Decoder | VCC A B C D 9 8 7 16 15 14 13 12 11 10 9 A B C D BCD-TO-DECIMAL 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 GND OUTPUTS | | 443-811 | 74LS125 | Quad bus<br>buffer gate<br>with 3-state<br>outputs | V <sub>C</sub> C 13 12 11 10 9 8 P P P P P P P P P P P P P P P P P P | | 443-818 | 74LS05 | Hex Inverter | V <sub>CC</sub> 14 13 12 11 10 9 8 F B C GND | | 443-822 | 74LS139 | Dual<br>2-to-4-line<br>decoder | ENABLE SELECT DATA OUTPUTS Vcc 2G 2A 2B 2Y0 2Y1 2Y2 2Y3 16 15 14 13 12 11 10 9 G A B Y0 Y1 Y2 Y3 A Y Y3 G A B Y0 Y1 Y2 Y3 FNABLE SELECT DATA OUTPUTS | | HEATH<br>PART<br>NUMBER | MAY BE<br>REPLACED<br>WITH | DESCRIPTION | LEAD CONFIGURATION<br>(TOP VIEW) | |-------------------------|----------------------------|-------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 443-824 | 74LS241 | Octal buffer | V <sub>CC</sub> 20 19 18 17 16 15 14 13 12 11 T T T T T T T T T T T T T T T T T T | | 443-837 | 74LS373 | Octal D<br>latch | VCC 8Q 8D 7D 7Q 6Q 6D 5D 5Q G Q D Q D Q D Q D Q D Q D Q D Q D Q D Q D | | 443-856 | S2350 | Universal<br>Synchronous<br>Receiver/<br>Transmitter (USRT) | GND 1 VCC 2 NPB 3 POE 4 CS 5 TSO 6 FCT 7 SCR 8 TBMT 9 RPE 10 ROR 11 RDA 12 RR 13 RESET 14 DO 15 D1 16 D2 17 D3 18 D4 19 D5 20 ROB 11 RDA 12 RSSS RDE RSSS RCP ROB 13 RDA 12 RB RD5 RESET 14 RESET 14 RESET 14 RESET 14 RESET 15 RESET 16 RESE | | HEATH<br>PART<br>NUMBER | MAY BE<br>REPLACED<br>WITH | DESCRIPTION | LEAD CONFIGURATION<br>(TOP VIEW) | |-------------------------|----------------------------|--------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------| | 443-857 | 74LS367 | Hex Bus Drivers | V <sub>CC</sub> G2 16 15 14 13 12 11 10 9 1 1 2 3 4 5 6 7 8 GND | | 443-872 | 74LS14 | Hex SCHMITT-<br>Trigger<br>Inverters | V <sub>CC</sub> 14 13 12 11 10 9 8 F B C GND | | 443-904<br>(Z-89 only) | MK4116-4 | RAM | V <sub>SS</sub> CAS D <sub>OUT</sub> A <sub>6</sub> A <sub>3</sub> A <sub>4</sub> A <sub>5</sub> V <sub>CC</sub> 11 10 9 1 1 1 10 9 1 1 1 10 10 9 1 1 1 1 | | 443-912<br>(Z-89 only) | 74LS148 | 8 TO 3 ENCODER | OUTPUTS INPUTS OUTPUT Vcc EO GS 3 2 1 0 AO EO GS 3 2 1 0 AO FO GS 3 2 1 0 AO INPUTS OUTPUTS OUTPUTS OUTPUTS OUTPUTS | | HEATH<br>PART<br>NUMBER | MAY BE<br>REPALCED<br>WITH | DESCRIPTION | LEAD CONFIGURATION<br>(TOP VIEW) | |-------------------------|----------------------------|--------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 443-952 | 8250B | ACE | Do Vcc 40 2 D1 R1 39 3 D2 RLSD 38 4 D3 DSR 37 S D4 CTS 36 37 CTS 38 D7 DTR 33 DTR 38 D7 DTR 38 D7 DTR 39 CTS | | 443-875 | 74LS32 | Quad 2-input<br>Positive OR<br>Gates | V <sub>CC</sub> 14 13 12 11 10 9 18 1 | | 443-877 | 74LS138 | 3-to-8-line<br>Decoder | DATA OUTPUTS VCC YO Y1 Y2 Y3 Y4 Y5 Y6 16 15 14 13 12 11 10 9 YO Y1 Y2 Y3 Y4 Y5 B C G2A G2B G1 Y7 A B C G2A G2B G1 Y7 GND SELECT ENABLE OUTPUT | | HEATH<br>PART<br>NUMBER | MAY BE<br>REPLACED<br>WITH | DESCRIPTION | LEAD CONFIGURATION<br>(TOP VIEW) | |-------------------------|----------------------------|--------------------------------|----------------------------------------------------------------------------------------------| | 443-881 | Z 80 | Microprocessor | SYSTEM CONTROL MREQ 19 | | 443-885 | 74LS245 | Octal bus<br>transceiver | ENABLE Vcc G 7 19 18 17 16 15 14 13 12 11 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | | 443-891 | 74LS86 | Quad 2-input<br>Exclusive — OR | V <sub>CC</sub><br>14-13-12-11-10-19-18<br>D D D<br>A B<br>1 H 2 H 3 H 4 H 5 H 6 H 7<br>6 ND | | HEATH<br>PART<br>NUMBER | MAY BE<br>REPLACED<br>WITH | DESCRIPTION | LEAD CONFIGURATION<br>(TOP VIEW) | |-------------------------|----------------------------|----------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 443-892 | 74LS166 | 8-bit<br>shift<br>register | PARALLEL INPUT H PARALLEL INPUT OUTPUT INPUTS VCC LOAD SERIAL LOAD SERIAL INPUT CLOCK A B C D INHIBIT VCLOCK GND INPUT PARALLEL INPUTS INHIBIT | | 443-900 | 74S74 | Dual-D<br>Flip-flop | VCC 2 CLR 2D 2CK 2PK 2Q 2Q 14 13 12 11 10 9 8 CLR Q CK B | | 443-904 | MK4116-4 | 16k × 1<br>RAM | VSS CAS DOUT A6 A3 A4 A5 VCC 16 15 14 13 12 11 10 9 1 2 3 4 5 6 7 8 VBB DIN WRITE RAS A0 A2 A1 VDD | | 443-906 | 6845 | CRT<br>Controller | Refresh Memory Addresses MA7 — 111 MA8 — 12 MA9 — 13 MA10 — 14 MA11 — 15 MA12 — 16 MA12 — 16 MA13 — 17 MA12 — 16 MA13 — 17 MA13 — 17 MA13 — 17 MA14 — 18 MA15 MA1 | | HEATH<br>PART<br>NUMBER | MAY BE<br>REPLACED<br>WITH | DESCRIPTION | LEAD CONFIGURATION (TOP VIEW) | |-------------------------|----------------------------|------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 443-912 | 74LS148 | 8-line-to-3-<br>line<br>Priority encoder | OUTPUTS INPUTS OUTPUT VCC EO GS 3 2 1 0 AO EO GS 3 2 1 0 AO 5 6 7 E1 A2 A1 MPUTS OUTPUTS INPUTS OUTPUTS | | 443-913 | S740 | Keyboard<br>Encoder | B3 1 VLL 2 CLOCK 3 39 69 CLOCK 3 38 B2 X9 4 37 B1 X8 5 36 B8 X7 6 32 B6 X5 8 33 B5 X4 9 X5 8 33 B5 X4 9 X5 8 33 B5 X4 9 X5 10 X5 11 X6 17 X7 10 X8 10 X9 Y8 X9 10 X9 Y8 X9 11 X1 12 | | 443-915 | 74\$86 | Quad 2-input<br>Exclusive — OR | V <sub>cc</sub><br>14 13 12 11 10 9 8<br>D D C<br>A B<br>1 1 2 3 4 5 6 7<br>GND | | HEATH<br>PART<br>NUMBER | MAY BE<br>REPLACED<br>WITH | DESCRIPTION | LEAD CONFIGURATION<br>(TOP VIEW) | |-------------------------|----------------------------|---------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------| | 444-19 | | | A7 1 24 V C C A6 2 23 A8 A5 3 22 A9 A4 4 21 C S 3 | | 444-29 | 2316 or<br>8316 | 2k × 8-bit<br>ROM<br>(Available only<br>from Heath Co.) | A3 5 20 CS1 A2 6 19 A10 A1 7 18 CS2 A0 8 17 08 | | 444-37 | | | 01 9 16 07<br>02 10 15 06<br>03 11 14 05<br>GND 12 13 04 | | 444-62<br>or<br>444-142 | 2716 | PROM<br>(Available only<br>from Heath Co.) | A7 1 24 V C C A6 2 23 A8 A5 3 22 A9 A4 4 21 V b B A3 5 20 A10 A2 6 19 V D D A1 7 18 C 5 A0 8 17 Q8 Q1 9 16 Q 7 Q2 10 Q3 11 V S S 12 13 Q 4 | | 444-66 | SN74S47D | 256 × 8-Bit | V <sub>CC</sub> AD HAD G AD F S2 S1 D0 8 D0 7 D0 6 D0 5 20 19 18 17 16 15 14 13 12 11 H G F S D0 8 D0 7 D0 6 | | 444-61 | | PROM (Available only from Heath Co.) | A DO 5 DO 2 DO 3 DO 4 DO 1 DO 2 DO 3 DO 4 GND | | HEATH<br>PART<br>NUMBER | MAY BE<br>REPLACED<br>WITH | DESCRIPTION | | |-------------------------|----------------------------|----------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------| | 444-46 | 8332A | 4k × 8-bit<br>PROM<br>(Available only<br>from Heath Co.) | V CC A8 A9 CS2 CS1 A10 A11 Q8 Q7 Q6 Q5 Q4 24 23 22 21 20 19 18 17 16 15 14 13 1 | | 444-41<br>or<br>444-83 | SN74S188A | 32k × 8<br>ROM<br>(Available only<br>from Heath Co.) | VCC CS AD E AD D AD C AD B AD A D08 16 15 14 13 12 11 10 9 CS AD E AD D AD C AD B AD A D01 D02 D03 D04 D05 D06 D07 D02 D03 D04 D05 D06 D07 GND | # **APPENDIX** # **ASCII CHARACTERS** The characters in the shaded areas are not processed by the Terminal. | 7-BIT<br>OCTAL<br>CODE | DECÎMAL<br>CODE | HEX<br>CODE | CHARACTERS | CONTROL<br>KEYS | DESCRIPTION | |------------------------|-----------------|-------------|------------|-----------------|--------------------------------------------------| | 000 | 0 | 0 | NUL | @ | Null, tape feed. | | 001 | 1 | 1 | SOH | Ā | Start of heading. | | 002 | 2 | 2 | STX | В | Start of text. | | 003 | 3 | 3 | ETX | C | End of text. | | 004 | 4 | 4 | EOT | D | End of transmission. | | 005 | 5 | 5 | ENQ | E | Enquiry; also WRU. | | 006 | 6 | 6 | ACK | F | Acknowledge; also RU. | | 007 | 7 | 7 | BEL | G | Rings the bell. | | 010 | 8 | 8 | BS | Н | Backspace; also FEB, format effector backspace. | | 011 | .9 | 9 | HT | I | Horizontal tab. | | 012 | 10 | Α | LF | J. | Line feed: advances cursor to next line. | | 013 | 11 | В | VT | K | Vertical tab (VTAB). | | 014 | 12 | C | FF | L | Form feed to top of next page. | | 015 | 13 | D | CR | M | Carriage return to beginning of line. | | 016 | 14 | E | SO | N | Shift out. | | 017 | 15 | F | SI | 0 | Shift in. | | 020 | 16 | 10 | DLE | P | Data line escape. | | 021 | 17 | 11 | DC1 | Q | Device control 1: turns transmitter on (XON). | | 022 | 18 | 12 | DC2 | R | Device control 2. | | 023 | 19 | 13 | DC3 | S | Device control 3: turns transmitter off (XOFF). | | 024 | 20 | 14 | DC4 | T | Device control 4. | | 025 | 21 | 15 | NAK | U | Negative acknowledge: also ERR (error). | | 026 | 22 | 16 | SYN | V | Synchronous idle (SYNC). | | 027 | 23 | 17 | ETB | W | End of transmission block. | | 030 | 24 | 18 | CAN | X | Cancel (CANCL). Cancels current escape sequence. | | 031 | 25 | 19 | EM | Y | End of medium. | | 032 | 26 | 1A | SUB | Z | Substitute. | | 033 | 27 | 1 <b>B</b> | ESC | [ | Escape. | | 034 | 28 | 1C | FS | 1 | File separator. | | 035 | 29 | 1D | GS | ] | Group separator. | | 036 | 30 | 1E | RS | * | Record separator. | | 037 | 31 | 1F | US | • | Unit separator. | | 7-BIT<br>OCTAL<br>CODE | DECIMAL<br>CODE | HEX<br>CODE | CHARACTERS | DESCRIPTION | |------------------------|-----------------|-------------|-------------|-----------------------------| | 040 | 32 | 20 | SP | Space. | | 041 | 33 | 21 | ! | Exclamation point. | | 042 | 34 | 22 | 11 | Quotation mark. | | 043 | <b>3</b> 5 | 23 | # | Number sign. | | 044 | 36 | 24 | \$ | Dollar sign. | | 045 | 37 | <b>2</b> 5 | % | Percent sign. | | 046 | 38 | 26 | & | Ampersand. | | 047 | <b>3</b> 9 | 27 | , | Acute accent or apostrophe. | | 050 | 40 | 28 | ( | Open parenthesis. | | 051 | 41 | <b>2</b> 9 | ) | Close parenthesis. | | 052 | 42 | 2 <b>A</b> | * | Asterisk. | | 053 | 43 | 2B | + | Plus sign. | | 054 | 44 | <b>2</b> C | , | Comma. | | <b>0</b> 55 | 45 | 2D | <del></del> | Hyphen or minus sign. | | 056 | 46 | <b>2</b> E | • | Period. | | <b>057</b> | 47 | 2F | 1 | Slash. | | 060 | 48 | 30 | 0 | Number 0. | | <b>06</b> 1 | 49 | 31 | 1 | Number 1. | | 062 | 50 | 32 | 2 | Number 2. | | 063 | 51 | 33 | 3 | Number 3. | | 064 | <b>52</b> | 34 | 4 | Number 4. | | 065 | 5 <b>3</b> | <b>3</b> 5 | 5 | Number 5. | | 066 | <b>54</b> | 36 | 6 | Number 6. | | 067 | 55 | 37 | 7 | Number 7. | | 070 | 5 <b>6</b> | 38 | 8 | Number 8. | | 071 | 5 <b>7</b> | <b>3</b> 9 | 9 | Number 9. | | 072 | 58 | 3 <b>A</b> | : | Colon. | | 073 | 59 | 3B | ; | Semicolon. | | 074 | 60 | <b>3</b> C | < | Less than. | | <b>07</b> 5 | 61 | <b>3</b> D | = | Equal sign. | | 076 | 62 | <b>3</b> E | > | Greater than. | | 077 | 63 | 3F | ? | Question mark. | | 7-BIT<br>OCTAL<br>CODE | DECIMAL<br>CODE | HEX<br>CODE | CHARACTERS | DESCRIPTION | GRAPHIC<br>SYMBOLS | |------------------------|-----------------|-------------|------------|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 100 | 64 | 40 | @ | At sign. | | | 101 | 65 | 41 | Α | Letter A. | | | 102 | 66 | 42 | В | Letter B. | | | 103 | 67 | 43 | С | Letter C. | | | 104 | 68 | 44 | D | Letter D. | | | 105 | <b>6</b> 9 | 45 | E | Letter E. | | | 106 | 70 | 46 | F | Letter F. | | | 107 | <b>7</b> 1 | 47 | G | Letter G. | | | 110 | 72 | 48 | Н | Letter H. | | | 111 | 73 | 49 | I | Letter I. | | | 112 | 74 | 4A | J | Letter J. | | | 113 | <b>7</b> 5 | 4B | K | Letter K. | | | 114 | 76 | 4C | L | Letter L. | | | 115 | 77 | 4D | M | Letter M. | | | 116 | 78 | 4E | N | Letter N. | | | 117 | <b>7</b> 9 | 4F | 0 | Letter O. | | | 120 | 80 | 50 | P | Letter P. | | | 121 | 81 | 51 | Q | Letter Q. | | | 122 | 82 | <b>52</b> | R | Letter R. | | | 123 | 83 | 5 <b>3</b> | S | Letter S. | | | 124 | 84 | 54 | T | Letter T. | | | 125 | 85 | 55 | U | Letter U. | | | 126 | 86 | <b>56</b> | V | Letter V. | | | 127 | 87 | 5 <b>7</b> | W | Letter W. | | | 130 | 88 | 58 | X | Letter X. | | | 131 | 89 | 59 | Y | Letter Y. | | | 132 | 90 | 5 <b>A</b> | Z | Letter Z. | | | 133 | 91 | 5 <b>B</b> | [ | Open brackets. | | | 134 | 92 | 5C | \ | Reverse slash. | | | 135 | 93 | 5D | ] | Close brackets. | | | 136 | 94 | 5E | <b>↑</b> | Up arrow/caret. | all and a second a | | 137 | 95 | 5F | _ | Underscore. | | | 7-BIT<br>OCTAL<br>CODE | DECIMAL<br>CODE | HEX<br>CODE | CHARACTERS | DESCRIPTION | GRAPHIC<br>SYMBOLS | |------------------------|-----------------|-------------|------------|----------------------|----------------------------------------| | 140 | 96 | 60 | | Grave accent. | | | 141 | 97 | 61 | a | Letter a. | === | | 142 | 98 | 62 | b | Letter b. | | | 143 | 99 | 63 | С | Letter c. | | | 144 | 100 | 64 | d | Letter d. | | | 145 | 101 | 65 | e | Letter e. | | | 146 | 102 | 66 | f | Letter f. | <b>#</b> | | 147 | 103 | 67 | g | Letter g. | ÷ | | 150 | 104 | 68 | h | Letter h. | ÷ | | 151 | 105 | 69 | i | Letter i. | | | 152 | 106 | 6 <b>A</b> | j | Letter j. | <u></u> | | 153 | 107 | 6B | k | Letter k. | # | | 154 | 108 | 6C | 1 | Letter 1. | | | 155 | 109 | 6D | m | Letter m. | | | 156 | 110 | 6E | n | Letter n. | | | 15 <b>7</b> | 111 | 6F | o | Letter o. | | | 160 | 112 | 70 | p | Letter p. | | | 161 | 113 | 71 | q | Letter q. | ************************************** | | 162 | 114 | 72 | r | Letter r. | | | 163 | 115 | 73 | S | Letter s. | | | 164 | 116 | 74 | t | Letter t. | | | 165 | 117 | <b>7</b> 5 | u | Letter u. | <u> </u> | | 166 | 118 | 76 | v | Letter v. | | | 167 | 119 | 77 | w | Letter w. | Ä | | 170 | 120 | 78 | x | Letter x. | / | | 171 | 121 | <b>7</b> 9 | y | Letter y. | : | | 172 | 122 | 7 <b>A</b> | z | Letter z. | | | 173 | 123 | 7B | { | Left brace. | | | 174 | 124 | <b>7</b> C | 1 | Vertical bar (broken | [= | | 175 | 125 | 7D | } | Right brace. | | | 176 | 126 | <b>7</b> E | ~ | Tilde. | Harris . | | 177 | 127 | 7F | DEL | Delete (rubout). | | # **GRAPHIC SYMBOLS** | KEY<br>(OCTAL)<br>[DECIMAL] | SYMBOL | KEY<br>(OCTAL)<br>[DECIMAL] | SYMBOL | KEY<br>(OCTAL)<br>[DECIMAL] | SYMBOL | KEY<br>(OCTAL)<br>[DECIMAL] | SYMBOL | |-----------------------------|-------------------------------------------------------------------------------|-----------------------------|---------------------------------------|-----------------------------|-----------------------------------------------|-----------------------------|------------------------------------------------------| | ^<br>(136)<br>[94] | ***<br>****<br>****<br>**** | C<br>(143)<br>[99] | *****<br>*****<br>** ** ** ** ** | <b>h</b><br>(150)<br>[104] | * | <b>m</b><br>(155)<br>[109] | | | <br>(137)<br>[95] | *******<br> ******<br> *****<br> ****<br> ****<br> ***<br> ***<br> *** | d<br>(144)<br>[100] | ** ** | i<br>(151)<br>[105] | ; * * * * * ;<br>; * * * * * ;<br>; * * * * * | n<br>(156)<br>[110] | ****<br>****<br>****<br>**** | | (140)<br>[96] | ** | e<br>(145)<br>[101] | ** ** ** ** ***** | j<br>(152)<br>[106] | ***** | O<br>(157)<br>[111] | ****<br>****<br>****<br>**** | | a<br>(141)<br>[97] | *******<br> ****** | f<br>(146)<br>[102] | *****<br>*****<br>** ** ** ** | k<br>(153)<br>[107] | * * * * * * * * * * * * * * * * * * * | p<br>(160)<br>[112] | ; *******;<br>; *******;<br>; *******;<br>; *******; | | b<br>(142)<br>[98] | ** ** ** ** ******* ******* ** ** | g<br>(147)<br>[103] | * * * * * * * * * * * * * * * * * * * | <br>(154)<br>[108] | ****<br>****<br>****<br>**** | q<br>(161)<br>[113] | ****<br>****<br>****<br>****<br>****<br>****<br>**** | | KEY<br>(OCTAL)<br>[DECIMAL] | SYMBOL | KEY<br>(OCTAL)<br>[DECIMAL] | SYMBOL | KEY<br>(OCTAL)<br>[DECIMAL] | SYMBOL | |-----------------------------|-----------------------------------------------------------|-----------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------|------------------------------------------------| | r<br>(162)<br>[114] | ****** ***** ***** **** **** **** **** **** | <b>W</b><br>(167)<br>[119] | ; * * * ; * * * ; * * * * ; * * * * ; * * * ; * * * ; * * * ; * * * ; * * * ; * * * ; * * * ; * * * ; * * * ; * * * ; * * * ; * * * ; * * * ; * * * ; * * * ; * * * ; * * * ; * * * ; * * * ; * * * ; * * * ; * * * ; * * * ; * * * ; * * * ; * * * ; * * * ; * * * ; * * ; * * * ; * * ; * * ; * * ; * * ; * * ; * * ; * * ; * * ; * * ; * * ; * * ; * * ; * * ; * * ; * * ; * * ; * * ; * * ; * * ; * * ; * * ; * * ; * * ; * * ; * * ; * * ; * * ; * * ; * * ; * * ; * * ; * * ; * ; * * ; * ; * * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * ; * | <br>(174)<br>[124] | : ** : ** : ** : ** : ** : ** : ** : ** | | <b>S</b><br>(163)<br>[115] | *******<br>******<br>** ** ** | X<br>(170)<br>[120] | ** ** ** ** ** ** ** ** ** | }<br>(175)<br>[125] | - ** ** ** ** ** ** ** ** | | t<br>(164)<br>[116] | ; ** ; ** ; ** ; ** ; ** ; ** ; ** ; * | <b>y</b><br>(171)<br>[121] | ** ** ** ** ** ** ** ** ** ** | ~<br>(176)<br>[126] | **** **** *** ** ** ** ** ** * | | u<br>(185)<br>[117] | ** ** ** ** *** *** ****** | <b>Z</b><br>(172)<br>[122] | *******<br>******* | | | | V<br>(166)<br>[118] | ** ** ** ** ** ** ** ** ** ** | {<br>(173)<br>[123] | ********<br>****** | | | # TRANSMITTED CODES The following tables list the octal code or codes transmitted by the Computer when the indicated keyboard keys are pressed. | KEY | LOWER CASE | UPPER CASE | |-----|-------------|------------| | Α | 141 | 101 | | В | 142 | 102 | | C | 143 | 103 | | D | 144 | 104 | | E | 145 | 105 | | F | 146 | 106 | | G | 147 | 107 | | Н | 150 | 110 | | I | 151 | 111 | | J | 152 | 112 | | K | 153 | 113 | | L | 154 | 114 | | М | 155 | 115 | | N | 156 | 116 | | 0 | 15 <i>7</i> | 117 | | P | 160 | 120 | | Q | 161 | 121 | | R | 162 | 122 | | S | 163 | 123 | | Т | 164 | 124 | | U | 165 | 125 | | V | 166 | 126 | | w | 167 | 127 | | х | 170 | 130 | | Y | 171 | 131 | | Z | 172 | 132 | | KEY | UNSHIFTED | SHIF | ГED | |-----|-----------|--------------|----------| | 0 | 060 | 051 | ) | | 1 | 061 | 041 | ! | | 2 | 062 | 100 | @ | | 3 | 063 | 043 | # | | 4 | 064 | 044 | \$ | | 5 | 065 | 045 | % | | 6 | 066 | 136 | <b>↑</b> | | 7 | 067 | 046 | & | | 8 | 070 | 052 | * | | 9 | 071 | 050 | ( | | _ | 055 | 137 | _ | | = | 075 | 053 | + | | [ | 133 | 1 <b>3</b> 5 | ] | | ; | 073 | 072 | : | | , | 047 | 042 | , ** | | , | 054 | 074 | < | | | 056 | 076 | > | | 1 | 057 | 077 | ? | | , | 140 | 176 | ~ | | \ | 134 | 174 | 1 | | {. | 173 | 175 | } | NONALPHABETIC KEYS **ALPHABETIC KEYS** | KEYPAD<br>KEYS | UNSHIFTED | HEATH<br>UNSHIFTED<br>ALTERNATE | ANSI<br>UNSHIFTED<br>ALTERNATE | SHIFTED | |----------------|-----------|---------------------------------|--------------------------------|-------------------------------------| | | | | | | | 0 | 0 | ESC ? p | ESC O p | 0 | | 1\IL | 1 | ESC ? q | ESC O q | ESC L (Insert Line) | | 2∖↓ | 2 | ESC ? r | ESC O r | ESC B (Down arrow) | | 3∖DL | 3 | ESC ? s | ESC O s | ESC M (Delete Line) | | 4\← | 4 | ESC ? t | ESC O t | ESC D (Left arrow) | | 5\HOME | 5 | ESC? u | ESC O u | ESC H (Home) | | 6∖→ | 6 | ESC ? v | ESC O v | ESC C (Right arrow) | | 7∖IC | 7 | ESC?w | ESC O w | ESC @ (Enter Insert Character Mode) | | | | | | ESC O (Exit Insert Character Mode) | | 8∖↑ | 8 | ESC ? x | ESC O x | ESC A (Up arrow) | | 9\DC | 9 | ESC ? y | ESC O y | ESC N (Delete Character) | | • | • | ESC?n | ESC O n | • | | ENTER | RETURN | ESC ? M | ESC O M | RETURN | | | | , | | | ## **KEYPAD KEYS** NOTE: The shifted mode and the unshifted (or alternate) mode (if the alternate mode was selected) can be interchanged by entering ESC t or ESC u. | KEY | ZDS<br>ESCAPE<br>CODE | ANSI<br>ESCAPE<br>CODE | |-------|-----------------------|------------------------| | 0 | ESC ? p | ESC O p | | 1 | ESC ? q | ESC O q | | 2 | ESC ? r | ESC O r | | 3 | ESC ? s | ESC O s | | 4 | ESC ? t | ESC O t | | 5 | ESC ? u | ESC O u | | 6 | ESC ? v | ESC O v | | 7 | ESC ? w | ESC O w | | 8 | ESC ? x | ESC O x | | 9 | ESC ? y | ESC O y | | | ESC ? n | ESC O n | | ENTER | ESC ? M | ESC O M | | KEY | OCTAL<br>CODE | ANSI<br>CODE | |-----------|---------------|--------------| | DECLIPA | 015 | 015 | | RETURN | 015 | 015 | | LINE FEED | 012 | 012 | | BACKSPACE | 010 | 010 | | SPACE BAR | 040 | 040 | | ТАВ | 011 | 011 | | DELETE | 177 | 177 | | ESC | 033 | 033 | **CONTROL KEYS** # ALTERNATE KEYPAD MODE | KEY | ZDS<br>ESCAPE<br>CODE | ANSI<br>ESCAPE<br>CODE | |------|-----------------------|------------------------| | | | | | F1 | ESC S | ESC O S | | F2 | ESC T | ESC O T | | F3 | E <b>S</b> C U | ESC O U | | F4 | ESC V | esc o v | | F5 | ESC W | ESC O W | | BLUE | ESC P | ESC O P | | RED | ESC Q | ESC O Q | | GRAY | ESC R | ESC O R | **SPECIAL FUNCTION KEYS** # ZDS ESCAPE SEQUENCES # **Summary Of Sequences** | Escape<br>Sequence | Mnemonic | <b>Definition</b> | |----------------------|----------|-------------------------------------------------------------------------------------| | CURSOR FI | UNCTIONS | | | | | | | ESC H | ZCUH | Cursor Home | | ESC C | ZCUF | Cursor Forward | | ESC D | ZCUB | Cursor Backward | | ESC B | ZCUD | Cursor Down | | ESC A | ZCUU | Cursor Up | | ESC I | ZRI | Reverse Index | | ESC n | ZCPR | Cursor Position Report | | ESC j | ZSCP | Save Cursor Position | | ESC k | ZRCP | Set Cursor To Previously Saved Position | | ESC Y | ZDCA | Direct Cursor Addressing (Same as VT52) | | ERASING AND EDITING | | | | ESC E | ZCD | Clear Display (Shift Erase) | | ESC b | ZBD | Erase Beginning Of Display | | ESC J | ZEOP | Erase To End Of Page (Erase Key) | | ESC Î | ZEL | Erase Entire Line | | ESC o | ZEBL | Erase Beginning Of Line | | ESC K | ZEOL | Erase To End Of Line | | ESC L | ZIL | Insert Line | | ESC M | ZDL | Delete Line | | ESC N | ZDCH | Delete Character | | ESC @ | ZEIM | Enter Insert Character Mode | | ESC O | ZERM | Exit Insert Character Mode | | CONFIGUR | RATION | | | ESC z | ZRAM | Reset to Power IIn Configuration | | ESC r B <sub>n</sub> | ZMBR | Reset to Power-Up Configuration<br>Modify Baud Rate ( $B_n$ =; A=110, B=150, C=300, | | LOC I D <sub>n</sub> | ZMDK | D=600, E=1200, F=1800, G=2000, H=2400, I=3600, | | | | J=4800, K=7200, L=9600, M=19200*) | | | | )-4000, K-7200, L=9600, M=19200^) | | $ESC \times P_s$ | ZSM | Set $Mode(s)$ : $P_s =$ | | | | 1 = Enable 25th line | | | | 2 = No key click | | | | 3 = Hold screen mode | | | | 4 = Block cursor | | | | 5 = Cursor off | | | | 6 = Keypad shifted | | | | 7 = Alternate keypad mode | | | | 8 = Auto line feed on receipt of CR | | | | 9 = Auto CR on receipt of line feed | | | | • | <sup>\*</sup>Not presently supported (may drop characters). ESC y $P_s$ ZRM Reset Mode(s): $P_s$ = 1 = Disable 25th line 2 = Enable key click 3 = Exit hold screen mode 4 = Underscore cursor 5 = Cursor on 6 = Keypad unshifted 7 = Exit alternate keypad mode 8 = No auto line feed 9 = No auto CR ESC < ZEAM Enter ANSI Mode # MODES OF OPERATION | ESC [ | ZEHS | Enter Hold Screen Mode | |-------|------|-----------------------------| | ESC \ | ZXHS | Exit Hold Screen Mode | | ESC p | ZERV | Enter Reverse Video Mode | | ESC q | ZXRV | Exit Reverse Video Mode | | ESC F | ZEGM | Enter Graphics Mode | | ESC G | ZXGM | Exit Graphics Mode | | ESC t | ZEKS | Enter Keypad Shifted Mode | | ESC u | ZXKS | Exit Keypad Shifted Mode | | ESC = | ZAKM | Enter Alternate Keypad Mode | | ESC > | ZXAM | Exit Alternate Keypad Mode | ## **ADDITIONAL FUNCTIONS** | ESC } | ZDK | Keyboard Disabled | |-------|-------------|----------------------------| | ESC { | ZEK | Keyboard Enabled | | ESC v | ZEWA | Wrap Around At End Of Line | | ESC w | ZXWA | Discard At End Of Line | | ESC Z | ZID | Identify As VT52 (ESC / K) | | ESC ] | <b>ZX25</b> | Transmit 25th Line | | ESC # | ZXMP | Transmit Page | NOTE: The Terminal will transmit the following sequences, but it will not respond to them if they are received by the Terminal. | ESC S | ZF1 | Function Key #1 (f1) | |-------|-----|----------------------| | ESC T | ZF2 | Function Key #2 (f2) | | ESC U | ZF3 | Function Key #3 (f3) | | ESC V | ZF4 | Function Key #4 (f4) | | ESC W | ZF5 | Function Key #5 (f5) | | ESC P | ZF7 | Function Key (BLUE) | | ESC Q | ZF8 | Function Key (RED) | | ESC R | ZF9 | Function Key (GRAY) | # **ZDS Escape Sequences Defined** #### **CURSOR FUNCTIONS** #### **ZCUH Cursor Home ESC H** Moves the cursor to the first character position on the first line (home). #### **ZCUF** Cursor Forward ESC C Moves the cursor one character position to the right. If the cursor is at the right end of the line, it will remain there. #### **ZCUB** Cursor Backward ESC D Moves the cursor one character position to the left (backspaces). If the cursor is at the start (left end) of a line, it will remain there. #### **ZCUD** Cursor Down ESC B Moves the cursor down one line without changing columns. The cursor will not move past the bottom (24th) line and no scrolling will take place. Use ZDCA (Direct Cursor Addressing) to move the cursor to line 25 — when line 25 is active. #### ZCUU Cursor Up ESC A Moves the cursor up one line. If the cursor reaches the top line, it remains there and no scrolling occurs. #### ZRI Reverse Index ESC I Moves the cursor to the same horizontal position on the preceding line. If the cursor is on the top line, a scroll down is performed. ## ZCPR Cursor Position Report ESC n The Terminal reports the cursor position in the form of ESC Y line# column#. #### **ZSCP** Save Cursor Position ESC j The present cursor position is saved so the cursor can be returned here later when given the HRCP (Set Cursor to Previously Saved Position) command. #### ZRCP Set Cursor to Previously Saved Position ESC k Returns the cursor to the position where it was when it received the HSCP (Save Cursor Position) command. #### **ZDCA** Direct Cursor Addressing ESC Y Moves the cursor to a position on the screen by entering the escape code, the ASCII character which represents the line number, and the ASCII character which represents the column number. The first line and the left column are both 32<sub>10</sub> (the smallest value of the printing characters) and increase from there. Since the lines are numbered from 1 to 25 (from top to bottom) and the columns from 1 to 80 (from left to right), you must add the proper line and column numbers to 31<sub>10</sub>. Then convert these decimal numbers to their equivalent ASCII characters and enter them in the following order: ESC Y line # (ASCII character) column # (ASCII character) If the line number entered is too high, the cursor will not move. If the column number is too high, the cursor will move to the end of the line. This is the only way to move the cursor to the 25th line, but the 25th line must first be enabled. #### **ERASING AND EDITING** #### ZCD Clear Display (Shift Erase) ESC E Erases the entire screen, fills the screen with spaces, and places the cursor in the home position. #### ZBD Erase Beginning of Display ESC b Erases from the start of the screen to the cursor, and includes the cursor position. #### ZEOP Erase to End Of Page (Erase Key) ESC J Erases all the information from the cursor (including the cursor position) to the end of the page. #### ZEL ERASE Entire Line ESC I Erases all of the line, including the cursor position. ### ZEBL Erase Beginning of Line ESC o Erases from the beginning of the line to the cursor, and includes the cursor position. #### ZEOL Erase to End Of Line ESC K Erases from the cursor (including the cursor position) to the end of the line. #### ZIL Insert Line ESC L Inserts a new blank line by moving the line that the cursor is on, and all following lines, down one line. Then the cursor is moved to the beginning of the new blank line. ### ZDL Delete Line ESC M Deletes the contents of the line that the cursor is on, places the cursor at the beginning of the line, moves all the following lines up one line, and adds a blank line at line 24. #### **ZDCH** Delete Character ESC N Deletes the character at the cursor position and shifts any existing text that is to the right of the cursor one character position to the left. ### ZEIM Enter Insert Character Mode ESC @ Lets you insert characters or words into text already displayed on the screen. As you type in new characters, existing text to the right of the cursor shifts to the right. As each new character is inserted, the character at the end of the line is lost. #### ZERM Exit Insert Character Mode ESC O Exits from the insert character mode. ## **CONFIGURATION** ### ZRAM Reset to Power-Up Configuration ESC z Nullifies all previously set escape modes and returns to the power-up configuration. ### ZMBR Modify Baud Rate ESC r Bn Modifies the baud rate, where Bn equals: A=110, B=150, C=300, D=600, E=1200, F=1800, G=2000, H=2400, I=3600, J=4800, K=7200, L=9600 ### ZSM Set Mode(s) ESC x P<sub>s</sub> Sets the following modes, where P<sub>s</sub> equals: 1=enable 25th line 2=no key click 3=hold screen mode 4=block cursor 5=cursor off 6=keypad shifted 7=alternate keypad mode 8=auto line feed on receipt of CR 9=auto CR on receipt of line feed ## ZRM Reset Mode(s) ESC y P<sub>s</sub> Resets special modes, where P<sub>s</sub> equals: 1=disable 25th line 2=enable key click 3=exit hold screen mode 4=underscore cursor 5=cursor on 6=keypad unshifted 7=exit alternate keypad mode 8=no auto line feed 9=no auto CR ## ZEAM Enter ANSI Mode ESC < Enters the ANSI mode. ## MODES OF OPERATION ### ZEHS Enter Hold Screen Mode ESC [ Controls when new information is printed on the screen. - Type the SCROLL key and a new line of information will be printed on the bottom line. The top line will scroll off. - Type SHIFT SCROLL and a whole new page of text will scroll onto the screen and stop as the old page scrolls up and off the screen. # ZXHS Exit Hold Screen Mode ESC \ Exits the hold screen mode. # ZERV Enter Reverse Video Mode ESC p Enters the reverse video mode so that characters are displayed as black characters on a white background. # ZXRV Exit Reverse Video Mode ESC q Exits the reverse video mode. # **ZEGM** Enter Graphics Mode ESC F Enters the graphics mode to display any of the 33 special symbols (26 lower-case keys and seven other keys) that correspond to the graphic symbols. # ZXGM Exit Graphics Mode ESC G Exits the graphics mode and returns to the display of normal characters. # ZEKS Enter Keypad Shifted Mode ESC t Inverts the normal and shifted functions of the keypad. Now, if you hold down the SHIFT key, you will get a normally unshifted character. # ZXKS Exit Keypad Shifted Mode ESC u Exits the keypad shifted mode. # ZAKM Enter Alternate Keypad Mode ESC = Enters the alternate keypad mode, which will then allow the keyboard keys to transmit the following escape codes instead of the normal ones. | KEY | <b>ESCAPE CODE</b> | |--------------|--------------------| | | | | 0 | ESC ? p | | 1 | ESC ? q | | 2 | ESC ? r | | 3 | ESC?s | | 4 | ESC?t | | 5 | ESC? u | | 6 | ESC? v | | 7 | ESC? w | | 8 | ESC?x | | 9 | ESC?y | | • | ESC? n | | ENTER | ESC? M | | <del>-</del> | | These special escape codes are user defined and must be recognized by your software. # ZXAM Exit Alternate Keypad Mode ESC > Exits the alternate keypad mode and returns to the transmission of normal character codes. # ADDITIONAL FUNCTIONS # **ZDK** Keyboard Disabled ESC } Inhibits the output of the keyboard. # **ZEK Keyboard Enabled ESC {** Enables the keyboard after it was inhibited by an HDK (Keyboard Disabled) command. # ZEWA Wrap Around at End of Line ESC v The 81st character on a line is automatically placed in the first character position on the next line. The page scrolls up if necessary. # ZXWA Discard at End of Line ESC w After the 80th character in a line, the characters overprint. Therefore, only the last character received will be displayed in position 80. # ZID Identify as VT52 (ESC / K) ESC Z The Terminal responds to the interrogation with ESC / K to indicate that it can perform as VT52. # ZX25 Transmit 25th Line ESC ] Transmits the 25th line. (The computer requires a special routine to use this feature.) # ZXMP Transmit Page ESC # Transmits lines 1 through 24. (The computer requires a special routine to use this feature.) # ZF1 Function Key #1 (F1) ESC S Transmits a unique escape code to perform a user-defined function. The Terminal will not respond to this code if it is received. # **ZF2** Function Key #2 (F2) ESC T Same as above. # ZF3 Function Key #3 (F3) ESC U Same as above. # ZF4 Function Key #4 (F4) ESC V Same as above. # ZF5 Function Key #5 (F5) ESC W Same as above. # **ZF7** Function Key Blue ESC P Same as above. # **ZF8** Function Key Red ESC Q Same as above. # **ZF9** Function Key Gray ESC R Same as above. # ANSI ESCAPE SEQUENCES # **Summary Of Sequences** # NOTES: - 1. In the ANSI mode, the Terminal recognizes and responds only to escape sequences whose syntax and semantics are in accordance with ANSI specifications. - 2. "Default" is a value that is assumed when no explicit value, or a value of zero, is specified. - 3. $P_n$ Numeric Parameter. Any decimal value may be substituted for $P_n$ . - 4. P<sub>s</sub> Selective Parameter. Any decimal number that is taken from a list and used to select a subfunction. You can select several subfunctions at once by putting one number after another but separating them with delimiters (semicolons). Example: To turn off the key click (ESC [ > 2 h) and turn on the block cursor (ESC [ > 4 h), type: ESC > 2;4 h | Escape | Mnemonic | <b>Definition</b> | |-------------------------|----------|--------------------------| | Sequence | | | | <b>CURSOR FUNCTIONS</b> | | | | ESC [ H or ESC [ Ø;Ø H | CUP | Cursor Home | | or ESC [ 1;1 H | or | | | ESC [for ESC [Ø;Øf | HVP | | | or ESC [ 1;1 f | | | | ESC [ $P_n$ C | CUF | Cursor Forward | | ESC [ $P_n$ D | CUB | Cursor Backward | | ESC [ $P_n$ B | CUD | Cursor Down | | ESC [ $P_n$ A | CUU | Cursor Up | | ESC M | RI | Reverse Index | | ESC[6n | CPR | Cursor Position Report | | ESC[s | PSCP | Save Cursor Position | | ESC[u | PRCP | Set Cursor Position | | $ESC[P_t;P_cH]$ | CUP | Direct Cursor Addressing | | or ESC[ $P_i$ ; $P_c$ f | | _ | # **ERASING AND EDITING** | ESC [ 2 j | ED | Clear Display (Shift Erase) | |-------------------------------|-----|------------------------------------------------| | ESC [ 1 j | ED | Erase Beginning Of Display | | ESC [jor ESC [ Ø J | ED | Erase To End Of Page (Erase Key) | | ESC [ 2 k | EL | Erase Entire Line | | ESC [ 1 K | EL | Ease Beginning Of Line | | ESC [K or ESC [ Ø K | EL | Erase To End Of Line | | ESC [ P <sub>n</sub> L | IL | Insert Line | | ESC [ $P_n$ M | DL | Delete Line | | $\stackrel{.}{ESC}$ [ $P_n$ P | DCH | Delete Character | | ESC [ 4 h | IRM | Insert/Replacement (Insert character) Mode On | | ESC [ 4 l | IRM | Insert/Replacement (Insert Character) Mode Off | | | | | # **CONFIGURATION** | ESC [ z | PRAM | Reset To Power-Up Configuration | |---------------|------|------------------------------------------| | ESC [ $P_n$ r | PMBR | Modify Baud Rate $(P_n =; 1=110, 2=150,$ | | | | 3=300, 4=600, 5=1200, 6=1800, 7=2000, | | | | 8=2400, 9=3600, 10=4800, 11=7200, | | | | 12=9600, 13=19200*) | | $ESC [ > P_n h]$ | SM | Set Mode(s): $P_n =$ | |------------------|----|----------------------| | | | 1 = Enable 25th line | | | | 2 = No key click | | | | 3 = Hold screen mode | | | | 4 = Block cursor | | | | 5 = Cursor off | | | | | 6 = Keypad shifted 7 = Alternate Keypad mode 8 = Auto line feed on receipt of CR 9 = Auto CR on receipt of line feed | ESC $[ > P_n ]$ | RM | Reset Mode(s): $P_n =$ | |-----------------|----|---------------------------| | <u>-</u> | | 1 = Disable 25th line | | | | 2 = Enable key click | | | | 3 = Exit hold screen mode | | | | 4 = Underscore cursor | | | | 5 = Cursor on | 5 = Cursor on 6 = Keypad unshifted 7 = Exit alternate keypad mode 8 = No auto line feed 9 = No auto CR ESC [ ? 2 h PEZM Enter ZDS Mode # MODES OF OPERATION | ESC [ 7 m | SGR | Enter Reverse Video Mode | |---------------------------|-----|--------------------------------------| | ESC [ m or ESC [ $\phi$ m | SGR | Exit Reverse Video Mode | | ESC [ > 7 h | SM | Enter Alternate Keypad Mode (ESC=)** | | ESC [ > 7 l | RM | Exit Alternate Keypad Mode (ESC>)** | | ESC [ 10 m | SGR | Enter Graphics Mode | | ESC [ 11 m | SGR | Exit Graphics Mode | <sup>\*</sup>Not presently supported (may drop characters). <sup>\*\*</sup>These escape codes may be used, but are not recommended. # **ADDITIONAL FUNCTIONS** | ESC [ 2 h | SM | Keyboard Disabled | |-------------|------|----------------------------| | ESC [ 2 ] | RM | Keyboard Enabled | | ESC [ ? 7 h | SM | Wrap Around At End Of Line | | ESC [ ? 7 l | RM | Discard At End Of Line | | ESC [ q | PX25 | Transmit 25th Line | | ESC [ p | PXMT | Transmit Page | NOTE: The Terminal will transmit the following functions, but it will not respond to them if they are received by the Terminal. | ESC O S | SS3 | Function Key #1 (F1) | |---------|-----|----------------------| | ESC O T | SS3 | Function Key #2 (F2) | | ESC O U | SS3 | Function Key #3 (F3) | | ESC O V | SS3 | Function Key #4 (F4) | | ESC O W | SS3 | Function Key #5 (F5) | | ESC O P | SS3 | Function Key (BLUE) | | ESC O Q | SS3 | Function Key (RED) | | ESC O R | SS3 | Function Key (GRAY) | # **ANSI Mode Summary** The ANSI controls SET MODE (SM) and RESET MODE (RM) are shown on the previous page. The following table shows all parameters which may be set or reset using the SM and RM control sequences. The control sequence for SET MODE is: ESC [ $P_s$ h. The control sequence for RESET MODE is: ESC [ $P_s$ l. | | MODE | $P_n$ | SET (SM) | RESET (RM) | |------|---------------------------------------------|----------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | ANSI | KAM<br>IRM | 2<br>4 | Keyboard Disabled<br>Insert Character Mode On | Keyboard Enabled<br>Insert Character<br>Mode OFF | | | LNM | 20 | New Line Mode<br>(Auto Line Feed On CR) | New Line Mode Off | | ZDS | L25 KCL ZSM CBL CDE KSH KAM ALF ACR ZMD WAR | >1<br>>2<br>>3<br>>4<br>>5<br>>6<br>>7<br>>8<br>>9<br>?2<br>?7 | Display 25th Line Disable Key Click Enable Hold Screen Mode Blinking Block Cursor Cursor Off Keypad Shifted Keypad Alternate Mode Auto Line Feed On Return Auto CR On Line Feed Enter ZDS Mode Wrap Around At End Of Line | Disable 25th Line Enable Key Click Disable Hold Screen Mode Blinking Underscore Cursor Cursor On Keypad Unshifted Keypad Normal Mode No Auto Line Feed No Auto CR On Line Feed N/A Discard Past End Of Line | ANSI modes which are always considered to be in either the SET or the RESET state, and those which do not apply to this product are as follows: | CRM | Control Representation Mode | RESET | |------|--------------------------------|--------------| | EBM | Editing Boundary Mode | RESET | | ERM | Erasure Mode | SET | | FEAM | Format Effector Action Mode | RESET | | FETM | Format Effector Transfer Mode | RESET | | GATM | Guarded Area Transfer Mode | RESET | | HEM | Horizontal Editing Mode | RESET | | MATM | Multiple Area Transfer Mode | N/A | | PUM | Positioning Unit Mode | RESET | | SATM | Selected Area Transfer Mode | SET | | SRTM | Status Reporting Transfer Mode | N/A | | TSM | Tabulation Stop Mode | N/A | | TTM | Transfer Termination Mode | SET | | VEM | Vertical Editing Mode | RESET | | SEM | Set Editing Extent Mode | Edit In Line | | | | | # **ANSI Escape Sequences Defined** # NOTES: - 1. In the ANSI mode, the Terminal recognizes and responds only to escape sequences whose syntax and semantics are in accordance with ANSI specifications. - "Default" is a value that is assumed when no explicit value, or a value of zero, is specified. - 3. $P_n$ Numeric Parameter. Any decimal number that is substituted for $P_n$ . - 4. $P_s$ Selective Parameter. Any decimal number that is taken from a list and used to select a subfunction. You can select several subfunctions at once by putting one number after another but separating them with delimiters (semicolons). # **CURSOR FUNCTIONS** CUP Cursor Position ESC [ H or ESC [ # or ESC ] or ESC [ 1;1 H HVP Horizontal & Vertical Position ESC [ f or ESC [ f; f) or **ESC** [ 1;1 f Moves the cursor to the position specified by the parameters. The first parameter specifies the line number and the second parameter specifies the column number. A parameter of zero is considered to be one. If no parameter is given, the cursor is placed in the home position. Default Value: 1 # CUF Cursor Forward ESC [ P, C Moves the cursor to the right the number of characters determined by the value of $P_n$ . If this number is zero or one, the cursor moves one position. The cursor stops at the right margin. Default Value: 1 # CUB Cursor Backward ESC [ P, D Moves the cursor to the left the number of characters determined by the value of $P_n$ . If this number is zero or one, the cursor moves one position. The cursor stops at the left margin. Default Value: 1 # CUD Cursor Down ESC [ Pn B Moves the cursor downward without changing columns. The number of lines moved is determined by the value of $P_n$ . If this number is zero or one, the cursor moves down one line. The cursor will stop at line 24. Direct Cursor Addressing must be used to move to line 25. # CUU Cursor Up ESC [ $P_n$ A Moves the cursor upward without changing columns. The number of lines moved is determined by the value of $P_n$ . If this number is zero or one, the cursor moves up one line. The cursor will stop at the top line. Default Value:1 #### RI Reverse Index ESC M Moves the cursor to the same position on the preceeding line. # CPR Cursor Position Report ESC[6n The Terminal reports the cursor position in the form of ESC[ $P_t$ ; $P_cR$ . # **PSCP** Save Cursor Position ESC [ s The present cursor position is remembered so the cursor can be returned here later when given the PRCP (Return to Previously Saved Position) command. # PRCP Set Cursor to Previously Saved Position ESC [ u Returns the cursor to the position where it was when it received the PSCP (Save Cursor Position) command. # CUP Direct Cursor Addressing ESC [ $P_i$ ; $P_c$ H or ESC [ $P_i$ ; $P_c$ f Same as CUP and HVP above. If the line number $(P_l)$ entered is too high, the cursor will not move. If the column number $(P_c)$ is too high, the cursor will move to the end of the line. This is the only way to move the cursor to the 25th line, but the 25th line must first be enabled. To move the cursor home, enter $\phi$ ; $\phi$ or 1;1 or do not enter any values. Default Values: 1 # **ERASING AND EDITING** # ED Erase In Display ESC [ Ps J Erases some or all of the characters in the display according to the value of P<sub>s</sub>. | $\mathbf{P}_{s}$ | Means | |----------------------------------|--------------------------------------------------------------------| | $\frac{\mathbf{P}_s}{\emptyset}$ | Erases from the cursor to the end of the screen and includes the | | | cursor position. | | 1 | Erases from the start of the screen to the cursor and includes the | | | cursor position. | | 2 | Erases all of the screen and the cursor goes to the HOME position. | Default Value: 0 # EL Erase In Line ESC [ Ps K Erases some or all of the characters in the cursor line according to the value of Ps. | $\mathbf{P}_{s}$ | Mea | ns | |------------------|---------------|---------------------------------------------------------------------| | Ø | Eras | es from the cursor to the end of the line and includes the cursor | | , | po <b>s</b> i | tion. | | 1 | Eras | es from the start of the line to the cursor and includes the cursor | | | posi | tion. | | 2 | Eras | es all of the line including the cursor position. | Default Value: 0 # IL Insert Line ESC [ P<sub>n</sub> L Inserts one or more blank lines (depending on the value of $P_n$ ) by moving the line that the cursor is on and all the following lines down $P_n$ lines. Then the cursor is moved to the beginning of the new blank line. # DL Delete Line ESC [ $P_n$ M Deletes the line of characters that the cursor is in, and other following lines if $P_n$ is greater than one. The remaining lines below the deleted area then move up the number of lines that were deleted. The cursor is placed at the beginning of the next line. Default Value: 1 # DCH Delete Character ESC [ Pn P Deletes the characters at the cursor position, and other positions on the cursor line to the right of the cursor if $P_n$ is greater than one. Any remaining characters to the right of the deleted characters then move left the number of characters that were deleted. Default Value: 1 # IRM Insert/Replacement Mode ON ESC [ 4 h Lets you insert characters or words into text already displayed on the screen. As new characters are entered, existing text to the right of the cursor shifts to the right. As each character is inserted, the character at the end of the line is lost. # IRM Insert/Replacement Mode OFF ESC [ 4 ] Exits from the IRM ON mode. # CONFIGURATION # PRAM Reset to Power-Up Configuration ESC [ z Nullifies all previously set escape modes and returns to the power-up configuration. # PMBR Modify Baud Rate ESC [ $P_n$ r Modifies the baud rate, where $P_n$ equals: ``` 1=110, 2=150, 3=300, 4=600, 5=1200, 6=1800, 7=2000, 8=2400, 9=3600, 10=4800, 11=7200, 12=9600, 13=19,200* ``` # SM Set Mode(s), ESC $[ > P_s h]$ Sets the following modes, where $P_n$ equals: 1=enable 25th line 2=no key click 3=hold screen mode 4=block cursor 5=cursor off 6=keypad shifted 7=alternate keypad mode 8=auto line feed on receipt of CR 9=auto CR on receipt of line feed Can set one or more modes as determined by the parameter string P<sub>s</sub>;P<sub>s</sub>;P<sub>s</sub>, etc. Default Value: None <sup>\*</sup>Not presently supported (may drop characters). # RM Reset Mode(s) ESC $[ > P_s ]$ Resets special modes, where P<sub>s</sub> equals: - 1=disable 25th line - 2=enable key click - 3=exit hold screen mode - 4=underscore cursor - 5=cursor on - 6=keypad unshifted - 7=exit alternate keypad mode - 8=no auto line feed - 9=no auto CR Can reset one or more modes as determined by the parameter string $P_s; P_s; P_s$ , etc. Default Value: None **PEZM** Enter ZDS Mode ESC [ ? 2 h Enters the ZDS mode. # MODES OF OPERATION # SM Enter Hold Screen Mode ESC [ > 3 h Controls when new information is printed onto the screen. - Type the SCROLL key and a new line of information will be printed on the bottom line. The top line will scroll off. - Type SHIFT SCROLL and a whole new page of text will scroll onto the screen and stop as the old page scrolls up and off the screen. # RM Exit Hold Screen Mode ESC [ > 3 l Exits the hold screen mode. # SGR Enter Reverse Video Mode ESC [ 7 m Enters the reverse video mode so that characters are displayed as black characters on a white background. # SGR Exit Reverse Video Mode ESC [ m or ESC [ 0 m Exits the reverse video mode. # SM Enter Keypad Shifted Mode ESC [ > 6 h Inverts the normal and shifted functions of the keypad. Now if you hold down the SHIFT key, you will get a normally unshifted character. # RM Exit Keypad Shifted Mode ESC [ > 6 l Exits the keypad shifted mode. # SM Enter Alternate Keypad Mode ESC = or ESC [ > 7 h Allows you to enter the alternate keypad mode, which will then transmit the following escape codes instead of the normal ones. | <u>KEY</u> | <b>ESCAPE CODE</b> | |------------|--------------------| | ø | ESC O p | | 1 | ESC O q | | 2 | ESC O r | | 3 | ESC O s | | 4 | ESC O t | | 5 | ESC O u | | 6 | ESC O v | | 7 | ESC O w | | 8 | ESC O x | | 9 | ESC O y | | • | ESC O n | | ENTER | ESC O M | These special escape codes are user defined and must be recognized by your software. # RM Exit Alternate Keypad Mode ESC > or ESC [ > 7 l Exits the alternate keypad mode and returns to the transmission of normal character codes. # **ADDITIONAL FUNCTIONS** # SM Kevboard Disabled ESC [ 2 h Inhibits the output of the keyboard. To activate the keyboard, send the "enable keyboard" escape sequence from the computer or reset the Terminal. #### RM Kevboard Enabled ESC [ 2 ] Enables the keyboard after it was inhibited by an SM (Keyboard Disabled) command. # SM Wrap Around At End Of Line ESC [?7 h 81st character on a line is automatically placed in the first character position on the next line. The page scrolls up if necessary and permitted. # RM Discard At End Of Line ESC [ ? 7 l After the 80th character in a line, the characters overprint. Therefore, only the last character received will be displayed in position 80. # PX25 Transmit 25th Line ESC [ q Transmits the 25th line. # PXMT Transmit Page ESC [p Transmits lines 1 through 24. (The computer requires a special routine to use this feature.) # SS3 Function Key #1 (F1) ESC O S Transmits a unique escape code to perform a user-defined function. The Terminal will not respond to this code if it is received. SS3 Function Key #2 (F2) ESC O T Same as above. SS3 Function Key #3 (F3) ESC O U Same as above. SS3 Function Key #4 (F4) ESC O V Same as above. SS3 Function Key #5 (F5) ESC O W Same as above. **SS3** Function Key (Blue) ESC O P Same as above. **SS3** Function Key (Red) ESC O Q Same as above. **SS3** Function Key (Gray) ESC O R Same as above. # THE FUNCTIONS OF A COMPUTER This section of the Manual introduces certain basic computer concepts. It provides background information and definitions which will be useful. # A TYPICAL COMPUTER SYSTEM A typical digital computer consists of: - a) A central processor unit (CPU) - b) A memory - c) Input/output (I/O) ports The memory serves as a place to store **instructions**, the coded information that directs the activities of the CPU, and **data**, the coded information processed by the CPU. A group of logically related instructions stored in memory is referred to as a **program**. The CPU "reads" each instruction from memory in a logically determined sequence, and uses it to initiate processing actions. If the program sequence is coherent and logical, processing the program produces intelligible and useful results. The memory is also used to store the data to be manipulated, as well as the instructions that direct manipulation. The program must be organized such that the CPU does not read a non-instruction word when it expects to see an instruction. The CPU can rapidly access data stored in memory, but often the memory is not large enough to store the data required for a particular application. This problem can be resolved by providing the computer with one or more input ports. The CPU can address these ports and input the data contained there. The addition of input ports enables the computer to receive information from external equipment (such as a magnetic tape console or floppy disk) at high rates of speed and in large volumes. A computer also requires one or more **output ports** that permit the CPU to communicate the result of its processing to the outside world. The output may go to a display, for use by a human operator, to a peripheral device that produces "hard copy," such as a line printer, to a peripheral storage device, such as a floppy disk unit, or the output may constitute process control signals that direct the operations of another system, such as an automated assembly line. Like input ports, output ports are addressable. The input and output ports together permit the processor to communicate with the outside world. The CPU unifies the system. It controls the functions performed by the other components. The CPU fetches instructions from memory, decodes their binary contents and executes them. It also references memory and I/O ports as necessary in the execution of instructions. In addition, the CPU recognizes and responds to certain external control signals, such as interrupt and wait requests. The functional units within a CPU that enable it to perform these functions are described below. ### CPU ARCHITECTURE A typical central processor unit (CPU) consists of the following interconnected functional units: - Registers - Arithmetic/Logic Unit (ALU) - Control Circuitry Registers are temporary storage units within the CPU. Some registers, such as the program counter and instruction register, have dedicated uses. Other registers, such as the accumulator, are for general-purpose use. #### Accumulator The accumulator usually stores one of the operands to be manipulated by the ALU. A typical instruction might direct the ALU to add the contents of some other register to the contents of the accumulator and store the result in the accumulator itself. In general, the accumulator is both a source (operand) and a destination (result) register. Often a CPU includes a number of additional general purpose registers used to store operands or intermediate data. The availability of general-purpose registers eliminates the need to "shuffle" intermediate results back and forth between memory and the accumulator, thus improving processing speed and efficiency. # Program Counter (Jumps, Subroutines and the Stack) The instructions that make up a program are stored in the system's memory. The central processor references the contents of memory in order to determine what action is appropriate. This means the processor must know which location contains the next instruction. Each of the locations in memory is numbered to distinguish it from all other locations in memory. The number that identifies a memory location is called its address. The processor maintains a counter that contains the address of the next program instruction. This register is called the **program counter**. The processor updates the program counter by adding "1" to the counter each time it fetches an instruction. Therefore, the program counter is always current (pointing to the next instruction). The programmer therefore stores his instructions in numerically adjacent addresses, so the lower addresses contain the first instructions to be executed and the higher addresses contain later instructions. The only time the programmer may violate this sequential rule is when an instruction in one section of memory is a **jump** instruction to another section of memory. A jump instruction contains the address of the instruction which is to follow it. The next instruction may be stored in any memory location, as long as the programmed jump specifies the correct address. During the execution of a jump instruction, the processor replaces the contents of its program counter with the address embodied in the instruction. Thus, the logical continuity of the program is maintained. A special kind of program jump occurs when the stored program "calls" a subroutine. In this kind of jump, the processor is required to "remember" the contents of the program counter at the time the call occurs. This enables the processor to resume execution of the main program when it is finished with the last instruction of the subroutine. A subroutine is a program within a program. Usually it is a general-purpose set of instructions that must be executed repeatedly in the course of a main program. Routines which calculate the square, the sine, or the logarithm of a program variable are good examples of functions often written as subroutines. Other exam- ples are programs designed for inputting or outputting data to a particular peripheral device. The processor has a special way of handling subroutines, in order to insure an orderly return to the main program. When the processor receives a call instruction, it increments the program counter and stores the counter's contents in a reserved memory area known as the **stack**. The stack thus saves the address of the instruction to be executed after the subroutine is completed. Then the processor loads the address specified in the call into its program counter. The next instruction fetched is therefore the first step of the subroutine. The last instruction in any subroutine is a **return**. Such an instruction need specify no address. When the processor fetches a return instruction, it simply replaces the current contents of the program counter with the address on the top of the stack. This causes the processor to resume execution of the program at the point immediately following the original call instruction. Subroutines are often **nested**; that is, one subroutine will sometimes call a second subroutine. The second may call a third, and so on. This is perfectly acceptable, as long as the processor has enough capacity to store the necessary return addresses, and the logical provision for doing so. In other words, the maximum depth of nesting is determined by the depth of the stack itself. If the stack has space for storing three return addresses, then three levels of subroutine nesting may be accommodated. Processors have different ways of maintaining stacks. Some have facilities for the storage of return addresses built into the processor itself. Other processors use a reserved area of external memory as the stack and simply maintain a pointer register which contains the address of the most recent stack entry. The external stack allows virtually unlimited subroutine nesting. In addition, if the processor provides instructions that cause the contents of the accumulator and other general-purpose registers to be "pushed" onto the stack or "popped" off the stack via the address stored in the stack pointer, multi-level interrupt processing (described later in this section) is possible. The status of the processor (for example, the contents of all the registers) can be saved in the stack when an interrupt is accepted and then restored after the interrupt has been serviced. This ability to save the processor's status at any given time is possible even if an interrupt service routine, itself, is interrupted. the entire instruction is present in the CPU, the program counter is incremented (in preparation for the next instruction fetch) and the instruction is decoded. The operation specified in the instruction will be executed in the remaining states of the instruction cycle. The instruction may call for a memory read or write, an input or output and/or internal CPU operation, such as a register-to-register transfer or an addregisters operation. # Memory Read An instruction **fetch** is merely a special memory read operation that brings the instruction to the CPU's instruction that brings the instruction fetched may then call for data to be read from memory into the CPU. The memory again issues a read signal and sends the proper memory address; memory responds by returning the requested word. The data received is placed in the accumulator or one of the other general-purpose registers (not the instruction register). # Memory Write A memory write operation is similar to a read except for the direction of data flow. The CPU issues a write signal, sends the proper memory address, then sends the data word to be written into the addressed memory location. # **JisW** As previously stated, the activities of the processor are timed by a master clock oscillator. The clock period determines the timing of all processing activity. The speed of the processing cycle is limited by the memory's access time. Once the processor has sent a read address to memory, it cannot proceed until the memory has had time to respond. Most memories are capable of responding much faster than the processing cycle requires. A few, however, cannot supply the addressed byte within the minimum time established by the processor's clock. Therefore, a processor contains a synchronization provision, which permits the memory to request a wait state. When the memory receives a read or write enable signal, it places a request signal on the processor's READY line, causing the CPU to idle temporarily. After the memory has had time to respond, it frees the processor's READY line, and the instruction cycle proceeds. # Control Circuitry memory or I/O port is ready with the data. CPU. The control circuitry will idle the CPU until the memory or I/O element that operates slower than the main program. A wait request is often issued by a interrupting device, then automatically return to the execution, jump to a special routine to service the circuitry to temporarily interrupt main program wait request. An interrupt request causes the control sponding to external signals, such as an interrupt or action. Often the control circuitry is capable of renal to the CPU) for initiating the proper processing appropriate signals (to units both internal and exterfetched and decoded, the control circuitry issues the quired for any processing task. After an instruction is cuitry maintains the proper sequence of events rewithin a CPU. Using clock inputs, the control cir-The control circuitry is the primary functional unit # COMPUTER OPERATIONS There are certain operations basic to almost any computer. A sound understanding of these basic operations is a necessary prerequisite to examining the specific operations of a particular computer. # gnimiT The activities of the central processor are cyclical. The processor fetches an instruction, performs the operations required, fetches the next instruction, and so on. This orderly sequence of events requires precise timing, and the CPU therefore requires a free-truning oscillator clock that furnishes the reference execution of a single instruction is referred to as an instruction cycle. The portion of a cycle identified with a clearly defined activity is called a state. And the interval between pulses of the timing oscillator is referred to as a clock period. As a general rule, one or not eclock periods are necessary for the completion more clock periods are necessary for the completion of a state, and there are several states in a cycle. # Instruction Fetch The first state(s) of any instruction cycle is dedicated to fetching the next instruction. The CPU issues a read signal and the contents of the program counter are sent to memory, which responds by returning the next instruction word. The first byte of the instruction is placed in the instruction register. If the instruction consists of more than one byte, additional states are consists of more than one byte, additional states are required to fetch each byte of the instruction. When identifies the operation to be performed, but cannot specify the object address as well. In a case like this, a two- or three-byte instruction must be used. Successive instruction bytes are stored in sequentially adjacent memory locations, and the processor performs instruction. The first byte retrieved from memory is placed in the processor's instruction register, and subsequent bytes are placed in temporary storage; the processor then proceeds with the execution phase. Buch an instruction is referred to as variable length. # Address Register(s) A CPU may use a register or register pair to hold the address of a memory location to be accessed for data. If the address register is **programmable**, (for example, if there are instructions that allow the programmer to alter the contents of the register) the program can "build" an address in the address register prior to executing a **memory reference** instruction (for example, an instruction that reads data from memory, ple, an instruction that reads data stored in writes data to memory, or operates on data stored in memory). # Arithmetic/Logic Unit (ALU) All processors contain an arithmetic/logic unit, often referred to simply as the ALU. The ALU, as its name implies, is that portion of the CPU hardware which performs the arithmetic and logical operations on the binary data. The ALU must contain an **adder** capable of combining the contents of two registers in accordance with the logic of binary arithmetic. This provision permits the processor to perform arithmetic manipulations on the data it obtains from memory and from its other inputs. Using only the basic adder, a capable programmer can write routines which will subtract, multiply and divide, giving the machine complete arithmetic capabilities. In practice, however, most ALU's provide other built-in functions, including hardware subtraction, Boolean logic operations, and shift capabilities. The ALU contains **flag bits** which specify certain conditions that arise in arithmetic and logical manipulations. Flags typically include **carry**, **zero**, **sign**, and **parity**. It is possible to program jumps which are conditionally dependent on the status of one or more flags. Thus, for example, the program may be designed to jump to a special routine if the carry bit is set signed to jump to a special routine if the carry bit is set following an addition instruction. # Instruction Register and Decoder tic 8-bit field is often referred to as a byte. eight bits: 16 bits, 24 bits, and so on. This characterisnumbers, or as numbers that are integral multiples of instructions are stored in memory as 8-bit binary bits in each addressable memory location. Data and such a processor is therefore organized to store eight 8-bit binary fields, and the memory associated with processor generally finds it most efficient to deal with to as an 8-bit parallel processor. An 8-bit parallel characteristic word length of eight bits and is referred s sad noitsmroini do stid this arster bas a store example, a computer whose registers and buses can and interconnecting paths (referred to as buses); for determined by the size of its internal storage elements that machine. A computer's word length is usually Every computer has a word length characteristic of Each operation the processor can perform is identified by a unique byte of data known as an instruction code or operation code. An 8-bit word used as an instruction code can distinguish between 256 alternative actions, more than adequate for most processors. The processor fetches an instruction in two distinct operations. First, the processor transmits the address in its program counter to the memory. Then the memory returns the addressed byte to the processor. The CPU stores this instruction byte in the instruction register, and uses it to direct activities during the remainder of the instruction execution. The mechanism by which the processor translates an instruction code into specific processing actions requires a more elaborate explanation than is given here. The concept, however, should be intuitively clear to any logic designer. The eight bits stored in the instruction register can be decoded and used to selectively activate one of a number of output lines, in this activities associated with execution of a particular activities associated with execution of a particular instruction code. The enabled line can be combined instruction code. The enabled line can be combined and that can then be used to initiate specific actions. This translation of code into action is performed by This translation of code into action is performed by the instruction decoder and the associated control instruction decoder and the associated control the instruction decoder and the associated control An 8-bit instruction code is often sufficient to specify a particular processing action. There are times, however, when execution of the instruction requires more information than eight bits can convey. circuitry. One example of this is when the instruction references a memory location. The basic instruction code # Input/Output Input and Output operations are similar to memory read and write operations with the exception that a peripheral I/O device is addressed instead of a memory location. The CPU issues the appropriate input or output control signal, sends the proper device address, and either receives the data being input or sends the data to be output. Data can be input/output in either parallel or serial form. All data within a digital computer is represented in binary coded form. A binary data word consists of a group of bits; each bit is either a one or a zero. Serial I/O consists of transferring one bit at a time on a single line. Naturally, serial I/O is much slower, but it requires considerably less hardware than does parallel I/O. # **Interrupts** **Interrupt** provisions are included on many central processors as a means of improving the processor's efficiency. Consider the case of a computer proces- sing a large volume of data, portions of which are to be output to a printer. The CPU can output a byte of data within a single machine cycle but it may take the printer the equivalent of many machine cycles to actually print the character specified by the data byte. The CPU could then remain idle, waiting until the printer can accept the next data byte. If an interrupt capability is implemented on the computer, the CPU can output a data byte, then return to data processing. When the printer is ready to accept the next data byte, it can request an interrupt. When the CPU acknowledges the interrupt, it suspends main program execution and automatically branches to a routine that will output the next data byte. After the byte is output, the CPU continues with main program execution. Note that this is, in principle, quite similar to a subroutine call, except the jump is initiated externally rather than by the program. More complex interrupt structures are possible in which several interrupting devices share the same processor but have different priority levels. Interruptive processing is an important feature that enables maximum utilization of a processor's capacity for high system throughput. # **INSTRUCTION SET** A computer, no matter how sophisticated, can only do what it is "told" to do. A computer is told what to do via a series of coded instructions referred to as a **program**. The realm of the programmer is referred to as **software**, in contrast to the **hardware** that comprises the actual computer equipment. A computer's software refers to all of the programs that have been written for that computer. When a computer is designed, the engineers provide the Central Processing Unit (CPU) with the ability to perform a particular set of operations. The CPU is designed such that a specific operation is performed when the CPU control logic decodes a particular instruction. Consequently, the operations that can be performed by a CPU define the computer's **instruction set**. Each computer instruction allows the programmer to initiate the performance of a specific operation. All computers implement certain arithmetic operations in their instruction set, such as an instruction to add the contents of two registers. Often logical operations (for example, OR the contents of two registers) and register operate instructions (for example, increment a register) are included in the instruction set. A computer's instruction set also has instructions that move data between registers, between a register and memory, and between a register and an I/O device. Most instruction sets also provide conditional instructions. A conditional instruction specifies an operation to be performed only if certain conditions have been met; for example, jump to a particular instruction if the result of the last operation was zero. Conditional instructions provide a program with a decision-making capability. By logically organizing a sequence of instructions into a coherent program, the programmer can "tell" the computer to perform a very specific and useful function. The computer, however, can only execute programs whose instructions are in a binary coded form (for example, a series of 1's and 0's), that is called **machine code**. Because it would be extremely cumbersome to program in machine code, programming languages have been developed. There are programs available which convert the programming language instructions into machine code that can be interpreted by the processor. One type of programming language is assembly language. A unique assembly language mnemonic is assigned to each of the computer's instructions. The programmer can write a program (called the source program) using these mnemonics and certain operands; the source program is then converted into machine instructions (called the object code). Each assembly language instruction is converted into one machine code instruction (1 or more bytes) by an assembler program. Assembly languages are usually machine dependent (for example, they are usually able to run on only one type of computer). O ERRORS DETECTED 15842 BYTES FREE #### THE 8080 INSTRUCTION SET This computer uses a Z80 microprocessor, which provides a great deal of flexibility in programming for you the user. However, Zenith Data Systems has chosen to support the more popular (and more familiar to most) instruction set of the 8080A. Therefore, when you use the ZDS assemblers, the documentation shows execution times and CPU responses for the 8080A rather than the Z80. Since some routines are time dependent, knowing the execution time for each instruction is essential. Also, when doing some sort of arithmetic operation, the conditions which affect the setting of the CPU flags must be known. To help you find the necessary information about each instruction, a cross reference from 8080A to Z80 mnemonics is shown below. From this, you can refer to the following Z80 section of the Manual. Even though the standard assemblers provided with ZDS products will not accept the Z80 mnemonics, you may use the DB and DW pseudos to take advantage of any Z80 instructions you may wish to use. An example using the DB pseudo is shown below. | | | | 1<br>2<br>3<br>4<br>5 | ** | Z80 IN | | EFINE BYTE (DB) STATEMENT FOR USING<br>H ARE NOT SUPPORTED BY THE HEATH | |--------------|-------|---------|-----------------------|-------|--------|-------------|-------------------------------------------------------------------------| | 000.355 | | | 6 | LDIR1 | EQU | 11101101B | Z80 LDIR INSTRUCTION BYTE 1 | | 000.260 | | | 7<br>8<br>9 | LDIR2 | EQU | 10110000B | Z80 LDIR INSTRUCTION BYTE 2 | | | | | 10 | | | | | | 000.000 | | | 11<br>12 | | ORG | 0 | | | 000.000 | 041 | 000 100 | 13 | | LXI | H, BUFF1 | COPY FROM BUFFER #1 | | 000.003 | 021 0 | 000 104 | 14 | | LXI | D.BUFF2 | TO BUFFER #2 | | 000.006 | 001 0 | 000 004 | 15<br>16 | | LXI | B,1024 | BUFFER LENGTH IS 1K | | | | | 17 | * | LDIR | | EVECUTE LINE CORV | | 000.011 | 355 2 | 260 | 18 | • | DB | LDIR1,LDIR2 | EXECUTE LDIR COPY | | | - | | 19 | | 2.2. | CDIRITEDIA. | | | | | | 20 | | | | | | | | | 21 | | | | | | | | | 22 | ** | RAM | | | | | | | 23 | ** | KHII | | | | 100.000 | | | 24 | | ORG | 100000A | | | | | | 25 | | ONO | 10000H | | | 100.000 | | | 26 | BUFF1 | DS | 1024 | | | 104.000 | | | 27 | BUFF2 | DS | 1024 | | | | | | 28 | | | | | | 110.000 | | | 29 | | END | | | | ASSEMBLY COM | | | | | | | | | 29 STATEM | ENTS | | | | | | | The 8080 instruction set includes five different types of instructions: - Data Transfer Group move data between registers or between memory and registers. - Arithmetic Group add, subtract, increment, or decrement data in registers or in memory. - Logical Group AND, OR, EXCLUSIVE-OR, compare, rotate, or complement data in registers or in memory. - Branch Group conditional and unconditional jump instructions, subroutine call instructions, and return instructions. • Stack, I/O, and Machine Control Group — includes I/O instructions, as well as instructions for maintaining the stack and internal control flags. # **Instruction and Data Formats** Memory for the 8080 is organized into 8-bit quantities called bytes. Each byte has a unique 16-bit binary address corresponding to its sequential position in memory. The 8080 can directly address up to 65,536 bytes of memory, which may consist of both read-only memory (ROM) elements and random-access memory (RAM) elements (read/write memory). | 8080<br>Mnemonic | Z-80<br>Mnemonic | 8080<br>Mnemonic | Z-80<br>Mnemonic | 8080<br>Mnemonic | Z-80<br>Mnemonic | |------------------|------------------|------------------|-----------------------|------------------|------------------| | ACI | ADC A,N | IN | IN A <sub>i</sub> (N) | POP H | POP HL | | ADC M | ADC A,(HL) | INR M | INC (HL) | POP PSW | POP AF | | ADC r | ADC A,R | INR r | INC R | PUSH B | PUSH BC | | ADD M | ADD A.(HL) | INX B | INC BC | PUSH D | PUSH DE | | ADD r | ADD A,R | INX D | INC DE | PUSH H | PUSH HL | | ADI ' | ADD A,N | INX H | INC HL | PUSH PSW | PUSH AF | | ANA M | AND (HL) | INX SP | INC SP | RAL | RLA | | ANA r | AND R | JC | JP C,NN | RAR | RRA | | ANI | AND N | JW | JP M,NN | RC | RET C | | CALL | CALL NN | JMP | JP NN | RET | RET | | cc | CALL C.NN | JNC | JP NC,NN | RLC | RLCA | | ČM | CALL MANN | JNZ | JP NZ,NN | RM | RET M | | CMA | CPL | JP | JP P,NN | RNC | RET NC | | CMC | CCF | JPE | JP PE,NN | RNZ | RET NZ | | CMP M | CP (HL) | JPO | JP PO.NN | RP | RET P | | CMP r | CP R | JZ | JP Z.NN | RPE | RET PE | | CNC | CALL NC.NN | LDA | LD A.(NN) | RPO | RET PO | | CNZ | CALL NZ,NN | LDAX B | LD A,(BC) | RRC | RRCA | | CP | CALL P.NN | LDAX D | LD A,(DE) | RST | RST P | | CP E | CALL PE,NN | LHLD | LD HL,(NN) | RZ | RET Z | | CPI | CP N | LXI B | LD BC,NN | SBB M | SBC A,(HL) | | CPO | CALL PO,NN | LXID | LD DE,NN | SBB r | SBC A,R | | cz | CALL Z,NN | LXIH | LD HL,NN | SBI | SBC A,N | | DAA | DAA | LXI SP | LD SP,NN | SHLD | LD (NN),HL | | DAD B | ADD HL.BC | MVI M | LD (HL),N | SPHL | LD SP,HL | | DAD D | ADD HL,DE | MVI r | LD R.N | STA | LD (NN),A | | DAD H | ADD HL,HL | MOV M.r | LD (HL),R | STAX B | LD (BC),A | | DAD SP | ADD HL,SP | MOV r.M | LD R,(HL) | STAX D | LD (DE),A | | DCR M | DEC (HL) | MOV r1,r2 | LD R.R' | STC | SCF | | DCR r | DEC R | NOP | NOP | SUB M | SUB (HL) | | DCX B | DEC BC | ORA M | OR (HL) | SUB r | SUB R | | DCX D | DEC DE | ORA r | OR R | SUI | SUB N | | DCX H | DEC HL | ORI | OR N | XCHG | EX DE,HL | | DCX SP | DEC SP | OUT | OUT (N),A | XRA M | XOR (HL) | | DI | DI | PCHL | JP (HL) | XRA r | XOR R | | EI | FI | POP B | POP BC | XRI | XOR N | | HLT | HALT | POP D | POP DE | XTHL | EX (SP),HL | Data in the 8080 is stored in the form of 8-bit binary integers: When a register or data word contains a binary number, it is necessary to establish the order in which the bits of the number are written. In the 8080, BIT 0 is referred to as the **Least Significant Bit (LSB)**, and BIT 7 (of an 8-bit number) is referred to as the **Most Significant Bit (MSB)**. The 8080 program instructions may be one, two, or three bytes in length. Multiple byte instructions must be stored in successive memory locations; the address of the first byte is always used as the address of the instructions. The exact instruction format will depend on the particular operation to be executed. # Addressing Modes Often the data to be operated on is stored in memory. When multi-byte numeric data is used, the data, like instructions, is stored in successive memory locations, with the least significant byte first, followed by increasingly significant bytes. The 8080 has four different modes for addressing data stored in memory or in registers: - Direct Bytes 2 and 3 of the instruction contain the exact memory address of the data item (the low-order bits of the address are in byte 2, the high-order bits in byte 3). - Register The instruction specifies the register or register pair in which the data is located. - Register Indirect The instruction specifies a register pair which contains the memory address where the data is located (the high-order bits of the address are in the first register of the pair, the low-order bits in the second). - Immediate The instruction contains the data itself. This is either an 8-bit quantity or a 16-bit quantity (least significant byte first, most significant byte second). Unless directed by an interrupt or branch instruction, the execution of instructions proceeds through consecutively increasing memory locations. A branch instruction can specify the address of the next instruction to be executed in one of two ways: - Direct The branch instruction contains the address of the next instruction to be executed. (Except for the "RST" instruction, byte 2 contains the low-order address and byte 3 the high-order address.) - Register Indirect The branch instruction indicates a register pair which contains the address of the next instruction to be executed. (The high-order bits of the address are in the first register of the pair, the loworder bits in the second.) The RST instruction is a special 1-byte call instruction (usually used during interrupt sequences). RST includes a 3-bit field; program control is transferred to the instruction whose address is eight times the contents of this 3-bit field. # **Condition Flags** There are five condition flags associated with the execution of instructions on the 8080. They are Zero, Sign, Parity, Carry, and Auxiliary Carry, and are each represented by a 1-bit register in the CPU. A flag is "set" by forcing the bit to 1; "reset" by forcing the bit to 0. Unless indicated otherwise, when an instruction affects a flag, it affects it in the following manner. Zero: If the result of an instruction has the value 0, this flag is set; otherwise it is reset. Sign: If the most significant bit of the result of the operation has the value 1, this flag is set; otherwise it is reset. SP represents the 16-bit stack pointer The bit pattern designating one of the register pairs B, D, H, SP: register. | Parity: | If the modulo 2 sum of the bits of the result of the operation is 0 (for example, if | | DDD or SSS<br>BINARY | OCTAL | REGISTER NAME | |---------------------|--------------------------------------------------------------------------------------------------------------------------------------------|----|----------------------|-------------|-----------------------------------------| | | the result has even parity), this flag is set; | | 111 | 7 | A | | | otherwise it is reset (for example, if the | | 000 | 0 | В | | | result has odd parity). | | 001 | 1 | C | | | | | 010 | 2 | D | | Carry: | If the instruction resulted in a carry | | 011 | 3 | E | | | (from addition), or a borrow (from sub- | | 100 | 4 | Н | | | traction or a comparison) out of the | | 101 | 5 | L | | | high-order bit, this flag is set; otherwise it is reset. | rp | One of t | he register | pairs: | | Auxiliary<br>Carry: | If the instruction caused a carry out of bit 3 and into bit 4 of the resulting value, the auxiliary carry is set; | | the high | | C pair with B as ster and C as the | | | otherwise it is reset. This flag is affected by single precision additions, subtractions, increments, decrements, comparisons, and logical | | the high | | , E pair with D as<br>ster and E as the | | | operations, but is principally used with additions and increments preceding a DAA (Decimal Adjust Accumulator) instruction. | | the high | | , L pair with H as<br>ster and L as the | # **Symbols and Abbreviations** The following symbols and abbreviations are used in the subsequent description of the 8080 instructions: | the subsequen | t description of the 8080 instructions: | | | | |------------------|-------------------------------------------|------|--------------------------------------------|---------------------| | SYMBOLS | MEANING | | RP | REGISTER PAIR | | OTWIDOES | WIEMING. | | 00 | В-С | | accumulator | Register A | | 01 | D-E | | | Ü | | 10 | H-L | | addr | 16-bit address quantity | | 11 | SP | | | | | _, , , , , , | | | data | 8-bit data quantity | rh | The first (high-ord | , , | | data 16 | 16 hit data amantitu | | designated register | r pair. | | data 16 | 16-bit data quantity | rl | The second (low-o | rder) register of a | | byte 2 | The second byte of the instruction | •• | designated register | , 0 | | -, | | | | Γ. | | byte 3 | The third byte of the instruction | PC | 16-bit program cou | ınter register (PCH | | | | | and PCL are used | to refer to the | | port | 8-bit address of an I/O device | | high-order and lov | v-order 8-bits, | | 1 -2 | One of the negletons A. B. C. D. E. H. I. | | respectively). | | | r, r1, r2 | One of the registers A, B, C, D, E, H, L | O.D. | 40111 1 1 114 | : (CDII | | DDD, SSS | The bit pattern designating one of the | SP | 16-bit stack pointe<br>and SPL are used to | | | <i>DDD</i> , 000 | registers A, B, C, D, E, H, L | | high-order and lov | | | | (DDD = destination, SSS = source): | | respectively). | Volume of bits, | | | , | | p , . | | ŖΡ rm Bit m of the register r (bits are numbered 7 through 0 from left to right). # Z, S, P, The condition flags: CY, AC Zero, Sign, Parity, Carry, and Auxiliary Carry, respectively. - ( ) The contents of the memory location or registers enclosed in the parentheses. - ← "Is transferred to" - ↑ Logical AND - ★ Exclusive OR - V Inclusive OR - + Addition - Two's complement subtraction - \* Multiplication - ←→ "Is exchanged with" - The one's complement (e. g., $(\overline{A})$ ) - n The restart number 0 through 7 NNN The binary representation 000 through 111 for restart number 0 through 7 respectively. # **Description Format** The following pages provide a detailed description of the instruction set of the 8080. Each instruction is described in the following manner: - 1. The numbers above the mnemonic are the octal opcodes for the instruction. - 2. The assembler format, consisting of the instruction mnemonic and operand fields, is printed in **BOLDFACE** on the left side of the first line. - 3. The name of the instruction is enclosed in parentheses on the right side of the first line. - 4. The next line(s) contain a symbolic description of the operation of the instruction. - 5. This is followed by a narrative description of the operation of the instruction. - 6. The following line(s) contain the binary fields and patterns that comprise the machine instruction. - 7. The last four lines contain incidental information about the execution of the instruction. The number of machine cycles and states required to execute the instruction are listed first. If the instruction has two possible execution times, as in a conditional jump, both times will be listed, separated by a slash. Next, any significant data addressing modes are listed. The last line lists any of the five Flags that are affected by the execution of the instruction. # **Data Transfer Group** This group of instructions transfers data to and from registers and memory. Condition flags are not affected by any instruction in this group. 1 (0-5,7) (0-5,7) **MOV r1, r2** (Move Register) $(r1) \leftarrow (r2)$ The content of register r2 is moved to register r1. 1(0-7)6 **MOV r, M** (Move from memory) $(r) \leftarrow ((H) (L))$ The content of the memory location, whose address is in registers H and L, is moved to register r. Cycles: 2 States: 7 Addressing: reg. indirect Flags: none 16 (0-7) #### MOV M, r (Move to memory) $((H)(L)) \leftarrow (r)$ The content of register r is moved to the memory location whose address is in registers H and L. Cycles: 2 States: 7 reg. indirect Addressing: > Flags: none 0 (0-7)6 (Move Immediate) 0(0-7)6 MVI r. data $(r) \leftarrow (byte 2)$ The content of byte 2 of the instruction is moved to register r. Cvcles: States: Addressing: immediate > Flags: none 2 7 066 (Move to memory immediate) MVI M. data $((H)(L)) \leftarrow (byte 2)$ The content of byte 2 of the instruction is moved to the memory location whose address is in registers H and L. Cycles: 3 States: Addressing: immed./reg. indirect Flags: none | 001 | (B, C) | 041 | (H, L) | |-----|--------|-----|--------| | 021 | (D, E) | 061 | (S, P) | LXI rp, data 16 (Load register pair immediate) $(rh) \leftarrow (byte 3),$ $(rl) \leftarrow (byte 2)$ Byte 3 of the instruction is moved into the highorder register (rh) of the register pair rp. Byte 2 of the instruction is moved into the low-order register (rl) of the register pair rp. | 0 ( | 0 F | P | 0 | 0 | 0 | 1 | | | |-----------------|-----|---|---|---|---|---|--|--| | low-order data | | | | | | | | | | high-order data | | | | | | | | | Cycles: 3 States: 10 immediate Addressing: > Flags: none 072 LDA addr (Load Accumulator direct) $(A) \leftarrow ((byte 3) (byte 2))$ The content of the memory location, whose address is specified in byte 2 and byte 3 of the instruction, is moved to the accumulator. Cycles: States: 13 Addressing: direct > Flags: none 062 STA addr (Store Accumulator direct) ((byte 3) (byte 2)) $\leftarrow$ (A) The content of the accumulator is moved to the memory location whose address is specified in byte 2 and byte 3 of the instruction. Cycles: 4 13 States: direct Addressing: Flags: none LHLD addr (Load H and L direct) $(L) \leftarrow ((byte 3) (byte 2))$ (H) $\leftarrow$ ((byte 3) (byte 2) + 1) The content of the memory location, whose address is specified in byte 2 and byte 3 of the instruction, is moved to register L. The content of the memory location at the succeeding address is moved to register H. 5 Cycles: States: 16 Addressing: direct > Flags: none 042 (Store H and L direct) SHLD addr $((byte 3) (byte 2)) \leftarrow (L)$ ((byte 3) (byte 2) + 1) $\leftarrow$ (H) The content of register L is moved to the memory location whose address is specified in byte 2 and byte 3. The content of register H is moved to the succeeding memory location. Cycles: 5 States: 16 Addressing: direct > Flags: none 012 (B, C) 032 (D, E) LDAX rp (Load accumulator indirect) $(A) \leftarrow ((rp))$ The content of the memory location, whose address is in the register pair rp, is moved to register A. NOTE: Only register pairs rp = B (registers B) and C) or rp = D (registers D and E) may be specified. 2 Cycles: States: Addressing: reg. indirect Flags: none 002 (B, C) 022 (D, E) STAX rp (Store accumulator indirect) $((rp)) \leftarrow (A)$ The content of register A is moved to the memory location whose address is in the register pair rp. NOTE: Only register pairs rp = B (registers B and C) or rp = D (registers D and E) may be specified. Cycles: 7 States: Addressing: reg, indirect > none Flags: 2 353 **XCHG** (Exchange H and L with D and E) $(H) \leftrightarrow (D)$ $(L) \longleftrightarrow (E)$ The contents of registers H and L are exchanged with the contents of registers D and E. Cycles: States: Addressing: register Flags: none # **Arithmetic Group** This group of instructions performs arithmetic operations on data in registers and memory. Unless indicated otherwise, all instructions in this group affect the Zero, Sign, Parity, Carry, and Auxiliary Carry flags according to the standard rules. All subtraction operations are performed via two's complement arithmetic and set the carry flag to one to indicate a borrow and clear it to indicate no borrow. 20 (0-5,7) ADD r (Add Register) $(A) \leftarrow (A) + (r)$ The content of register r is added to the content of the accumulator. The result is placed in the accumulator. Cycles: 1 States: Addressing: register > Flags: Z,S,P,CY,AC ADD M (Add memory) $(A) \leftarrow (A) + ((H)(L))$ The content of the memory location whose address is contained in the H and L registers is added to the content of the accumulator. The result is placed in the accumulator. Cycles: 7 States: Addressing: reg. indirect Z,S,P,CY,AC Flags: 216 ADC M (Add memory with carry) $(A) \leftarrow (A) + ((H) (L)) + (CY)$ The content of the memory location whose address is contained in the H and L registers and the content of the CY flag are added to the content of the accumulator. The result is placed in the accumulator. Cycles: 2 States: 7 reg. indirect Addressing: Z,S,P,CY,AC Flags: 306 **ADI DATA** (Add immediate) $(A) \leftarrow (A) + (byte 2)$ The content of the second byte of the instruction is added to the content of the accumulator. The result is placed in the accumulator. Cycles: States: Addressing: immediate Flags: Z,S,P,CY,AC 316 **ACI** data (Add immediate with carry) $(A) \leftarrow (A) + (byte 2) + (CY)$ The content of the second byte of the instruction and the content of the CY flag are added to the content of the accumulator. The result is placed in the accumulator. 2 Cycles: States: 7 Addressing: immediate Z,S,P,CY,AC Flags: 21 (0-5,7) ADC r (Add Register with carry) $(A) \leftarrow (A) + (r) + (CY)$ The content of register r and the content of the carry bit are added to the content of the accumulator. The result is placed in the accumulator. Cycles: 1 States: Addressing: register Z,S,P,CY,AC Flags: 22 (0-5,7) SUB r (Subtract Register) $(A) \leftarrow (A) - (r)$ The content of register r is subtracted from the content of the accumulator. The result is placed in the accumulator. Cycles: 1 States: 4 Addressing: register > Flags: Z,S,P,CY,AC SUB M (Subtract memory) $(A) \leftarrow (A) - ((H)(L))$ The content of the memory location whose address is contained in the H and L registers is subtracted from the content of the accumulator. The result is placed in the accumulator. Cycles: States: 7 Addressing: reg. indirect Flags: Z,S,P,CY,AC 2 336 236 SBB M 326 (Subtract immediate) **SUI data** $(A) \leftarrow (A) - (byte 2)$ The content of the second byte of the instruction is subtracted from the content of the accumulator. The result is placed in the accumulator. 2 Cycles: States: 7 Addressing: immediate Flags: Z,S,P,CY,AC SBI data (Subtract immediate with borrow) $(A) \leftarrow (A) - (byte 2) - (CY)$ Cycles: States: Flags: Addressing: The contents of the second byte of the instruction and the contents of the CY flag are both subtracted from the content of the accumulator. The result is placed in the accumulator. (Subtract memory with borrow) The content of the memory location whose ad- dress is contained in the H and L registers and the content of the CY flag are both subtracted from the content of the accumulator. The result is 2 7 reg. indirect Z,S,P,CY,AC 0 $(A) \leftarrow (A) - ((H) (L)) - (CY)$ placed in the accumulator. 0 Cycles: 2 States: 7 Addressing: immediate Flags: Z,S,P,CY,AC 23 (0-5,7) SBB r (Subtract Register with borrow) $(A) \leftarrow (A) - (r) - (CY)$ The content of register r and the content of the CY flag are both subtracted from the content of the accumulator. The result is placed in the accumulator. Cycles: 1 States: Addressing: register > Flags: Z,S,P,CY,AC 0 (0-5,7)4 INR r (Increment Register) The content of register r is incremented by one. NOTE: All condition flags except CY are affected. Cycles: 1 5 States: Addressing: register Z,S,P,AC Flags: #### INR M (Increment memory) $((H)(L)) \leftarrow ((H)(L)) + 1$ The content of the memory location whose address is contained in the H and L registers is incremented by one. NOTE: All condition flags except CY are affected. Cycles: 3 States: 10 Addressing: req. indirect Z,S,P,AC Flags: 0 (0-5,7)5 # DCR r (Decrement Register) $(r) \leftarrow (r) - 1$ The content of register r is decremented by one. NOTE: All condition flags except CY are affected. Cycles: States: 5 Addressing: register Z,S,P,AC Flags: 065 #### DCR M (Decrement memory) $((H)(L)) \leftarrow ((H)(L)) - 1$ The content of the memory location whose address is contained in the H and L registers is decremented by one. NOTE: All condition flags except CY are affected. Cycles: 3 10 States: reg. indirect Addressing: Flags: Z,S,P,AC | 003 | (B,C) | 043 | (H,L) | |-----|-------|-----|-------| | _ | (D,E) | | (S,P) | #### INX rp (Increment register pair) $(rh) (rl) \leftarrow (rh) (rl) + 1$ The content of the register pair rp is incremented by one. NOTE: No condition flags are affected. 1 Cycles: 5 States: register Addressing: > Flags: none 013 (B,C)033 (D.E) #### (Decrement register pair) DCX rp $(rh) (rl) \leftarrow (rh) (rl) - 1$ The content of the register pair rp is decremented by one. NOTE: No condition flags are affected. Cycles: 5 States: Addressing: register > none Flags: (B,C)011 071 (S,P)(D,E) 031 (Add register pair to H and L) DAD rp $(H) (L) \leftarrow (H) (L) + (rh) (rl)$ The content of the register pair rp is added to the content of the register pair H and L. The result is placed in the register pair H and L. NOTE: Only the CY flag is affected. It is set if there is a carry out of the double precision add; otherwise it is reset. Cycles: 3 States: 10 Addressing: register > Flags: CY # DAA (Decimal Adjust Accumulator) The eight-bit number in the accumulator is adjusted to form two 4-bit Binary-Coded-Decimal digits by the following process: - 1. If the value of the least significant 4 bits of the accumulator is greater than 9, **or** if the AC flag is set, 6 is added to the accumulator. - 2. If the value of the most significant 4 bits of the accumulator is now greater than 9, or if the CY flag is set, 6 is added to the most significant 4 bits of the accumulator. NOTE: All flags are affected. Cycles: States: 4 Flags: Z,S,P,CY,AC # **Logical Group:** This group of instructions performs logical (Boolean) operations on data in registers and memory and on condition flags. Unless indicated otherwise, all instructions in this group affect the Zero, Sign, Parity, Auxiliary Carry, and Carry flags according to the standard rules. 24 (0-5,7) $(A) \leftarrow (A) \land (r)$ The content of register r is logically anded with the content of the accumulator. The result is placed in the accumulator. The CY flag is cleared. Cycles: 1 States: Addressing: register Flags: Z,S,P,CY,AC 246 # ANA M (AND memory) $(A) \leftarrow (A) \land ((H) (L))$ The contents of the memory location whose address is contained in the H and L registers is logically anded with the content of the accumulator. The result is placed in the accumulator. The CY flag is cleared. Cycles: 2 States: 7 Addressing: reg. indirect Flags: Z,S,P,CY,AC 346 # ANI data (AND immediate) $(A) \leftarrow (A) \land (byte 2)$ The content of the second byte of the instruction is logically anded with the content of the accumulator. The result is placed in the accumulator. The CY and AC flags are cleared. Cycles: 2 States: 7 Addressing: immediate Flags: Z,S,P,CY,AC 25 (0-5,7) # XRA r (Exclusive OR Register) $(A) \leftarrow (A) \forall (r)$ The content of register r is exclusive-OR'd with the content of the accumulator. The result is placed in the accumulator. The CY and AC flags are cleared. Cycles: 1 States: 4 Addressing: register Flags: Z,S,P,CY,AC #### XRA M (Exclusive OR Memory) $(A) \leftarrow (A) \leftrightarrow ((H) (L))$ The content of the memory location whose address is contained in the H and L registers is exclusive-OR'd with the content of the accumulator. The result is placed in the accumulator. The CY and AC flags are cleared. Cycles: States: Addressing: reg. indirect Z,S,P,CY,AC Flags: 2 266 ORA M (OR memory) $(A) \leftarrow (A) \lor ((H) (L))$ > The content of the memory location whose address is contained in the H and L registers is inclusive-OR'd with the content of the accumulator. The result is placed in the accumulator. The CY and AC flags are cleared. Cycles: 2 States: 7 Addressing: reg. indirect Flags: Z,S,P,CY,AC 356 #### XRI data (Exclusive OR immediate) $(A) \leftarrow (A) \lor (byte 2)$ The content of the second byte of the instruction is exclusive-OR'd with the content of the accumulator. The result is placed in the accumulator. The CY and AC flags are cleared. Cycles: 2 States: 7 Addressing: immediate Flags: Z,S,P,CY,AC 366 #### ORI data (OR Immediate) $(A) \leftarrow (A) \lor (byte 2)$ The content of the second byte of the instruction is inclusive-OR'd with the content of the accumulator. The result is placed in the accumulator. The CY and AC flags are cleared. Cycles: States: Addressing: immediate Z,S,P,CY,AC Flags: 26 (0-5,7) #### ORA r (OR Register) $(A) \leftarrow (A) \lor (r)$ The content of register r is inclusive-OR'd with the content of the accumulator. The result is placed in the accumulator. The CY and AC flags are cleared. Cycles: 1 States: Addressing: register Flags: Z,S,P,CY,AC 27 (0-5,7) #### CMP r (Compare Register) (A) - (r) The content of register r is subtracted from the accumulator. The accumulator remains unchanged. The condition flags are set as a result of the subtraction. The Z flag is set to 1 if (A) = (r). The CY flag is set to 1 if (A) < (r). Cycles: 1 States: Addressing: register > Flags: Z,S,P,CY,AC > > Œ. #### CMP M (Compare memory) (A) - ((H) (L)) The content of the memory location whose address is contained in the H and L registers is subtracted from the content of the accumulator. The accumulator remains unchanged. The condition flags are set as a result of the subtraction. The Z flag is set to 1 if (A) = ((H)(L)). The CY flag is set to 1 if (A) < ((H)(L)). Cycles: 2 States: 7 Addressing: reg. indirect Flags: Z,S,P,CY,AC 376 #### CPI data (Compare immediate) (A) - (byte 2) The content of the second byte of the instruction is subtracted from the content of the accumulator. The condition flags are set by the result of the subtraction. The Z flag is set to 1 if (A) = (byte 2). The CY flag is set to 1 if (A) < (byte 2)2). Cycles: 2 7 States: Addressing: immediate > Flags: Z,S,P,CY,AC 007 #### **RLC** (Rotate left) $$(A_{n+1}) \leftarrow (A_n); (A_0) \leftarrow (A_7)$$ $$(CY) \leftarrow (A_7)$$ The content of the accumulator is rotated left one position. The low-order bit and the CY flag are both set to the value shifted out of the high-order bit position. Only the CY flag is affected. 1 Cycles: States: > Flags: CY 017 **RRC** (Rotate right) $$(A_n) \leftarrow (A_{n-1}); (A_7) \leftarrow (A_0)$$ $$(CY) \leftarrow (A_0)$$ The content of the accumulator is rotated right one position. The high-order bit and the CY flag are both set to the value shifted out of the loworder bit position. Only the CY flag is affected. Cycles: States: 4 Flags: CY 027 #### RAL (Rotate left through carry) $$(A_{n+1}) \leftarrow (A_n); (CY) \leftarrow (A_7)$$ $$(A_0) \leftarrow (CY)$$ The content of the accumulator is rotated left one position through the CY flag. The low-order bit is set equal to the CY flag and the CY flag is set to the value shifted out of the high-order bit. Only the CY flag is affected. 037 #### RAR (Rotate right through carry) $$(A_n) \leftarrow (A_{n+1}); (CY) \leftarrow (A_0)$$ $$(A_7) \leftarrow (CY)$$ The content of the accumulator is rotated right one position through the CY flag. The high-order bit is set to the CY flag and the CY flag is set to the value shifted out of the low-order bit. Only the CY flag is affected. Cycles: 1 4 States: Flags: CY CMA (Complement accumulator) $(A) \leftarrow (A)$ The content of the accumulator is complemented (zero bits become 1, one bits become 0). No flags are affected. 077 **CMC** (Complement carry) $(CY) \leftarrow (\overline{CY})$ The CY flag is complemented. No other flags are affected. 067 STC (Set carry) $(CY) \leftarrow 1$ The CY flag is set to 1. No other flags are affected. # **Branch Group** This group of instructions alters normal sequential program flow. **Condition flags are not affected** by any instruction in this group. The two types of branch instructions are unconditional and conditional. Unconditional transfers simply perform the specified operation on register PC (the program counter). Conditional transfers examine the status of one of the four processor flags to determine if the specified branch is to be executed. The conditions that may be specified are as follows: | CONDITION | CCC | OCTAL | |----------------------------------|-----|-------| | NZ — not zero ( $Z = 0$ ) | 000 | 0 | | Z - zero(Z = 1) | 001 | 1 | | NC - no carry (CY = 0) | 010 | 2 | | C - carry(CY = 1) | 011 | 3 | | PO — parity odd (P = 0) | 100 | 4 | | PE — parity even $(P = 1)$ | 101 | 5 | | $P \longrightarrow plus (S = 0)$ | 110 | 6 | | M - minus (S = 1) | 111 | 7 | 303 JMP addr (Jump) $(PC) \leftarrow (byte 3) (byte 2)$ Control is transferred to the instruction whose address is specified in byte 3 and byte 2 of the current instruction. Cycles: 3 States: 10 Addressing: immediate Flags: none 3 (0-7)2 Jeondition addr (Condition jump) If (CCC), $(PC) \leftarrow (byte 3) (byte 2)$ If the specified condition is true, control is transferred to the instruction whose address is specified in byte 3 and byte 2 of the current instruction; otherwise, control continues sequentially. Cycles: 3 States: 10 Addressing: immediate Flags: none 315 CALL addr (Call) $((SP) - 1) \leftarrow (PCH)$ $((SP) - 2) \leftarrow (PCL)$ $(SP) \leftarrow (SP) - 2$ $(PC) \leftarrow (byte 3) (byte 2)$ The high-order eight bits of the next instruction address are moved to the memory location whose address is one less than the content of register SP. The low-order eight bits of the next instruction address are moved to the memory location whose address is two less than the content of register SP. The content of register SP is decremented by 2. Control is transferred to the instruction whose address is specified in byte 3 and byte 2 of the current instruction. Cycles: 5 States: 17 Addressing: immediate/reg. indirect Flags: none 3 (0-7) 4 Ccondition addr (Condition call) If (CCC), ((SP) - 1) $\leftarrow$ (PCH) ((SP) - 2) $\leftarrow$ (PCL) (SP) $\leftarrow$ (SP) - 2 (PC) $\leftarrow$ (byte 3) (byte 2) If the specified condition is true, the actions specified in the CALL instruction (see above) are performed; otherwise, control continues sequentially. Cycles: 3/5 States: 11/17 Addressing: immediate/reg. indirect Flags: none 311 **RET** (Return) (PCL) ← ((SP)); (PCH) ← ((SP) + 1); (SP) ← (SP) + 2; The content of the memory location whose address is specified in register SP is moved to the low-order eight bits of register PC. The content of the memory location whose address is one more than the content of register SP is moved to the high-order eight bits of register PC. The content of register SP is incremented by 2. Cycles: 3 States: 10 Addressing: reg. indirect Flags: none 3 (0-7) 0 Recondition (Conditional return) If (CCC), (PCL) $\leftarrow$ ((SP)) (PCH) $\leftarrow$ ((SP) + 1) (SP) $\leftarrow$ (SP) + 2 If the specified condition is true, the actions specified in the RET instruction (see above) are performed; otherwise, control continues sequentially. Cycles: 1/3 States: 5/11 Addressing: reg. indirect Flags: none 3 (0-7)7 **RST n** (Restart) ((SP) - 1) $\leftarrow$ (PCH) ((SP) - 2) $\leftarrow$ (PCL) (SP) $\leftarrow$ (SP) - 2 (PC) $\leftarrow$ 8 \* (NNN) The high-order eight bits of the next instruction address are moved to the memory location whose address is one less than the content of register SP. The low-order eight bits of the next instruction address are moved to the memory location whose address is two less than the content of register SP. The content of register SP is decremented by two. Control is transferred to the instruction whose address is eight times the content of NNN. Cycles: 3 States: 11 reg. indirect Addressing: Flags: Program Counter After Restart 351 (Jump H and L indirect — move H and L **PCHL** to PC) $$(PCH) \leftarrow (H)$$ $(PCL) \leftarrow (L)$ The content of register H is moved to the highorder eight bits of register PC. The content of register L is moved to the low-order eight bits of register PC. Cycles: 1 5 States: Addressing: register none Flags: # Stack, I/O, and Machine Control Group This group of instructions performs I/O, manipulates the Stack, and alters internal control flags. Unless otherwise specified, condition flags are not affected by any instructions in this group. PUSH rp (Push) $$((SP) - 1) \leftarrow (rh)$$ $$((SP) - 2) \leftarrow (rl)$$ $(SP) \leftarrow (SP) - 2$ $$(SP) \leftarrow (SP) - 2$$ The content of the high-order register of register pair rp is moved to the memory location whose address is one less than the content of register SP. The content of the low-order register of register pair rp is moved to the memory location whose address is two less than the content of register SP. The content of register SP is decremented by 2. NOTE: Register pair rp = SP may not be specified. 3 Cycles: 11 States: Addressing: reg. indirect > none Flags: 365 (Push processor status word) **PUSH PSW** $$((SP) - 1) \leftarrow (A)$$ $$((SP) - 2)_0 \leftarrow (CY), ((SP) - 2)_1 \leftarrow 1$$ $$((SP) - 2)_2 \leftarrow (P), ((SP) - 2)_3 \leftarrow 0$$ $$((SP) - 2)_4 \leftarrow (AC), ((SP) - 2)_5 \leftarrow 0$$ $$((SP) - 2)_6 \leftarrow (Z), ((SP) - 2)_7 \leftarrow (S)$$ $$(SP) \leftarrow (SP) - 2$$ The content of the accumulator is moved to the memory location whose address is one less than register SP. The contents of the condition flags are assembled into a processor status word and the word is moved to the memory location whose address is two less than the content of register SP. The content of register SP is decremented by 2. Cycles: 3 States: 11 Addressing: reg. indirect > none Flags: **FLAG WORD** | D <sub>7</sub> | | | | | | | | |----------------|---|---|----|---|---|---|----| | S | Z | 0 | AC | 0 | Р | 1 | CY | 301 (B,C) 321 (D,E) 341 (H,L) POP rp (Pop) (rl) $$\leftarrow$$ ((SP)) (rh) $\leftarrow$ ((SP) + 1) (SP) $\leftarrow$ (SP) + 2 The content of the memory location, whose address is specified by the content of register SP is moved to the low-order register of register pair rp. The content of the memory location whose address is one more than the content of register SP is moved to the high-order register of register pair rp. The content of register SP is incremented by 2. NOTE: Register pair rp = SP may not be specified. Cycles: 3 States: 10 Addressing: reg. indirect Flags: none 361 **POP PSW** (Pop processor status word) $(CY) \leftarrow ((SP))_0$ $(P) \leftarrow ((SP))_2$ $(AC) \leftarrow ((SP))_4$ $(Z) \leftarrow ((SP))_6$ $(S) \leftarrow ((SP))_7$ $(A) \leftarrow ((SP) + 1)$ $(SP) \leftarrow (SP) + 2$ The content of the memory location whose address is specified by the content of register SP is used to restore the condition flags. The content of the memory location whose address is one more than the content of register SP is moved to register A. The content of register SP is incremented by 2. Cycles: 3 States: 10 Addressing: reg. indirect Flags: Z,S,P,CY,AC 343 XTHL (Exchange stack top with H and L) $(L) \leftrightarrow ((SP))$ $(H) \leftrightarrow ((SP) + 1)$ The content of the L register is exchanged with the content of the memory location whose address is specified by the content of register SP. The content of the H register is exchanged with the content of the memory location whose address is one more than the content of register SP. Cycles: 5 States: 18 Addressing: reg. indirect Flags: none 371 **SPHL** (Move HL to SP) $(SP) \leftarrow (H) (L)$ The contents of registers H and L (16 bits) are moved to register SP. Cycles: 1 States: 5 Addressing: register Flags: none 333 IN port (Input) (A)←(data) The data placed on the eight-bit bi-directional data bus by the specified port is moved to the accumulator. Cycles: 3 States: 10 Addressing: direct Flags: none **OUT port** (Output) $(data) \leftarrow (A)$ The content of the accumulator is placed on the eight-bit bi-directional data bus for transmission to the specified port. Cycles: 3 States: 10 Addressing: direct Flags: none 373 EI (Enable interrupt) The interrupt system is enabled following the execution of the next instruction. Cycles: 1 States: 4 Flags: none 363 **DI** (Disable interrupt) The interrupt system is disabled immediately following the execution of the DI instruction. Cycles: 1 States: 4 Flags: none 166 HLT (Halt) The processor is stopped. The registers and flags are unaffected. Cycles: 1 States: 7 Flags: none 000 NOP (No op) No operation is performed. The registers and flags are unaffected. Cycles: 1 States: 4 Flags: none 6 8 # **DEMONSTRATION PROGRAMS** These BASIC programs demonstrate some of the Computer features. These include: - Erase Page - Direct Cursor Addressing - Graphics - Reverse Video - 25th Line If you are using the HDOS, you must first map for lower case output before the programs will work. To do this, first boot up your system. Then type: >SET TT: NOMLO # **DEMONSTRATION PROGRAM #1** This program draws a simple maze on the screen. NOTE: Notice the semicolon at the end of line 350. This prevents a Carriage Return and a Line Feed, and the cursor remains at its present location on the line. Normally this is acceptable. However, some BASIC languages count the number of characters sent to the Terminal and automatically insert their own Carriage Return and Line Feed. If this automatic CR & LF comes during a sucessive execution of line 350, the direct cursor addressing sequence is upset and the character is placed randomly on the screen. To prevent this, PRINT statement has been placed at line 440. This forces a CR & LF every ninth execution of line 350, thus preventing an automatic CR & LF. The semicolon at the end of line 350 and the PRINT statement at line 440 can both be eliminated. However, the cursor will return to the left side of the screen after each execution of line 350. This is also acceptable, but the cursor will jump back and forth between the left side and the center of the screen. 00010 REM Demonstration Program #1 00020 REM 00030 DIM R(8,18),0\$(6) 00040 REM Read Data 00050 FOR I=1 TO 6. 00060 READ Q\$(I) 00070 NEXT I ``` 00090 PRINT CHR$(27);CHR$(69) 00100 REM Print Message 00110 FOR I=1 TO 3 00120 PRINT Q#(I) 00130 NEXT I 00140 REM Print message on the bottom line 00150 PRINT CHR$(27);CHR$(89);CHR$(53);CHR$(43);Q$(6) 00160 REM Read Data 00170 FOR I=0 TO 8 00180 FOR J=0 TO 18 00190 READ R(I,J) 00200 MEXT J 00210 NEXT I 00220 REM Erase Bottom Line 00230 PRINT CHR#(27);CHR#(89);CHR#(53);CHR#(33);CHR#(27);CHR#(75) 00240 REM Enter Reverse Video Mode 00250 PRINT CHR#(27);CHR#(112); 00260 REM Print 'Start' 00270 PRINT CHR$(27);CHR$(89);CHR$(38);CHR$(46);Q$(4) 00280 REM Exit Reverse Video Mode 00290 PRINT CHR$(27);CHR$(113); 00300 REM Enter Graphics Mode 00310 PRINT CHR#(27);CHR#(70); 00320 I=5 00330 J=11 00340 REM Use Direct Cursor Addressing & Print 1 Graphic Character gg35g PRINT CHR$(27);CHR$(89);CHR$(41+I);CHR$(46+J);CHR$(R(I,J)); 00360 REM Randomly change the values of I & J 00370 I=I+5 00380 IF IK9 THEN 400 00390 I=I-9 00400 J=J+13 00410 IF JK19 THEN 430 00420 J=J-19 00430 IF I<>5 THEN 350 00440 PRINT 00450 IF J<>11 THEN 350 00460 REM Exit Graphics Mode ``` ``` 00470 PRINT CHR#(27);CHR#(71); 00480 REM Enter Reverse Video Mode 00490 PRINT CHR$(27);CHR$(112); 00500 REM Print 'Finish' 00510 PRINT CHR$(27);CHR$(89);CHR$(52);CHR$(59);Q$(5) 00520 REM Exit Reverse Video Mode 00530 PRINT CHR#(27);CHR#(113); 00540 REM Move the cursor to the bottom line 00550 PRINT CHR$(27);CHR$(89);CHR$(89);CHR$(33) 00560 END 00570 DATA "This program demonstrates the 'Erase Page', 'Graphics'," 00580 DATA "'Erase To End Of Lime', 'Reverse Video', and the 'Direct Cursor" 00590 DATA "Addressing" features of the ZDS Video Computer." 00600 DATA "Start" 00610 DATA "Finish" 00620 DATA "Hans on while I read the data list" 00630 DATA 102,97,100,101,115,97,115,97,97 00640 DATA 97,97,97,115,97,97,97,97,97,97 00650 DATA 118,32,116,102,100,118,115,100 00660 DATA 101,97,99,101,97,97,97,117,99,32,96 00670 DATA 96,32,117,97,115,100,118,98,99 00680 DATA 96,118,97,117,97,116,96,101,32,96 00690 DATA 118,97,97,100,118,99,101,99,101 00700 DATA 97,100,118,97,32,101,97,98,32,116 00710 DATA 96,102,100,101,100,96,96,101,115 00720 DATA 32,118,100,101,99,118,99,101,97,116 00730 DATA 96,101,99,96,32,96,96,118,97 00740 DATA 97,98,97,100,118,97,117,99,32,96 00750 DATA 96,32,96,101,115,97,117,99,118 00760 DATA 32,98,99,32,100,102,99,96,32,96 00770 DATA 96,32,101,97,116,101,115,97,98 00780 DATA 32,96,101,98,97,100,96,101,97,116 00790 DATA 101,97,97,97,117,97,97,117,97 00800 DATA 97,97,97,117,97,97,99,102,97,100 ``` ## **DEMONSTRATION PROGRAM #2** This program demonstrates the "25th line" and the "remember the cursor position" features. ``` 90010 REM "25th Line Demo Program" 00020 REM Enase Page 00030 PRINT CHR$(27); CHR$(69) 00040 PRINT "This program demonstrates the 'twenty-fifth line' feature." 00050 PPINT "In this demonstration, the 25th line is beind used as a label" 00060 PRINT "for the top row of special function keys. Reverse video" 00070 PRINT "is used to make the labels stand out better, and also to" 00080 PRINT "help avoid confusion with any normal text on the screen above" 00090 PRINT "this line. You may now run another program. Line 25 will stay" 00100 PRINT "as it is until it is changed or until this unit is RESET or" 00110 PRINT "turned off." 00120 REM Remember The Cursor Position 00130 PRINT CHR$(27); CHR$(106) 00140 REM Enable 25th Line 00150 PRINT CHR$(27); CHR$(120); CHR$(49) 00160 PEM Position Cursor At Start Of 25th Line 00170 PRINT CHR$(27); CHR$(89); CHR$(56); CHR$(32) 00180 PRINT 00190 PEM Enter Reverse Video Mode 00200 PRINT CHR$(27); CHR$(112); 00210 REM Print 25th Line 90220 PRINT "LINE f 1 f \mathbb{S} f4 f:5 ERASE"; 00230 PRINT " BLU GRY RESET BREAK"; RED 00240 REM Exit Reverse Video 00250 PRINT CHR$(27); CHR$(113) 00260 REM Set Cursor To Previously Saved Position 00270 PRINT CHR$(27); CHR$(107) 00280 PRINT : PRINT 99299 PRINT "These lines demonstrate the fremember cursor positionf feature." 00300 PRINT "First, the above paragraph was printed; next, the 25th line" 00310 PRINT "was printed; and then these lines were printed by remembering" 00320 PRINT "the proper cursor position." 00330 PRINT :PRINT 00340 END ``` ## **DEMONSTRATION PROGRAM #3** This program draws a reasonable facsimile of the American flag. ``` 100 REM 49-Star American Flas Prosram 110 PRINT CHR$(27);CHR$(120);CHR$(53); 120 S1$=" * * * * * * " 130 S2$=" * * * * * * " 140 E#=CHR#(155) 150 R1#=E#+"p" 160 R2$=E$+"q" 170 G1$=E$+"F" 180 G2$=E$+"G" 190 B$=G1$+"↑"+G2$ 200 P1$=" "+R1$+R2$ 210 P2$=P1$+G1$+"9 "+G2$ 220 FOR I=1 TO 45 230 L1$=L1$+"i" 240 L2*=L2*+" " 250 NEXT I 260 PRINT " "+B$ 270 PRINT " "+R1$+" "+B$+R2$ 280 FOR I=1 TO 7 290 PRINT P2#; 300 IF I-2*(INT(I/2))<>0 THEN 320 310 PRINT S2$+R1$+MID$(L2$,1,45-LEN(S2$))+R2$:GOTO 330 320 PRINT S1*+G1*+MID*(L1*,1,45-LEN(S1*))+G2* 330 NEXT I 340 FOR I≕8 TO 13 350 PRINT P2≸; 360 IF I-2*(INT(I/2))<>0 THEN 380 370 PRINT R1$+L2$+R2$:GOTO 390 380 PRINT G1$+L1$+G2$ 390 NEXT I 400 PRINT " "+R1$+" "+B$+R2$ 410 PRINT P2$ 420 FOR I=1 TO 6 430 PRINT P2$ 440 NEXT I 450 PRINT " "+G1$+"9999"+R1$+" "+R2$+"xxxx"+G2$; 460 LINE INPUT "";Z≸ 470 PRINT CHR$(27);"95"; 480 END ``` # Z80<sup>®</sup> CPU The following pages are reprinted by permission of Zilog, Inc. Copyright<sup>©</sup> 1977 by Zilog, Inc. All rights reserved. No part of this publication may be reproduced, stored in a retrieval system, or transmitted, in any form or by any means, electronic, mechanical, photocopying, recording, or otherwise, without the prior written permission of Zilog. Zilog assumes no responsibility for the use of any circuitry other than circuitry embodied in a Zilog product. No other circuit patent licenses are implied. TM: Z80 is a trademark of Zilog. Inc. | Chap | ter Page | |------|----------------------------------------------| | 1.0 | Introduction | | 2.0 | Z80-CPU Architecture | | 3.0 | Z80-CPU Pin Description | | 4.0 | CPU Timing | | 5.0 | Z80-CPU Instruction Set12-20 | | 6.0 | Flags | | 7.0 | Summary of OP Codes and Execution Times12-45 | | 8.0 | Interrupt Response | | 9.0 | Hardware Implementation Examples | | 10.0 | Software Implementation Examples | | 11.0 | Electrical Specifications | | 12 0 | 780-CPU Instruction Set Summary | #### 1.0 INTRODUCTION The term "microcomputer" has been used to describe virtually every type of small computing device designed within the last few years. This term has been applied to everything from simple "microprogrammed" controllers constructed out of TTL MSI up to low end minicomputers with a portion of the CPU constructed out of TTL LSI "bit slices." However, the major impact of the LSI technology within the last few years has been with MOS LSI. With this technology, it is possible to fabricate complete and very powerful computer systems with only a few MOS LSI components. The Zilog Z-80 family of components is a significant advancement in the state-of-the art of micro-computers. These components can be configured with any type of standard semiconductor memory to generate computer systems with an extremely wide range of capabilities. For example, as few as two LSI circuits and three standard TTL MSI packages can be combined to form a simple controller. With additional memory and I/O devices a computer can be constructed with capabilities that only a minicomputer could previously deliver. This wide range of computational power allows standard modules to be constructed by a user that can satisfy the requirements of an extremely wide range of applications. The major reason for MOS LSI domination of the microcomputer market is the low cost of these few LSI components. For example, MOS LSI microcomputers have already replaced TTL logic in such applications as terminal controllers, peripheral device controllers, traffic signal controllers, point of sale terminals, intelligent terminals and test systems. In fact the MOS LSI microcomputer is finding its way into almost every product that now uses electronics and it is even replacing many mechanical systems such as weight scales and automobile controls. The MOS LSI microcomputer market is already well established and new products using them are being developed at an extraordinary rate. The Zilog Z-80 component set has been designed to fit into this market through the following factors: - 1. The Z-80 is fully software compatible with the popular 8080A CPU offered from several sources. Existing designs can be easily converted to include the Z-80 as a superior alternative. - 2. The Z-80 component set is superior in both software and hardware capabilities to any other micro-computer system on the market. These capabilities provide the user with significantly lower hardware and software development costs while also allowing him to offer additional features in his system. - 3. For increased throughput the Z80A operating at a 4 MHZ clock rate offers the user significant speed advantages over competitive products. - 4. A complete product line including full software support with strong emphasis on high level languages and a disk-based development system with advanced real-time debug capabilities is offered to enable the user to easily develop new products. Microcomputer systems are extremely simple to construct using Z-80 components. Any such system consists of three parts: - 1. CPU (Central Processing Unit) - 2. Memory - 3. Interface Circuits to peripheral devices The CPU is the heart of the system. Its function is to obtain instructions from the memory and perform the desired operations. The memory is used to contain instructions and in most cases data that is to be processed. For example, a typical instruction sequence may be to read data from a specific peripheral device, store it in a location in memory, check the parity and write it out to another peripheral device. Note that the Zilog component set includes the CPU and various general purpose I/O device controllers, while a wide range of memory devices may be used from any source. Thus, all required components can be connected together in a very simple manner with virtually no other external logic. The user's effort then becomes primarily one of software development. That is, the user can concentrate on describing his problem and translating it into a series of instructions that can be loaded into the microcomputer memory. Zilog is dedicated to making this step of software generation as simple as possible. A good example of this is our assembly language in which a simple mnemonic is used to represent every instruction that the CPU can perform. This language is self documenting in such a way that from the mnemonic the user can understand exactly what the instruction is doing without constantly checking back to a complex cross listing. #### 2.0 Z-80 CPU ARCHITECTURE A block diagram of the internal architecture of the Z-80 CPU is shown in figure 2.0-1. The diagram shows all of the major elements in the CPU and it should be referred to throughout the following description. Z-80 CPU BLOCK DIAGRAM FIGURE 2.0-1 #### 2.1 CPU REGISTERS The Z-80 CPU contains 208 bits of R/W memory that are accessible to the programmer. Figure 2.0-2 illustrates how this memory is configured into eighteen 8-bit registers and four 16-bit registers. All Z-80 registers are implemented using static RAM. The registers include two sets of six general purpose registers that may be used individually as 8-bit registers or in pairs as 16-bit registers. There are also two sets of accumulator and flag registers. #### **Special Purpose Registers** - Program Counter (PC). The program counter holds the 16-bit address of the current instruction being fetched from memory. The PC is automatically incremented after its contents have been transferred to the address lines. When a program jump occurs the new value is automatically placed in the PC, overriding the incrementer. - 2. Stack Pointer (SP). The stack pointer holds the 16-bit address of the current top of a stack located anywhere in external system RAM memory. The external stack memory is organized as a last-in first-out (LIFO) file. Data can be pushed onto the stack from specific CPU registers or popped off of the stack into specific CPU registers through the execution of PUSH and POP instructions. The data popped from the stack is always the last data pushed onto it. The stack allows simple implementation of multiple level interrupts, unlimited subroutine nesting and simplification of many types of data manipulation. | MAIN RE | G SET | ALTERNAT | _ | | |---------------|------------|----------------|-------------|---------------------------| | ACCUMULATOR A | FLAGS<br>F | ACCUMULATOR A' | FLAGS<br>F' | | | В | С | B' | C, | 7) | | D | E | D' | E' | GENERAL PURPOSE REGISTERS | | н | L | H' | L' | | | | | | | | | INTERRUPT<br>VECTOR<br>I | MEMORY<br>REFRESH<br>R | ]) | | | | | | |--------------------------|------------------------|----|--|--|--|--|--| | INDEX REGISTE | SPECIAL | | | | | | | | INDEX REGISTE | INDEX REGISTER IY | | | | | | | | STACK POINTER | STACK POINTER SP | | | | | | | | PROGRAM COU | ]] | | | | | | | # Z-80 CPU REGISTER CONFIGURATION FIGURE 2.0-2 - 3. Two Index Registers (IX & IY). The two independent index registers hold a 16-bit base address that is used in indexed addressing modes. In this mode, an index register is used as a base to point to a region in memory from which data is to be stored or retrieved. An additional byte is included in indexed instructions to specify a displacement from this base. This displacement is specified as a two's complement signed integer. This mode of addressing greatly simplifies many types of programs, especially where tables of data are used. - 4. Interrupt Page Address Register (I). The Z-80 CPU can be operated in a mode where an indirect call to any memory location can be achieved in response to an interrupt. The I Register is used for this purpose to store the high order 8-bits of the indirect address while the interrupting device provides the lower 8-bits of the address. This feature allows interrupt routines to be dynamically located anywhere in memory with absolute minimal access time to the routine. - 5. Memory Refresh Register (R). The Z-80 CPU contains a memory refresh counter to enable dynamic memories to be used with the same ease as static memories. Seven bits of this 8 bit register are automatically incremented after each instruction fetch. The eighth bit will remain as programmed as the result of an LD R, A instruction. The data in the refresh counter is sent out on the lower portion of the address bus along with a refresh control signal while the CPU is decoding and executing the fetched instruction. This mode of refresh is totally transparent to the programmer and does not slow down the CPU operation. The programmer can load the R register for testing purposes, but this register is normally not used by the programmer. During refresh, the contents of the I register are placed on the upper 8 bits of the address bus. ## Accumulator and Flag Registers The CPU includes two independent 8-bit accumulators and associated 8-bit flag registers. The accumulator holds the results of 8-bit arithmetic or logical operations while the flag register indicates specific conditions for 8 or 16-bit operations, such as indicating whether or not the result of an operation is equal to zero. The programmer selects the accumulator and flag pair that he wishes to work with with a single exchange instruction so that he may easily work with either pair. ## General Purpose Registers There are two matched sets of general purpose registers, each set containing six 8-bit registers that may be used individually as 8-bit registers or as 16-bit register pairs by the programmer. One set is called BC, DE and HL while the complementary set is called BC', DE' and HL'. At any one time the programmer can select either set of registers to work with through a single exchange command for the entire set. In systems where fast interrupt response is required, one set of general purpose registers and an accumulator/flag register may be reserved for handling this very fast routine. Only a simple exchange commands need be executed to go between the routines. This greatly reduces interrupt service time by eliminating the requirement for saving and retrieving register contents in the external stack during interrupt or subroutine processing. These general purpose registers are used for a wide range of applications by the programmer. They also simplify programming, especially in ROM based systems where little external read/write memory is available. ## 2.2 ARITHMETIC & LOGIC UNIT (ALU) The 8-bit arithmetic and logical instructions of the CPU are executed in the ALU. Internally the ALU communicates with the registers and the external data bus on the internal data bus. The type of functions performed by the ALU include: Add Left or right shifts or rotates (arithmetic and logical) Subtract Increment Logical AND Decrement Logical OR Set bit Logical Exclusive OR Reset bit Compare Test bit ## 2.3 INSTRUCTION REGISTER AND CPU CONTROL As each instruction is fetched from memory, it is placed in the instruction register and decoded. The control sections performs this function and then generates and supplies all of the control signals necessary to read or write data from or to the registers, control the ALU and provide all required external control signals. #### 3.0 Z-80 CPU PIN DESCRIPTION The Z-80 CPU is packaged in an industry standard 40 pin Dual In-Line Package. The I/O pins are shown in figure 3.0-1 and the function of each is described below. A<sub>0</sub>-A<sub>15</sub> (Address Bus) Tri-state output, active high. $A_0$ - $A_{15}$ constitute a 16-bit address bus. The address bus provides the address for memory (up to 64K bytes) data exchanges and for I/O device data exchanges. I/O addressing uses the 8 lower address bits to allow the user to directly select up to 256 input or 256 output ports. $A_0$ is the least significant address bit. During refresh time, the lower 7 bits contain a valid refresh address. D<sub>0</sub>-D<sub>7</sub> (Data Bus) Tri-state input/output, active high. D<sub>0</sub>-D<sub>7</sub> constitute an 8-bit bidirectional data bus. The data bus is used for data exchanges with memory and I/O devices. M<sub>1</sub> (Machine Cycle one) Output, active low. $\overline{M}_1$ indicates that the current machine cycle is the OP code fetch cycle of an instruction execution. Note that during execution of 2-byte op-codes, $\overline{M}_1$ is generated as each op code byte is fetched. These two byte op-codes always begin with CBH, DDH, EDH or FDH. $\overline{M}_1$ also occurs with $\overline{10RQ}$ to indicate an interrupt acknowledge cycle. MREQ (Memory Request) Tri-state output, active low. The memory request signal indicates that the address bus holds a valid address for a memory read or memory write operation. **IORQ** (Input/Output Request) Tri-state output, active low. The $\overline{IORQ}$ signal indicates that the lower half of the address bus holds a valid I/O address for a I/O read or write operation. An $\overline{IORQ}$ signal is also generated with an $\overline{M1}$ signal when an interrupt is being acknowledged to indicate that an interrupt response vector can be placed on the data bus. Interrupt Acknowledge operations occur during $M_1$ time while I/O operations never occur during $M_1$ time. RD (Memory Read) Tri-state output, active low. 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. WR (Memory Write) Tri-state output, active low. WR indicates that the CPU data bus holds valid data to be stored in the addressed memory or I/O device. RFSH (Refresh) Output, active low. $\overline{RFSH}$ indicates that the lower 7 bits of the address bus contain a refresh address for dynamic memories and the current $\overline{MREQ}$ signal should be used to do a refresh read to all dynamic memories. HALT (Halt state) Output, active low. HALT indicates that the CPU has executed a HALT software 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 NOP's to maintain memory refresh activity. WAIT (Wait) Input, active low. WAIT indicates to the Z-80 CPU that the addressed memory or I/O devices are not ready for a data transfer. The CPU continues to enter wait states for as long as this signal is active. This signal allows memory or I/O devices of any speed to be synchronized to the CPU. INT (Interrupt Request) Input, active low. The Interrupt Request signal is generated by I/O devices. A request will be honored at the end of the current instruction if the internal software controlled interrupt enable flip-flop (IFF) is enabled and if the $\overline{BUSRQ}$ signal is not active. When the CPU accepts the interrupt, an acknowledge signal ( $\overline{IORQ}$ during $M_1$ time) is sent out at the beginning of the next instruction cycle. The CPU can respond to an interrupt in three different modes that are described in detail in section 5.4 (CPU Control Instructions). NMI (Non Maskable Interrupt) Input, negative edge triggered. The non maskable interrupt request line has a higher priority than $\overline{INT}$ and is always recognized at the end of the current instruction, independent of the status of the interrupt enable flip-flop. $\overline{NMI}$ automatically forces the Z-80 CPU to restart to location $0066_H$ . The program counter is automatically saved in the external stack so that the user can return to the program that was interrupted. Note that continuous WAIT cycles can prevent the current instruction from ending, and that a $\overline{BUSRQ}$ will override a $\overline{NMI}$ . ## RESET Input, active low. RESET forces the program counter to zero and initializes the CPU. The CPU initialization includes: - 1) Disable the interrupt enable flip-flop - 2) Set Register I = 00<sub>H</sub> - 3) Set Register R = 00<sub>H</sub> - 4) Set Interrupt Mode 0 During reset time, the address bus and data bus go to a high impedance state and all control output signals go to the inactive state. ## BUSRQ (Bus Request) Input, active low. The bus request signal is used to request the CPU address bus, data bus and tri-state output control signals to go to a high impedance state so that other devices can control these buses. When BUSRQ is activated, the CPU will set these buses to a high impedance state as soon as the current CPU machine cycle is terminated. ## BUSAK (Bus Acknowledge) Output, active low. Bus acknowledge is used to indicate to the requesting device that the CPU address bus, data bus and tri-state control bus signals have been set to their high impedance state and the external device can now control these signals. Single phase TTL level clock which requires only a 330 ohm pull-up resistor to +5 volts to meet all clock requirements. ## 4.0 CPU TIMING The Z-80 CPU executes instructions by stepping through a very precise set of a few basic operations. These include: Memory read or write I/O device read or write Interrupt acknowledge All instructions are merely a series of these basic operations. Each of these basic operations can take from three to six clock periods to complete or they can be lengthened to synchronize the CPU to the speed of external devices. The basic clock periods are referred to as T cycles and the basic operations are referred to as M (for machine) cycles. Figure 4.0-0 illustrates how a typical instruction will be merely a series of specific M and T cycles. Notice that this instruction consists of three machine cycles (M1, M2 and M3). The first machine cycle of any instruction is a fetch cycle which is four, five or six T cycles long (unless lengthened by the wait signal which will be fully described in the next section). The fetch cycle (M1) is used to fetch the OP code of the next instruction to be executed. Subsequent machine cycles move data between the CPU and memory or I/O devices and they may have anywhere from three to five T cycles (again they may be lengthened by wait states to synchronize the external devices to the CPU). The following paragraphs describe the timing which occurs within any of the basic machine cycles. In section 7, the exact timing for each instruction is specified. BASIC CPU TIMING EXAMPLE FIGURE 4.0-0 All CPU timing can be broken down into a few very simple timing diagrams as shown in figure 4.0-1 through 4.0-7. These diagrams show the following basic operations with and without wait states (wait states are added to synchronize the CPU to slow memory or I/O devices). - 4.0-1. Instruction OP code fetch (M1 cycle) - 4.0-2. Memory data read or write cycles - 4.0-3. I/O read or write cycles - 4.0-4. Bus Request/Acknowledge Cycle - 4.0-5. Interrupt Request/Acknowledge Cycle - 4.0-6. Non maskable Interrupt Request/Acknowledge Cycle - 4.0-7. Exit from a HALT instruction #### **INSTRUCTION FETCH** Figure 4.0-1 shows the timing during an M1 cycle (OP code fetch). Notice that the PC is placed on the address bus at the beginning of the M1 cycle. One half clock time later the $\overline{MREQ}$ signal goes active. At this time the address to the memory has had time to stabilize so that the falling edge of $\overline{MREQ}$ can be used directly as a chip enable clock to dynamic memories. The $\overline{RD}$ line also goes active to indicate that the memory read data should be enabled onto the CPU data bus. The CPU samples the data from the memory on the data bus with the rising edge of the clock of state T3 and this same edge is used by the CPU to turn off the $\overline{RD}$ and $\overline{MRQ}$ signals. Thus the data has already been sampled by the CPU before the $\overline{RD}$ signal becomes inactive. Clock state T3 and T4 of a fetch cycle are used to refresh dynamic memories. (The CPU uses this time to decode and execute the fetched instruction so that no other operation could be performed at this time). During T3 and T4 the lower 7 bits of the address bus contain a memory refresh address and the $\overline{RFSH}$ signal becomes active to indicate that a refresh read of all dynamic memories should be accomplished. Notice that a $\overline{RD}$ signal is not generated during refresh time to prevent data from different memory segments from being gated onto the data bus. The $\overline{MREQ}$ signal during refresh time should be used to perform a refresh read of all memory elements. The refresh signal can not be used by itself since the refresh address is only guaranteed to be stable during $\overline{MREQ}$ time. INSTRUCTION OP CODE FETCH FIGURE 4.0-1 Figure 4.0-1 A illustrates how the fetch cycle is delayed if the memory activates the WAIT line. During T2 and every subsequent Tw, the CPU samples the WAIT line with the falling edge of $\Phi$ . If the WAIT line is active at this time, another wait state will be entered during the following cycle. Using this technique the read cycle can be lengthened to match the access time of any type of memory device. INSTRUCTION OP CODE FETCH WITH WAIT STATES FIGURE 4.0-1A ## **MEMORY READ OR WRITE** Figure 4.0-2 illustrates the timing of memory read or write cycles other than an OP code fetch (M1 cycle). These cycles are generally three clock periods long unless wait states are requested by the memory via the $\overline{WAIT}$ signal. The $\overline{MREQ}$ signal and the $\overline{RD}$ signal are used the same as in the fetch cycle. In the case of a memory write cycle, the $\overline{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 data on the data bus is stable so that it can be used directly as a R/W pulse to virtually any type of semiconductor memory. Furthermore the $\overline{WR}$ signal goes inactive one half T state before the address and data bus contents are changed so that the overlap requirements for virtually any type of semiconductor memory type will be met. MEMORY READ OR WRITE CYCLES FIGURE 4.0-2 Figure 4.0-2A illustrates how a WAIT request signal will lengthen any memory read or write operation. This operation is identical to that previously described for a fetch cycle. Notice in this figure that a separate read and a separate write cycle are shown in the same figure although read and write cycles can never occur simultaneously. #### MEMORY READ OR WRITE CYCLES WITH WAIT STATES FIGURE 4.0-2A #### INPUT OR OUTPUT CYCLES Figure 4.0-3 illustrates an I/O read or I/O write operation. Notice that during I/O operations a single wait state is automatically inserted. The reason for this is that during I/O operations, the time from when the IORQ signal goes active until the CPU must sample the WAIT line is very short and without this extra state sufficient time does not exist for an I/O port to decode its address and activate the WAIT line if a wait is required. Also, without this wait state it is difficult to design MOS I/O devices that can operate at full CPU speed. During this wait state time the WAIT request signal is sampled. During a read I/O operation, the RD line is used to enable the addressed port onto the data bus just as in the case of a memory read. For I/O write operations, the WR line is used as a clock to the I/O port, again with sufficient overlap timing automatically provided so that the rising edge may be used as a data clock. Figure 4.0-3A illustrates how additional wait states may be added with the WAIT line. The operation is identical to that previously described. ### **BUS REQUEST/ACKNOWLEDGE CYCLE** Figure 4.0-4 illustrates the timing for a Bus Request/Acknowledge cycle. The BUSRQ signal is sampled by the CPU with the rising edge of the last clock period of any machine cycle. If the BUSRQ signal is active, the CPU will set its address, data and tri-state control signals to the high impedance state with the rising edge of the next clock pulse. At that time any external device can control the buses to transfer data between memory and I/O devices. (This is generally known as Direct Memory Access [DMA] using cycle stealing). The maximum time for the CPU to respond to a bus request is the length of a machine cycle and the external controller can maintain control of the bus for as many clock cycles as is desired. Note, however, that if very long DMA cycles are used, and dynamic memories are being used, the external controller must also perform the refresh function. This situation only occurs if very large blocks of data are transferred under DMA control. Also note that during a bus request cycle, the CPU cannot be interrupted by either a NMI or an INT signal. INPUT OR OUTPUT CYCLES FIGURE 4.0-3 INPUT OR OUTPUT CYCLES WITH WAIT STATES FIGURE 4.0-3A \* Automatically inserted WAIT state BUS REQUEST/ACKNOWLEDGE CYCLE FIGURE 4.0-4 ## INTERRUPT REQUEST/ACKNOWLEDGE CYCLE Figure 4.0-5 illustrates the timing associated with an interrupt cycle. The interrupt signal (INT) is sampled by the CPU with the rising edge of the last clock at the end of any instruction. The signal will not be accepted if the internal CPU software controlled interrupt enable flip-flop is not set or if the BUSRQ signal is active. When the signal is accepted a special M1 cycle is generated. During this special M1 cycle the IORQ signal becomes active (instead of the normal MREQ) to indicate that the interrupting device can place an 8-bit vector on the data bus. Notice that two wait states are automatically added to this cycle. These states are added so that a ripple priority interrupt scheme can be easily implemented. The two wait states allow sufficient time for the ripple signals to stabilize and identify which I/O device must insert the response vector. Refer to section 8.0 for details on how the interrupt response vector is utilized by the CPU. INTERRUPT REQUEST/ACKNOWLEDGE CYCLE FIGURE 4.0-5 Figures 4.0-5A and 4.0-5B illustrate how a programmable counter can be used to extend interrupt acknowledge time. (Configured as shown to add one wait state) EXTENDING INTERRUPT ACKNOWLEDGE TIME WITH WAIT STATE FIGURE 4.0-5A REQUEST/ACKNOWLEDGE CYCLE WITH ONE ADDITIONAL WAIT STATE FIGURE 4.0-5B #### NON MASKABLE INTERRUPT RESPONSE Figure 4.0-6 illustrates the request/acknowledge cycle for the non maskable interrupt. This signal is sampled at the same time as the interrupt line, but this line has priority over the normal interrupt and it can not be disabled under software control. Its usual function is to provide immediate response to important signals such as an impending power failure. The CPU response to a non maskable interrupt is similar to a normal memory read operation. The only difference being that the content of the data bus is ignored while the processor automatically stores the PC in the external stack and jumps to location 0066<sub>H</sub>. The service routine for the non maskable interrupt must begin at this location if this interrupt is used. #### **HALT EXIT** Whenever a software halt instruction is executed the CPU begins executing NOP's until an interrupt is received (either a non maskable or a maskable interrupt while the interrupt flip flop is enabled). The two interrupt lines are sampled with the rising clock edge during each T4 state as shown in figure 4.0-7. If a non maskable interrupt has been received or a maskable interrupt has been received and the interrupt enable flip-flop is set, then the halt state will be exited on the next rising clock edge. The following cycle will then be an interrupt acknowledge cycle corresponding to the type of interrupt that was received. If both are received at this time, then the non maskable one will be acknowledged since it has highest priority. The purpose of executing NOP instructions while in the halt state is to keep the memory refresh signals active. Each cycle in the halt state is a normal M1 (fetch) cycle except that the data received from the memory is ignored and a NOP instruction is forced internally to the CPU. The halt acknowledge signal is active during this time to indicate that the processor is in the halt state. ## 5.0 Z-80 CPU INSTRUCTION SET The Z-80 CPU can execute 158 different instruction types including all 78 of the 8080A CPU. The instructions can be broken down into the following major groups: - Load and Exchange - Block Transfer and Search - Arithmetic and Logical - Rotate and Shift - Bit Manipulation (set, reset, test) - Jump, Call and Return - Input/Output - Basic CPU Control ## 5.1 INTRODUCTION TO INSTRUCTION TYPES The load instructions move data internally between CPU registers or between CPU registers and external memory. All of these instructions must specify a source location from which the data is to be moved and a destination location. The source location is not altered by a load instruction. Examples of load group instructions include moves between any of the general purpose registers such as move the data to Register B from Register C. This group also includes load immediate to any CPU register or to any external memory location. Other types of load instructions allow transfer between CPU registers and memory locations. The exchange instructions can trade the contents of two registers. A unique set of block transfer instructions is provided in the Z-80. With a single instruction a block of memory of any size can be moved to any other location in memory. This set of block moves is extremely valuable when large strings of data must be processed. The Z-80 block search instructions are also valuable for this type of processing. With a single instruction, a block of external memory of any desired length can be searched for any 8-bit character. Once the character is found or the end of the block is reached, the instruction automatically terminates. Both the block transfer and the block search instructions can be interrupted during their execution so as to not occupy the CPU for long periods of time. The arithmetic and logical instructions operate on data stored in the accumulator and other general purpose CPU registers or external memory locations. The results of the operations are placed in the accumulator and the appropriate flags are set according to the result of the operation. An example of an arithmetic operation is adding the accumulator to the contents of an external memory location. The results of the addition are placed in the accumulator. This group also includes 16-bit addition and subtraction between 16-bit CPU registers. The rotate and shift group allows any register or any memory location to be rotated right or left with or without carry either arithmetic or logical. Also, a digit in the accumulator can be rotated right or left with two digits in any memory location. The bit manipulation instructions allow any bit in the accumulator, any general purpose register or any external memory location to be set, reset or tested with a single instruction. For example, the most significant bit of register H can be reset. This group is especially useful in control applications and for controlling software flags in general purpose programming. The jump, call and return instructions are used to transfer between various locations in the user's program. This group uses several different techniques for obtaining the new program counter address from specific external memory locations. A unique type of call is the restart instruction. This instruction actually contains the new address as a part of the 8-bit OP code. This is possible since only 8 separate addresses located in page zero of the external memory may be specified. Program jumps may also be achieved by loading register HL, IX or IY directly into the PC, thus allowing the jump address to be a complex furction of the routine being executed. The input/output group of instructions in the Z-80 allow for a wide range of transfers between external memory locations or the general purpose CPU registers, and the external I/O devices. In each case, the port number is provided on the lower 8 bits of the address bus during any I/O transaction. One instruction allows this port number to be specified by the second byte of the instruction while other Z-80 instructions allow it to be specified as the content of the C register. One major advantage of using the C register as a pointer to the I/O device is that it allows different I/O ports to share common software driver routines. This is not possible when the address is part of the OP code if the routines are stored in ROM. Another feature of these input instructions is that they set the flag register automatically so that additional operations are not required to determine the state of the input data (for example its parity). The Z-80 CPU includes single instructions that can move blocks of data (up to 256 bytes) automatically to or from any I/O port directly to any memory location. In conjunction with the dual set of general purpose registers, these instructions provide for fast I/O block transfer rates. The value of this I/O instruction set is demonstrated by the fact that the Z-80 CPU can provide all required floppy disk formatting (i.e., the CPU provides the preamble, address, data and enables the CRC codes) on double density floppy disk drives on an interrupt driven basis. Finally, the basic CPU control instructions allow various options and modes. This group includes instructions such as setting or resetting the interrupt enable flip flop or setting the mode of interrupt response. #### 5.2 ADDRESSING MODES Most of the Z-80 instructions operate on data stored in internal CPU registers, external memory or in the I/O ports. Addressing refers to how the address of this data is generated in each instruction. This section gives a brief summary of the types of addressing used in the Z-80 while subsequent sections detail the type of addressing available for each instruction group. Immediate. In this mode of addressing the byte following the OP code in memory contains the actual operand. Examples of this type of instruction would be to load the accumulator with a constant, where the constant is the byte immediately following the OP code. Immediate Extended. This mode is merely an extension of immediate addressing in that the two bytes following the OP codes are the operand. | OP code | one or 2 bytes | |---------|----------------| | Operand | low order | | Operand | high order | Examples of this type of instruction would be to load the HL register pair (16-bit register) with 16 bits (2 bytes) of data. Modified Page Zero Addressing. The Z-80 has a special single byte CALL instruction to any of 8 locations in page zero of memory. This instruction (which is referred to as a restart) sets the PC to an effective address in page zero. The value of this instruction is that it allows a single byte to specify a complete 16-bit address where commonly called subroutines are located, thus saving memory space. **Relative Addressing.** Relative addressing uses one byte of data following the OP code to specify a displacement from the existing program to which a program jump can occur. This displacement is a signed two's complement number that is added to the address of the OP code of the following instruction. The value of relative addressing is that it allows jumps to nearby locations while only requiring two bytes of memory space. For most programs, relative jumps are by far the most prevalent type of jump due to the proximity of related program segments. Thus, these instructions can significantly reduce memory space requirements. The signed displacement can range between +127 and -128 from A + 2. This allows for a total displacement of +129 to -126 from the jump relative OP code address. Another major advantage is that it allows for relocatable code. **Extended Addressing.** Extended Addressing provides for two bytes (16 bits) of address to be included in the instruction. This data can be an address to which a program can jump or it can be an address where an operand is located. Extended addressing is required for a program to jump from any location in memory to any other location, or load and store data in any memory location. When extended addressing is used to specify the source or destination address of an operand, the notation (nn) will be used to indicate the content of memory at nn, where nn is the 16-bit address specified in the instruction. This means that the two bytes of address nn are used as a pointer to a memory location. The use of the parentheses always means that the value enclosed within them is used as a pointer to a memory location. For example, (1200) refers to the contents of memory at location 1200. Indexed Addressing. In this type of addressing, the byte of data following the OP code contains a displacement which is added to one of the two index registers (the OP code specifies which index register is used) to form a pointer to memory. The contents of the index register are not altered by this operation. An example of an indexed instruction would be to load the contents of the memory location (Index Register + Displacement) into the accumulator. The displacement is a signed two's complement number. Indexed addressing greatly simplifies programs using tables of data since the index register can point to the start of any table. Two index registers are provided since very often operations require two or more tables. Indexed addressing also allows for relocatable code. The two index registers in the Z-80 are referred to as IX and IY. To indicate indexed addressing the notation: $$(IX+d)$$ or $(IY+d)$ is used. Here d is the displacement specified after the OP code. The parentheses indicate that this value is used as a pointer to external memory. Register Addressing. Many of the Z-80 OP codes contain bits of information that specify which CPU register is to be used for an operation. An example of register addressing would be to load the data in register B into register C. Implied Addressing. Implied addressing refers to operations where the OP code automatically implies one or more CPU registers as containing the operands. An example is the set of arithmetic operations where the accumulator is always implied to be the destination of the results. Register Indirect Addressing. This type of addressing specifies a 16-bit CPU register pair (such as HL) to be used as a pointer to any location in memory. This type of instruction is very powerful and it is used in a wide range of applications. An example of this type of instruction would be to load the accumulator with the data in the memory location pointed to by the HL register contents. Indexed addressing is actually a form of register indirect addressing except that a displacement is added with indexed addressing. Register indirect addressing allows for very powerful but simple to implement memory accesses. The block move and search commands in the Z-80 are extensions of this type of addressing where automatic register incrementing, decrementing and comparing has been added. The notation for indicating register indirect addressing is to put parentheses around the name of the register that is to be used as the pointer. For example, the symbol (HL) specifies that the contents of the HL register are to be used as a pointer to a memory location. Often register indirect addressing is used to specify 16-bit operands. In this case, the register contents point to the lower order portion of the operand while the register contents are automatically incremented to obtain the upper portion of the operand. Bit Addressing. The Z-80 contains a large number of bit set, reset and test instructions. These instructions allow any memory location or CPU register to be specified for a bit operation through one of three previous addressing modes (register, register indirect and indexed) while three bits in the OP code specify which of the eight bits is to be manipulated. #### ADDRESSING MODE COMBINATIONS Many instructions include more than one operand (such as arithmetic instructions or loads). In these cases, two types of addressing may be employed. For example, load can use immediate addressing to specify the source and register indirect or indexed addressing to specify the destination. #### 5.3 INSTRUCTION OP CODES This section describes each of the Z-80 instructions and provides tables listing the OP codes for every instruction. In each of these tables the OP codes in shaded areas are identical to those offered in the 8080A CPU. Also shown is the assembly language mnemonic that is used for each instruction. All instruction OP codes are listed in hexadecimal notation. Single byte OP codes require two hex characters while double byte OP codes require four hex characters. The conversion from hex to binary is repeated here for convenience. | Hex | | Binary | | Decimal | Hex | Binary | | Decimal | |-----|---|--------|---|---------|-----|--------|---|---------| | 0 | = | 0000 | = | 0 | 8 = | 1000 | = | 8 | | 1 | = | 0001 | = | 1 | 9 = | 1001 | = | 9 | | 2 | = | 0010 | = | 2 | A = | 1010 | = | 10 | | 3 | = | 0011 | = | 3 | В = | 1011 | = | 11 | | 4 | = | 0100 | = | 4 | C = | 1100 | = | 12 | | 5 | = | 0101 | = | 5 | D = | 1101 | = | 13 | | 6 | = | 0110 | = | 6 | E = | 1110 | = | 14 | | 7 | = | 0111 | = | 7 | F = | 1111 | = | 15 | Z-80 instruction mnemonics consist of an OP code and zero, one or two operands. Instructions in which the operand is implied have no operand. Instructions which have only one logical operand or those in which one operand is invariant (such as the Logical OR instruction) are represented by a one operand mnemonic. Instructions which may have two varying operands are represented by two operand mnemonics. #### LOAD AND EXCHANGE Table 5.3-1 defines the OP code for all of the 8-bit load instructions implemented in the Z-80 CPU. Also shown in this table is the type of addressing used for each instruction. The source of the data is found on the top horizontal row while the destination is specified by the left hand column. For example, load register C from register B uses the OP code 48H. In all of the tables the OP code is specified in hexadecimal notation and the 48H (=0100 1000 binary) code is fetched by the CPU from the external memory during M1 time, decoded and then the register transfer is automatically performed by the CPU. The assembly language mnemonic for this entire group is LD, followed by the destination followed by the source (LD DEST., SOURCE). Note that several combinations of addressing modes are possible. For example, the source may use register addressing and the destination may be register indirect; such as load the memory location pointed to by register HL with the contents of register D. The OP code for this operation would be 72. The mnemonic for this load instruction would be as follows: The parentheses around the HL means that the contents of HL are used as a pointer to a memory location. In all Z-80 load instruction mnemonics the destination is always listed first, with the source following. The Z-80 assembly language has been defined for ease of programming. Every instruction is self documenting and programs written in Z-80 language are easy to maintain. Note in table 5.3-1 that some load OP codes that are available in the Z-80 use two bytes. This is an efficient method of memory utilization since 8, 16, 24 or 32 bit instructions are implemented in the Z-80. Thus often utilized instructions such as arithmetic or logical operations are only 8-bits which results in better memory utilization than is achieved with fixed instruction sizes such as 16-bits. All load instructions using indexed addressing for either the source or destination location actually use three bytes of memory with the third byte being the displacement d. For example a load register E with the operand pointed to by IX with an offset of +8 would be written: $$LDE, (IX + 8)$$ The instruction sequence for this in memory would be: The two extended addressing instructions are also three byte instructions. For example the instruction to load the accumulator with the operand in memory location 6F32H would be written: and its instruction sequence would be: Notice that the low order portion of the address is always the first operand. The load immediate instructions for the general purpose 8-bit registers are two-byte instructions. The instruction load register H with the value 36H would be written: and its sequence would be: Loading a memory location using indexed addressing for the destination and immediate addressing for the source requires four bytes. For example: would appear as: Notice that with any indexed addressing the displacement always follows directly after the OP code. Table 5.3-2 specifies the 16-bit load operations. This table is very similar to the previous one. Notice that the extended addressing capability covers all register pairs. Also notice that register indirect operations specifying the stack pointer are the PUSH and POP instructions. The mnemonic for these instructions is "PUSH" and "POP." These differ from other 16-bit loads in that the stack pointer is automatically decremented and incremented as each byte is pushed onto or popped from the stack respectively. For example the instruction: ## PUSH AF is a single byte instruction with the OP code of F5H. When this instruction is executed the following sequence is generated: Decrement SP LD (SP), A Decrement SP LD (SP), F Thus the external stack now appears as follows: | | | | | | | | | | | SOUR | CE | | | | | | | | |-------------|-----------------|--------|-------|----------|----------------|---------------|---------------|----------------|---------------|---------------|---------------|------|-------|------|---------------|---------------|---------------|---------| | | | ſ | | | | | | GISTER | | | | BEC | INDIR | CT | INDE | XED | EXT.<br>ADDR. | IMME. | | | | ŀ | IMPL | R | A | В | c T | D | E | н | L | (HL) | (BC) | (DE) | (IX + d) | (IY + d) | (nn) | n | | | | A | ED 57 | ED<br>5F | 7# | 78 | 79 | 78 | 78 | ж | 70 | 7€ | 6A | 14 | DD<br>7E<br>d | FD<br>7E<br>d | ¥ | 3E<br>n | | | | В | | | 47 | 40 | 41 | 42 | 43 | 44 | 45 | 46 | | | DD<br>46<br>d | FD<br>46<br>d | | 06<br>1 | | | | с | | | 45 | 46 | 49 | 44 | 46 | #C | 40 | 4E | | | DD<br>4E<br>d | FD<br>4E<br>d | | QE<br>n | | | REGISTER | D | | | 57 | 50 | 61 | 52 | 53 | 54 | 56 | 56 | | | DD<br>56<br>d | FD<br>56<br>d | | 16 | | | | E | | | SF | 58 | 59 | 64 | 58 | 5C | 50 | 5E | | | DD<br>5E<br>d | FD<br>SE<br>d | | 1E | | | | н | | | 67 | 60 | 61 | 62 | 62 | и | š | 8 | | | 00<br>66<br>d | FD<br>66<br>d | | 26 | | | | ι | | | of | | 99 | 6A | 68 | <b>8</b> C | 8 | βĒ | | | DD<br>6E<br>d | FD<br>6E<br>d | | 2E n | | DESTINATION | REG<br>INDIRECT | (HL) | | | 77 | 70 | 71 | 72 | 73 | 74 | 76 | | | | | | | ** | | | | (BC) | | | 02 | | | | | | | | | | | | | | | | | (DE) | | | 12 | | | | | | | | | | | | | DD | | | INDEXED | (IX+d) | | | DD<br>77<br>d | DD<br>70<br>d | DD<br>71<br>d | DD<br>72<br>d | DD<br>73<br>4 | DD<br>74<br>d | DD<br>75<br>d | | | | | | | 36<br>d | | | INDEXED | (IY+d) | | | F.D<br>77<br>d | FD<br>70<br>d | FD<br>71<br>d | F D<br>72<br>d | 73<br>d | 74<br>d | 75<br>d | | | | | | | 36<br>d | | | EXT. ADDR | (nn) | | | 33 | | | | | | | | | - | - | | | | | | IMPLIED | 1 | | | ED<br>47 | | | | | | | | | | _ | | | | | | IMPLIED | R | | | ED<br>4F | | | | | | | | | | | | | | 8 BIT LOAD GROUP 'LD' TABLE 5.3-1 The POP instruction is the exact reverse of a PUSH. Notice that all PUSH and POP instructions utilize a 16-bit operand and the high order byte is always pushed first and popped last. That is a: PUSH BC is PUSH B then C PUSH DE is PUSH D then E PUSH HL is PUSH H then-L POP HL is POP L then H The instruction using extended immediate addressing for the source obviously requires 2 bytes of data following the OP code. For example: LD DE, 0659H will be: Address A 11 OP Code A+1 59 Low order operand to register E A+2 06 High order operand to register D In all extended immediate or extended addressing modes, the low order byte always appears first after the OP code. Table 5.3-3 lists the 16-bit exchange instructions implemented in the Z-80. OP code 08H allows the programmer to switch between the two pairs of accumulator flag registers while D9H allows the programmer to switch between the duplicate set of six general purpose registers. These OP codes are only one byte in length to absolutely minimize the time necessary to perform the exchange so that the duplicate banks can be used to effect very fast interrupt response times. #### **BLOCK TRANSFER AND SEARCH** Table 5.3-4 lists the extremely powerful block transfer instructions. All of these instructions operate with three registers. HL points to the source location. DE points to the destination location. BC is a byte counter. After the programmer has initialized these three registers, any of these four instructions may be used. The LDI (Load and Increment) instruction moves one byte from the location pointed to by HL to the location pointed to by DE. Register pairs HL and DE are then automatically incremented and are ready to point to the following locations. The byte counter (register pair BC) is also decremented at this time. This instruction is valuable when blocks of data must be moved but other types of processing are required between each move. The LDIR (Load, increment and repeat) instruction is an extension of the LDI instruction. The same load and increment operation is repeated until the byte counter reaches the count of zero. Thus, this single instruction can move any block of data from one location to any other. Note that since 16-bit registers are used, the size of the block can be up to 64K bytes (1K = 1024) long and it can be moved from any location in memory to any other location. Furthermore the blocks can be overlapping since there are absolutely no constraints on the data that is used in the three register pairs. The LDD and LDDR instructions are very similar to the LDI and LDIR. The only difference is that register pairs HL and DE are decremented after every move so that a block transfer starts from the highest address of the designated block rather than the lowest. | | | | | | 5 | SOURCE | | | | | | | |-------------------|-----------------|------|----|----------------------|---------------|--------------|---------------|----------------|---------------|---------------|---------------------|----------| | | | | | | | IMM.<br>EXT. | EXT.<br>ADDR. | REG.<br>INDIR. | | | | | | | | | AF | AF BC DE HL SP IX IY | | | | | | | | (SP) | | | | AF | | | | | | | | | | F1 | | | | вс | | | | | | | | 01<br>n<br>n | ED<br>4B<br>n | C1 | | | R E G I S T E R | DE | | | | | | | | 11<br>n<br>n | ED<br>5B<br>n | D1 | | DESTINATION | | HL | | | | | | | | 21<br>n<br>n | 2A<br>n<br>n | E1 | | | | SP | | | | F9 | | DD<br>F9 | FD<br>F9 | 31<br>n | ED<br>'7B<br>n<br>n | | | | | ıx | | | | | , | | | DD<br>21<br>n | DD<br>2A<br>n | DD<br>E1 | | | | IY | | | , | | | | | FD<br>21<br>n | FD<br>2A<br>n | FD<br>E1 | | | EXT.<br>ADDR. | (nn) | | ED<br>43<br>n | ED<br>53<br>n | 22<br>n<br>n | ED<br>73<br>n | DD<br>22<br>n | FD<br>22<br>n | | | | | PUSH INSTRUCTIONS | REG.<br>IND. | (SP) | F5 | C5 | D5 | E5 | | DD<br>E5 | FD<br>E5 | | | | NOTE: The Push & Pop Instructions adjust the SP after every execution POP INSTRUCTIONS 16 BIT LOAD GROUP 'LD' 'PUSH' AND 'POP' TABLE 5.3-2 | | | | IMPLIED ADDRESSING | | | | | | | | | | |---------|----------------------|-----------------|--------------------|----|----------|----------|--|--|--|--|--|--| | | | AF <sup>'</sup> | BC, DE & HL | HL | IX | ΙY | | | | | | | | | AF | 08 | | | | | | | | | | | | IMPLIED | BC,<br>DE<br>&<br>HL | | D9 | | | | | | | | | | | | DE | | | EB | | | | | | | | | | REG. | (SP) | | | E3 | DD<br>E3 | FD<br>E3 | | | | | | | EXCHANGES 'EX' AND 'EXX' TABLE 5.3-3 | | | | REG.<br>INDIR. | | |-------------|----------------|------|----------------|----------------------------------------------------------------------------------| | | REG.<br>INDIR. | (DE) | ED<br>A0 | 'LDI' - Load (DE)→ (HL)<br>Inc HL & DE, Dec BC | | DESTINATION | | | ED<br>B0 | 'LDIR,' — Load (DE) | | DESTINATION | | | ED<br>A8 | 'LDD' — Load (DE) <del>←</del> (HL)<br>Dec HL & DE, Dec BC | | | | | ED<br>B8 | 'LDDR' — Load (DE) <del>→</del> (HL)<br>Dec HL & DE, Dec BC, Repeat until BC = 0 | Reg HL points to source Reg DE points to destination Reg BC is byte counter #### BLOCK TRANSFER GROUP TABLE 5.3-4 Table 5.3-5 specifies the OP codes for the four block search instructions. The first, CPI (compare and increment) compares the data in the accumulator, with the contents of the memory location pointed to by register HL. The result of the compare is stored in one of the flag bits (see section 6.0 for a detailed explanation of the flag operations) and the HL register pair is then incremented and the byte counter (register pair BC) is decremented. The instruction CPIR is merely an extension of the CPI instruction in which the compare is repeated until either a match is found or the byte counter (register pair BC) becomes zero. Thus, this single instruction can search the entire memory for any 8-bit character. The CPD (Compare and Decrement) and CPDR (Compare, Decrement and Repeat) are similar instructions, their only difference being that they decrement HL after every compare so that they search the memory in the opposite direction. (The search is started at the highest location in the memory block). It should be emphasized again that these block transfer and compare instructions are extremely powerful in string manipulation applications. #### ARITHMETIC AND LOGICAL Table 5.3-6 lists all of the 8-bit arithmetic operations that can be performed with the accumulator, also listed are the increment (INC) and decrement (DEC) instructions. In all of these instructions, except INC and DEC, the specified 8-bit operation is performed between the data in the accumulator and the source data specified in the table. The result of the operation is placed in the accumulator with the exception of compare (CP) that leaves the accumulator unaffected. All of these operations affect the flag register as a result of the specified operation. (Section 6.0 provides all of the details on how the flags are affected by any instruction type). INC and DEC instructions specify a register or a memory location as both source and destination of the result. When the source operand is addressed using the index registers the displacement must follow directly. With immediate addressing the actual operand will follow directly. For example the instruction: AND 07H would appear as: Address A E6 OP Code A+1 07 Operand | SEARCH | | |----------------|-------------------------------------------------------------| | REG.<br>INDIR. | | | (HL) | | | ED<br>A1 | 'CPI'<br>Inc HL, Dec BC | | ED<br>B1 | 'CPIR', Inc HL, Dec BC<br>repeat until BC = 0 or find match | | ED<br>A9 | 'CPD' Dec HL & BC | | ED<br>B9 | 'CPDR' Dec HL & BC<br>Repeat until BC = 0 or find match | HL points to location in memory to be compared with accumulator contents BC is byte counter ### BLOCK SEARCH GROUP TABLE 5.3-5 Assuming that the accumulator contained the value F3H the result of 03H would be placed in the accumulator: Acc before operation 0000 0111 = F3H 0000 0111 = 07H Result to Acc 0000 0011 = 03H The Add instruction (ADD) performs a binary add between the data in the source location and the data in the accumulator. The subtract (SUB) does a binary subtraction. When the add with carry is specified (ADC) or the subtract with carry (SBC), then the carry flag is also added or subtracted respectively. The flags and decimal adjust instruction (DAA) in the Z-80 (fully described in section 6.0) allow arithmetic operations for: multiprecision packed BCD numbers multiprecision signed or unsigned binary numbers multiprecision two's complement signed numbers Other instructions in this group are logical and (AND), logical or (OR), exclusive or (XOR) and compare (CP). These five are listed in table 5.3-7. The decimal adjust instruction can adjust for subtraction as well as addition, thus making BCD arithmetic operations simple. Note that to allow for this operation the flag N is used. This flag is set if the last arithmetic operation was a subtract. The negate accumulator (NEG) instruction forms the two's complement of the number in the accumulator. Finally notice that a reset carry instruction is not included in the Z-80 since this operation can be easily achieved through other instructions such as a logical AND of the accumulator with itself. Table 5.3-8 lists all of the 16-bit arithmetic operations between 16-bit registers. There are five groups of instructions including add with carry and subtract with carry. ADC and SBC affect all of the flags. These two groups simplify address calculation operations or other 16-bit arithmetic operations. ## SOURCE | | | | REGIST | TER ADD | | REG.<br>INDIR. | INDE | XED | IMMED. | | | |--------------------|----|------|--------|---------|----|----------------|------|------|----------------------|---------------|---------| | | Α | В | С | D | E | н | L | (HL) | (IX+d) | (IY+d) | n | | 'ADD' | 87 | 80 | 81 | 82 | 63 | 84 | 85 | 86 | DD<br>86<br>d | FD<br>86<br>d | C6 | | ADD w CARRY | 8F | 88 | 89 | 8A | 88 | 8C | 8D | 8E | DD<br>8E<br>d | FD<br>8E<br>d | CE<br>n | | SUBTRACT<br>'SUB' | 97 | 90 | 91 | 92 | 93 | 34 | 95 | 96 | DD<br>96<br>d | FD<br>96<br>d | D6<br>n | | SUB w CARRY | 9F | 98 | 99 | 9A | 9B | 90 | 90 | 9E | DD<br>9E<br>d | FD<br>9E<br>d | DE<br>n | | 'AND' | A7 | A0 . | A1 | A2 | А3 | A4 | A5 | A6 | DD<br>A6<br>d | FD<br>A6<br>d | E6<br>n | | 'XOR' | AF | AB | A9 | AA | AB | AC | AD | AE | DD<br>AE<br>d | FD<br>AE<br>d | EE n | | 'OR' | 87 | 80 | 81 | B2 | 83 | 84 | 85 | 86 | DD<br>B6<br>d | FD<br>B6<br>d | F6<br>n | | COMPARE 'CP' | BF | 88 | B9 | ВА | 88 | BC | BD | BE | DD<br>BE<br>d | FD<br>BE<br>d | FE n | | INCREMENT | 3C | 04 | OC. | 14 | 10 | 24 | 2C | 34 | DD<br><b>34</b><br>d | FD<br>34<br>d | | | DECREMENT<br>'DEC' | 3D | 05 | 00 | 15 | 1D | 25 | 2D | 35 | DD<br>35<br>d | FD<br>35<br>d | | # 8 BIT ARITHMETIC AND LOGIC TABLE 5.3-6 | Decimal Adjust Acc, 'DAA' | 27 | |---------------------------------------|----------| | Complement Acc, 'CPL' | 2F | | Negate Acc, 'NEG'<br>(2's complement) | ED<br>44 | | Complement Carry Flag, 'CCF' | 3F | | Set Carry Flag, 'SCF' | 37 | GENERAL PURPOSE AF OPERATIONS TABLE 5.3-7 | | | | SOU | RCE | | | | | |-------------|---------------------------------------|----|----------|----------|----------|----------|----------|----------| | | | | ВС | DE | HL | SP | ıx | IY | | | | HL | 09 | 19 | 29 | 39 | | | | | 'ADD' | IX | DD<br>09 | DD<br>19 | · | DD<br>39 | DD<br>29 | | | DESTINATION | | IY | FD<br>09 | FD<br>19 | | FD<br>39 | | FD<br>29 | | | ADD WITH CARRY AND<br>SET FLAGS 'ADC' | HL | ED<br>4A | ED<br>5A | ED<br>6A | ED<br>7A | | | | | SUB WITH CARRY AND<br>SET FLAGS 'SBC' | HL | ED<br>42 | ED<br>52 | ED<br>62 | ED<br>72 | | | | | INCREMENT 'INC | • | 8 | 13 | 23 | 3 | DD<br>23 | FD<br>23 | | | DECREMENT 'DE | C' | 08 | 18 | 28 | 38 | DD<br>2B | FD<br>2B | # 16 BIT ARITHMETIC TABLE 5.3–8 ## **ROTATE AND SHIFT** A major capability of the Z-80 is its ability to rotate or shift data in the accumulator, any general purpose register, or any memory location. All of the rotate and shift OP codes are shown in table 5.3-9. Also included in the Z-80 are arithmetic and logical shift operations. These operations are useful in an extremely wide range of applications including integer multiplication and division. Two BCD digit rotate instructions (RRD and RLD) allow a digit in the accumulator to be rotated with the two digits in a memory location pointed to by register pair HL. (See figure 5.3-9). These instructions allow for efficient BCD arithmetic. #### BIT MANIPULATION The ability to set, reset and test individual bits in a register or memory location is needed in almost every program. These bits may be flags in a general purpose software routine, indications of external control conditions or data packed into memory locations to make memory utilization more efficient. The Z-80 has the ability to set, reset or test any bit in the accumulator, any general purpose register or any memory location with a single instruction. Table 5.3-10 lists the 240 instructions that are available for this purpose. Register addressing can specify the accumulator or any general purpose register on which the operation is to be performed. Register indirect and indexed addressing are available to operate on external memory locations. Bit test operations set the zero flag (Z) if the tested bit is a zero. (Refer to section 6.0 for further explanation of flag operation). #### JUMP, CALL AND RETURN Figure 5.3-11 lists all of the jump, call and return instructions implemented in the Z-80 CPU. A jump is a branch in a program where the program counter is loaded with the 16-bit value as specified by one of the three available addressing modes (Immediate Extended, Relative or Register Indirect). Notice that the jump group has several different conditions that can be specified to be met before the jump will be made. If these conditions are not met, the program merely continues with the next sequential instruction. The conditions are all dependent on the data in the flag register. (Refer to section 6.0 for details on the flag register). The immediate extended addressing is used to jump to any location in the memory. This instruction requires three bytes (two to specify the 16-bit address) with the low order address byte first followed by the high order address byte. # ROTATES AND SHIFTS TABLE 5.3-9 For example an unconditional Jump to memory location 3E32H would be: | Address A | C3 | OP Code | |-----------|----|--------------------| | A+1 | 32 | Low order address | | A+2 | 3E | High order address | The relative jump instruction uses only two bytes, the second byte is a signed two's complement displacement from the existing PC. This displacement can be in the range of +129 to -126 and is measured from the address of the instruction OP code. Three types of register indirect jumps are also included. These instructions are implemented by loading the register pair HL or one of the index registers IX or IY directly into the PC. This capability allows for program jumps to be a function of previous calculations. A call is a special form of a jump where the address of the byte following the call instruction is pushed onto the stack before the jump is made. A return instruction is the reverse of a call because the data on the top of the stack is popped directly into the PC to form a jump address. The call and return instructions allow for simple subroutine and interrupt handling. Two special return instructions have been included in the Z-80 family of components. The return from interrupt instruction (RETI) and the return from non maskable interrupt (RETN) are treated in the CPU as an unconditional return identical to the OP code C9H. The difference is that (RETI) can be used at the end of an interrupt routine and all Z-80 peripheral chips will recognize the execution of this instruction for proper control of nested priority interrupt handling. This instruction coupled with the Z-80 peripheral devices implementation simplifies the normal return from nested interrupt. Without this feature the following software sequence would be necessary to inform the interrupting device that the interrupt routine is completed: | | | | I | REGISTE | R ADDF | RESSING | | | REG.<br>INDIR. | INDE | XED | |--------------|-----|----------|----------|----------|----------|----------|----------|----------|----------------|----------------------------------------------------------------------------|---------------------| | | BIT | A | В | С | D | E | н | L | (HL) | (IX+d) | (IY+d) | | | 0 | CB<br>47 | CB<br>40 | CB<br>41 | CB<br>42 | CB<br>43 | CB<br>44 | CB<br>45 | CB<br>46 | DD<br>CB<br>d | FD<br>CB<br>d<br>46 | | | 1 | CB<br>4F | CB<br>48 | CB<br>49 | CB<br>4A | CB<br>4B | CB<br>4C | CB<br>4D | CB<br>4E | DD<br>CB<br>d<br>4E | FD<br>CB<br>d<br>4E | | | 2 | C8<br>57 | CB<br>50 | CB<br>51 | CB<br>52 | CB<br>53 | CB<br>54 | CB<br>55 | CB<br>56 | DD<br>CB<br>d<br>56 | FD<br>CB<br>d<br>56 | | TEST | 3 | C8<br>5F | CB<br>58 | CB<br>59 | CB<br>5A | CB<br>5B | CB<br>5C | CB<br>5D | CB<br>5E | DD<br>CB<br>d<br>5E | FD<br>CB<br>d<br>5E | | 'BIT' | 4 | C8<br>67 | CB<br>60 | CB<br>61 | CB<br>62 | CB<br>63 | CB<br>64 | CB<br>65 | CB<br>66 | DD<br>CB<br>66 | FD<br>CB<br>d<br>66 | | | 5 | CB<br>6F | CB<br>68 | CB<br>69 | CB<br>6A | CB<br>6B | CB<br>6C | CB<br>6D | CB<br>6E | DD<br>CB<br>d<br>6E | FD<br>CB<br>d<br>6E | | | 6 | CB<br>77 | CB<br>70 | CB<br>71 | CB<br>72 | CB<br>73 | CB<br>74 | GB<br>75 | CB<br>76 | d<br>76 | FD<br>CB<br>d<br>76 | | | 7 | CB<br>7F | CB<br>78 | CB<br>79 | CB<br>7A | CB<br>7B | CB<br>7C | C8<br>7D | CB<br>7E | CB<br>d<br>7E | FD<br>CB<br>d<br>7E | | | 0 | CB<br>87 | CB<br>80 | CB<br>81 | CB<br>82 | CB<br>83 | CB<br>84 | CB<br>85 | CB<br>86 | B v 86 | FD<br>CB<br>d<br>86 | | | 1 | CB<br>8F | CB<br>88 | CB<br>89 | CB<br>8A | CB<br>88 | CB<br>8C | CB<br>8D | CB<br>8E | 8 <b>E</b> | FD<br>CB<br>d<br>8E | | | 2 | CB<br>97 | CB<br>90 | CB<br>91 | CB<br>92 | CB<br>93 | CB<br>94 | CB<br>95 | CB<br>96 | DDD CB dd de DDD CB dd dd de DDD CB dd | FD<br>CB<br>d<br>96 | | RESET<br>BIT | 3 | CB<br>9F | CB<br>98 | CB<br>99 | CB<br>9A | CB<br>98 | CB<br>9C | CB<br>9D | CB<br>9E | CB<br>d<br>9E | FDB d BE | | 'RES' | 4 | CB<br>A7 | CB<br>A0 | CB<br>A1 | CB<br>A2 | CB<br>A3 | CB<br>A4 | CB<br>A5 | CB<br>A6 | CB<br>d<br>A6 | FD<br>CB<br>d<br>A6 | | | 5 | CB<br>AF | CB<br>A8 | CB<br>A9 | CB<br>AA | CB<br>AB | CB<br>AC | CB<br>AD | CB<br>AE | d<br>AE | FD<br>CB<br>AE | | | 6 | CB<br>B7 | CB<br>BO | CB<br>B1 | CB<br>B2 | CB<br>B3 | CB<br>B4 | CB<br>B5 | CB<br>B6 | CB<br>d<br>B6 | FD<br>CB<br>d<br>B6 | | | 7 | CB<br>BF | CB<br>B8 | CB<br>B9 | CB<br>BA | CB<br>BB | CB<br>BC | CB<br>BD | CB<br>BE | CB<br>d<br>BE | FD<br>CB<br>d<br>BE | | | 0 | CB<br>C7 | СВ<br>СО | CB<br>C1 | CB<br>C2 | СВ<br>СЗ | CB<br>C4 | CB<br>C5 | CB<br>C6 | CB<br>d<br>C6 | FDB d C6 | | | 1 | CB<br>CF | CB<br>C8 | CB<br>C9 | CB<br>CA | CB<br>CB | CB<br>CC | CB<br>CD | CB<br>CE | d<br>CE | FD<br>CB<br>CE | | | 2 | C8<br>D7 | CB<br>D0 | CB<br>D1 | CB<br>D2 | CB<br>D3 | CB<br>D4 | CB<br>D5 | CB<br>D6 | CB<br>d<br>D6 | FD<br>CB<br>d<br>D6 | | SET<br>BIT | 3 | CB<br>DF | CB<br>D8 | CB<br>D9 | CB<br>DA | CB<br>DB | CB<br>DC | CB<br>DD | CB<br>DE | d<br>DE | EB DE | | 'SET' | 4 | CB<br>E7 | CB<br>E0 | CB<br>E1 | CB<br>E2 | CB<br>E3 | CB<br>E4 | CB<br>E5 | CB<br>E6 | e<br>E6 | FDB de | | | 5 | CB<br>EF | CB<br>E8 | CB<br>E9 | CB<br>EA | CB<br>EB | CB<br>EC | CB<br>ED | CB<br>EE | ĒE | FD<br>CB<br>EE | | | 6 | CB<br>F7 | CB<br>F0 | CB<br>F1 | CB<br>F2 | CB<br>F3 | CB<br>F4 | CB<br>F5 | CB<br>F6 | F6 | FD CB F6 | | | 7 | CB<br>FF | CB<br>F8 | CB<br>F9 | CB<br>FA | CB<br>FB | CB<br>FC | CB<br>FD | CB<br>FE | DD<br>CB<br>d<br>FE | FD<br>CB<br>d<br>FE | BIT MANIPULATION GROUP TABLE 5.3-10 Disable Interrupt - prevent interrupt before routine is exited. LD A, n OUT n, A notify peripheral that service routine is complete Enable Interrupt Return This seven byte sequence can be replaced with the one byte EI instruction and the two byte RETI instruction in the Z80. This is important since interrupt service time often must be minimized. To facilitate program loop control the instruction DJNZ e can be used advantageously. This two byte, relative jump instruction decrements the B register and the jump occurs if the B register has not been decremented to zero. The relative displacement is expressed as a signed two's complement number. A simple example of its use might be: Address Instruction Comments N, N + 1 LD B, 7 ; set B register to count of 7 N + 2 to N + 9 (Perform a sequence of instructions) ; loop to be performed 7 times N + 10, N + 11 DJNZ -8 ; to jump from N + 12 to N + 2 N + 12 (Next Instruction) #### CONDITION | | | | UN-<br>COND. | CARRY | NON<br>CARRY | ZERO | NON<br>ZERO | PARITY<br>EVEN | PARITY<br>ODD | SIGN<br>NEG | SIGN<br>POS | REG<br>B≠0 | |--------------------------------------------|--------------------|----------------|------------------|--------------|--------------|-----------|-------------|----------------|---------------|-------------|-------------|------------| | JUMP 'JP' | IMMED.<br>EXT. | nn | C3<br>B<br>B | DA<br>n<br>n | D2<br>n<br>n | Č e e | C2<br>n | EA<br>n | E2<br>n | FA<br>n | F2<br>n | | | JUMP 'JR' | RELATIVE | PC+e | 18<br>e-2 | 38<br>e-2 | 30<br>e-2 | 28<br>e-2 | 20<br>e-2 | | | | | | | JUMP 'JP' | | (HL) | E9 | | | | | | | | | | | JUMP 'JP' | REG.<br>INDIR. | (IX) | DD<br>E9 | | | | | | | | | | | JUMP 'JP' | | (IY) | FD<br>E9 | | | | | | | | | | | 'CALL' | IMMED.<br>EXT. | nn | 9 e e | DC<br>n<br>n | D4<br>n<br>n | • • B | CI<br>n | EC<br>n | E4<br>0 | FC<br>n | F4<br>n | | | DECREMENT B,<br>JUMP IF NON<br>ZERO 'DJNZ' | RELATIVE | PC+e | | | | | | | | | | 10<br>e-2 | | RETURN<br>'RET' | REGISTER<br>INDIR. | (SP)<br>(SP+1) | C9 | D8 | Do | CE . | 8 | ES | EO | FB | FO | | | RETURN FROM<br>INT 'RETI' | REG.<br>INDIR. | (SP)<br>(SP+1) | ED<br>4D | | | | | | | | | | | RETURN FROM<br>NON MASKABLE<br>INT 'RETN' | | (SP)<br>(SP+1) | ED<br><b>4</b> 5 | | | | | | | | | | NOTE-CERTAIN FLAGS HAVE MORE THAN ONE PURPOSE. REFER TO SECTION 6.0 FOR DETAILS JUMP, CALL and RETURN GROUP TABLE 5.3-11 Table 5.3-12 lists the eight OP codes for the restart instruction. This instruction is a single byte call to any of the eight addresses listed. The simple mnemonic for these eight calls is also shown. The value of this instruction is that frequently used routines can be called with this instruction to minimize memory usage. | | | OP<br>CODE | | |---------------|-------------------|------------|----------| | | 0000 <sub>H</sub> | <b>C7</b> | 'RST 0' | | | 0008 <sub>H</sub> | CF | 'RST 8' | | C A L | 0010 <sub>H</sub> | D7 | 'RST 16' | | | 0018 <sub>H</sub> | DF | 'RST 24' | | A D D R E S S | 0020 <sub>H</sub> | E7 | 'RST 32' | | S | 0028 <sub>H</sub> | EF | 'RST 40' | | | 0030 <sup>H</sup> | F7 | 'RST 48' | | | 0038 <sub>H</sub> | FF | 'RST 56' | RESTART GROUP TABLE 5.3-12 ## INPUT/OUTPUT The Z-80 has an extensive set of Input and Output instructions as shown in table 5.3-13 and table 5.3-14. The addressing of the input or output device can be either absolute or register indirect, using the C register. Notice that in the register indirect addressing mode data can be transferred between the I/O devices and any of the internal registers. In addition eight block transfer instructions have been implemented. These instructions are similar to the memory block transfers except that they use register pair HL for a pointer to the memory source (output commands) or destination (input commands) while register B is used as a byte counter. Register C holds the address of the port for which the input or output command is desired. Since register B is eight bits in length, the I/O block transfer command handles up to 256 bytes. In the instructions IN A, n and OUT n, A the I/O device address n appears in the lower half of the address bus $(A_0 A_7)$ while the accumulator content is transferred in the upper half of the address bus. In all register indirect input output instructions, including block I/O transfers the content of register C is transferred to the lower half of the address bus (device address) while the content of register B is transferred to the upper half of the address bus. | | | | | PORT A | DDRESS | 3 | |-------------|-----------------------------------------------|------------------|------|---------|----------------|-------------| | | | | | IMMED. | REG.<br>INDIR. | | | · | | | | (n) | (C) | | | | | | A | DB<br>N | ED<br>78 | | | | | R | В | | ED<br>40 | | | | INPUT 'IN' | G | С | | ED<br>48 | | | | | A D D R E S S I | D | | ED<br>50 | | | INPUT | | S<br>S<br>I<br>N | E | | ED<br>58 | | | DESTINATION | | G | н | | ED<br>60 | | | | | | L | | ED<br>68 | | | | 'INI' – INPUT &<br>Inc HL, Dec B | | | | ED<br>A2 | | | | 'INIR'- INP, Inc HL,<br>Dec B, REPEAT IF B≠0 | REG, | (HL) | | ED<br>B2 | BLOCK INPUT | | | 'IND' INPUT &<br>Dec HL, Dec B | INDÍR | | | ED<br>AA | COMMANDS | | | 'INDR'-INPUT, Dec HL,<br>Dec B, REPEAT IF B≠0 | | | | ED<br>BA | | | | | | | | | • | SOURCE INPUT GROUP TABLE 5.3-13 ## **CPU CONTROL GROUP** The final table, table 5.3-15 illustrates the six general purpose CPU control instructions. The NOP is a donothing instruction. The HALT instruction suspends CPU operation until a subsequent interrupt is received, while the DI and EI are used to lock out and enable interrupts. The three interrupt mode commands set the CPU into any of the three available interrupt response modes as follows. If mode zero is set the interrupting device can insert any instruction on the data bus and allow the CPU to execute it. Mode 1 is a simplified mode where the CPU automatically executes a restart (RST) to location 0038H so that no external hardware is required. (The old PC content is pushed onto the stack). Mode 2 is the most powerful in that it allows for an indirect call to any location in memory. With this mode the CPU forms a 16-bit memory address where the upper 8-bits are the content of register I and the lower 8-bits are supplied by the interrupting device. This address points to the first of two sequential bytes in a table where the address of the service routine is located. The CPU automatically obtains the starting address and performs a CALL to this address. | | | | sou | RCE | | | | | | | | |--------------------------------------------------|--------------|-----|----------|----------|----------|--------------|----------|----------|----------|----------|-------------------| | | | | | | F | REG.<br>IND. | | | | | | | | | | А | В | С | D | E | н | L | (HL) | | | (OUT) | IMMED. | (n) | D3<br>n | | | | | | | | | | 'OUT' | REG.<br>IND. | (C) | ED<br>79 | ED<br>41 | ED<br>49 | ED<br>51 | ED<br>59 | ED<br>61 | ED<br>69 | | | | 'OUTI' — OUTPUT<br>Inc HL, Dec b | REG.<br>IND. | (C) | | | | | | | | ED<br>A3 | | | 'OTIR' — OUTPUT, Inc HL,<br>Dec B, REPEAT IF B≠0 | REG.<br>IND. | (C) | | | | | | | | ED<br>B3 | BLOCK<br>> OUTPUT | | 'OUTD' — OUTPUT<br>Dec HL & B | REG.<br>IND. | (C) | | | | | | | | ED<br>AB | COMMANDS | | 'OTDR' — OUTPUT, Dec HL<br>& B, REPEAT IF B≠0 | REG.<br>IND. | (C) | | | | | | | | ED<br>BB | | | PORT<br>DESTINATION<br>ADDRESS | | | | | | | | | | | | OUTPUT GROUP TABLE 5.3-14 | 'NOP' | 00 | | |-------------------------|----------|----------------------------------------------------------------------------------------| | 'HALT' | 76 | | | DISABLE INT '(DI)' | Ð | | | ENABLE INT '(EI)' | FB | | | SET INT MODE 0 | ED<br>46 | 8080A MODE | | SET INT MODE 1 | ED<br>56 | CALL TO LOCATION 0038 <sub>H</sub> | | SET INT MODE 2<br>'IM2' | ED<br>5E | INDIRECT CALL USING REGISTER<br>I AND 8 BITS FROM INTERRUPTING<br>DEVICE AS A POINTER. | MISCELLANEOUS CPU CONTROL TABLE 5.3-15 ## 6.0 FLAGS Each of the two Z-80 CPU Flag registers contains six bits of information which are set or reset by various CPU operations. Four of these bits are testable; that is, they are used as conditions for jump, call or return instructions. For example a jump may be desired only if a specific bit in the flag register is set. The four testable flag bits are: - Carry Flag (C) This flag is the carry from the highest order bit of the accumulator. For example, the carry flag will be set during an add instruction where a carry from the highest bit of the accumulator is generated. This flag is also set if a borrow is generated during a subtraction instruction. The shift and rotate instructions also affect this bit. - 2) Zero Flag (Z) This flag is set if the result of the operation loaded a zero into the accumulator. Otherwise it is reset. - 3) Sign Flag (S) This flag is intended to be used with signed numbers and it is set if the result of the operation was negative. Since bit 7 (MSB) represents the sign of the number (A negative number has a 1 in bit 7), this flag stores the state of bit 7 in the accumulator. - 4) Parity/Overflow Flag (P/V) This dual purpose flag indicates the parity of the result in the accumulator when logical operations are performed (such as AND A, B) and it represents overflow when signed two's complement arithmetic operations are performed. The Z-80 overflow flag indicates that the two's complement number in the accumulator is in error since it has exceeded the maximum possible (+127) or is less than the minimum possible (-128) number than can be represented in two's complement notation. For example consider adding: $$+120 = 0111\ 1000 +105 = 0110\ 1001 C = 0 1110\ 0001 = -95 (wrong) Overflow has occured$$ Here the result is incorrect. Overflow has occurred and yet there is no carry to indicate an error. For this case the overflow flag would be set. Also consider the addition of two negative numbers: $$\frac{-5 = }{-16 = } \frac{1111 \ 1011}{1111 \ 0000}$$ $$C = \frac{1}{1} \frac{1110 \ 1011}{1110 \ 1011} = -21 \text{ correct}$$ Notice that the answer is correct but the carry is set so that this flag can not be used as an over-flow indicator. In this case the overflow would not be set. For logical operations (AND, OR, XOR) this flag is set if the parity of the result is even and it is reset if it is odd. There are also two non-testable bits in the flag register. Both of these are used for BCD arithmetic. They are: - 1) Half carry (H) This is the BCD carry or borrow result from the least significant four bits of operation. When using the DAA (Decimal Adjust Instruction) this flag is used to correct the result of a previous packed decimal add or subtract. - 2) Subtract Flag (N) Since the algorithm for correcting BCD operations is different for addition or subtraction, this flag is used to specify what type of instruction was executed last so that the DAA operation will be correct for either addition or subtraction. The Flag register can be accessed by the programmer and its format is as follows: X means flag is indeterminate. Table 6.0-1 lists how each flag bit is affected by various CPU instructions. In this table a '•' indicates that the instruction does not change the flag, an 'X' means that the flag goes to an indeterminate state, a '0' means that it is reset, a '1' means that it is set and the symbol '‡' indicates that it is set or reset according to the previous discussion. Note that any instruction not appearing in this table does not affect any of the flags. Table 6.0-1 includes a few special cases that must be described for clarity. Notice that the block search instruction sets the Z flag if the last compare operation indicated a match between the source and the accumulator data. Also, the parity flag is set if the byte counter (register pair BC) is not equal to zero. This same use of the parity flag is made with the block move instructions. Another special case is during block input or output instructions, here the Z flag is used to indicate the state of register B which is used as a byte counter. Notice that when the I/O block transfer is complete, the zero flag will be reset to a zero (i.e. B=0) while in the case of a block move command the parity flag is reset when the operation is complete. A final case is when the refresh or I register is loaded into the accumulator, the interrupt enable flip flop is loaded into the parity flag so that the complete state of the CPU can be saved at any time. | | 1 | 1 | P | 1 | l | l | 1 | |-------------------------------------------------|-----|----|-----|--------|----|----------|---------------------------------------------------------------------------------| | Instruction | C | Z | ľv | S | N | Н | Comments | | ADD A, s; ADC A,s | 1 | \$ | V | 1 | 0 | \$ | 8-bit add or add with carry | | SUB s; SBC A, s, CP s, NEG | 1 | 1 | ļν | 1 | 1 | \$ | 8-bit subtract, subtract with carry, compare and | | | | l | ı | | l | | negate accumulator | | AND s | 0 | ‡ | P | ‡ | ]0 | ] 1 | Logical operations | | OR s; XOR s | 0 | 1 | P | 1 | 0 | 0 | And set's different flags | | INC s | • | 1 | l۷ | \$ | 0 | <b>‡</b> | 8-bit increment | | DEC m | • | 1 | V | \$ | 1 | \$ | 8-bit decrement | | ADD DD, ss | ‡ | • | • | • | 0 | X | 16-bit add | | ADC HL, ss | ‡ | 1 | V | 1 | 0 | X | 16-bit add with carry | | SBC HL, ss | ‡ | t | l۷ | 1 | 1 | Х | 16-bit subtract with carry | | RLA; RLCA, RRA, RRCA | \$ | • | • | • | 0 | 0 | Rotate accumulator | | RL m; RLC m; RR m; RRC m<br>SLA m; SRA m; SRL m | ‡ | \$ | P | \$ | 0 | 0 | Rotate and shift location m | | RLD, RRD | | 1 | P | ‡ | 0 | 0 | Rotate digit left and right | | DAA | 1 ‡ | 1 | P | 1 | • | <b>‡</b> | Decimal adjust accumulator | | CPL | • | • | • | • | 1 | 1 | Complement accumulator | | SCF | 1 | • | • | • | 0 | 0 | Set carry | | CCF | 1 ‡ | • | • | • | 0 | X | Complement carry | | IN r, (C) | • | ‡ | P | \$ | 0 | 0 | Input register indirect | | INI; IND; OUTI; OUTD | • | ŧ | x | x | 1 | Х | Block input and output | | INIR; INDR; OTIR; OTDR | • | 1 | x | X | 1 | х | $\int Z = 0$ if $B \neq 0$ otherwise $Z = 1$ | | LDI, LDD | • | X | ‡ | x | 0 | 0 | Block transfer instructions | | LDIR, LDDR | • | Х | 0 | x | 0 | 0 | $P/V = 1$ if BC $\neq 0$ , otherwise $P/V = 0$ | | CPI, CPIR, CPD, CPDR | • | \$ | ‡ | | 1 | | Block search instructions | | , , | | | | | | | Z = 1 if $A = (HL)$ , otherwise $Z = 0P/V = 1 if BC \neq 0, otherwise P/V = 0$ | | LD A, I; LD A, R | • | \$ | IFI | ‡‡<br> | 0 | 0 | The content of the interrupt enable flip-flop (IFF) is copied into the P/V flag | | BIT b, s | • | \$ | X | X | 0 | 1 | The state of bit b of location s is copied into the Z flag | | NEG | ‡ | \$ | lv | \$ | 1 | 1 | Negate accumulator | The following notation is used in this table: | Symbol | Operation | |------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | С | Carry/link flag. C=1 if the operation produced a carry from the MSB of the operand or result. | | Z | Zero flag. Z=1 if the result of the operation is zero. | | S | Sign flag. S=1 if the MSB of the result is one. | | P/V | Parity or overflow flag. Parity (P) and overflow (V) share the same flag. Logical operations affect this flag with the parity of the result while arithmetic operations affect this flag with the overflow of the result. If P/V holds parity, P/V=1 if the result of the operation is even, P/V=0 if result is odd. If P/V holds overflow, P/V=1 if the result of the operation produced an overflow. | | Н | Half-carry flag. H=1 if the add or subtract operation produced a carry into or borrow from into bit 4 of the accumulator. | | N | Add/Subtract flag. N=1 if the previous operation was a subtract. | | | H and N flags are used in conjunction with the decimal adjust instruction (DAA) to properly correct the result into packed BCD format following addition or subtraction using operands with packed BCD format. | | ‡ • 0 1 X V P | The flag is affected according to the result of the operation. The flag is unchanged by the operation. The flag is reset by the operation. The flag is set by the operation. The flag is a "don't care." P/V flag affected according to the overflow result of the operation. P/V flag affected according to the parity result of the operation. | | r<br>s<br>ss<br>ii<br>R<br>n<br>nn | Any one of the CPU registers A, B, C, D, E, H, L. Any 8-bit location for all the addressing modes allowed for the particular instruction. Any 16-bit location for all the addressing modes allowed for that instruction. Any one of the two index registers IX or IY. Refresh counter. 8-bit value in range <0, 255> 16-bit value in range <0, 65535> | | m | Any 8-bit location for all the addressing modes allowed for the particular instruction. | # SUMMARY OF FLAG OPERATION TABLE 6.0-1 ## 7.0 SUMMARY OF OP CODES AND EXECUTION TIMES The following section gives a summary of the Z-80 instructions set. The instructions are logically arranged into groups as shown on tables 7.0-1 through 7.0-11. Each table shows the assembly language mnemonic OP code, the actual OP code, the symbolic operation, the content of the flag register following the execution of each instruction, the number of bytes required for each instruction as well as the number of memory cycles and the total number of T states (external clock periods) required for the fetching and execution of each instruction. Care has been taken to make each table self-explanatory without requiring any cross reference with the test or other tables. | | Symbolic | 1 | | Fla | ngs | | | ١ | OP-C | ode | No. | No.<br>of M | No.<br>of T | | | |-----------------------------------------|-----------------------|-----|----------|-----|-----|---|----|------------|----------|----------|-------|-------------|-------------|-------|------| | Mnemonic | Operation | C | Z | P/V | S | N | Н | 76 | 543 | 210 | Bytes | Cycles | Cycles | Comm | ents | | LD r, r' | r ← r' | • | • | • | • | • | • | 01 | r | r' | 1 | 1 | 4 | r, r' | Reg. | | LD r, n | r ← n | • | • | • | • | • | • | 00 | r | 110 | 2 | 2 | 7 | 000 | В | | | | | | | | | | - | n | <b>→</b> | | | | 001 | С | | LD r, (HL) | r ← (HL) | • | • | • | • | • | • | 01 | r | 110 | 1 | 2 | 7 | 010 | D | | LD r, (IX+d) | $r \leftarrow (IX+d)$ | • | • | • | • | • | • | 11 | 011 | 101 | 3 | 5 | 19 | 011 | E | | | | | | | ١, | | | 01 | r | 110 | | | | 100 | н | | 1 | | | | | | | | - | d | <b>→</b> | l l | | | 101 | L | | LD r, (IY+d) | r ← (IY+d) | • | • | • | • | • | • | | 111 | | 3 | 5 | 19 | 111 | A | | | | | | | | | | 01 | r | 110 | | | | | | | 10 (11) | (111) | | _ | | | _ | | + | d | <b>→</b> | ١. ا | | - | | | | LD (HL), r | (HL) ← r | • | • | • | • | • | • | 01 | | r | 1 | 2 | 7 | | | | LD (IX+d), r | (IX+d) ← r | • | • | • | • | • | • | 11 | | 101 | 3 | 5 | 19 | | | | | | | | | | | | <br>← | 110<br>d | r<br>→ | | | | | | | ID (IV+4) • | (IY+d) ← r | | | | | | | 1 | -111 | | 3 | 5 | 19 | | | | LD (IY+d), r | (11+4) -1 | • | • | • | ٦ | • | • | 1 | 110 | r | ' | 3 | 17 | | | | | | | | | | | | ļ., | d | → | 1 | | | | | | LD (HL), n | (HL) ← n | | | ١. | | | | ı | 110 | | 2 | 3 | 10 | | | | 22 (112), 11 | (112) | _ | | | | | | - | n | → | - | | | | | | LD (IX+d), n | (IX+d) ← n | | • | | • | • | | 11 | 011 | 101 | 4 | 5 | 19 | | | | ( , , , , , , , , , , , , , , , , , , , | | | | | | | | | 110 | | | | | | | | | | | | | | | l | ← | d | <b>→</b> | | | | | | | | | | | | | | | <b> </b> - | n | <b>→</b> | | | | | | | LD (IY+d), n | (IY+d) ← n | • | • | • | • | • | • | 11 | 111 | 101 | 4 | 5 | 19 | | | | | | | | | | | | 00 | 110 | 110 | | | | | | | | | | | | | | | - | d | <b>→</b> | | | | | | | | | | | | | | | - | n | <b>→</b> | | | | | | | LD A, (BC) | <b>A</b> ← (BC) | • | • | • | • | • | • | | 001 | | 1 | 2 | 7 | | | | LD A, (DE) | <b>A</b> ← (DE) | • | • | • | • | • | • | 1 | 011 | | 1 | 2 | 7 | | | | LD A, (nn) | A ← (nn) | • | • | • | • | • | • | 1 | 111 | | 3 | 4 | 13 | | | | | | | | | | | | - | n | <b>→</b> | | | | | | | ID (BC) A | (BC) A | ا ا | | | ا ا | | | 1 | n | →<br>010 | ١, ا | , | 7 | | | | LD (BC), A | (BC) ← A<br>(DE) ← A | • | • | • | • | • | : | 1 | 000 | | 1 | 2 2 | 7 | | | | LD (DE), A | (DE) ← A<br>(nn) ← A | | • | | | • | | | 110 | | 3 | 4 | 13 | | | | LD (nn), A | (IIII) — A | | Ĭ | • | • | | ľ | 1 | n | → | ' | • | 13 | | | | | | | | | | | | | n | <i>→</i> | | | | | | | LD A, I | A ← ſ | | ı | IF | f t | 0 | 0 | 11 | 101 | | 2 | 2 | 9 | | | | , • | | | | | | | اً | | 010 | | _ | _ | | | | | LD A, R | A ← R | | <b>‡</b> | IF | F ‡ | 0 | 0 | | 101 | | 2 | 2 | 9 | | | | | | | | | | | | 1 | 011 | | | | | | | | LD I, A | I ← A | | • | • | • | • | • | 1 | 101 | | 2 | 2 | 9 | | | | | | | | | | | | 01 | 000 | 111 | | | | | | | LD R, A | R ← A | • | • | • | • | • | • | 11 | 101 | 101 | 2 | 2 | 9 | | | | , | | | | | | | | 01 | 001 | 111 | | | | | | | ' | . ' | • | . ' | • | | | • | • | | | | | . ' | | | Notes: r, r' means any of the registers A, B, C, D, E, H, L IFF the content of the interrupt enable flip-flop (IFF) is copied into the P/V flag Flag Notation: • = flag not affected, 0 = flag reset, 1 = flag set, X = flag is unknown, **‡** = flag is affected according to the result of the operation. 8-BIT LOAD GROUP TABLE 7.0-1 | ı | | Flags | | | | _ ( | Op-C | ode | No. No. | | No. | | | | | |------------------------|----------------------------------------------------|-------|----|-------------|----|-----|------|---------------|---------|------------|-------------|----------------|----------------|-----|-------| | Mnemonic | Symbolic<br>Operation | С | z | <b>1</b> /v | s | N | н | 76 | 543 | 210 | of<br>Bytes | of M<br>Cycles | of T<br>States | Com | ments | | LD dd, nn | dd ← nn | • | • | • | | • | • | $\overline{}$ | dd0 | | 3 | 3 | 10 | dd | Pair | | | | | | | | | | - | n | - | | | | 00 | BC | | | | | | | П | | | - | n | - | | | | 01 | DE | | LD IX, nn | IX ← nn | • | • | • | • | • | • | 11 | 011 | 101 | 4 | 4 | 14 | 10 | HL | | | | | | | | | | 00 | 100 | 001 | - | | | 11 | SP | | | | | | | | | | - | n | - | | | | | | | | | | | | | | | - | n | <b>→</b> | | 4 | ١., | | | | LD IY, nn | IY ← nn | • | • | • | • | • | • | | | 101 | 4 | 4 | 14 | | | | | | | | | | | | | 100 | 001 | | | | | | | | | | | | | | | | n | <b>→</b> | | | | | | | LD HL, (nn) | H ← (nn+1) | | | | | | | 00 | | 010 | 3 | 5 | 16 | | | | LD IIL, (III.) | L ← (nn) | 1 | | | | | | | n | <b>-</b> | - | - | | | | | | _ (, | | | | | | | - | n | - | | | | | | | LD dd, (nn) | dd <sub>H</sub> ← (nn+1) | • | • | • | | • | • | 11 | 101 | 101 | 4 | 6 | 20 | | | | | dd <sub>L</sub> ← (nn) | l | | | | l | | 01 | ddl | 011 | | | l | | | | | _ ~ | | | | | | | - | n | <b>→</b> | | | | | | | | | | | | 1 | | | ← | n | - | | | | | | | LD IX, (nn) | IX <sub>H</sub> ← (nn+1) | • | ١• | • | • | • | • | | | 101 | 4 | 6 | 20 | | | | | IX <sub>L</sub> ← (nn) | | | | | | | 00 | | 010<br>→ | | | | | | | | | | l | | | | | - | n<br>n | _ | | | | | | | LD IY, (nn) | IY <sub>H</sub> ← (nn+1) | | | | | | | 11 | 111 | 101 | 4 | 6 | 20 | ŀ | | | LD 11, (iii) | IY <sub>L</sub> ← (nn) | ľ | ľ | ľ | ľ | ľ | ľ | 00 | | 010 | | • | | | | | | | | | | | | | - | n | - | | ŀ | | | | | | | | l | | | | | - | n | - | | | | | | | LD (nn), HL | (nn+1) ← H | • | • | • | • | • | • | 00 | 100 | 010 | 3 | 5 | 16 | | | | | (nn) ← L | | l | 1 | | | | - | n | - | | 1 | | | | | | | | | | | | | - | n | - | | ١. | l | | | | LD (nn), dd | (nn+1) ← dd <sub>H</sub> | • | • | • | • | • | • | | | 101 | 4 | 6 | 20 | | | | | (nn) ← dd <sub>L</sub> | | | l | | | | 01 | | 011 | | l | | | | | | | | | | | | | ΙΞ | n<br>n | - | | | | | | | LD (nn), IX | (nn+1) ← IX <sub>H</sub> | | | | | ١. | | 11 | | 101 | 4 | 6 | 20 | | | | 22 (111), 170 | (nn) ← IX <sub>L</sub> | | | | | | | 00 | | 010 | | - | | | | | | ,, <u>L</u> | ł | | | | | | - | n | - | | | | | | | | | | | | | ! | | - | n | - | | | | | | | LD (nn), IY | (nn+1) ← IY <sub>H</sub> | • | • | • | • | • | • | | | 101 | 4 | 6 | 20 | | | | | (nn) ← IY <sub>L</sub> | l | | | | | | 00 | 100 | 010 | | | | | | | | | 1 | | | | | | - | n | <b>→</b> | | | | | | | | | ١. | ١. | ١. | ١. | ١. | | ١ | n | →<br>001 | 1 | 1 | 6 | | | | LD SP, HL<br>LD SP, IX | SP ← HL<br>SP ← IX | : | : | | : | | 1 | 1 | | 001<br>101 | 2 | 2 | 10 | | | | LD SF, IX | 31 - 12 | ľ | ľ | ľ | ľ | ľ | ľ | | | 001 | * | 1 | ." | | | | LD SP, IY | SP ← IY | ١. | | | ١. | | | | | 101 | 2 | 2 | 10 | | | | , | | | l | | l | | | | | 001 | | | | 99 | Pair | | PUSH qq | $(SP-2) \leftarrow qq_L$ | • | • | • | • | • | • | 11 | qq0 | 101 | 1 | 3 | 11 | 00 | BC | | | (SP-1) ← qq <sub>H</sub> | 1 | ı | | l | | İ | | | | | | 1 | 01 | DE | | PUSH IX | $(SP-2) \leftarrow IX_L$ | • | ١• | • | • | • | • | | | 101 | 2 | 4 | 15 | 10 | HL | | | (SP-1) ← IX <sub>H</sub> | | 1 | 1 | 1 | 1 | 1 | | | 101 | ١. | ١. | ١., | 11 | AF | | PUSH IY | (SP-2) ← IY <sub>L</sub> | • | • | • | • | • | • | | | 101 | 2 | 4 | 15 | | | | BOD | (SP-1) ← IYH | ۱. | ١. | 1. | 1. | ١. | ١. | | | 101 | ١, | 3 | 10 | | | | POP qq | qq <sub>H</sub> (SP+1) | • | • | ١. | • | • | • | ۱" | ddr | 001 | ' | ' | 1.0 | | | | POP IX | qq <sub>L</sub> ← (SP)<br>IX <sub>H</sub> ← (SP+1) | | ١. | ١. | ١. | ١. | ١. | ١,, | 011 | 101 | 2 | 4 | 14 | | | | | $IX_{L} \leftarrow (SP)$ | ١ | ٦ | ľ | ۱ | ۱ | ۱ | | | 001 | _ | | 1 | | | | POP :Y | IY <sub>H</sub> - (SP+1) | | | ١. | | | | | | 101 | 2 | 4 | 14 | | | | | IY - (SP) | | 1 | | | | | 11 | 100 | 001 | | | | | | | | . L | • | • | • | • | • | • | ' | | | • | • | • | • | | Notes: dd is any of the register pairs BC, DE, HL, SP qq is any of the register pairs AF, BC, DE, HL (PAIR)<sub>H</sub>, (PAIR)<sub>L</sub> refer to high order and low order eight bits of the register pair respectively. E.g. BC<sub>L</sub> = C, AF<sub>H</sub> = A Flag Notation: e = flag not affected, 0 = flag reset, 1 = flag set, X = flag is unknown, † flag is affected according to the result of the operation. **16-BIT LOAD GROUP TABLE 7.0-2** | | | | | F | lags | | | - | Op- | Co <b>d</b> e | | 1 | | | |-------------|---------------------------------------------------------------------------------------------------------------------------------------|-----|--------|---------------------|----------|---|---|-----|------------|---------------|--------------------|-----------------------|-----------------------|---------------------------------------------------------------------------------| | Mnemonic | Symbolic<br>Operation | C | z | P <sub>/</sub><br>V | s | N | н | 7,6 | 541 | 210 | No.<br>of<br>Bytes | No.<br>of M<br>Cycles | No.<br>of T<br>States | Comments | | EX DE, HL | DE ·· HL | • | • | + | • | | • | +- | | 011 | 1 | 1 | 4 | Comments | | EX AF, AF' | AF ·· AF' | | | | | | | 1 | | 000 | 1 | ı | 4 | | | EXX | (BC)<br>DE',<br>HL') | • | • | • | • | • | • | 1 | | 001 | 1 | 1 | 4 | Register bank and<br>auxiliary register<br>bank exchange | | EX (SP), HL | $H \leftrightarrow (SP+1)$<br>$L \leftrightarrow (SP)$ | • | • | • | • | • | • | 11 | 100 | 011 | 1 | 5 | 19 | | | EX (SP), IX | $IX_{H} \leftrightarrow (SP+1)$<br>$IX_{L} \leftrightarrow (SP)$ | • | • | • | • | • | • | 1 | | 101<br>011 | 2 | 6 | 23 | | | FX (SP), IY | $\begin{array}{c} \text{IY}_{\text{H}} \leftrightarrow (\text{SP+1}) \\ \text{IY}_{\text{L}} \leftrightarrow (\text{SP}) \end{array}$ | • | • | • | • | • | • | 1 | | 101 | 2 | 6 | 23 | | | LDI | (DE) ← (HL) DE ← DE+1 HL ← HL+1 BC ← BC-1 | • | • | 1 | • | 0 | 0 | 1 | | 101 | 2 | 4 | 16 | Load (HL) into (DE), increment the pointers and decrement the byte counter (BC) | | LDIR | (DE) ← (HL) | • | • | 0 | • | 0 | 0 | 111 | 101 | 101 | 2 | 5 | 21 | If BC ≠ 0 | | | DE ← DE+1<br>HL ← HL+1<br>BC ← BC-1<br>Repeat until | | | | | | | 10 | 110 | 000 | 2 | 4 | 16 | If BC = 0 | | L.DD | BC = 0<br>(DE) ← (HL)<br>DE ← DE-1<br>HL ← HL-1<br>BC ← BC-1 | • | • | 1 | • | υ | 0 | 1 | | 101<br>000 | 2 | 4 | 16 | | | LDDR | (DE) ← $(HL)DE$ ← $DE$ -1<br>HL ← $HL$ -1<br>BC ← $BC$ -1<br>Repeat until<br>BC = 0 | • | • | 0 | • | 0 | 0 | 1 | | 101<br>000 | 2 2 | 5 | 21<br>16 | If BC ≠ 0<br>If BC = 0 | | СРІ | A - (HL)<br>HL ← HL+1<br>BC ← BC-1 | • | 1 | 1 | ‡ | 1 | ţ | ı | 101<br>100 | | 2 | 4 | 16 | | | ('PIR | $A = (HL)$ $HL \leftarrow HL+1$ $BC \leftarrow BC-1$ $Repeat until$ $A = (HL)$ or $BC = 0$ | • | 1 | 1 | <b>1</b> | 1 | ‡ | ı | 101<br>110 | | 2 2 | 5 | 21 | If BC $\neq$ 0 and A $\neq$ (HL) If BC = 0 or A = (HL) | | CPD | A - (HL)<br>HL HL-1<br>BC ← BC-1 | - 1 | ②<br>! | - 1 | <b>‡</b> | 1 | 1 | ı | 101<br>101 | | 2 | 4 | 16 | | | CPDR | A - (HL) HL + HL-1 BC + BC-1 Repeat until A = (HL) or BC = 0 | - 1 | 2 | - 1 | I I | 1 | 1 | | 101<br>111 | | 2 2 | 5 4 | 21<br>16 | If BC $\neq$ 0 and A $\neq$ (HL)<br>If BC = 0 or A = (HL) | Notes: ① P/V flag is 0 if the result of BC-1 = 0, otherwise P/V = 1 Flag Notation: • = flag not affected, 0 = flag reset, 1 = flag set, X = flag is unknown, ‡ = flag is affected according to the result of the operation. ② Z flag is 1 if A = (HL), otherwise Z = 0. | ı | | Flags | | | | | | Op-Code | | ١ | ١ | l | | | | |---------------|--------------------------------|-------|---|---------------------|---|-----|---|---------|-------|----------|--------------------|-----------------------|-----------------------|--------------------|---------------------------| | Mnemonic | Symbolic<br>Operation | С | z | P <sub>/</sub><br>V | s | N | н | 76 | 6 543 | 210 | No.<br>of<br>Bytes | No.<br>of M<br>Cycles | No.<br>of T<br>States | Comme | nts | | ADD A, r | $A \leftarrow A + r$ | ‡ | ţ | ν | t | 0 | 1 | 10 | 000 | r | 1 | 1 | 4 | r | Reg. | | ADD A, n | <b>A</b> ← <b>A</b> + <b>n</b> | ‡ | ‡ | V | t | 0 | 1 | 1 | 1 000 | 110 | 2 | 2 | 7 | 000 | В | | | | | | | | | | - | n | - | | | | 001<br>010 | C<br>D | | ADD A, (HL) | $A \leftarrow A + (HL)$ | 1 | t | V | ‡ | 0 | ‡ | 10 | 000 | 110 | 1 | 2 | 7 | 011 | E | | ADD A, (IX+d) | $A \leftarrow A + (IX + d)$ | t | ţ | v | ţ | 0 | t | 11 | 011 | 101 | 3 | 5 | 19 | 100 | Н | | | | | | | | | l | 10 | 000 | 110 | | | | 101<br>111 | L<br>A | | | | | | | | l | | - | d | <b>→</b> | | | | | , • | | ADD A, (IY+d) | A←A+(IY+d) | ‡ | 1 | v | 1 | 0 | ‡ | 11 | 1111 | 101 | 3 | 5 | 19 | | | | | | l | | | | | İ | 10 | 000 | 110 | | | | | | | | | | | | | | | - | d | - | | | | | | | ADC A, s | $A \leftarrow A + s + CY$ | ‡ | ‡ | v | ‡ | 0 | ţ | | 001 | | | | | s is any | | | SUB s | A ← A - s | ţ. | ‡ | v | ŧ | 1 | ţ | | 010 | | | | | (HL), (I | | | SBC A, s | $A \leftarrow A - s - CY$ | t | t | v | ţ | 1 | ţ | | 011 | | | | | | as shown for<br>struction | | AND s | $A \leftarrow A \wedge s$ | 0 | t | P | ţ | 0 | 1 | | 100 | | | | | | | | OR s | $A \leftarrow A \lor s$ | 0 | ţ | P | ţ | 0 | 0 | | 110 | | | | | | icated bits | | XOR s | A ← A ⊕ s | 0 | t | Ρ. | 1 | 0 | 0 | | 101 | | | | | | the 000 in Diset above. | | CP s | A - s | 1 | ‡ | v | ţ | i | ţ | 1 | 111 | | | | | the ADI | o set above. | | INC r | r r + 1 | • | ţ | V | 1 | 0 | 1 | 00 | ) r [ | 100 | 1 | 1 | 4 | | | | INC (HL) | $(HL) \leftarrow (HL)+1$ | • | 1 | v | ţ | 0 | t | 00 | 110[ | 100 | 1 | 3 | 11 | | | | INC (IX+d) | (IX+d) +- | • | t | V | ŧ | 0 | ţ | 11 | 011 | 101 | 3 | 6 | 23 | | | | | (IX+d)+1 | | | | | | | 00 | 110[ | 100 | | | | | | | | | | | | | | | 1 | d | | | | | | | | INC (IY+d) | (IY+d) ← | • | ‡ | V | 1 | 0 | 1 | 11 | 111 | 101 | 3 | 6 | 23 | | | | | (IY+d) + 1 | | | | | | | 00 | 110 | 100 | | | | | | | | | | | | | | | - | d | | | | | | | | DEC m | m←m-1 | • | ‡ | V | ŧ | 1 | ı | | [ | 101 | | | | | of r, (HL), | | ı | ' | ' | | | ' | . ' | • | 1 | | , | ' | 1 | , | (IX+d),<br>shown f | (IY+d) as | | | | | | | | | | | | | | | | SHOWN | OF FIRE | Same format and states as INC. Replace 100 with 101 m OP code. Notes: The V symbol in the P/V flag column indicates that the P/V flag contains the overflow of the result of the operation. Similarly the P symbol indicates parity, V=1 means overflow, V=0 means not overflow, P=1 means parity of the result is even, P=0 means parity of the result is odd. - Flag Notation: = flag not affected, 0 = flag reset, 1 = flag set, X = flag is unknown, t = flag is affected according to the result of the operation. 8-BIT ARITHMETIC AND LOGICAL GROUP **TABLE 7.0-4** | | l | Flags | | | | | | | Ор-С | ode | l | l | I . | 1 | |----------|------------------------------------------------------------------------------------------------------------|-------|---|---------------------|---|---|---|----|------------|-----|--------------------|-----------------------|-----------------------|-------------------------------------------------| | Mnemonic | Symbolic<br>Operation | C | z | P <sub>/</sub><br>V | s | N | н | 76 | 543 | 210 | No.<br>of<br>Bytes | No.<br>of M<br>Cycles | No.<br>of T<br>States | Comments | | DAA | Converts acc,<br>content into<br>packed BCD<br>following add<br>or subtract<br>with packed<br>BCD operands | ‡ | ‡ | P | ‡ | • | ‡ | 00 | 100 | 111 | 1 | 1 | 4 | Decimal adjust accumulator | | CPL | <b>A</b> ← Ā | • | • | • | • | 1 | 1 | 00 | 101 | 111 | 1 | 1 | 4 | Complement<br>accumulator<br>(one's complement) | | NEG. | A ← 0 − A | ‡ | ‡ | v | ‡ | 1 | ‡ | 11 | 101<br>000 | 101 | 2 | 2 | 8 | Negate acc. (two's complement) | | CCF | $CY \leftarrow \overline{CY}$ | ‡ | • | • | • | 0 | x | | 111 | | 1 | 1 | 4 | Complement carry | | SCF | CY ← 1 | 1 | • | • | • | 0 | 0 | 00 | 110 | 111 | 1 | 1 | 4 | Set carry flag | | NOP | No operation | • | • | • | • | • | • | 00 | 000 | 000 | 1 | 1 | 4 | | | HALT | CPU halted | • | • | • | • | • | • | 01 | 110 | 110 | 1 | 1 | 4 | | | DI | IFF ← 0 | • | • | • | • | • | • | 11 | 110 | 011 | 1 | 1 | 4 | | | EI | IFF ← 1 | • | • | • | • | • | • | 11 | 111 | 011 | 1 | 1 | 4 | | | IM 0 | Set interrupt<br>mode 0 | • | • | • | • | • | • | ı | 101<br>000 | | 2 | 2 | 8 | | | IM 1 | Set interrupt<br>mode 1 | • | • | • | • | • | • | | 101<br>010 | | 2 | 2 | 8 | | | IM2 | Set interrupt<br>mode 2 | • | • | • | • | • | • | 11 | 101<br>011 | 101 | 2 | 2 | 8 | | Notes: IFF indicates the interrupt enable flip-flop CY indicates the carry flip-flop. Flag Notation: • = flag not affected, 0 = flag reset, 1 = flag set, X = flag is unknown, t = flag is affected according to the result of the operation. GENERAL PURPOSE ARITHMETIC AND CPU CONTROL GROUPS TABLE 7.0-5 | | Symbolic | Flags | | | | | | Op-Code | | | No. | No.<br>of M | No.<br>of T | | | |----------------|----------------------------|-------|----------|-----------------|----------|---|---|-------------------------------------------|----------------------|-----|-------|-------------|-------------|------------------------|--------------------------------------------| | Mnemonic | | c | Z | P <sub>/V</sub> | S | N | Н | 76 54 | 3 21 | 0 | Bytes | Cycles | States | Comme | nts | | ADD HL, ss | HL ← HL+ss | : | • | • | • | 0 | х | 00 ss | 1 00 | 1 | 1 | 3 | 11 | 35 | Reg. | | ADC HL, ss | HL+HL+ ss +CY | : | <b>‡</b> | v | ‡ | 0 | x | 11 10<br><b>01 ss</b> | | - 1 | 2 | 4 | 15 | 00<br>01<br>10<br>11 | BC<br>DE<br>HL<br>SP | | SBC HL, ss | HL←HL-ss-CY | ‡ | <b>‡</b> | v | <b>‡</b> | 1 | x | 11 10 | 1 10 | 1 | 2 | 4 | 15 | 11 | Sr | | ADD IX, pp | | ‡ | • | • | • | | | 01 ss<br>11 01<br>00 pp<br>11 11<br>00 rr | 1 10<br>1 00<br>1 10 | 1 1 | 2 | 4 | 15 | PP 00 01 10 11 m 00 00 | Reg.<br>BC<br>DE<br>IX<br>SP<br>Reg.<br>BC | | INC ss | ss ← ss + 1<br>1X ← IX + 1 | • | • | • | | | | 00 ss0 | | | 1 2 | 1 | 6 | 01<br>10<br>11 | DE<br>IY<br>SP | | INC IY DEC ss | IY ← IY + 1 ss ← ss - 1 | • | • | • | • | • | • | 00 10<br>11 11<br>00 10<br>00 ss | 1 10<br>0 01 | 1 | 2 | 2 | 10<br>6 | | | | DEC IX | IX + IX - 1 IY + IY - 1 | • | • | • | • | • | • | 11 <b>0</b> 1 00 10 11 11 00 10 | 1 01<br>1 10 | 1 | 2 | 2 | 10 | | | | | | | | | | | | 100 10 | | . 1 | | | | | | Notes: ss is any of the register pairs BC, DE, HL, SP pp is any of the register pairs BC, DE, IX, SP rr is any of the register pairs BC, DE, IY, SP. Flag Notation: • = flag not affected, 0 = flag reset, 1 = flag set, X = flag is unknown, t = flag is affected according to the result of the operation. **16-BIT ARITHMETIC GROUP TABLE 7.0-6** | | İ | Flags | | | | | | Op-Code | l | | | | |------------|-----------------------------------------------|-------|----------|---------|---|---|---|----------------------------------------------|--------------------|-----------------------|-----------------------|-----------------------------------------------------------------------------------| | Mnemonic | Symbolic<br>Operation | c | z | P/<br>V | s | N | н | 76 543 210 | No.<br>of<br>Bytes | No.<br>of M<br>Cycles | No.<br>of T<br>States | Comments | | RLCA | CY 7 - 0- | ‡ | • | • | • | 0 | 0 | 00 000 111 | 1 | 1 | 4 | Rotate left circular accumulator | | RLA | CY = 7 = 0= | ‡ | • | • | • | 0 | 0 | 00 010 111 | 1 | 1 | 4 | Rotate left<br>accumulator | | RRCA | 7 0 CY | ŧ | • | • | • | 0 | 0 | 00 001 111 | 1 | 1 | 4 | Rotate right circular accumulator | | RRA | 7 - 0 - CY | ‡ | • | • | • | 0 | 0 | 00 011 111 | 1 | 1 | 4 | Rotate right<br>accumulator | | RLC r | ) | ŧ | ‡ | P | ŧ | 0 | 0 | 11 001 011<br>00 000 r | 2 | 2 | 8 | Rotate left circular<br>register r | | RLC (HL) | | ‡ | ‡ | P | ‡ | 0 | 0 | 11 001 011 | 2 | 4 | 15 | r Reg. | | RLC (IX+d) | 7 — 0 r, (HL), (IX+d), (IY+d) | ‡ | ‡ | P | ‡ | 0 | 0 | 00 000 110<br>11 011 101<br>11 001 011 | 4 | 6 | 23 | 000 B | | RLC (IY+d) | | ‡ | ŧ | P | ‡ | 0 | 0 | ← d → 00 000 110 11 111 101 11 001 011 ← d → | 4 | 6 | 23 | 100 H<br>101 L<br>111 A | | RL m | m : r. (HL), (IX+d), (IV+d) | ‡ | ‡ | P | ‡ | 0 | 0 | 010 | | | | Instruction format and states are as shown for RLC,m. To form | | RRC m | 7 0 CY<br>m r, (HL), (IX+d), (IY+d) | ‡ | ‡ | P | : | 0 | 0 | 001 | • | | | new OP-code replace<br>000 of RLC,m with<br>shown code | | RR m | 7 0 CY m ≡ r. (HL). (IX+d). (IY+d) | : | ‡ | P | | 0 | 0 | 011 | | | | | | SLA m | CY 7 0 0 0<br>m ÷ r. (HL). (IX+d). (IY+d) | : | : | P | ‡ | 0 | 0 | 100 | | | | | | SRA m | 7 - 0 - CY<br>m · r, (HL), (IX+d), (IY+d) | : | : | P | ŀ | 0 | 0 | 101 | | | | | | SRL m | 0 - 7 - 0 - CY<br>m = r, (HL), (IX+d), (IY+d) | : | | P | : | 0 | 0 | 111 | | | | | | RLD | A 7 43 0 7 43 0 (HL) | • | ; | P | : | 0 | 0 | 11 101 101<br>01 101 111 | 2 | 5 | 18 | Rotate digit left and right between the accumulator | | RRD | A7 43 9 7 43 9(HL) | • | <b>‡</b> | P | ‡ | 0 | 0 | 11 101 101<br>01 100 111 | 2 | 5 | 18 | and location (HL). The content of the upper half of the accumulator is unaffected | Flag Notation: • = flag not affected, 0 = flag reset, 1 = flag set, X = flag is unknown, ‡ = flag is affected according to the result of the operation. **ROTATE AND SHIFT GROUP TABLE 7.0-7** | | | Flags | | | | | | | )p-( c | de | No. | No. | | | | |---------------|----------------------------------------------------------------|-------|----|---------------------|---|---|---|----|-----------------|-------------------------------|-------------|----------------|-----------------------|-----------------------------------------------|------------------------------------------------------------------------| | Mnemonic | Symbolic<br>Operation | С | z | P <sub>/</sub><br>V | s | Z | н | 76 | 543 | 210 | of<br>Bytes | of M<br>Cycles | No.<br>of T<br>States | Comm | ents | | BIT b, r | $Z \leftarrow \overline{r}_b$ | • | \$ | х | х | 0 | 1 | , | | 011 | 2 | 2 | 8 | r | Reg. | | BIT b, (HL) | $z \leftarrow \overline{(HL)}_b$ | • | ŧ | x | x | 0 | 1 | 11 | b<br>001<br>b | r<br>011<br>110 | 2 | 3 | 12 | 000<br>001<br>010<br>011 | B<br>C<br>D<br>E | | BIT b, (IX+d) | $Z \leftarrow \overline{(IX+d)}_b$ | • | ‡ | х | х | 0 | 1 | | 011<br>001<br>d | 101<br>011<br>→ | 4 | 5 | 20 | 100<br>101<br>111 | H<br>L<br>A | | BIT b, (IY+d) | $Z \leftarrow \overline{(IY+d)}_b$ | • | ŧ | х | х | 0 | 1 | | 111<br>001<br>d | 110<br>101<br>011<br>→<br>110 | 4 | 5 | 20 | 000<br>001<br>010<br>011<br>100<br>101<br>110 | Bit Tested 0 1 2 3 4 5 6 7 | | SET b, r | r <sub>b</sub> ← 1 | • | • | • | • | • | • | | 001 | | 2 | 2 | 8 | 111 | , | | SET b, (HL) | (HĽ) <sub>b</sub> ← 1 | • | • | • | • | • | • | _ | b<br>001<br> b | r<br>011<br>110 | 2 | 4 | 15 | | | | SET b, (IX+d) | (IX+d) <sub>b</sub> ← 1 | • | • | • | • | • | • | 1 | 011<br>001<br>d | 101 | 4 | 6 | 23 | | | | SET b, (IY+d) | (IY+d) <sub>b</sub> ← 1 | • | • | • | • | • | • | 11 | 111<br>001<br>d | 101<br>011<br><br>110 | 4 | 6 | 23 | | | | RES b, m | $s_b \leftarrow 0$<br>$m \equiv r, (HL),$<br>(IX+d),<br>(IY+d) | | | | | | | 10 | ] | | | | | code re<br>of SET<br>10. Fl | m new OP-<br>eplace [1]<br>b,m with<br>ags and time<br>for SET<br>tion | | | | | | | | | | | | | | | | | | Notes: The notation $s_b$ indicates bit b (0 to 7) or location s. Flag Notation: • = flag not affected, 0 = flag reset, 1 = flag set, X = flag is unknown, # = flag is affected according to the result of the operation. BIT SET, RESET AND TEST GROUP TABLE 7.0-8 | | 1 | Flags | | | Эр-Сс | ode | 1 | ۱ | ١ | l | | | | | |-----------|--------------------------------------|-------|---|---------------------|-------|-----|---|--------------|-------------------|---------------|--------------------|-----------------------|-----------------------|--------------------------------------------------------------------------------------------------------------------------| | Mnemonic | Symbolic<br>Operation | С | z | P <sub>/</sub><br>V | s | N | н | 76 | 543 | 210 | No.<br>of<br>Bytes | No.<br>of M<br>Cycles | No.<br>of T<br>States | Comments | | JP nn | PC ← nn | • | • | • | • | • | • | 1 | 000 | 011 | 3 | 3 | 10 | | | JP cc, nn | If condition cc is true PC ←nn, | • | | | • | • | | ←<br>11<br>← | n<br>n<br>cc<br>n | →<br>010<br>→ | 3 | 3 | 10 | cc Condition 000 NZ non zero 001 Z zero | | JR e | otherwise<br>continue<br>PC ← PC + e | • | • | • | • | • | | ı | n<br>011<br>e-2 | | 2 | 3 | 12 | 010 NC non carry<br>011 C carry<br>100 PO parity odd<br>101 PE parity even<br>110 P sign positive<br>111 M sign negative | | JR C, e | If C = 0,<br>continue | • | • | • | • | • | • | 00 | 111<br>e-2 | 000 | 2 | 2 | 7 | If condition not met | | | If C = 1,<br>PC ← PC+e | | | | | | | | | | 2 | 3 | 12 | If ∞ndition is met | | JR ŅC, e | If C = 1, continue | • | • | • | • | • | • | | 110<br>e-2 | 000<br>→ | 2 | 2 | 7 | If condition not met | | | If C = 0,<br>PC ← PC + e | | | | | | | | | | 2 | 3 | 12 | If condition is met | | JR Z, e | If Z = 0<br>continue | • | • | • | • | • | • | | 101<br>e-2 | 000<br>→ | 2 | 2 | 7 | If condition not met | | | If Z = 1,<br>PC ← PC + e | | | | | | | | | | , 2 | 3 | 12 | If condition is met | | JR NZ, e | If Z = 1,<br>continue | • | • | • | • | • | • | | 100<br>e-2 | 1 | 2 | 2 | 7 | If condition not me | | | If Z = 0,<br>PC ← PC + e | | | | | | | | | | 2 | 3 | 12 | If condition met | | JP (HL) | PC ← HL | • | • | ٠ | • | • | • | 11 | 101 | 001 | 1 | 1 | 4 | | | JP (IX) | PC ← IX | • | • | • | • | • | • | | 011<br>101 | | 2 | 2 | 8 | | | JP (IY) | PC ← IY | • | • | • | • | • | ٠ | 11 | 111<br>101 | 101 | 2 | 2 | 8 | | | DJNZ,e | B ← B-1<br>If B = 0,<br>continue | • | • | • | • | • | ٠ | | 010<br>e-2 | 000 | 2 | 2 | 8 | lf B = 0 | | | If B ≠ 0,<br>PC ← PC + e | | | | | | | | | | 2 | 3 | 13 | IF B ≠ 0 | Notes: e represents the extension in the relative addressing mode. e is a signed two's complement number in the range <-126, 129> e-2 in the op-code provides an effective address of pc +e $\,$ as PC is incremented by 2 prior to the addition of e. Flag Notation: • = flag not affected, 0 = flag reset, 1 = flag set, X = flag is unknown, # = flag is affected according to the result of the operation. JUMP GROUP TABLE 7.0-9 | | | Flags | | | 0 | р-Сс | de | No. | No. | No. | | | | | |-------------|----------------------------------------------------------------------------------------------|-------|---|---------|---|------|----|--------------|---------------|-----------------------|-------------|----------------|----------------|----------------------------------------------------------------------------------------------------------| | Mnemonic | Symbolic<br>Operation | С | z | P/<br>V | s | Z | н | 76 | 543 | 210 | of<br>Bytes | of M<br>Cycles | of T<br>States | Comments | | CALL nn | (SP-1)←PC <sub>H</sub><br>(SP-2)←PC <sub>L</sub><br>PC←nn | • | • | • | • | • | • | 11<br>←<br>← | 001<br>n<br>n | 101<br>→<br>→ | 3 | 5 | 17 | | | CALL cc, nn | If condition<br>cc is false<br>continue,<br>otherwise | • | • | • | | • | • | 11<br>←<br>← | cc<br>n<br>n | 100<br>→<br>→ | 3 | 3 5 | 10<br>17 | If cc is false If cc is true | | RET | same as CALL nn PCL←(SP) | | | | | | | 11 | 001 | 001 | 1 | 3 | 10 | | | RET cc | PCH (SP+1) If condition cc is false continue, otherwise same as RET | • | • | | | | • | 11 | сс | 000 | 1 | 3 | 5 | If cc is false If cc is true cc Condition 000 NZ non zero | | RETI | Return from interrupt | | | | | | | | | 1 101<br>1 101 | 2 | 4 | 14 | 001 Z zero 010 NC non carry 011 C carry 100 PO parity odd 101 PE parity even | | RETN | Return from<br>non maskable<br>interrupt | | | • | | | | 01 | | 1 101<br>0 101<br>111 | | 3 | 11 | 110 P sign positive<br>111 M sign negative | | RST p | (SP-1)←PC <sub>H</sub><br>(SP-2)←PC <sub>L</sub><br>PC <sub>H</sub> ←0<br>PC <sub>L</sub> ←P | | | | | | | | | | | | | t P 000 00H 001 08H 010 10H 011 18H 100 20H 101 28H 110 30H 111 38H | Flag Notation: • = flag not affected, 0 = flag reset, 1 = flag set, X = flag is unknown ‡ = flag is affected according to the result of the operation. **CALL AND RETURN GROUP TABLE 7.0-10** | | 1 | Flags | | | | | | ۱ | Эр-С | ode | 1 | ı | l | 1 | |------------|-----------------------------------|-----------------|------|--------------|------------|-----|------------|----------|------------|----------|-----------|----------------------------------------------------------|-------------|-----------------------------------------| | | Symbolic | Γ | Γ | P | Γ | | Γ | | | | No.<br>of | No.<br>of M | No.<br>of T | | | Mnemonic | Operation | C | Z | v | S | N | Н | 76 | 543 | 210 | Bytes | Cycles | States | Comments | | IN A, (n) | A ← (n) | • | | • | • | • | • | 11 | 011 | 011 | 2 | 3 | 11 | n to $A_0 \sim A_7$ | | | | | 1 | | | | | - | n | <b>→</b> | | | | Acc to A <sub>8</sub> ~ A <sub>15</sub> | | IN r, (C) | r ← (C) | • | ‡ | P | 1 | 0 | ţ | 1 | 101 | 101 | 2 | 3 | 12 | C to $A_0 \sim A_7$ | | | if r = 110 only<br>the flags will | | 1 | l | | | | 01 | r | 000 | | 1 | l | B to A <sub>8</sub> ~ A <sub>15</sub> | | | be affected | | | | | | | | | | | | | | | | | | 1 | | l | | | l | | | | | | | | INI | (HL) ← (C) | x | | x | l x | 1 | x | 11 | 101 | 101 | 2 | 4 | 16 | C to A <sub>0</sub> ~ A <sub>7</sub> | | | B ← B - 1 | | | | l | | | | | 010 | | | . " | B to $A_8 \sim A_{15}$ | | | HL ← HL + 1 | l | | | | | | | | | | | | 8 115 | | INIR | (HL) ← (C) | x | 1 | х | x | 1 | x | 11 | 101 | 101 | 2 | 5 | 21 | C to $A_0 \sim A_7$ | | | B ← B - 1 | | | | | | | 10 | 110 | 010 | | $(\text{If B} \neq 0)$ | | B to $A_8^0 \sim A_{15}^7$ | | | HL ← HL + 1 | | | | | | | | | | 2 | 4 | 16 | 8 13 | | | Repeat until | | | | | | | | | | | (If B = 0) | | | | | B = 0 | | | | | | | | | | | | | | | | | | (1) | | | | | ŀ | | | | | | | | IND | (HL) ← (C) | Х | ‡ | X | Х | 1 | Х | | 101 | | 2 | 4 | 16 | C to $A_0 \sim A_7$ | | | B ← B · 1 | | | | | | | 10 | 101 | 010 | | | | B to $A_8 \sim A_{15}$ | | INDR | HL ← HL - 1<br>(HL) ← (C) | x | ١. ا | v | v | | v | ١., | | | _ | | | _ | | INDK | (HL) ← (C)<br>B ← B - 1 | ^ | 1 | Х | х | 1 | Х | | 101<br>111 | | 2 | $(If B \neq 0)$ | 21 | C to $A_0 \sim A_7$ | | | HL ← HL -1 | | | | | | | 10 | 111 | 010 | | (1. 5 + 0) | | B to $A_8 \sim A_{15}$ | | | Repeat until | | | | | | | | | | 2 | 4 | 16 | | | | B = 0 | | | | | | | | | | | (If B = 0) | | | | OUT (n), A | (n) ← A | • | • | • | • | • | • | 11 | 010 | 011 | 2 | 3 | 11 | n to $A_0 \sim A_7$ | | | | | | | | | | <b>←</b> | n - | → | | | | Acc to A <sub>8</sub> ~ A <sub>15</sub> | | OUT (C), r | (C) ← r | • | • | • | • | • | • | 11 | 101 | 101 | 2 | 3 | 12 | C to $A_0 \sim A_7$ | | | | | | | | 1 | | 01 | r | 001 | | | | B to $A_8 \sim A_{15}$ | | | | | 0 | | | - 1 | | | | | | | | 6 13 | | OUTI | (C) ← (HL) | Х | ‡ | X | X | 1 | X | | 101 | | 2 | 4 | 16 | C to $A_0 \sim A_7$ | | | B ← B - 1 | | | | | | | 10 | 100 | 011 | | | | B to $A_8 \sim A_{15}$ | | OTIB | HL ← HL + 1 | | | | | | | | | | | | | | | OTIR | (C) ← (HL)<br>B ← B - 1 | X | 1 | X | X | 1 | X | | 101 | | 2 | $\begin{array}{c} 5 \\ (\text{If B} \neq 0) \end{array}$ | 21 | C to A <sub>0</sub> ~ A <sub>7</sub> | | | HL ← HL + 1 | | - 1 | 1 | 1 | | - 1 | 10 | 110 | 011 | | (11 15 7 0) | | B to A = A 15 | | | Repeat until | | | | | | ı | | | 1 | 2 | 4 | 16 | | | | B = 0 | | - 1 | | | 1 | | | | ı | | (If B = 0) | - 1 | | | | | | പ | | | 1 | | | | | | | l | | | OUTD | (C) ← (HL) | $_{\mathbf{x}}$ | Ÿ | $\mathbf{x}$ | $_{\rm x}$ | ا، | $_{\rm x}$ | 11 | 101 | 101 | 2 | 4 | 16 | Cto A ~ A | | | B ← B - 1 | | | | | 1 | | | 101 - | - 1 | - | , | " | C to $A_0 \sim A_7$ | | | HL ← HL · 1 | | | | | | - | - | | | | | l | B to $A_8 \sim A_{15}$ | | OTDR | (C) ← (HL) | x | 1 | x | x | 1 | χĺ | 11 | 101 | 101 | 2 | 5 | 21 | C to A <sub>0</sub> ~ A <sub>7</sub> | | | B ← B · 1 | | | | | | | | 111 | | l | $(\text{If B} \neq 0)$ | - | B to $A_8 \sim A_{15}$ | | | HL ← HL ·1 | | | | | | | | | | 2 | 4 | 16 | 8 15 | | | Repeat until | - | | | | | | | | J | | (If B = 0) | 16 | | | 1 | B = 0 | 1 | ١ | ١ | ı | | | | | ١ | | " " | 1 | | | | | | | | | | | | | | | | | | Notes: $\bigcirc$ If the result of B - 1 is zero the Z flag is set, otherwise it is reset. Flag Notation: • = flag not affected, 0 = flag reset, 1 = flag set, X = flag is unknown, ‡ = flag is affected according to the result of the operation. INPUT AND OUTPUT GROUP TABLE 7.0-11 ## **8.0 INTERRUPT RESPONSE** The purpose of an interrupt is to allow peripheral devices to suspend CPU operation in an orderly manner and force the CPU to start a peripheral service routine. Usually this service routine is involved with the exchange of data, or status and control information, between the CPU and the peripheral. Once the service routine is completed, the CPU returns to the operation from which it was interrupted. ## INTERRUPT ENABLE - DISABLE The Z80 CPU has two interrupt inputs, a software maskable interrupt and a non maskable interrupt. The non maskable interrupt (NMI) can not be disabled by the programmer and it will be accepted whenever a peripheral device requests it. This interrupt is generally reserved for very important functions that must be serviced whenever they occur, such as an impending power failure. The maskable interrupt (INT) can be selectively enabled or disabled by the programmer. This allows the programmer to disable the interrupt during periods where his program has timing constraints that do not allow it to be interrupted. In the Z80 CPU there is an enable flip flop (called IFF) that is set or reset by the programmer using the Enable Interrupt (EI) and Disable Interrupt (DI) instructions. When the IFF is reset, an interrupt can not be accepted by the CPU. Actually, for purposes that will be subsequently explained, there are two enable flip flops, called $IFF_1$ and $IFF_2$ . IFF<sub>1</sub> IFF<sub>2</sub> Actually disables interrupts from being accepted. Temporary storage location for IFF<sub>1</sub>. The state of IFF<sub>1</sub> is used to actually inhibit interrupts while IFF<sub>2</sub> is used as a temporary storage location for IFF<sub>1</sub>. The purpose of storing the IFF<sub>1</sub> will be subsequently explained. A reset to the CPU will force both $IFF_1$ and $IFF_2$ to the reset state so that interrupts are disabled. They can then be enabled by an EI instruction at any time by the programmer. When an EI instruction is executed, any pending interrupt request will not be accepted until after the instruction following EI has been executed. This single instruction delay is necessary for cases when the following instruction is a return instruction and interrupts must not be allowed until the return has been completed. The EI instruction sets both $IFF_1$ and $IFF_2$ to the enable state. When an interrupt is accepted by the CPU, both $IFF_1$ and $IFF_2$ are automatically reset, inhibiting further interrupts until the programmer wishes to issue a new EI instruction. Note that for all of the previous cases, $IFF_1$ and $IFF_2$ are always equal. The purpose of IFF<sub>2</sub> is to save the status of IFF<sub>1</sub> when a non maskable interrupt occurs. When a non maskable interrupt is accepted, IFF<sub>1</sub> is reset to prevent further interrupts until reenabled by the programmer. Thus, after a non maskable interrupt has been accepted, maskable interrupts are disabled but the previous state of IFF<sub>1</sub> has been saved so that the complete state of the CPU just prior to the non maskable interrupt can be restored at any time. When a Load Register A with Register I (LD A, I) instruction or a Load Register A with Register R (LD A, R) instruction is executed, the state of IFF<sub>2</sub> is copied into the parity flag where it can be tested or stored. A second method of restoring the status of $IFF_1$ is thru the execution of a Return From Non Maskable Interrupt (RETN) instruction. Since this instruction indicates that the non maskable interrupt service routine is complete, the contents of $IFF_2$ are now copied back into $IFF_1$ , so that the status of $IFF_1$ just prior to the acceptance of the non maskable interrupt will be restored automatically. Figure 8.0-1 is a summary of the effect of different instructions on the two enable flip flops. | Action | IFF <sub>1</sub> IFF <sub>2</sub> | | |------------|-----------------------------------|---------------------------------| | CPU Reset | 0 0 | • | | DI | 0 0 | | | EI | 1 1 | | | LD A, I | • • | IFF <sub>2</sub> → Parity flag | | LD A, R | • • | $IFF_2 \rightarrow Parity flag$ | | Accept NMI | 0 • | | | RETN | IFF <sub>2</sub> • | $IFF_2 \rightarrow IFF_1$ | "•" indicates no change # FIGURE 8.0-1 INTERRUPT ENABLE/DISABLE FLIP FLOPS #### **CPU RESPONSE** #### Non Maskable A nonmaskable interrupt will be accepted at all times by the CPU. When this occurs, the CPU ignores the next instruction that it fetches and instead does a restart to location 0066H. Thus, it behaves exactly as if it had received a restart instruction but, it is to a location that is not one of the 8 software restart locations. A restart is merely a call to a specific address in page 0 of memory. #### Maskable The CPU can be programmed to respond to the maskable interrupt in any one of three possible modes. #### Mode 0 This mode is identical to the 8080A interrupt response mode. With this mode, the interrupting device can place any instruction on the data bus and the CPU will execute it. Thus, the interrupting device provides the next instruction to be executed instead of the memory. Often this will be a restart instruction since the interrupting device only need supply a single byte instruction. Alternatively, any other instruction such as a 3 byte call to any location in memory could be executed. The number of clock cycles necessary to execute this instruction is 2 more than the normal number for the instruction. This occurs since the CPU automatically adds 2 wait states to an interrupt response cycle to allow sufficient time to implement an external daisy chain for priority control. Section 5.0 illustrates the detailed timing for an interrupt response. After the application of RESET the CPU will automatically enter interrupt Mode 0. #### Mode 1 When this mode has been selected by the programmer, the CPU will respond to an interrupt by executing a restart to location 0038H. Thus the response is identical to that for a non maskable interrupt except that the call location is 0038H instead of 0066H. Another difference is that the number of cycles required to complete the restart instruction is 2 more than normal due to the two added wait states. #### Mode 2 This mode is the most powerful interrupt response mode. With a single 8 bit byte from the user an indirect call can be made to any memory location. With this mode the programmer maintains a table of 16 bit starting addresses for every interrupt service routine. This table may be located anywhere in memory. When an interrupt is accepted, a 16 bit pointer must be formed to obtain the desired interrupt service routine starting address from the table. The upper 8 bits of this pointer is formed from the contents of the I register. The I register must have been previously loaded with the desired value by the programmer, i.e. LD I, A. Note that a CPU reset clears the I register so that it is initialized to zero. The lower eight bits of the pointer must be supplied by the interrupting device. Actually, only 7 bits are required from the interrupting device as the least significant bit must be a zero. This is required since the pointer is used to get two adjacent bytes to form a complete 16 bit service routine starting address and the addresses must always start in even locations. The first byte in the table is the least significant (low order) portion of the address. The programmer must obviously fill this table in with the desired addresses before any interrupts are to be accepted. Note that this table can be changed at any time by the programmer (if it is stored in Read/Write Memory) to allow different peripherals to be serviced by different service routines. Once the interrupting devices supplies the lower portion of the pointer, the CPU automatically pushes the program counter onto the stack, obtains the starting address from the table and does a jump to this address. This mode of response requires 19 clock periods to complete (7 to fetch the lower 8 bits from the interrupting device, 6 to save the program counter, and 6 to obtain the jump address.) Note that the Z80 peripheral devices all include a daisy chain priority interrupt structure that automatically supplies the programmed vector to the CPU during interrupt acknowledge. Refer to the Z80-PIO, Z80-SIO and Z80-CTC manuals for details. ## 9.0 HARDWARE IMPLEMENTATION EXAMPLES This chapter is intended to serve as a basic introduction to implementing systems with the Z80-CPU. #### **MINIMUM SYSTEM** Figure 9.0-1 is a diagram of a very simple Z-80 system. Any Z-80 system must include the following five elements: - 1) Five volt power supply - 2) Oscillator - 3) Memory devices - 4) I/O circuits - 5) CPU FIGURE 9.0-1 MINIMUM Z80 COMPUTER SYSTEM Since the Z80-CPU only requires a single 5 volt supply, most small systems can be implemented using only this single supply. The oscillator can be very simple since the only requirement is that it be a 5 volt square wave. For systems not running at full speed, a simple RC oscillator can be used. When the CPU is operated near the highest possible frequency, a crystal oscillator is generally required because the system timing will not tolerate the drift or jitter that an RC network will generate. A crystal oscillator can be made from inverters and a few discrete components or monolithic circuits are widely available. The external memory can be any mixture of standard RAM, ROM, or PROM. In this simple example we have shown a single 8K bit ROM (1K bytes) being utilized as the entire memory system. For this example we have assumed that the Z-80 internal register configuration contains sufficient Read/Write storage so that external RAM memory is not required. Every computer system requires I/O circuits to allow it to interface to the "real world." In this simple example it is assumed that the output is an 8 bit control vector and the input is an 8 bit status word. The input data could be gated onto the data bus using any standard tri-state driver while the output data could be latched with any type of standard TTL latch. For this example we have used a Z80-PIO for the I/O circuit. This single circuit attaches to the data bus as shown and provides the required 16 bits of TTL compatible I/O. (Refer to the Z80-PIO manual for details on the operation of this circuit.) Notice in this example that with only three LSI circuits, a simple oscillator and a single 5 volt power supply, a powerful computer has been implemented. ## **ADDING RAM** Most computer systems require some amount of external Read/Write memory for data storage and to implement a "stack." Figure 9.0-2 illustrates how 256 bytes of static memory can be added to the previous example. In this example the memory space is assumed to be organized as follows: FIGURE 9.0-2 ROM & RAM IMPLEMENTATION EXAMPLE In this diagram the address space is described in hexidecimal notation. For this example, address bit A<sub>10</sub> separates the ROM space from the RAM space so that it can be used for the chip select function. For larger amounts of external ROM or RAM, a simple TTL decoder will be required to form the chip selects. ## MEMORY SPEED CONTROL For many applications, it may be desirable to use slow memories to reduce costs. The WAIT line on the CPU allows the Z-80 to operate with any speed memory. By referring back to section 4 you will notice that the memory access time requirements are most severe during the M1 cycle instruction fetch. All other memory accesses have an additional one half of a clock cycle to be completed. For this reason it may be desirable in some applications to add one wait state to the M1 cycle so that slower memories can be used. Figure 9.0-3 is an example of a simple circuit that will accomplish this task. This circuit can be changed to add a single wait state to any memory access as shown in Figure 9.0-4. FIGURE 9.0-3 ADDING ONE WAIT STATE TO AN M1 CYCLE FIGURE 9.0-4 ADDING ONE WAIT STATE TO ANY MEMORY CYCLE #### INTERFACING DYNAMIC MEMORIES This section is intended only to serve as a brief introduction to interfacing dynamic memories. Each individual dynamic RAM has varying specifications that will require minor modifications to the description given here and no attempt will be made in this document to give details for any particular RAM. Separate application notes showing how the Z80-CPU can be interfaced to most popular dynamic RAM's are available from Zilog. Figure 9.0-5 illustrates the logic necessary to interface 8K bytes of dynamic RAM using 18 pin 4K dynamic memories. This figure assumes that the RAM's are the only memory in the system so that $A_{12}$ is used to select between the two pages of memory. During refresh time, all memories in the system must be read. The CPU provides the proper refresh address on lines $A_0$ through $A_6$ . To add additional memory to the system it is necessary to only replace the two gates that operate on $A_{12}$ with a decoder that operates on all required address bits. For larger systems, buffering for the address and data bus is also generally required. FIGURE 9.0-5 INTERFACING DYNAMIC RAMS #### 10.0 SOFTWARE IMPLEMENTATION EXAMPLES #### 10.1 METHODS OF SOFTWARE IMPLEMENTATION Several different approaches are possible in developing software for the Z-80 (Figure 10.1). First of all, Assembly Language or PL/Z may be used as the source language. These languages may then be translated into machine language on a commercial time sharing facility using a cross-assembler or cross-compiler or, in the case of assembly language, the translation can be accomplished on a Z-80 Development System using a resident assembler. Finally, the resulting machine code can be debugged either on a time-sharing facility using a Z-80 simulator or on a Z-80 Development System which uses a Z80-CPU directly. In selecting a source language, the primary factors to be considered are clarity and ease of programming vs. code efficiency. A high level language such as PL/Z with its machine independent constructs is typically better for formulating and maintaining algorithms, but the resulting machine code is usually somewhat less efficient than what can be written directly in assembly language. These tradeoffs can often be balanced by combining PL/Z and assembly language routines, identifying those portions of a task which must be optimized and writing them as assembly language subroutines. Deciding whether to use a resident or cross assembler is a matter of availability and short-term vs. long-term expense. While the initial expenditure for a development system is higher than that for a time-sharing terminal, the cost of an individual assembly using a resident assembler is negligible while the same operation on a time-sharing system is relatively expensive and in a short time this cost can equal the total cost of a development system. Debugging on a development system vs. a simulator is also a matter of availability and expense combined with operational fidelity and flexibility. As with the assembly process, debugging is less expensive on a development system than on a simulator available through time-sharing. In addition, the fidelity of the operating environment is preserved through real-time execution on a Z80-CPU and by connecting the I/O and memory components which will actually be used in the production system. The only advantage to the use of a simulator is the range of criteria which may be selected for such debugging procedures as tracing and setting breakpoints. This flexibility exists because a software simulation can achieve any degree of complexity in its interpretation of machine instructions while development system procedures have hardware limitations such as the capacity of the real-time storage module, the number of breakpoint registers and the pin configuration of the CPU. Despite such hardware limitations, debugging on a development system is typically more productive than on a simulator because of the direct interaction that is possible between the programmer and the authentic execution of his program. #### 10.2 SOFTWARE FEATURES OFFERED BY THE Z80-CPU The Z-80 instruction set provides the user with a large and flexible repetoire of operations with which to formulate control of the Z80-CPU. The primary, auxiliary and index registers can be used to hold the arguments of arithmetic and logical operations, or to form memory addresses, or as fast-access storage for frequently used data. Information can be moved directly from register to register; from memory to memory; from memory to registers; or from registers to memory. In addition, register contents and register/memory contents can be exchanged without using temporary storage. In particular, the contents of primary and auxilary registers can be completely exchanged by executing only two instructions, EX and EXX. This register exchange procedure can be used to separate the set of working registers between different logical procedures or to expand the set of available registers in a single procedure. Storage and retrieval of data between pairs of registers and memory can be controlled on a last-in first-out basis through PUSH and POP instructions which utilize a special stack pointer register, SP. This stack register is available both to manipulate data and to automatically store and retrieve addresses for subroutine linkage. When a subroutine is called, for example, the address following the CALL instruction is placed on the top of the push-down stack pointed to by SP. When a subroutine returns to the calling routine, the address on the top of the stack is used to set the program counter for the address of the next instruction. The stack pointer is adjusted automatically to reflect the current "top" stack position during PUSH, POP, CALL and RET instructions. This stack mechanism allows pushdown data stacks and subroutine calls to be nested to any practical depth because the stack area can potentially be as large as memory space. The sequence of instruction execution can be controlled by six different flags (carry, zero, sign, parity/overflow, add-subtract, half-carry) which reflect the results of arithmetic, logical, shift and compare instructions. After the execution of an instruction which sets a flag, that flag can be used to control a conditional jump or return instruction. These instructions provide logical control following the manipulation of single bit, eight-bit byte (or) sixteen-bit data quantities. A full set of logical operations, including AND, OR, XOR (exclusive – OR), CPL (NOR) and NEG (two's complement) are available for Boolean operations between the accumulator and 1) all other eight-bit registers, 2) memory locations or 3) immediate operands. In addition, a full set of arithmetic and logical shifts in both directions are available which operate on the contents of all eight-bit primary registers or directly on any memory location. The carry flag can be included or simply set by these shift instructions to provide both the testing of shift results and to link register/register or register/memory shift operations. #### 10.3 EXAMPLES OF USE OF SPECIAL Z80 INSTRUCTIONS A. Let us assume that a string of data in memory starting at location "DATA" is to be moved into another area of memory starting at location "BUFFER" and that the string length is 737 bytes. This operation can be accomplished as follows: | LD | HL, DATA | ; START ADDRESS OF DATA STRING | |------|------------|-----------------------------------------------| | LD | DE, BUFFER | ; START ADDRESS OF TARGET BUFFER | | LD | BC, 737 | ; LENGTH OF DATA STRING | | LDIR | | ; MOVE STRING – TRANSFER MEMORY POINTED TO | | | | ; BY HL INTO MEMORY LOCATION POINTED TO BY DE | | | | ; INCREMENT HL AND DE, DECREMENT BC | | | | ; PROCESS UNTIL BC = 0. | 11 bytes are required for this operation and each byte of data is moved in 21 clock cycles. B. Let's assume that a string in memory starting at location "DATA" is to be moved into another area of memory starting at location "BUFFER" until an ASCII \$ character (used as string delimiter) is found. Let's also assume that the maximum string length is 132 characters. The operation can be performed as follows: | LD | HL, DATA | ; STARTING ADDRESS OF DATA STRING | |---------|---------------------------|------------------------------------------| | LD | DE , BUFFER | ; STARTING ADDRESS OF TARGET BUFFER | | LD | BC, 132 | ; MAXIMUM STRING LENGTH | | LD | A , '\$' | ; STRING DELIMITER CODE | | LOOP:CP | (HL) | ; COMPARE MEMORY CONTENTS WITH DELIMITER | | JR | $\hat{Z}, \hat{E}ND - \$$ | ; GO TO END IF CHARACTERS EQUAL | | LDI | , | ; MOVE CHARACTER (HL) to (DE) | | | | ; INCREMENT HL AND DE, DECREMENT BC | | JP | PE, LOOP | ; GO TO "LOOP" IF MORE CHARACTERS | | END: | | ; OTHERWISE, FALL THROUGH | | 2.12. | | ; NOTE: P/V FLAG IS USED | | | | TO INDICATE THAT REGISTER BC WAS | | | | ; DECREMENTED TO ZERO. | 19 bytes are required for this operation. C. Let us assume that a 16-digit decimal number represented in packed BCD format (two BCD digits/byte) has to be shifted as shown in the Figure 10.2 in order to mechanize BCD multiplication or division. The operation can be accomplished as follows: | HL, DATA | ; ADDRESS OF FIRST BYTE | |------------|-----------------------------------------| | B, COUNT | ; SHIFT COUNT | | Α | ; CLEAR ACCUMULATOR | | | ; ROTATE LEFT LOW ORDER DIGIT IN ACC | | | ; WITH DIGITS IN (HL) | | HL | ; ADVANCE MEMORY POINTER | | ROTAT - \$ | ; DECREMENT B AND GO TO ROTAT IF | | | ; B IS NOT ZERO, OTHERWISE FALL THROUGH | | | B , COUNT<br>A<br>HL | 11 bytes are required for this operation. D. Let us assume that one number is to be subtracted from another and a) that they are both in packed BCD format, b) that they are of equal but varying length, and c) that the result is to be stored in the location of the minuend. The operation can be accomplished as follows: | LD | HL, ARG1 | ; ADDRESS OF MINUEND | |------------|-------------|----------------------------------------| | LD | DE, ARG2 | ; ADDRESS OF SUBTRAHEND | | LD | B, LENGTH | ; LENGTH OF TWO ARGUMENTS | | AND | Α | ; CLEAR CARRY FLAG | | SUBDEC: LD | A , (DE) | ; SUBTRAHEND TO ACC | | SBC | A , (HL) | ; SUBTRACT (HL) FROM ACC | | DAA | | ; ADJUST RESULT TO DECIMAL CODED VALUE | | LD | (HL), A | ; STORE RESULT | | INC | HL | ; ADVANCE MEMORY POINTERS | | INC | DE | | | DJNZ | SUBDEC - \$ | ; DECREMENT B AND GO TO "SUBDEC" IF B | | | | : NOT ZERO, OTHERWISE FALL THROUGH | 17 bytes are required for this operation. ## 10.4 EXAMPLES OF PROGRAMMING TASKS A. The following program sorts an array of numbers each in the range (0,255) into ascending order using a standard exchange sorting algorithm. | 01/22/7 | 6 11:14:3 | 37 | | BUBE | BLE LISTING | PAGE 1 | |--------------|----------------|----------|--------------|----------|------------------------------------|-----------------------------------------------------------| | LOC | OBJ CODE | STMT | SOURC | E STATE | EMENT | | | | | 1 | ; *** ST. | ANDARE | EXCHANGE (B | UBBLE) SORT ROUTINE *** | | | | 2 | ; | | _ | | | | | 3 | ; AT EN | ΓRY: H | L CONTAINS AL | DDRESS OF DATA | | | | 4 | | | | MBER OF ELEMENTS TO BE SORTED | | | | 5 | | (1 | <c<256)< td=""><td></td></c<256)<> | | | | | 6<br>7 | ; | T. DATA | COPTED IN AS | CENDING ORDER | | | | 8 | , AI EAI | II. DAIA | A SOKIED IN AS | CENDING ORDER | | | | 9 | · USE OF | REGIST | TERS | | | | | 10 | ; | TE GIS | | | | | | 11 | ; REGIS | TER C | ONTENTS | | | | | 12 | ; | | | | | | | 13 | ; <b>A</b> | | | DRAGE FOR CALCULATIONS | | | | | ; B | | OUNTER FOR D | | | | | | ; C | | ENGTH OF DAT | | | | | | ; D | | | IN COMPARISON | | | | | ; E | | | WT IN COMPARISON | | | | | ; H | | LAG TO INDICA | TE EXCHANGE | | | | | ; L | | NUSED<br>OINTER INTO D | ATA ADDAV | | | | 20<br>21 | ; IX<br>; IY | | NUSED | ATA ARRAT | | | | 22 | . 11 | O | NOSED | | | 0000 | 222600 | 23 | SORT: | LD | (DATA), HL | ; SAVE DATA ADDRESS | | 0003 | CB84 | 24 | LOOP: | RES | FLAG, H | ; INITIALIZE EXCHANGE FLAG | | 0005 | 41 | 25 | | LD | B, C | ; INITIALIZE LENGTH COUNTER | | 0006 | 05 | 26 | | DEC | В | ; ADJUST FOR TESTING | | 0007 | DD2A2600 | 27 | | LD | IX, (DATA) | ; INITIALIZE ARRAY POINTER | | 000B | DD7E00 | 28 | NEXT: | LD | A, (IX) | ; FIRST ELEMENT IN COMPARISON | | 000E | 57 | 29 | | LD | D, A | ; TEMPORARY STORAGE FOR ELEMENT | | 000F | DD5E01 | 30 | | LD | E, (IX+1) | ; SECOND ELEMENT IN COMPARISON | | 0012 | 93 | 31 | | SUB | E<br>No NOEV 6 | ; COMPARISON FIRST TO SECOND | | 0013 | 3008 | 32 | | JR | NC, NOEX-\$ | ; IF FIRST > SECOND, NO JUMP<br>; EXCHANGE ARRAY ELEMENTS | | 0015 | DD7300 | 33 | | LD<br>LD | (IX), E<br>(IX+1), D | , EXCHANGE ARRAT ELEMENTS | | 0018<br>001B | DD7201<br>CBC4 | 34<br>35 | | SET | FLAG, H | ; RECORD EXCHANGE OCCURRED | | 001B | DD23 | 36 | NOEX: | INC | IX | ; POINT TO NEXT DATA ELEMENT | | 001B | 10EA | 37 | NOLA. | DJNZ | NEXT-\$ | COUNT NUMBER OF COMPARISONS | | 0011 | 102.1 | 38 | | | | , REPEAT IF MORE DATA PAIRS | | 0021 | CB44 | 39 | | BIT | FLAG, H | ; DETERMINE IF EXCHANGE OCCURRED | | 0023 | 20DE | 40 | | JR | NZ, LOOP-\$ | ; CONTINUE IF DATA UNSORTED | | 0025 | C9 | 41 | | RET | | ; OTHERWISE, EXIT | | | | 42 | ; | | | PROJECT A TION OF FLAC BIT | | 0026 | | 43 | FLAG: | EQU | 0 | DESIGNATION OF FLAG BIT | | 0026 | | 44 | DATA: | DEFS | 2 | ; STORAGE FOR DATA ADDRESS | | | | 45 | | END | | | B. The following program multiplies two unsigned 16 bit integers and leaves the result in the HL register pair. | 01/22/<br>LOC | 76 11:32::<br>OBJ CODE | 36<br>STM | T SOURC | MULT<br>E STAT | TIPLY LISTING<br>EMENT | PAG | GE 1 | |----------------------|------------------------|----------------|-----------------------------------------|--------------------|-----------------------------|---------------------------------------------------------------------------|------------| | 0000 | | 1<br>2<br>3 | MULT:;;; | | TRANCE: MULT | T INTEGER MULTIPLY.<br>TPLIER IN DE.<br>TPLICAND IN HL. | | | | | 4<br>5 | ; | ON EX | IT: RESULT IN I | HL. | | | | | 6<br>7<br>8 | ; | REGIS | TER USES: | | | | | | 9<br>10 | ; | Н | | ARTIAL RESULT | | | | | 11<br>12<br>13 | ;<br>; | L<br>D<br>E | HIGH ORDER M | | | | | | 14<br>15 | · , , , , , , , , , , , , , , , , , , , | B<br>C | COUNTER FOR<br>HIGH ORDER E | NUMBER OF SHIFTS<br>BITS OF MULTIPLIER | | | 0000 | 0610 | 16<br>17<br>18 | ; | A<br>LD | LOW ORDER BI<br>B, 16; | ITS OF MULTIPLIER NUMBER OF BITS- INITIALIZE | 7 | | 0002<br>0003 | 4A<br>7B | 19<br>20 | | LD<br>LD | C, D;<br>A, E; | MOVE MULTIPLIER | _ | | 0004<br>0005<br>0008 | EB<br>210000<br>CB39 | 21<br>22<br>23 | MLOOP: | EX<br>LD<br>SRL | DE, HL;<br>HL, 0;<br>C; | MOVE MULTIPLICAND CLEAR PARTIAL RESULT SHIFT MULTIPLIER RIGHT | | | 000A | 1F | 24<br>25 | ; | RRA | C, | LEAST SIGNIFICANT BIT IS<br>IN CARRY. | | | 000D | 3001<br>19 | 26<br>27<br>28 | | JR<br>ADD | NC, NOADD-\$;<br>HL, DE; | IF NO CARRY, SKIP THE ADD.<br>ELSE ADD MULTIPLICAND TO<br>PARTIAL RESULT. | | | 000E<br>000F | EB<br>29 | 29<br>30 | NOADD: | EX<br>ADD | DE, HL;<br>HL, HL; | SHIFT MULTIPLICAND LEFT<br>BY MULTIPLYING IT BY TWO. | | | 0010<br>0011<br>0013 | EB<br>10F5<br>C9 | 31<br>32<br>33 | | EX<br>DJNZ<br>RET; | DE, HL;<br>MLOOP-\$; | REPEAT UNTIL NO MORE BITS | <b>S</b> . | | | | 34 | | END; | | | | ## **Absolute Maximum Ratings** Temperature Under Bias Storage Temperature Voltage On Any Pin with Respect to Ground Power Dissipation Specified operating range. -65°C to +150°C -0.3V to +7V 1.5W \*Comment Stresses above those listed under "Absolute Maximum Rating" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other condition above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability. Note: For Z80-CPU all AC and DC characteristics remain the same for the military grade parts except I<sub>cc</sub>. $I_{cc} = 200 \text{ mA}$ ## **Z80-CPU D.C.** Characteristics $T_A = 0^{\circ}C$ to $70^{\circ}C$ , $V_{cc} = 5V \pm 5\%$ unless otherwise specified | Symbol | Parameter | Min. | Тур. | Max. | Unit | Test Condition | |------------------|-------------------------------------------|-------------------|------|---------------------|------------|------------------------------------------| | v <sub>ILC</sub> | Clock Input Low Voltage | -0.3 | | 0.45 | V | | | v <sub>IHC</sub> | Clock Input High Voltage | V <sub>cc</sub> 6 | | V <sub>cc</sub> +.3 | ٧ | | | v <sub>IL</sub> | Input Low Voltage | -0.3 | | 0.8 | V | | | v <sub>IH</sub> | Input High Voltage | 2.0 | | v <sub>cc</sub> | V | | | v <sub>OL</sub> | Output Low Voltage | | | 0.4 | V | IOL=1.8mA | | v <sub>OH</sub> | Output High Voltage | 2.4 | | | V | I <sub>OH</sub> = -250μA | | Icc | Power Supply Current | | | 150 | m <b>A</b> | | | I <sub>LI</sub> | Input Leakage Current | | | 10 | μΑ | V <sub>IN</sub> =0 to V <sub>cc</sub> | | I <sub>LOH</sub> | Tri-State Output Leakage Current in Float | | | 10 | μΑ | V <sub>OUT</sub> =2.4 to V <sub>cc</sub> | | I <sub>LOL</sub> | Tri-State Output Leakage Current in Float | | | -10 | μA | V <sub>OUT</sub> =0.4V | | I <sub>LD</sub> | Data Bus Leakage Current in Input Mode | | | ±10 | μΑ | 0 < V <sub>IN</sub> < V <sub>cc</sub> | ## Capacitance $T_A = 25^{\circ}C, f = 1 \text{ MHz},$ unmeasured pins returned to ground | Symbol | Parameter | Max. | Unit | |-----------------|--------------------|------|------| | СФ | Clock Capacitance | 35 | pF | | C <sub>IN</sub> | Input Capacitance | 5 | pF | | COUT | Output Capacitance | 10 | pF | ## **Z80-CPU Ordering Information** C - Ceramic P - Plastic F - Flashic S - Standard 5V ±5% 0° to 70°C E - Extended 5V ±5% -40° to 85°C M - Military 5V ±10% -55° to 125°C ## **Z80A-CPU D.C. Characteristics** $T_A = 0^{\circ}C$ to $70^{\circ}C$ , $V_{cc} = 5V \pm 5\%$ unless otherwise specified | Symbol | Parameter | Min. | Typ. | Max. | Unit | Test Condition | |------------------|-------------------------------------------|-------------------|------|---------------------|------|------------------------------------------| | v <sub>ILC</sub> | Clock Input Low Voltage | -0.3 | | 0.45 | v | | | v <sub>IHC</sub> | Clock Input High Voltage | V <sub>cc</sub> 6 | | V <sub>cc</sub> +.3 | v | | | v <sub>IL</sub> | Input Low Voltage | -0.3 | | 0.8 | V | | | v <sub>iH</sub> | Input High Voltage | 2.0 | | V <sub>cc</sub> | V | | | v <sub>ot.</sub> | Output Low Voltage | | | 0.4 | V | I <sub>OL</sub> =1.8mA | | v <sub>oH</sub> | Output High Voltage | 2.4 | | | V | I <sub>OH</sub> = -250μΛ | | 1 <sub>CC</sub> | Power Supply Current | | 90 | 200 | mA | | | LLI | Input Leakage Current | | | 10 | μΑ | V <sub>IN</sub> =0 to V <sub>ee</sub> | | <sup>1</sup> LOH | Tri-State Output Leakage Current in Float | | | 10 | μΛ | V <sub>OUT</sub> =2.4 to V <sub>ee</sub> | | I <sub>LOL</sub> | Tri-State Output Leakage Current in Float | | | -10 | μΑ | V <sub>OUT</sub> =0.4V | | l <sub>LD</sub> | Data Bus Leakage Current in Input Mode | | | ±10 | μΛ | 0 ≤ V <sub>IN</sub> ≤ V <sub>cc</sub> | ## **Capacitance** $T_A = 25^{\circ}C$ , f = 1 MHz, unmeasured pins returned to ground | Symbol | Parameter | Max. | Unit | |------------------|--------------------|------|------| | Сф | Clock Capacitance | 35 | рF | | C <sub>IN</sub> | Input Capacitance | 5 | рF | | c <sub>out</sub> | Output Capacitance | 10 | рF | ## **Z80A-CPU Ordering Information** P - Plastic $S-Standard~5V~\pm5\%~0^{\circ}~to~70^{\circ}C$ ## A.C. Characteristics ## **Z80-CPU** $T_A = O^{\circ}C$ to $70^{\circ}C$ , $V_{cc} = +5V \pm 5\%$ , Unless Otherwise Noted. | Signal | Symbol | Parameter | Min | Max | Unit | Test Condition | |-------------------|--------------------------------------------------|-----------------------------------------------------------------------------------------------------|-----------------|--------------------------------------------------|-------|-----------------------| | | t <sub>e</sub> | Clock Period | .4 | [12] | μsec | | | Ф | t <sub>w</sub> (ΦH) | Clock Pulse Width, Clock High | 180 | [E] | nsec | ] | | • | t <sub>w</sub> (ΦL) | Clock Pulse Width, Clock Low | 180 | 2000 | nsec | ] | | | t <sub>r,f</sub> | Clock Rise and Fall Time | | 30 | nsec | | | | <sup>t</sup> D (AD) | Address Output Delay | | 145 | nsec | 1 | | | <sup>t</sup> F (AD) | Delay to Float | <del> 10</del> | 110 | nsec | 4 | | A <sub>0-15</sub> | t <sub>aem</sub><br>t <sub>aei</sub> | Address Stable Prior to MREQ (Memory Cycle) Address Stable Prior to IORQ, RD or WR (1/O Cycle) | 121 | <b> </b> | nsec | $C_L = 50pF$ | | | tea | Address Stable from RD, WR, IORQ or MREQ | [3] | <del> </del> | nsec | 1 | | | tcaf | Address Stable From RD or WR During Float | [4] | † · · · · · · · · · · · · · · · · · · · | nsec | 1 | | | <sup>t</sup> D (D) | Data Output Delay | | 230 | nsec | | | | <sup>t</sup> F (D) | Delay to Float During Write Cycle | | 90 | nsec | 1 | | | <sup>t</sup> SΦ(D) | Data Setup Time to Rising Edge of Clock During M1 Cycle | 50 | | nsec | ] | | $D_{0-7}$ | <sup>t</sup> SΦ (D) | Data Setup Time to Falling Edge of Clock During M2 to M5 | 60 | ļ | nsec | $C_L = 50pF$ | | | <sup>t</sup> dcm | Data Stable Prior to WR (Memory Cycle) Data Stable Prior to WR (I/O Cycle) | [5] | <del> </del> | nsec | 1 | | | <sup>t</sup> dei<br><sup>t</sup> edf | Data Stable From WR | [7] | | lisec | 1 | | | t <sub>H</sub> | Any Hold Time for Setup Time | 0 | | nsec | | | · | <del> </del> | MREQ Delay From Falling Edge of Clock, MREQ Low | <del> </del> | 100 | nsec | | | | ¹DLΦ (MR) | MREQ Delay From Rising Edge of Clock, MREQ Low | | 100 | nsec | 1 | | MREQ | <sup>t</sup> DHΦ (MR)<br><sup>t</sup> DHΦ (MR) | MREQ Delay From Falling Edge of Clock, MREQ High | | 100 | nsec | C <sub>L</sub> = 50pF | | | tw (MRL) | Pulse Width, MREQ Low | [8] | | nsec | , r | | | tw (MRH) | Pulse Width, MREQ High | [9] | | nsec | | | | ¹DLΦ (IR) | IORQ Delay From Rising Edge of Clock, IORQ Low- | | 90 | nsec | | | IORO | <sup>t</sup> DLΦ (IR) | IORQ Delay From Falling Edge of Clock, IORQ Low | | 110 | nsec | C <sub>L</sub> = 50pF | | ionq | tDHФ (IR) | IORQ Delay From Rising Edge of Clock, IORQ High | | 100 | nsec | CL - 30pr | | | <sup>t</sup> DHΦ (IR) | IORQ Delay From Falling Edge of Clock, IORQ High | | 110 | nsec | | | | <sup>†</sup> DLΦ (RD) | RD Delay From Rising Edge of Clock, RD Low | | 100 | nsec | | | $\overline{RD}$ | ¹DLΦ (RD) | RD Delay From Falling Edge of Clock, RD Low | | 130 | nsec | $C_T = 50pF$ | | | <sup>t</sup> DHΦ (RD)<br><sup>t</sup> DHΦ (RD) | RD Delay From Rising Edge of Clock, RD High RD Delay From Falling Edge of Clock, RD High | | 100 | nsec | L . | | | <u> </u> | WP Delay From Pising Edge of Clask WP Law | <u> </u> | 80 | | | | _ | <sup>t</sup> DLΦ (WR) | WR Delay From Rising Edge of Clock, WR Low WR Delay From Falling Edge of Clock, WR Low | | 80<br>90 | nsec | - | | WR | <sup>†</sup> DLΦ (WR)<br><sup>†</sup> DHΦ (WR) | WR Delay From Falling Edge of Clock, WR High | <b>—</b> | 100 | nsec | $C_L = 50pF$ | | | tw (WRL) | Pulse Width, WR Low | [10] | | nsec | | | 177 | <sup>t</sup> DL (M1) | MI Delay From Rising Edge of Clock, MI Low | | 130 | nsec | 0 50 5 | | M1 | tDH (M1) | M1 Delay From Rising Edge of Clock, M1 High | | 130 | nsec | $C_L = 50pF$ | | DECLI | <sup>t</sup> DL(RF) | RFSH Delay From Rising Edge of Clock, RFSH Low | | 180 | nsec | 6 . 50 5 | | RFSH | tDH (RF) | RFSH Delay From Rising Edge of Clock, RFSH High | | 150 | nsec | $C_L = 50pF$ | | WAIT | ts (WT) | WAIT Setup Time to Falling Edge of Clock | 70 | | nsec | | | HALT | <sup>t</sup> D (HT) | HALT Delay Time From Falling Edge of Clock | | 300 | nsec | C <sub>L</sub> = 50pF | | ĪNT | t <sub>s</sub> (IT) | INT Setup Time to Rising Edge of Clock | 80 | <u> </u> | nsec | | | NMI | tw (NML) | Pulse Width, NM1 Low | 80 | | nsec | | | BUSRQ | t <sub>s</sub> (BQ) | BUSRQ Setup Time to Rising Edge of Clock | 80 | | nsec | | | | | BUSAK Delay From Rising Edge of Clock, BUSAK Low | | 120 | 2000 | | | BUSAK | <sup>t</sup> DL (BA)<br><sup>t</sup> DH (BA) | BUSAK Delay From Rising Edge of Clock, BUSAK Low BUSAK Delay From Falling Edge of Clock, BUSAK High | | 110 | nsec | C <sub>L</sub> = 50pF | | RESET | t <sub>s</sub> (RS) | RESET Setup Time to Rising Edge of Clock | 90 | | nsec | | | | <sup>t</sup> F (C) | Delay to Float (MREQ, TORQ, RD and WR) | | 100 | nsec | | | | | MI Stable Prior to IORO (Interrupt Ack.) | (11) | | nsec | | | | <sup>t</sup> mr | an state that to long (interrupt dec.) | T | L | L | | [12] $$t_c = t_w(\Phi H) + t_w(\Phi L) + t_r + t_f$$ [1] $$t_{acm} = t_{w(\Phi H)} + t_{f} - 75$$ [2] $$t_{aci} = t_c - 80$$ [3] $$t_{ca} = t_{w(\Phi L)} + t_r - 40$$ [4] $$t_{caf} = t_{w(\Phi L)} + t_{r} - 60$$ [5] $$t_{dcm} = t_c - 210$$ [6] $$t_{dci} = t_{w(\Phi L)} + t_r - 210$$ [7] $$t_{cdf} = t_{w(\Phi L)} + t_{r} - 80$$ [8] $$t_{w(MRL)} = t_{c} - 40$$ [9] $$t_{w(MRH)} = t_{w(\Phi H)} + t_{f} - 30$$ [10] $$t_{w(\overline{WR}L)} = t_{c} - 40$$ [11] $$t_{mr} = 2t_c + t_{w(\Phi H)} + t_f - 80$$ #### NOTES: - A. Data should be enabled onto the $\underline{CPU}$ data bus when $\overline{RD}$ is active. During interrupt acknowledge data should be enabled when $\overline{M1}$ and $\overline{10RQ}$ are both active. - All control signals are internally synchronized, so they may be totally asynchronous with respect to the clock. The RESET signal must be active for a minimum of 3 clock cycles. - D. Output Delay vs. Loaded Capacitance TA = 70°C Vcc = +5V ±5% Add 10nsec delay for each 50pf increase in load up to a maximum of 200pf for the data bus & 100pf for address & control lines E. Although static by design, testing guarantees $t_{w(\Phi H)}$ of 200 $\mu$ sec maximum Load circuit for Output ## **Z80A-CPU** $T_A = O^{\circ}C$ to $70^{\circ}C$ , $V_{cc} = +5V \pm 5\%$ , Unless Otherwise Noted. | Signal | Symbol | Parameter | Min | Max | Unit | Test Condition | |-------------------|-----------------------------------------------------------|-----------------------------------------------------------------------------------------------------|------|--------------|----------|-----------------------| | | t <sub>e</sub> | Clock Period | .25 | [12] | μsec | | | Ф | t <sub>w</sub> (ΦH) | Clock Pulse Width, Clock High | 110 | [E] | nsec | | | 18* | ι <sub>w</sub> (ΦL) | Clock Pulse Width, Clock Low | 110 | 2000 | nsec | | | | t <sub>r, f</sub> | Clock Rise and Fall Time | | 30 | nsec | | | | <sup>t</sup> D (AD) | Address Output Delay | | 110 | nsec | | | | <sup>t</sup> F (AD) | Delay to Float | | 90 | nsec | | | Δ | t <sub>acm</sub> | Address Stable Prior to MREQ (Memory Cycle) | [1] | | nsec | C <sub>1</sub> = 50pF | | A <sub>0-15</sub> | l <sub>aci</sub> | Address Stable Prior to IORQ, RD or WR (1/O Cycle) | [2] | | nsec | L sopi | | | t <sub>ca</sub> | Address Stable from RD, WR, IORQ or MREQ | [3] | | nsec | | | *** | <sup>l</sup> caf | Address Stable From RD or WR During Float | [4] | | nsec | | | | <sup>t</sup> D (D) | Data Output Delay | | 150 | nsec | | | | tF(D) | Delay to Float During Write Cycle | | 90 | nsec | | | | tSΦ (D) | Data Setup Time to Rising Edge of Clock During M1 Cycle | 35 | | nsec | | | $D_{0-7}$ | tSΦ(D) | Data Setup Time to Falling Edge of Clock During M2 to M5 | 50 | | nsec | $C_L = 50 pF$ | | | <sup>t</sup> dcm | Data Stable Prior to WR (Memory Cycle) | [5] | | nsec | _ | | | <sup>t</sup> dci | Data Stable Prior to WR (I/O Cycle) | [6] | | nsec | | | | <sup>t</sup> cdf | Data Stable From WR | [7] | | | | | | tH TH | Any Hold Time for Setup Time | | 0 | nsec | | | | <sup>t</sup> DL⊕ (MR) | MREQ Delay From Falling Edge of Clock, MREQ Low | | 85 | nsec | | | | <sup>t</sup> DHΦ (MR) | MREQ Delay From Rising Edge of Clock, MREQ High | | 85 | nsec | | | MREQ | tDHΦ (MR) | MREQ Delay From Falling Edge of Clock, MREQ High | | 85 | nsec | $C_1 = 50pF$ | | | tw (MRL) | Pulse Width, MREQ Low | [8] | | nsec | ] ~ | | | tw (MRH) | Pulse Width, MREQ High | [9] | | nsec | | | | <sup>t</sup> DLΦ (IR) | IORQ Delay From Rising Edge of Clock, IORQ Low | | 75 | nsec | | | IORQ | ¹DLΦ (IR) | IORQ Delay From Falling Edge of Clock, IORQ Low | | 85 | nsec | C <sub>L</sub> = 50pF | | IOKŲ | <sup>t</sup> DHΦ (IR) | IORQ Delay From Rising Edge of Clock, IORQ High | | 85 | nsec | CL - Sobr | | | <sup>t</sup> DHΦ(IR) | IORQ Delay From Falling Edge of Clock, IORQ High | | 85 | nsec | | | | <sup>t</sup> DLΦ (RD) | RD Delay From Rising Edge of Clock, RD Low | | 85 | nsec | | | $\overline{RD}$ | <sup>t</sup> DL <del>\overline{\overline{\pi}}</del> (RD) | RD Delay From Falling Edge of Clock, RD Low | | 95 | nsec | C = 50=E | | KD | <sup>†</sup> DHΦ (RD) | RD Delay From Rising Edge of Clock, RD High | | 85 | nsec | C <sub>L</sub> = 50pF | | | ¹DHΦ (RD) | RD Delay From Falling Edge of Clock, RD High | | 85 | nsec | | | | <sup>t</sup> DLΦ (WR) | WR Delay From Rising Edge of Clock, WR Low | | 65 | nsec | | | WR | ¹DLΦ (WR) | WR Delay From Falling Edge of Clock, WR Low | | 80 | nsec | C = 50pE | | WK | <sup>t</sup> DHΦ (WR) | WR Delay From Falling Edge of Clock, WR High | | 80 | nsec | C <sub>L</sub> = 50pF | | | tw (WRL) | Pulse Width, WR Low | [10] | | nsec | | | <del></del> | tDL(M1) | MI Delay From Rising Edge of Clock, MI Low | | 100 | nsec | C <sub>L</sub> = 50pF | | Μī | tDH (M1) | MI Delay From Rising Edge of Clock, MI High | | 100 | nsec | CL - 30 pr | | | <sup>t</sup> DL(RF) | RFSH Delay From Rising Edge of Clock, RFSH Low | | 130 | nsec | C - 50 F | | RFSH | <sup>1</sup> DH (RF) | RFSH Delay From Rising Edge of Clock, RFSH High | | 120 | nsec | $C_L = 50pF$ | | WAIT | t <sub>s</sub> (WT) | WAIT Setup Time to Falling Edge of Clock | 70 | | nsec | | | HALT | <sup>t</sup> D (HT) | HALT Delay Time From Falling Edge of Clock | | 300 | nsec | C <sub>1</sub> = 50pF | | ĪNT | t <sub>s</sub> (IT) | INT Setup Time to Rising Edge of Clock | 80 | | nsec | | | NMI | l | Pulse Width, NM1 Low | 80 | | nsec | | | | <sup>t</sup> w (NML) | 4 | + | <del> </del> | <b>-</b> | | | BUSRQ | t <sub>s</sub> (BQ) | BUSRQ Setup Time to Rising Edge of Clock | 50 | | nsec | | | BUSAK | <sup>t</sup> DL (BA)<br><sup>t</sup> DH (BA) | BUSAK Delay From Rising Edge of Clock, BUSAK Low BUSAK Delay From Falling Edge of Clock, BUSAK High | | 100 | nsec | C <sub>L</sub> = 50pF | | RESET | is (RS) | RESET Setup Time to Rising Edge of Clock | 60 | | nsec | | | | <sup>t</sup> F (C) | Delay to Float (MREQ, IORQ, RD and WR) | ļ | 80 | nsec | | | | | M1 Stable Prior to IORQ (Interrupt Ack.) | (11) | I | nsec | 1 | [12] $$t_c = t_{w(\Phi H)} + t_{w(\Phi L)} + t_f + t_f$$ [1] $$t_{acm} = t_{w(\Phi H)} + t_f - 65$$ [2] $$t_{aci} = t_c - 70$$ [3] $$t_{ca} = t_{w(\Phi L)} + t_r - 50$$ [4] $$t_{caf} = t_{w(\Phi L)} + t_r - 45$$ [5] $$t_{dcm} = t_c - 170$$ [6] $$t_{dci} = t_{w(\Phi L)} + t_r - 170$$ [7] $$t_{cdf} = t_{w(\Phi L)} + t_r - 70$$ [8] $$t_{w(\overline{MR}L)} = t_{c} - 30$$ [9] $$t_{w(\overline{MR}H)} = t_{w(\Phi H)} + t_{f} - 20$$ [10] $$t_{w}(\overline{WR}L) = t_{c} -30$$ [11] $$t_{mr} = 2t_c + t_{w(\Phi H)} + t_f - 65$$ #### NOTES: - Data should be enabled onto the CPU data bus when RD is active. During interrupt acknowledge data should be enabled when MI and IORQ are both active. B. All control signals are internally synchronized, so they may be totally asynchronous with respect to the clock. - to the clock. The RESET signal must be active for a minimum of 3 clock cycles. - D. Output Delay vs. Loaded Capacitance $TA = 70^{\circ}C$ $Vcc = +5V \pm 5\%$ Add 10nsec delay for each 50pf increase in load up to maximum of 200pf for data bus and 100pf for address & control lines. E. Although static by design, testing guarantees $t_{w(\Phi H)}$ of 200 $\mu sec$ maximum Load circuit for Output ## A.C. Timing Diagram | 12.0 | | DEC IY | Decrement IY | | |---------------|-----------------------------------------------------------------------------|-------------|-----------------------------------------------------------------|--| | | Z80-CPU | DEC ss | Decrement Reg. pair ss | | | Zilog INST | TRUCTION SET | DI | Disable interrupts | | | ADC HL, ss | Add with Carry Reg. pair ss to HL | DJNZ e | Decrement B and Jump<br>relative if B≠0 | | | ADC A, s | Add with carry operand s to Acc. | EI | Enable interrupts | | | ADD A, n | Add value n to Acc. | EX (SP), HL | Exchange the location (SP) and HL | | | ADD A, r | Add Reg. r to Acc. | EX (SP), IX | Exchange the location (SP) and IX | | | ADD A, (HL) | Add location (HL) to Acc. | EX (SP), IY | Exchange the location (SP) and IY | | | ADD A, (IX+d) | Add location (IX+d) to Acc. | EX AF, AF' | Exchange the contents of AF | | | ADD A, (IY+d) | Add location (IY+d) to Acc. | | and AF' | | | ADD HL, ss | Add Reg. pair ss to HL | EX DE, HL | Exchange the contents of DE and HL | | | ADD IX, pp | Add Reg. pair pp to IX | EXX | Exchange the contents of BC, DE, | | | ADD IY, rr | Add Reg. pair rr to IY | | HL with contents of BC', DE', HL' | | | AND s | Logical 'AND' of operand s and Acc. | | respectively | | | BIT b, (HL) | Test BIT b of location (HL) | HALT | HALT (wait for interrupt or reset) | | | BIT b, (IX+d) | Test BIT b of location (IX+d) | IM 0 | Set interrupt mode 0 | | | BIT b, (IY+d) | Test BIT b of location (IY+d) | IM 1 | Set interrupt mode 1 | | | BIT b, r | Test BIT b of Reg. r | IM 2 | Set interrupt mode 2 | | | CALL cc, nn | Call subroutine at location nn if condition cc if true | IN A, (n) | Load the Acc. with input from device n | | | CALL nn | Unconditional call subroutine at location nn | IN r, (C) | Load the Reg. r with input from device (C) | | | CCF | Complement carry flag | INC (HL) | Increment location (HL) | | | CP s | Compare operand s with Acc. | INC IX | Increment IX | | | CPD | Compare location (HL) and Acc. | INC (IX+d) | Increment location (IX+d) | | | | decrement HL and BC | INC IY | Increment IY | | | CPDR | Compare location (HL) and Acc. decrement HL and BC, repeat | INC (IY+d) | Increment location (IY+d) | | | | until BC=0 | INC r | Increment Reg. r | | | СРІ | Compare location (HL) and Acc. increment HL and decrement BC | INC ss | Increment Reg. pair ss | | | CPIR | Compare location (HL) and Acc. increment HL, decrement BC repeat until BC=0 | IND | Load location (HL) with input from port (C), decrement HL and B | | | CPL | Complement Acc. (1's comp) | INDR | Load location (HL) with input from port (C), decrement HL and | | | DAA | Decimal adjust Acc. | | decrement B, repeat until B=0 | | | DEC m | Decrement operand m | INI | Load location (HL) with input from port (C); and increment HL | | | DEC IX | Decrement IX | | and decrement B | | | INIR | Load location (HL) with input from port (C), increment HL | LD (nn), A | Load location (nn) with Acc. | | | |----------------|-----------------------------------------------------------|--------------------|------------------------------------------------------------------------|--|--| | | and decrement B, repeat until | LD (nn), dd | Load location (nn) with Reg. pair dd | | | | | B=0 | LD (nn), HL | Load location (nn) with HL | | | | JP (HL) | Unconditional Jump to (HL) | LD (nn), IX | Load location (nn) with IX | | | | JP (IX) | Unconditional Jump to (IX) | LD (nn), IY | Load location (nn) with IY | | | | JP (IY) | Unconditonal Jump to (IY) | LD R, A | Load R with Acc. | | | | JP cc, nn | Jump to location nn if condition cc is true | LD r, (HL) | Load Reg. r with location (HL) | | | | JP nn | Unconditional jump to location | LD r, (IX+d) | Load Reg. r with location (IX+d) | | | | <b>.</b> ,,,,, | nn | LD r, (IY+d) | Load Reg. r with location (IY+d) | | | | JP C, e | Jump relative to PC+e if carry=1 | LD r, n | Load Reg. r with value n | | | | JR e | Unconditional Jump relative | LD r, r' | Load Reg. r with Reg. r' | | | | | to PC+e | LD SP, HL | Load SP with HL | | | | JP NC, e | Jump relative to PC+e if carry=0 | LD SP, IX | Load SP with IX | | | | JR NZ, e | Jump relative to PC+e if non zero (Z=0) | LD SP, IY | Load SP with IY | | | | JR Z, e | Jump relative to PC+e if zero (Z=1) | LDD | Load location (DE) with location (HL), decrement DE, HL and BC | | | | LD A, (BC) | Load Acc. with location (BC) | LDDR | | | | | LD A, (DE) | Load Acc. with location (DE) | | Load location (DE) with location (HL), decrement DE, HL and BC; | | | | LD A, I | Load Acc. with I | | repeat until BC=0 | | | | LD A, (nn) | Load Acc. with location nn | LDI | Load location (DE) with location (HL), increment DE, HL, | | | | LD A, R | Load Acc. with Reg. R | | decrement BC | | | | LD (BC), A | Load location (BC) with Acc. | LDIR | Load location (DE) with location | | | | LD (DE), A | Load location (DE) with Acc. | | (HL), increment DE, HL,<br>decrement BC and repeat until | | | | LD (HL), n | Load location (HL) with value n | | BC=0 | | | | LD dd, nn | Load Reg. pair dd with value nn | NEG | Negate Acc. (2's complement) | | | | LD HL, (nn) | Load HL with location (nn) | NOP | No operation | | | | LD (HL), r | Load location (HL) with Reg. r | OR s | Logical 'OR' or operand s and Acc. Load output port (C) with location | | | | LD I, A | Load I with Acc. | OTDR | (HL) decrement HL and B, repeat | | | | LF IX, nn | Load IX with value nn | 0715 | until B=0 | | | | LD IX, (nn) | Load IX with location (nn) | OTIR | Load output port (C) with location (HL), increment HL, decrement B, | | | | LD (IX+d), n | Load location (IX+d) with value n | | repeat until B=0 | | | | LD (IX+d), r | Load location (IX+d) with Reg. r | OUT (C), r | Load output port (C) with Reg. r | | | | LD IY, nn | Load IY with value nn | OUT (n), A<br>OUTD | Load output port (n) with Acc. Load output port (C) with location | | | | LD IY, (nn) | Load IY with location (nn) | JJ.5 | (HL), decrement HL and B | | | | LD (IY+d), n | Load location (IY+d) with value n | OUTI | Load output port (C) with location | | | | LD (IY+d), r | Load location (IY+d) with Reg. r | | (HL), increment HL and decrement B | | | | | | | | | | | POP IX | Load IX with top of stack | RR m | Rotate right through carry operand m | |------------|------------------------------------------------|---------------|------------------------------------------| | POP IY | Load IY with top of stack | RRA | Rotate right Acc. through carry | | POP qq | Load Reg. pair qq with top of stack | RRC m | Rotate operand m right circular | | PUSH IX | Load IX onto stack | RRCA | Rotate right circular Acc. | | PUSH IY | Load IY onto stack | RRD | Rotate digit right and left between | | PUSH qq | Load Reg. pair qq onto stack | | Acc. and location (HL) | | RES b, m | Reset Bit b of operand m | RST p | Restart to location p | | RET | Return from subroutine | SBC A, s | Subtract operand s from Acc. with carry | | RET cc | Return from subroutine if condition cc is true | SBC HL, ss | Subtract Reg. pair ss from HL with carry | | RETI | Return from interrupt | SCF | Set carry flag (C=1) | | RETN | Return from non maskable interrupt | SET b, (HL) | Set Bit b of location (HL) | | RL m | Rotate left through carry operand m | • | Set Bit b of location (IX+d) | | RLA | Rotate left Acc. through carry | SET b, (1X+d) | | | RLC (HL) | Rotate location (HL) left circular | SET b, (IY+d) | Set Bit b of location (IY+d) | | RLC (IX+d) | Rotate location (IX+d) left circular | SET b, r | Set Bit b of Reg. r | | RLC (IY+d) | Rotate location (IY+d) left circular | SLA m | Shift operand m left arithmetic | | RLCr | Rotate Reg. r left circular | SRA m | Shift operand m right arithmetic | | RLCA | Rotate left circular Acc. | SRL m | Shift operand m right logical | | RLD | Rotate digit left and right between | SUB s | Subtract operand s from Acc. | | | Acc. and location (HL) | XOR s | Exclusive 'OR' operand s and Acc. | ## **INS8250 ASYNCHRONOUS COMMUNICATIONS ELEMENT\*** # INS8250 Functional Pin Description The function of all INS8250 input/output pins are described in the following paragraphs. (See the INS8250 Block Diagram, Illustration Booklet, Page 16). Some of these descriptions reference internal circuits. A low in these descriptions represents a logic 0 (0 volt nominal) and a high represents a logic 1 (+2.4 volts nominal). #### **INPUT SIGNALS** Chip Select (CSØ, CS1, CS2), Pins 12 - 14: When CSØ and CS1 are high and CS2 is low, the chip is selected. Chip selection is complete when the decoded chip select signal is latched with an active (low) Address Strobe (ADS) input. This enables communication between the INS8250 and the CPU. Data Input Strobe (DISTR, DISTR), Pins 22 and 21: When DISTR is high or DISTR is low while the chip is selected, this allows the CPU to read status information or data from a selected register of the INS8250. NOTE: Only an active DISTR or DISTR input is required to transfer data from the INS8250 during a read operation. Therefore, tie either the DISTR input permanently low or the DISTR input permanently high, if not used. Data Output Strobe (DOSTR, DOSTR), Pins 19 and 18: When DOSTR is high or DOSTR is low while the chip is selected, this allows the CPU to write data or control words into a selected register of the INS8250. NOTE: Only an active DOSTR or DOSTR input is required to transfer data to the INS8250 during a write operation. Therefore, tie either the DOSTR input permanently low or the DOSTR input permanently high, if not used. Address Strobe (ADS), Pin 25: When low, it provides latching for the Register Select (A0, A1, A2) and Chip Select (CSØ, CS1, CS2) signals. NOTE: An active $\overline{ADS}$ input is required when the Register Select (A0, A1, A2) signals are not stable for the duration of a read or write operation. If not required, tie the $\overline{ADS}$ input permanently low. Register Select (A0, A1, A2), Pins 26 - 28: These three inputs are used during a read or write operation to select an INS8250 register to read from or write into as indicated in the table below. Note that the state of the Divisor Latch Access Bit (DLAB), which is the most significant bit of the line control register, affects the selection of certain INS8250 registers. The DLAB is reset low when the Master Reset (MR) input is active (low); the DLAB must be set high by the system software to access the baud generator divisor latches. | DLAB | $lack A_2$ | Aı | <b>A</b> o | Register | |------|------------|----|------------|-----------------------------------------------------------------| | 0 | 0 | 0 | 0 | Receiver Buffer (read), Transmitter<br>Holding Register (write) | | 0 | 0 | 0 | 1 | Interrupt Enable | | X | 0 | 1 | 0 | Interrupt Identification (read only) | | X | 0 | 1 | 1 | Line Control | | X | 1 | 0 | 0 | MODEM Control | | X | 1 | 0 | 1 | Line Status | | X | 1 | 1 | 0 | MODEM Status | | X | 1 | 1 | 1 | None | | 1 | 0 | 0 | 0 | Divisor Latch (least significant byte) | | 1 | 0 | 0 | 1 | Divisor Latch (most significant byte) | Master Reset (MR), Pin 35: When high, it clears all the registers (except the receiver buffer, transmitter holding, and divisor latches), and the control logic of the INS8250. Also, the state of various output signals (SOUT, INTRPT, OUT 1, OUT 2, RTS, DTR) are affected by an active MR input. (Refer to Table 1 on Page 14-3.) Receiver Clock (RCLK), Pin 9: This input is the 16x baud rate clock for the receiver section of the chip. **Serial Input (SIN), Pin 10:** Serial data input from the communications link (peripheral device, MODEM, or data set). <sup>\*</sup> Portions of this section are reprinted with the permission of National Semiconductor. Clear to Send (CTS), Pin 36: The CTS signal is a MODEM control function input whose condition can be tested by the CPU by reading bit 4 (CTS) of the MODEM status register. Bit 0 (DCTS) of the MODEM status register indicates whether the CTS input has changed state since the previous reading of the MODEM status register. NOTE: Whenever the CTS bit of the MODEM status register changes state, an interrupt is generated if enabled. Data Set Ready (DSR), Pin 37: When low, it indicates that the MODEM or data set is ready to establish the communications link and transfer data with the INS8250. The DSR signal is a MODEM-control function input whose condition can be tested by the CPU by reading bit 5 (DSR) of the MODEM status register. Bit 1 (DDSR) of the MODEM status register indicates whether the DSR input has changed state since the previous reading of the MODEM status register. NOTE: Whenever the DSR bit of the MODEM status register changes state, an interrupt is generated if enabled. Received Line Signal Detect (RLSD), Pin 38: When low, it indicates that the data carrier has been detected by the MODEM or data set. The RLSD signal is a MODEM-control function input whose condition can be tested by the CPU by reading bit 7 (RLSD) of the MODEM status register. Bit 3 (DRLSD) of the MODEM status register indicates whether the RLSD input has changed state since the previous reading of the MODEM status register. NOTE: Whenever the RLSD bit of the MODEM status register changes state, an interrupt is generated if enabled. **Ring Indicator** ( $\overline{RI}$ ), **Pin 39:** When low, it indicates that a telephone ringing signal has been received by the MODEM or data set. The $\overline{RI}$ signal is a MODEM control function input whose condition can be tested by the CPU by reading bit 6 (RI) of the MODEM status register. Bit 2 (TERI) of the MODEM status register indicates whether the $\overline{RI}$ input has changed from a low to a high state since the previous reading of the MODEM status register. NOTE: Whenever the RI bit of the MODEM status register changes from a high to a low state, an interrupt is generated if enabled. $V_{CC}$ , Pin 40: +5-volt supply. $V_{SS}$ , Pin 20: Ground (0-volt) reference. #### **OUTPUT SIGNALS** Data Terminal Ready (DTR), Pin 33: When low, it informs the MODEM or data set that the INS8250 is ready to communicate. The DTR output signal can be set to an active low by programming bit 0 (DTR) of the MODEM control register to a high level. The DTR signal is set high upon a Master Reset operation. Request to Send (RTS), Pin 32: When low, it informs the MODEM-or data set that the INS8250 is ready to transmit data. The RTS output signal can be set to an active low by programming bit 1 (RTS) of the MODEM control register. The RTS signal is set high upon a Master Reset operation. Output 1 (OUT 1), Pin 34: A user-designated output that can be set to an active low by programming bit 2 (OUT 1) of the MODEM control register to a high level. The OUT 1 signal is set high upon a Master Reset operation. Output 2 (OUT 2), Pin 31: A user-designated output that can be set to an active low by programming bit 3 (OUT 2) of the MODEM control register to a high level. The OUT 2 signal is set high upon a Master Reset operation. Chip Select Out (CSOUT), Pin 24: When high, it indicates that the chip has been selected by active $CS\emptyset$ , CS1, and $\overline{CS2}$ inputs. No data transfer can be initiated until the CSOUT signal is a logic 1. **Driver Disable (DDIS), Pin 23:** Goes low whenever the CPU is reading data from the INS8250. A high-level DDIS output can be used to disable an external transceiver (if used between the CPU and INS8250 on the $D_7$ - $D_0$ Data Bus) at all times, except when the CPU is reading data. Baud Out (BAUDOUT), Pin 15: 16x clock signal for the transmitter section of the INS8250. The clock rate is equal to the main reference oscillator frequency divided by the specified divisor in the baud generator divisor latches. The BAUDOUT may also be used for the receiver section by typing this output to the RCLK input of the chip. Interrupt (INTRPT), Pin 30: Goes high whenever any one of the following interrupt sources has an active high condition: Receiver Error Flag; Received Data Available; Transmitter Holding Register Empty; and MODEM Status. The INTRPT signal is reset low upon a Master Reset operation. Serial Output (SOUT), Pin 11: Composite serial data output to the communications link (peripheral, MODEM or data set). The SOUT signal is set to the Marking (logic 1) state upon a Master Reset operation. #### INPUT/OUTPUT SIGNALS Data ( $D_7$ - $D_0$ ) Bus, Pins 1 - 8: This bus comprises eight TRI-STATE input/output lines. The bus provides bidirectional communications between the INS8250 and the CPU. Data, control words, and status information are transferred via the $D_7$ - $D_0$ data bus. External Clock Input/Output (XTAL 1, XTAL 2), Pins 16 and 17: These two pins connect the main timing reference (crystal or signal clock) to the INS8250. | Register/Signal | Reset Control | Reset State | | |-----------------------------------|--------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------|--| | Receiver Buffer Register | First Word Received | Data | | | Transmitter Holding Register | Writing into the<br>Transmitter Holding Register | Data | | | Interrupt Enable Register | Master Reset | All bits Low<br>(0 - 3 forced and 4 - 7 permanent | | | Interrupt Identification Register | Master Reset | Bit 0 is High and<br>Bits 1 - 7 Are Permanently Low | | | Line Control Register | Master Reset | All Bits Low | | | MODEM Control Register | Master Reset | All Bits Low | | | Line Status Register | Master Reset | All Bits Low, Except Bits 5 & 6 Are High | | | MODELL OLDER Business | Master Reset | Bits 0 - 3 Low | | | MODEM Status Register | MODEM Signal Inputs | Bits 4 - 7 — Input Signal | | | Divisor Latch (low order bits) | Writing into the Latch | Data | | | Divisor Latch (high order bits) | Writing into the Latch | Data | | | SOUT | Master Reset | High | | | BAUDOUT | Writing into Either Divisor Latch | Low | | | CSOUT | ADS Strobe Signal and State of<br>Chip Select Lines | High/Low | | | DDIS | DDIS = CSOUT • RCLK • DISTR (AT Master Reset, the CPU sets RCLK and DISTR low.) | High | | | INTRPT | Master Reset | Low | | | OUT 2 | Master Reset | High | | | RTS Master Reset | | High | | | DTR | DTR Master Reset Hi | | | | OUT 1 | Master Reset | High | | | D₁ - D₀ Data Bus Lines | In TRI-STATE Mode, O <sub>7</sub> - D <sub>0</sub> Data Bus Lines Unless CSOUT • DISTR = High or CSOUT • DOSTR = High | | | Table 1 ## **Programming** When you use ZDS software, you will not be concerned with programming the 8250 ACE (asynchronous communications element) in the serial I/O circuit board. However, this section will be indispensable if you intend to assemble your own program code. In order to easily program the 8250, you should: - 1. Disable all UART interrupts by clearing the interrupt enable register. - 2. Set the ACE in its loop-back mode. - 3. Program the ACE as you want it. - 4. Read a character. - 5. Wait two character times. - Read a second character. - 7. Take the ACE out of the loop-back mode. #### **INS8250 ACCESSIBLE REGISTERS** You (the system programmer) may access or control any of the INS8250 registers summarized in Table 1 via the CPU. These registers are used to control INS8250 operations and to transmit and receive data. #### **INS8250 Line Control Register** Specify the format of the asynchronous data communications exchange via the Line Control Register. In addition to controlling the format, you may retrieve the contents of the Line Control Register for inspection. This feature simplifies system programming and eliminates the need for separate storage in system memory of the line characteristics. The contents of the Line Control Register are indicated in Table 2 and are described below. **Bits 0 and 1:** These two bits specify the number of bits in each transmitted or received serial character. The encoding of bits 0 and 1 is as follows: | Bit 1 | Bit 0 | Word Length | | | |-------------|------------------|--------------------------------------|--|--| | 0<br>0<br>1 | 0<br>1<br>0<br>1 | 5 Bits<br>6 Bits<br>7 Bits<br>8 Bits | | | **Bit 2:** This bit specifies the number of Stop bits in each transmitted or received serial character. If bit 2 is a logic 0, 1 Stop bit is generated or checked in the transmit or receive data, respectively. If bit 2 is a logic 1 when a 5-bit word length is selected via bits 0 and 1, 1-1/2 Stop bits are generated or checked. If bit 2 is a logic 1 when either a 6-, 7-, or 8-bit word length is selected, 2 Stop bits are generated or checked. Bit 3: This is the Parity Enable bit. When Bit 3 is a logic 1, a Parity bit is generated (transmit data) or checked (receive data) between the last data word bit and Stop bit of the serial data. (The Parity bit is used to produce an even or odd number of 1s when the data word bits and the Parity bit are summed.) **Bit 4:** This is the Even Parity Select bit. When bit 3 is a logic 1 and bit 4 is a logic 0, an odd number of logic 1s is transmitted or checked in the data word bits and Parity bit. When bit 3 is a logic 1 and bit 4 is a logic 1, an even number of bits is transmitted or checked. **Bit 5:** This is the Stick Parity bit. When bit 3 is a logic 1 and bit 5 is a logic 1, the Parity bit is transmitted and then detected by the receiver in the opposite state indicated by bit 4. **Bit 6:** This is the Set Break Control bit. When bit 6 is a logic 1, the serial output (SOUT) is forced to the spacing (logic 0) state and remains there (until reset by a low-level bit 6) regardless of other transmitter activity. This feature enables the CPU to alert a terminal in a computer communications system. Bit 7: This is the Divisor Latch Access bit (DLAB). It must be set high (logic 1) to access the Divisor Latches of the baud rate generator during a Read or Write operation. It must be set low (logic 0) to access the receiver buffer, the transmitter holding register, or the interrupt enable register. | | Register Address | | | | | | | | | | |---------|-----------------------------------------------|-------------------------------------------|-------------------------------------------------------------------------------|-----------------------------------------|---------------------------------------------|------------------------------------|-------------------------------------------------------|---------------------------------------------------------|--------------------------|--------------------------| | | 0 DLAB = 0 0 DLAB = 0 1 DLAB = 0 | | 2 | 3 | 4 | 5 | 6 | 0 DLAB = 1 | 1 DLAB = 1 | | | Bit No. | Receiver<br>Buffer<br>Register<br>(Read Only) | Transmitter Holding Register (Write Only) | Interrupt<br>Enable<br>Register | Interrupt<br>Identification<br>Register | Line<br>Control<br>Register | MODEM<br>Control<br>Register | Line<br>Status<br>Register | MODEM<br>Status<br>Register | Divisor<br>Latch<br>(LS) | Divisor<br>Latch<br>(MS) | | 0 | Data Bit 0° | Data Bit 0 | Enable<br>Received<br>Data<br>Available<br>Interrupt<br>(ERBFI) | "0" if<br>Interrupt<br>Pending | Word Length<br>Select Bit 0<br>(WLS0) | Data<br>Terminal<br>Ready<br>(DTR) | Data Ready<br>(DR) | Delta Clear<br>to Send<br>(DCTS) | Bit 0 | Bit 8 | | 1 | Data Bit 1 | Data Bit 1 | Enable<br>Transmitter<br>Holding<br>Register<br>Empty<br>Interrupt<br>(ETBEI) | Interrupt<br>ID<br>Bit (0) | Word Length<br>Select Bit 1<br>(WLS1) | Request to<br>Send<br>(RTS) | Overrun<br>Error<br>(OR) | Delta Data<br>Set Ready<br>(DDSR) | Bit 1 | Bit 9 | | 2 | Data Bit 2 | Data Bit 2 | Enable<br>Receiver<br>Line<br>Status<br>Interrupt<br>(ELSI) | Interrupt<br>ID<br>Bit (1) | Number of<br>Stop Bits<br>(STB) | Out 1 | Parity<br>Error<br>(PE) | Trailing<br>Edge<br>Ring<br>Indicator<br>(TERI) | Bit 2 | Bit 10 | | 3 | Data Bit 3 | Data Bit 3 | Enable<br>MODEM<br>Status<br>Interrupt<br>(EDSSI) | 0 | Parity<br>Enable<br>(PEN) | Out 2 | Framing<br>Error<br>(FE) | Delta<br>Receive<br>Line<br>Signal<br>Detect<br>(DRLSD) | Bit 3 | Bit 11 | | 4 | Data Bit 4 | Data Bit 4 | 0 | o | Even<br>Parity<br>Select<br>(EPS) | Loop | Break<br>Interrupt<br>(BI) | Clear to<br>Send<br>(CTS) | Bit 4 | Bit 12 | | 5 | Data Bit 5 | Data Bit 5 | 0 | 0 | Stick<br>Parity | 0 | Transmitter<br>Holding<br>Register<br>Empty<br>(THRE) | Data<br>Set<br>Ready<br>(DSR) | Bit 5 | Bit 13 | | 6 | Data Bit 6 | Data Bit 6 | 0 | 0 | Set<br>Break | 0 | Transmitter<br>Shift<br>Register<br>Empty<br>(TSRE) | Ring<br>Indicator<br>(RI) | Bit 6 | Bit 14 | | .7 | Data Bit 7 | Data Bit 7 | 0 | o | Divisor<br>Latch<br>Access<br>Bit<br>(DLAB) | 0 | 0 | Received<br>Line<br>Signal<br>Detect<br>(RLSD) | Bit 7 | Bit 15 | <sup>\*</sup> Bit 0 is the least significant bit. It is the first bit serially transmitted or received. Table 2 Summary of INS8250 Accessible Registers. ## 8250 PROGRAMMABLE BAUD RATE GENERATOR The 8250 contains a programmable baud rate generator that takes the 1.8432 MHz clock and divides it by any divisor from 1 to $2^{16}$ - 1. The output frequency of the baud generator is $16 \times$ the baud rate. Two 8-bit latches store the divisor in a 16-bit binary format. These Divisor Latches must be loaded during initialization in order to insure desired operation of the baud rate generator. Upon loading either of the divisor latches, a 16-bit baud counter is immediately loaded. This prevents long counts on initial load. Table 3 illustrates the standard baud rates and the contents of the LS (least significant) and MS (most significant) latches expressed in byte octal. | BAUD RATE | DIVISOR LATCH | | | |-----------|---------------|------|--| | • | (LS) | (MS) | | | 75 | 000 | 006 | | | 110 | 027 | 004 | | | 134.5 | 131 | 003 | | | 150 | 000 | 003 | | | 300 | 200 | 001 | | | 600 | 300 | 000 | | | 1200 | 140 | 000 | | | 2400 | 060 | 000 | | | 4800 | 030 | 000 | | | 9600 | 014 | 000 | | | 19200 | 006 | 000 | | | 38400 | 003 | 000 | | | 57600 | 002 | 000 | | Table 3 Baud Rates. #### LINE STATUS REGISTER This 8-bit register provides status information to the CPU concerning the data transfer. The contents of the line status register are indicated in Table 2 and are described below. Bit 0: This bit is the receiver Data Ready (DR) indicator. Bit 0 is set to a logic 1 whenever a complete incoming character has been received and transferred into the receiver buffer register. Bit 0 may be reset to a logic 0 either by the CPU reading the data in the receiver buffer register or by writing a logic 0 into it from the CPU. Bit 1: This bit is the Overrun Error (OE) indicator. Bit 1 indicates that data in the Receiver Buffer Register was not read by the CPU before the next character was transferred into the receiver buffer register, thereby destroying the previous character. The OE indicator is reset whenever the CPU reads the contents of the line status register. **Bit 2:** This bit is the Parity Error (PE) indicator. Bit 2 indicates that the received data character does not have the correct even or odd parity, as selected by the even-parity-select bit. The PE bit is set to a logic 1 upon detection of a parity error and is reset to a logic 0 whenever the CPU reads the contents of the line status register. **Bit 3:** This bit is the Framing Error (FE) indicator. Bit 3 indicates that the received character did not have a valid Stop bit. Bit 3 is set to a logic 1 whenever the Stop bit following the last data bit or parity bit is detected as a zero bit (Spacing level). **Bit 4:** This bit is the Break Interrupt (BI) indicator. Bit 4 is set to a logic 1 whenever the received data input is held in the Spacing (logic 0) state for longer than a full word transmission time (that is, the total time of Start bit + data bits + Parity + Stop bits). NOTE: Bits 1 through 4 are the error conditions that produce a Receiver Line Status interrupt whenever any of the corresponding conditions are detected. Bit 5: This bit is the Transmitter Holding Register Empty (THRE) indicator. Bit 5 indicates that the INS8250 is ready to accept a new character for transmission. In addition, this bit causes the INS8250 to issue an interrupt to the CPU when the Transmit Holding Register Empty Interrupt enable is set high. The THRE bit is set to a logic 1 when a character is transferred from the transmitter holding register into the transmitter shift register. The bit is reset to logic 0 concurrently with the loading of the transmitter holding register by the CPU. Bit 6: This bit is the Transmitter Shift Register Empty (TSRE) indicator. Bit 6 is set to a logic 1 whenever the transmitter shift register is idle. It is reset to logic 0 upon a data transfer from the transmitter holding register to the transmitter shift register. Bit 6 is a read-only bit. Bit 7: This bit is permanently set to logic 0. #### INTERRUPT IDENTIFICATION REGISTER The INS8250 has an on-chip interrupt capability that allows for complete flexibility in interfacing to all the popular microprocessors presently available. In order to provide minimum software overhead during data character transfers, the INS8250 prioritizes interrupts into four levels. The four levels of interrupt conditions are as follows: Receiver Line Status (priority 1); Received Data Ready (priority 2); Transmitter Holding Register Empty (priority 3); and MODEM Status (priority 4). Information indicating that a prioritized interrupt is pending and the source of that interrupt are stored in the interrupt identification register (refer to Table 4). The interrupt identification register (IIR, when addressed during chip-select time, freezes the highest priority interrupt pending and no other interrupts are acknowledged until the particular interrupt is serviced by the CPU. The contents of the IIR are indicated in Table 2 and are described below. Bit 0: This bit can be used in either a hardwired prioritized or polled environment to indicate whether an interrupt is pending. When bit 0 is a logic 0, an interrupt is pending and the IIR contents may be used as a pointer to the appropriate interrupt service routine. When bit 0 is a logic 1, no interrupt is pending and polling (if used) continues. **Bits 1 and 2:** These two bits of the IIR are used to identify the highest priority interrupt pending as indicated in table 3. **Bits 3 through 7:** These five bits of the IIR are always logic 0. #### INTERRUPT ENABLE REGISTER This 8-bit register enables the four interrupt sources of the INS8250 to separately activate the chip Interrupt (INTRPT) output signal. It is possible to totally disable the interrupt system by resetting bits 0 through 3 of the interrupt enable register. Similarly, by setting the appropriate bits of this register to a logic 1, selected interrupts can be enabled. Disabling the interrupt system inhibits the interrupt identification register and the active (high) INTRPT output from the chip. All other system functions operate in their normal manner, including the setting of the line status and MODEM status registers. The contents of the interrupt enable register are indicated in Table 1 and are described below. **Bit 0:** This bit enables the Received Data Available Interrupt when set to logic 1. Bit 0 is reset to logic 0 upon completion of the associated interrupt service routine. **Bit 1:** This bit enables the Transmitter Holding Register Empty Interrupt when set to logic 1. Bit 1 is reset to logic 0 immediately upon reading the Interrupt Identification Register. **Bit 2:** This bit enables the Receiver Line Status Interrupt when set to logic 1. Bit 2 is reset to logic 0 upon completion of the associated interrupt service routine. Bit 3: This bit enables the MODEM Status Interrupt when set to logic 1. Bit 3 is reset to logic 0 upon completion of the associated interrupt service routine. Bits 4 through 7: These four bits are always logic 0. #### MODEM CONTROL REGISTER This 8-bit register controls the interface with the MODEM or data set (or a peripheral device emulating a MODEM). The contents of a MODEM control register are indicated in Table 2 and are described below. Bit 0: This bit controls the Data Terminal Ready (DTR) output. When bit 0 is set to a logic 1, the DTR output is forced to a logic 0. When bit 0 is reset to a logic 0, the DTR output is forced to a logic 1. NOTE: The DTR output of the INS8250 may be applied to an EIA inverting line driver (such as the DS1488) to obtain the proper polarity input at the succeeding MODEM or data set. Bit 1: This bit controls the Request to Send (RTS) output. Bit 1 affects the RTS output in a manner identical to that described above for bit 0. Bit 2: This bit controls the Output 1 (OUT 1) signal, which is an auxiliary user-designated output. Bit 2 affects the OUT 1 output in a manner identical to that described above for bit 0. Bit 3: This bit controls the Output 2 (OUT 2) signal, which is an auxiliary user-designated output. Bit 3 affects the OUT 2 output in a manner identical to that described above for bit 0. Bit 4: This bit provides a loopback feature for diagnostic testing of the INS8250. When bit 4 is set to logic 1, the following occur: the transmitter Serial Output (SOUT) is set to the Marking (logic 1) state; the receiver Serial Input (SIN) is disconnected; the output of the transmitter shift register is "looped back" into the receiver shift register input; the four MODEM control inputs (CTS, DSR, RLSD, and RI) are disconnected; and the four MODEM control outputs (DTR, RTS, OUT 1, and OUT 2) are internally connected to the four MODEM Control inputs. In the diagnostic mode, data that is transmitted is immediately received. This feature allows the processor to verify the transmit- and receive-data paths of the INS8250. In the diagnostic mode, the receiver and transmitter interrupts are fully operational. The MODEM control Interrupts are also operational but the interrupts sources are now the lower four bits of the MODEM control register instead of the four MODEM control inputs. The interrupts are still controlled by the interrupt enable register. The INS8250 interrupt system can be tested by writing into the lower six bits of the line status register and the lower four bits of the MODEM status register. Setting any of these bits to a logic 1 generates the appropriate interrupt (if enabled). The resetting of these interrupts is the same as in normal INS8250 operation. To return to this operation, the registers must be reprogrammed for normal operation and then bit 4 must be reset to logic 0. **Bits 5 through 7:** These bits are permanently set to logic 0. #### **MODEM STATUS REGISTER** This 8-bit register provides the current state of the control lines from the MODEM (or peripheral device) to the CPU. In addition to this current-state information, four bits of the MODEM status register provide change information. These bits are set to a logic 1 whenever a control input from the MODEM changes state. They are reset to logic 0 whenever the CPU reads the MODEM status register. The contents of the MODEM status register are indicated in Table 2 and are described below. **Bit 0:** This bit is the Delta Clear to Send (DCTS) indicator. Bit 0 indicates that the CTS input to the chip has changed state since the last time it was read by the CPU. Bit 1: This bit is the Delta Data Set Ready (DDSR) indicator. Bit 1 indicates that the DSR input to the chip has changed state since the last time it was read by the CPU. **Bit 2:** This bit is the Trailing Edge of Ring Indicator (TERI) detector, Bit 2 indicates that the RI input to the chip has changed from an On (logic 1) to an Off (logic 0) condition. **Bit 3:** This bit is the Delta Received Line Signal Detector (DRLSD) indicator. Bit 3 indicates that the RLSD input to the chip has changed state. NOTE: Whenever bit 0, 1, 2, or 3 is set to logic 1, a MODEM Status interrupt is generated. **Bit 4:** This bit is the complement of the Clear to Send (CTS) input. Bit 5: This bit is the complement of the Data Set Ready (DSR) input. Bit 6: This bit is the complement of the Ring Indicator $(\overline{RI})$ input. Bit 7: This bit is the complement of the Received Line Signal Detect (RLSD) input. | Interrupt Identification Register | | | | Interrupt Set and Reset Functions | | | | | |-----------------------------------|-------|-------|-------------------|------------------------------------------|----------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------|--|--| | Bit 2 | Bit 1 | Bit 0 | Priority<br>Level | Interrupt<br>Fl <b>ag</b> | Interrupt<br>Source | Interrupt<br>Reset Control | | | | 0 | 0 | 1 | _ | None | None | _ | | | | 1 | 1 | 0 | Highest | Receiver<br>Line Status | Overrun Error or Parity Error or Framing Error or Break Interrupt | Reading the<br>Line Status Register | | | | 1 | 0 | 0 | Second | Received<br>Data Available | Receiver<br>Data Available | Reading the<br>Receiver Buffer Register | | | | 0 | 1 | 0 | Third | Transmitter<br>Holding Register<br>Empty | Transmitter<br>Holding Register<br>Empty | Reading the IIR Register (if source of interrupt) or Writing into the Transmitter Holding Register | | | | 0 | 0 | 0 | Fourth | MODEM<br>Status | Clear to Send or Data Set Ready or Ring Indicator or Received Line Signal Detect | Reading the<br>MODEM Status<br>Register | | | Table 4 Interrupt Control Functions. Ç1 #### **INDEX** ANSI Escape Sequences, 11-17 General Troubleshooting Information, 7-2 Summary of Sequences, 11-17 Go, 3-3, 5-2, ANSI Mode Summary, 11-19 Graphic Symbols, 11-4, 11-5, 11-6 ANSI Escape Sequences Defined, 11-20 Appendix, 11-1 Initial Tests. 3-3 ASCII Characters, 11-1 Instruction Set, 11-31 INS8250 Asynchronous Communications Element, Baud Rates, 4-2, 4-3 Boot Disk, 6-1 Introduction, 1-3 I/O Port Map, 4-6 Cabinet Removal, 3-2 Keyboard Operation, 5-2 Circuit Board X-Ray Views, Illus. Bk. Pg. 8 Keypad Functions, 5-14, 11-8, 11-9 CPU Circuit Board, Pg. 13 Power Supply, Pg. 10 List of Features, 1-5 Serial Interface Circuit Board, Pg. 14 Terminal Logic Circuit Board, Pg. 11 Memory Map, 4-6 Video Circuit Board, Pg. 11 Memory Test, 3-3 Video Driver Circuit Board, Pg. 12 Modem, 4-5, 4-7 Circuit Description, 8-1 CPU Logic Circuit Board, 8-15 Nonalphabetic Keys, 5-4 Power Supply Circuit Board, 8-2 Normal Modes and Keys, 5-4 Terminal Logic Circuit Board, 8-6 Alphabetic Keys, 5-4 Video Circuit Board, 8-3 Control Keys, 5-6 Video Driver Circuit Board, 8-6 Nonalphabetic Keys, 5-4 Command Summary, 5-1 Miscellaneous Keys, 5-5 Computing Test, 3-4 Configuration, 4-1, 5-10 Operation, 5-1 ZDS System Configuration, 4-1 Non-ZDS System Configuration, 4-7 Parity, 4-2, 4-3 Cursor Functions, 5-7, 11-10, 11-12, 11-17, 11-21 Power Line Considerations, 3-1 Programming Jumpers, 4-4, 4-5 Demonstration Programs, 11-50 Readjustment, 6-1 Duplex (Half/Full), 4-2, 4-3, 5-3 Replacement Parts List, 9-1 Dynamic RAM Test, 3-3 Chassis Parts, 9-5 CPU Logic Circuit Board, 9-4 Erasing and Editing, 5-9, 11-10, 11-13, 11-18, 11-22 Power Supply Circuit Board, 9-1 Escape Sequences, 5-4, 5-14, 5-15, 11-1, 11-10 — Serial Interface Circuit Board, 9-6 11-26 Terminal Logic Circuit Board, 9-3 Video Circuit Board, 9-1 Video Driver Circuit Board, 9-3 Functions of a Computer, The, 11-27 Schematic Diagram (3-part), fold-in Semiconductor Identification, 10-1 Component Number Index, 10-1 Part Number Index, 10-5 Set-up and Testing, 3-1 Special Modes and Keys, 5-7 Specifications, 2-1 Split Octal, 5-1, 5-2 Substitute memory, 5-2 System Configuration, 4-1 Terminal Logic Circuit Board, 4-1 Switch S402, 4-1 Switch S401, 4-2 CPU Logic Circuit Board, 4-4 Switch SW501, 4-4 Serial Interface, 4-4 Testing, 3-3 Initial Tests, 3-3 Memory Test, 3-3 Transmitted Codes, 11-7 Use as a Terminal, 5-18 ZDS Escape Sequences, 5-5, 5-6, 5-7, 11-10 Summary of Sequences, 11-10 ZDS Escape Sequences Defined, 5-7, 11-12 ZDS System Configuration, 4-1 Z80 CPU, 8-1