**XEROX**® ## **TECHNICAL REFERENCE MANUAL** **Xerox Professional Computer** Copyright © 1984 Xerox Corporation. All rights reserved. Reprint permission granted by Zilog, Inc. for Zilog Reprint on pages 49-108. Reprint permission granted by Shugart Associates for SA 1403D Controller Reprint on pages 253-278. Reprint permission granted by Western Digital for Western Digital Reprint on pages 279-302. Zilog, Z80®, and Z80-A are trademarks of Zilog, Inc., with whom the publisher is not associated. 8086 is a trademark of Intel Corporation. IBM, IBM PC, and IBM PCXT are trademarks of International Business Machines. Xerox®, 820™, 820-II™, and 16/8™ are trademarks of Xerox Corporation. CP/M®, CP/M®-80, and CP/M-86® are registered trademarks of Digital Research, Inc.. MS™ is a trademark of Microsoft Corporation. **WARNING:** This equipment has been certified to comply with the limits for a Class B computing device, pursuant to Subpart J of part 15 of FCC Rules. Only peripherals (computer input/output devices, terminals, printers, etc.) certified to comply with the Class B limits may be attached to this computer. Operating with non-certified peripherals is likely to result in interference to radio and TV reception. **WARNING:** This equipment generates and uses radio frequency energy and if not installed and used properly, that is, in strict accordance with the manufacturer's instructions, may cause interference to radio and television reception. It has been type tested and found to comply with the limits for a Class B computing device in accordance with the specifications in Subpart J of part 15 of FCC Rules, which are designed to provide reasonable protection against such interference in a residential installation. However, there is no guarantee that interference will not occur in a particular installation. 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: Reorient the receiving antenna. Relocate the computer with respect to the receiver. Move the computer away from the receiver. Plug the computer into a different outlet so that computer and receiver are on different branch circuits. If necessary, the user should consult the dealer or an experienced radio/television technician for additional suggestions. The user may find the following booklet prepared by the Federal Communications Commission helpful. This booklet is available from the U.S. GOVERNMENT PRINTING OFFICE, WASHINGTON, D.C. 20402, STOCK NO. 004-000-00345-4. "HOW TO IDENTIFY AND RESOLVE RADIO-TV PROBLEMS" Xerox Corporation reserves the right to make improvements to products without incurring any obligation to incorporate such improvements in products previously sold. THIS PAGE INTENTIONALLY BLANK. ## **Table of Contents** # Introduction | Introduction & Miscellaneous Information Hardware Description Configurations and Product Codes Functional Description Hardware Interface Operating Systems: CP/M-80 CP/M-86 MS-DOS | 2<br>3,4<br>4,5<br>5,6<br>6-9<br>9,10<br>10,11 | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------| | Hardware | | | Miscellaneous Hardware Information | | | Dimensions | 13 | | Electrical Requirements | 13 | | Operating Environment | 13 | | Disk Drive Storage | 14 | | Disk Drive Format | 14 | | <ul> <li>Display Specification, Functional Description,</li> </ul> | | | and General Information | 15-17 | | <ul> <li>System Bus Expansion Slot - Electrical &amp;</li> </ul> | | | Environmental Requirements | 18 | | <ul> <li>Hardware Interface - Connectors:</li> </ul> | | | J1 (Disk), J2 (Keyboard), J3 (Printer), J4 (Comm) | 19 | | J1 Illustration | 20 | | J8 Illustration | 21 | | J5, J6 (Power Supplies), J7 (Video Connector) | 22 | | J8 (Parallel Connector) | 23 | | Parallel Connector Illustration | 24 | | J9 (COMM Port Strapping Options) | 25 | | J9 (COMM Port Strapping Options) (Etch 2 CPU) | 26 | | J13 (System Bus)<br>J12 (Disk Access) | 27-32<br>33-37 | | J1 (Floppy Disk) | 33-37 | | J1 (Rigid Disk) | 39 | | JI (Mgia Disk) | 33 | # Hardware continued | • CPU | | |----------------------------------------------------------------|--------| | | 41 | | ROM and RAM Memory | 41 | | 6 - 8k ROM Memory | 42 | | • 64k RAM | 42 | | Counter Timer Circuit | 42 | | Serial I/O Controller | 42 | | <ul> <li>Serial I/O Ports</li> </ul> | 42,43 | | Parallel I/O Controller | 43 | | Parallel Port | 43 | | CRT Controller | 43,44 | | <ul> <li>CRT RAM Memory Allocation</li> </ul> | 45 | | Scroll Register | 46 | | Speaker | 47 | | <ul> <li>Disk Drive Daughter Board</li> </ul> | 47 | | Rigid Disk Drive Caution | 47 | | System Bus | 48 | | Keyboard Interface | 48 | | Zilog Reprint (SIO, PIO, CTC, & CPU Data sheets) | 49-108 | | Schematics: | | | #1 Etch 1 CPU - Power Distribution | 109 | | #2 Etch 1 CPU - CRT Controller | 110 | | #3 Etch 1 CPU - CRT Controller | 111 | | #4 Etch 1 CPU - U16, U26, U28, U32, U37-U41, U54,<br>U57, U58 | 112 | | #5 Etch 1 CPU - U41, U54-U58, U66-U73 | 113 | | #6 Etch 1 CPU - RAM | 114 | | #7 Etch 1 CPU - CTC | 115 | | #8 Etch 1 CPU - GP, PIO, SIO | 116 | | #9 Etch 2 CPU - Power Distribution | 117 | | #10 Etch 2 CPU - CRT Controller | 118 | | #11 Etch 2 CPU - CRT Controller | 119 | | #12 Etch 2 CPU - U16, U26, U28, U32, U37-U41, U54,<br>U57, U58 | 120 | | #13 Etch 2 CPU - U41, U54-U58, U66-U73 | 121 | | #14 Etch 2 CPU - RAM | 122 | | #15 Etch 2 CPU - CTC, Keyboard, PIO | 123 | | | 124 | # Hardware continued | #17 | Floppy Controller - Power Distribution | 125 | |--------|----------------------------------------------|----------| | #18 | Floppy Controller | 126 | | #19 | Rigid Controller | 127 | | #20 | 8086 Processor - Power Distribution & Connec | tors 128 | | #21 | 8086 Processor - U21-U24, U29-U32 | 129 | | #22 | 8086 Processor - U27, U33-U42 | 130 | | #23 | 8086 Processor - U1-U16, U18-U20, U25, U26, | U28 131 | | #24 | Memory Expansion PWB - 8086 | 132 | | Softv | vare | | | Device | Initialization | | | • + | low the ROM works | 133,134 | | | Counter Timer Circuit | 134 | | | System PIO Controller | 134 | | | General Purpose PIO Controller | 135 | | | SIO Controller | 135 | | | Channels A & B Baud Rate Generator | 136 | | • N | Monitor Commands - Summary Table | 137 | | | Display Memory, Modify Memory | 138,139 | | | Xtended Memory, Fill Memory | 139 | | | Copy Memory, Verify Memory Block, Go To | 140,141 | | | Input, Output | 141,142 | | | Load From Disk | 142 | | | Read Disk Sector, Write Disk Sector | 143 | | | Baud Rate, Typewriter, Host Terminal Mode | 144 | | | Host Terminal Options | 145,146 | | | Host Terminal Command Set | 147,148 | | | Protocol | 148,149 | | | | | | • | ing System Interface | | | | Accessing BIOS | 151,152 | | | ogical/Physical Device Mapping | 153-155 | | | O Port Assignments | 156,157 | | | OM Operating System Interface | 158 | | | CRT Entries | 158-160 | | | xecute Physical Driver Entries | 161,162 | | | Printer Entries | 163,164 | | • ( | Communications Entries | 165 | # **Software continued** | Keyboard Entries | 166 | |-------------------------------------------------------------------|---------| | IOBYTE Directed I/O | 167-169 | | <ul> <li>Programmable Functions</li> </ul> | 170-176 | | Sample Code Sequence | 177-179 | | <ul> <li>Miscellaneous Functions - Cold, Warm, Getsel,</li> </ul> | | | Daytim, Config, Start Screen Print | 177-182 | | CRT Control & Interface | | | <ul> <li>Modes of Operation</li> </ul> | 183 | | Text Character Set | 184 | | Graphics Character Set | 185 | | Display Manipulation | 186 | | Control Sequences | 186-188 | | Escape Sequences | 189-193 | | | | | Peripherals | | | Keyboards | | | • ASCII | 195-199 | | Low Profile (LPK) | 200-206 | | | | | Disk Drive Specifications | 207-212 | | Disk Parameter Headers | 213-218 | | Disk Formats | 219-226 | | | 213 220 | | 20 & 40 CPS Printers | | | <ul> <li>20 CPS Operating Switches</li> </ul> | 227-230 | | <ul> <li>20 CPS Command Codes</li> </ul> | 231-233 | | <ul> <li>20 CPS Command/Control/Hex Code Chart</li> </ul> | 234 | | <ul> <li>20 CPS Specifications</li> </ul> | 235,236 | | <ul> <li>20 CPS Cabling Requirements</li> </ul> | 236 | | <ul> <li>40 CPS - HPRO5 Board</li> </ul> | 237 | | <ul> <li>40 CPS Operating Switches</li> </ul> | 238-240 | | <ul> <li>40 CPS Command Codes</li> </ul> | 242-244 | | <ul> <li>40 CPS Command/Control/Hex Code Chart</li> </ul> | 245 | | • 40 CDS Floatrical Interface | 246 250 | # **Peripherals continued** | | <ul><li>40 CPS Specifications</li><li>40 CPS Cabling Requirements</li></ul> | 251-252<br>252 | |----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------| | SA | 1403D Manual Reprint | 253-278 | | We | estern Digital Reprint | 279-302 | | Αį | ppendices | | | A. | BIOS Entry Vector Table | A1-A6 | | В. | Monitor Entry Vector Table | B1-B2 | | C. | <ul> <li>Documented System Storage &amp; Structures</li> <li>Z80-A Mode 2 Interrupt Vectors</li> <li>Keyboard Interface</li> <li>Logical to Physical Drive Mapping Table</li> <li>Physical Driver Address Table &amp; Request Block</li> <li>Time-of-Day and Timer Variables</li> </ul> | C1, C2<br>C1<br>C2<br>C3<br>C4 | | D. | <ul><li>Program Samples</li><li>How to make Monitor Calls with BASIC</li><li>Bank Program &amp; Switching</li></ul> | D1-D3<br>D4 | | E. | ROM Listings • CBIOS | E1-E110<br>E7-E12 | | F. | Macros & Symbols | F1-F24 | | G. | Cold Start Loader | G1-G6 | | Н. | BIOS Jump Table | H1-H18 | | ı. | Banked Physical Driver | 11-112 | | 1. | Position-Encoded Keyboard Handler | 11-138 | # **Appendices** continued | K. | Code Charts | | | |----|-------------------------------|-----------------------------------------|-------| | | Baud Rates | | K 1 | | | Decimal to ASCII to Hex | | K2 | | L. | Additional References | 1 - 1 - 1 - 1 - 1 - 1 - 1 - 1 - 1 - 1 - | L1-L2 | | M. | Contacts/reference: | | M1-M2 | | | • Diablo | | | | | Digital Research | | | | | <ul> <li>Microsoft</li> </ul> | | | | | <ul><li>Shugart</li></ul> | | | | N. | Abbreviations | | N1-N2 | ## Introduction The purpose of this manual is to provide technical reference material for the Xerox 820-II and 16/8 Professional Computers for programmers and engineers involved in hardware, software, and interface design. It is also intended for interested persons who have a desire to know how the Xerox 820-II and 16/8 operate and how to access their many features. A list of the abbreviations and naming conventions used in this manual can be found in Appendix N. #### SYSTEM OVERVIEW The modular design of the 820-II and 16/8 systems enhance the flexibility provided by the operating systems. The combination of operations provided by the system gives it a flexibility that allows it to be tailored to the needs of each user. ## **Overview of Xerox Personal Computers** Xerox Personal Computers are comprised of four components: display/processor, disk drives, keyboard, and optional printers. Both the 820-II and 16/8 use the CP/M®-80 2.2 Operating System from Digital Research, Inc. Additionally, the 16/8 PC includes CP/M-86® 1.1and MS™-DOS Version 2.0 as standard operating systems. # HARDWARE DESCRIPTION System Board The system board uses a Zilog Z80-A®-based microprocessor operating on a 4 megahertz clock with 64k RAM and 8k ROM. It is a single-board computer and uses a daughter board to interface with the disk drives. The 820-II is equipped with three user-accessible I/O ports. Two of the ports are located on the back of the display/processor; the third is located on the CPU board. On the back are the printer and the communications ports (both RS232C). The port inside the display is a dual parallel port (most printers and other devices that follow a standard Centronics 36-pin interface can be successfully attached). The 16/8 has all of the above features as well as an Intel 8086®-based microprocessor operating with a 4.772 megahertz clock. The 8086 is equipped with 128k of RAM which is expandable to 256k total by adding a 128k daughter board to the 8086 board. The 820-II and 16/8 are capable of having up to 8k of read only memory (four 2k ROMs): the 820-II has 6k of this 8k occupied; the 16/8 uses the full 8K. The last 2k on the 16/8 is used for decoding the position-encoded Low Profile Keyboard. The firmware contained in the ROM is capable of doing such things as executing a one-sector loader from disk; i.e., loading CP/M, emulating a terminal, operating in typewriter mode, etc. The monitor also has other commands that are useful for debugging hardware and software. The mother board also contains a speaker as well as an expansion slot (used by the 16/8 for the 8086 board). There are two types of daughter boards: one interfaces the display/processor to a rigid disk controller. 2 ## Display The display/processor houses the video display, the CPU mother board, the disk drive daughter board, and the 8086 processor board if so configured. The video display is a standard 24 line by 80 characters. It uses a 7 x 10 dot matrix for each character in all text modes and displays white characters on a black screen. For graphics characters, it uses a 4 x 4 pixel resolution. The display attributes can be changed to display either in blink, highlight/lowlight, inverse, or graphics characters. 820-II Display/processor for floppy disks 820-II Display/processor for rigid disk 16/8 Display/processor for floppy disks 16/8 Display/processor for rigid disk Product Code #U03 Product Code #U05 Product Code #H69 Product Code #H70 ## Keyboards The 820-II and 16/8 use either a standard 96-character ASCII or Low Profile keyboards. Both keyboards include additional keys to the right of the keyboard, a 10-key numeric key pad and a set of keys for software control of the cursor. The low profile keyboard also includes 12 function keys that can be software-enabled and other keys such as Accept, Delete, Next, Previous, Home, and Undo. ASCII Keyboard Low Profile Keyboard Product Code #X928 Product Code #G25 #### **Disk Drives** Five disk drive options are offered for the 820-II: Dual 5¼" single-sided floppy disk drives Dual 5¼" double-sided floppy disk drives Dual 8" single-sided floppy disk drives Dual 8" double-sided floppy disk drives One 10mb rigid disk drive with an 8" double-sided disk drive Product Code #X929 Product Code #T66 Product Code #X973 Product Code #F10 Product Code #U07 Three disk drive options are offered for the 16/8: Dual 8" single sided floppy disk drives Dual 8" double sided floppy disk drives One 10mb rigid disk drive with an 8" double sided disk drive Product Code #X973 Product Code #F10 Product Code #U07 #### **Printers** 40 CPS Printer and 20 CPS Printer As their names imply, the printers have a printing speed of 20 and 40 characters per second (CPS) respectfully. Both printers have a wide range of print styles available. The 20 CPS Printer supports 10, 12, and 15 pitch as well as Proportional Spacing (PS), while the 40 CPS Printer supports either metal or plastic printwheels in 10, 12, 15, and PS. More detailed information on these printers can be found in the Printer section under Peripherals. The standard RS232C printer connector and dual parallel port are available to interface with many types of serial and parallel printers. 40 CPS Printer 20 CPS Printer Product Code # D80 Product Code # U01 #### **FUNCTIONAL DESCRIPTION** The 820-II and 16/8 systems are a collection of four components working in unison -- the display, keyboard, disk drives, and printer. The computer itself is housed in the display. ## **System Monitor - ROM** The system monitor contained within the 8k ROM controls the essential functions of initializing and controlling all system input/output resources, and also provides a number of monitor commands that can be used to assist in programming. #### **Ports** Three ports are standard on the 820-II and 16/8: two serial ports located at the back of the display unit and an additional dual parallel port inside the display unit. These allow printers, communication devices, and other peripheral equipment to be interfaced with the system. ## **Operating Systems** The 820-II uses Digital Research's 2.2 CP/M-80 Operating System. The 16/8 can use Digital Research's 2.2 CP/M Operating System, as well as their CP/M-86 1.1 Operating System and Microsoft's MS-DOS 2.0 Operating System. These operating systems provide the user with a general environment for program construction, storage, and editing, along with assembly and program checkout facilities. CP/M-80 operating system software as implemented on the 820-II and the 16/8 is logically divided into four parts: ROSR ROM Operating System Routines (hardware dependent) BIOS Basic I/O System (hardware dependent)\* BDOS Basic Disk Operating System\* BDOS Basic Disk Operating System\* CCP Console Command Processor\* ROSR provides code in ROM that can be executed without the presence of the CP/M system disk and provides the primitive operations necessary to access the disk drives and to interface with peripherals. BIOS provides the interface between BDOS and ROSR. BDOS provides disk management by controlling one or more disk drives containing independent file directories. CCP provides symbolic interface between the user's console and the remainder of the CP/M system. #### HARDWARE INTERFACE The 820-II and 16/8 are equipped with six input/output connectors. Four are on the back of the display unit and two are inside the display. #### **Disk Drive** Used for connection of either the 8" or the $5\frac{1}{4}$ " Dual Floppy Drives, or the 8" Rigid Disk Drive. This is determined by the type of disk daughter board installed in the display processor. ## Keyboard Used for connection of either the ASCII or Low Profile keyboard. #### Printer A serial printer can be attached to this RS-232-C connector. ## сомм COMM is a second RS-232-C connector and can be used for a modem. <sup>\*</sup>Disk resident portions of CP/M-80 #### Parallel Port A dual parallel port inside the display cabinet is also provided. ## **Expansion Slot** The expansion slot inside the display cabinet provides all of the Z80-A microprocessor control signals for connection to custom devices for future expansion. This slot is used for the 8086 co-processor if you have a 16/8. #### CP/M-80 The CP/M-80 2.2-C disk for the 820-II contains the standard Digital Research software development and checkout programs. Xerox issues additional utility programs that are unique to the 820-II. A description of each program is listed below: ## **Digital Research Files** | ASM.COM | The Assembler allows you to create a program | |---------|----------------------------------------------| | | which can be read and executed by the 820-II | | DDT.COM | The Dynamic Debugging Tool is used to debug a | |---------|-----------------------------------------------| ## LOAD.COM Reads a .HEX file and creates a command file. MOVCPM.COM Lets you modify and move the CP/M system image to allocate a specific lesser memory size. PIP.COM Allows you to selectively copy a file or files from one disk to another or on the same disk. STAT.COM The status utility is a frequently-used transient command for all system housekeeping; i.e., checking the amount of space available on a disk. SUBMIT.COM Used to submit a file of commands for batch processing. SYSGEN.COM Used to generate a CP/M-80 system image and copy the operating system to another disk. XSUB.COM Same as Submit.com, but has the facility to include line input to programs as well as the console command processor. ## Xerox Files BACKUP.COM A multi-option utility that allows you to archive and retrieve files, delete files, list directories of any drive, and to verify data integrity of a floppy or rigid disk. ## CONFIGUR.COM Using Configur.com, you can select seven different options: - Record Restart Command lets you enter a oneline command which will automatically load a program. For example, you could enter DIR as the restart command and every time you boot the system, it will automatically display the directory for you. Or you could enter the name of your application software package and it would automatically load that application package for you. This command is recorded on the disk and you can have a different one for each disk. - Select Printer Port Options allows you to determine printer protocol. This option allows configuration for alternate printers without modifying the BIOS. - Select Communications Port Options a convenient method for setting up the communications port on the 820-II or 16/8; that is, baud rate, protocol, stop bits, etc. - Select I/O Device Assignments lets you select alternative input/output device assignments; i.e., set up the system so that everything displayed on the screen automatically prints on the printer. - 5. Select Keyboard Data Format lets you choose 7-bit or 8-bit mode for the keyboard. - Select Screen Attributes includes blink, inverse video, highlight/lowlight, and graphics modes. - If you have a floppy disk system, Select Floppy Disk Head Step Rate will appear as selection 7. If you have a rigid disk system, Configure Rigid Disk will appear (program must be loaded from floppy or the first partition of the rigid). - Select Floppy Disk Head Step Rate lets you adjust the floppy head step rate for optimum performance. - b. Configure Rigid Disk lets you divide the eight megabyte rigid disk into sections (e.g., 4 Mb, 2 Mb, 1 Mb, 1 Mb). COPY.COM Makes an exact copy of a disk, track for track. Allows you to format (initialize) a rigid disk. Verification of the rigid disk is performed using the Backup.com utility. HELP.COM A guide for CP/M-80 users that contains basic information about CP/M-80 commands; also cross-references to additional information in the CP/M-80 reference manual, Reorder #9R80448. INIT.COM Prepares new (or used) disks for storing information. It will also alert the user to any flawed sectors on the disk. KILLESC.COM Turns off the <CTRL> + <ESC> feature to enable use of <CTRL> + <ESC> for other purposes; for example, setting margins and tabs on a 40 CPS printer uses a < CTRL> + < ESC> sequence. A convenient method to temporarily change communication and printer port options in RAM. A utility that allows the user to swap drive names. For example, "A" and "E" for a rigid disk drive. By designating an alternate drive as the "A" drive, you can load software directly from that drive. Many CP/M-80 application packages have been written to be executed from the "A" disk drive only. Using Swap.com allows you to place your application software on any disk drive and load. Displays the time and date on screen. Since there is no battery backup, however, you must re-enter the time and date each time you reload the system. This utility lists the logical and physical names for each disk drive, as well as the density, number of 8 SET.COM SWAP.COM TIME.COM WHATSA.COM sides, and types of disks logged into the system, (e.g., double density, single-sided 8" floppy). #### CP/M-86 The CP/M-80 2.2 and CP/M-86 1.1-F disks for the 16/8 contain the standard Digital Research software development and checkout programs. These disks contain the same files as described in the CP/M-80 section as well as the following files. | Digital | Research | Files | |---------|----------|-------| |---------|----------|-------| ASM86.CMD The Assembler allows you to create a program which can be read and executed by the 8086. DDT86.CMD The Dynamic Debugging Tool is used to debug a $8086 \ as sembly \ language \ program.$ ED.CMD A line-oriented screen editor. GENCMD.CMD Uses the hex output of ASM-86 and other language processors to produce a .CMD file. GENCMD.COM Uses the hex output of ASM-86 and other language processors to produce a .COM file. GENDEF.CMD Reads a 16-bit file containing the disk definition statements, and produces a 16-bit output file containing assembly language statements which define the tables necessary to support a particular drive configuration. GENDEF.COM Reads a 16-bit file containing the disk definition statements, and produces an 8-bit output file containing assembly language statements which define the tables necessary to support a particular drive configuration. HELP.CMD Provides summarized information for all of the CP/M-86 commands described in the Digital Research Users manual. LMCMD.CMD Operates in exactly the same manner as Gencmd.cmd, except Lmcmd also accepts an Intel L- module file as input. LMCMD.COM Operates in exactly the same manner as Gencmd.com except Lmcmd also accepts an Intel L- module file as input. PIP.CMD Allows you to selectively copy a file or files from one disk to another or on the same disk. STAT.CMD The status utility is a frequently-used transient command for all system housekeeping, i.e., checking the amount of space available on a disk. Used to submit a file of commands for batch SUBMIT.CMD processing. Time of day. TOD.CMD Xerox Files CPM86.COM Used by Load86.com to boot the 8086. 86CON.COM Switches from Z80-A console to the 8086 console. GOBACK.CMD Switches from 8086 console to the Z80-A console. LOAD86.COM Loads the 8086 for concurrent processing. REBOOT COM From the concurrent mode, reboots the system as a 780-A standalone SOFTKEYS.COM Used to set up the 10-key pad with programmable functions (<CTRL> + one of the 10-key pad keys). #### MS-DOS The MS-DOS 2.0 disk for the 16/8 contains the standard Microsoft software development and checkout programs. Microsoft Files ANSI.SYS Allows programs that use the standard ANSI driver to be executed. COMMAND.COM This is the MS-DOS command processor. It is recommended that this file be placed on every application program disk. CONFIG.SYS Configures system at boot. CHKDSK COM Checks disk CREF.EXE Assists in debugging assembly language programs. DEBUG COM Debugger supplied with MS-DOS. DISKCOPY.COM Copies a disk. EDLIN.COM Line-oriented screen editor. EXE2BIN.EXE Converts .EXE files to binary format. FC.EXE Compares two files for similarity. Finds a string in a list of files or standard input. FIND EXE FORMAT COM Formats an 8" floppy or a rigid disk. LINK.EXE Linker. MORE.COM Used to display text in 23-line segments. MASM.EXE Macro Assembler for MS-DOS. PRINT.COM Print spooler. RDCPM.COM Reads a CP/M-80 file and converts data to MS-DOS- readable file. RECOVER.COM Recovers bad or damaged disks. SORT.EXE Used to sort text. **Xerox Files** SAMPLE.TXT Provided to assist going through MS-DOS Handbook. ## Notes 12 Introduction ## **Specifications** This section details the following specifications: dimensions, electrical requirements, operating environment, and disk drive capacities of the Xerox 820-II and 16/8 PCs. | Dimensions | | | | | |------------------------|--------|--------|--------|---------| | Equipment | Height | Depth | Width | Weight | | 820-II-16/8 Display | 12.20" | 14.75" | 15.00" | 30 lbs. | | ASCII keyboard | 3.75" | 9.50" | 20.00" | 10 lbs. | | Low profile keyboard | 1.60" | 8.25" | 19.90" | 5 lbs. | | 5½" Floppy disk drives | 7.00" | 10.20" | 7.00" | 10 lbs. | | 8" Floppy disk drives | 10.50" | 17.50" | 14.50" | 48 lbs. | | 8" Rigid disk drive | 10.50" | 17.50" | 15.50" | 54 lbs. | | 40 CPS printer | 10.00" | 17.50" | 15.50" | 56 lbs. | | 20 CPS printer | 9.25" | 17.50" | 24.00" | 45 lbs. | ## **Electrical Requirements** All Xerox products listed below require voltage of 115 VAC, a frequency of 60 Hz, and a two-pole, three-wire grounded duplex receptical. | Current | |----------| | 1.1 Amps | | 2.0 Amps | | 2.2 Amps | | 2.0 Amps | | 1.0 Amp | | | ## **Operating Environment** All Xerox equipment is tested to perform between 50 and 90 degrees Fahrenheit with a relative humidity factor between 20% and 80%. | Disk Drive Storage | Unformatted | <b>Formatted</b> | Usable | |--------------------|--------------|------------------|---------------| | 5¼" SS/SD | 125 k | 90 k | <b>8</b> 1 k | | 5¼" SS/DD | 250 k | 168 k | 155 k | | 5¾" DS/SD | 250 k | 180 k | 1 <b>72</b> k | | 5¼" DS/DD | 500 k | 338 k | 322 k | | 8" SS/SD | 400 k | 250 k | 241 k | | 8" SS/DD | 800 k | 497 k | 482 k | | 8" DS/SD | <b>800</b> k | 500 k | <b>49</b> 0 k | | 8" DS/DD | 1.6 Mb | <b>997</b> k | <b>98</b> 0 k | | 8" Rigid (DS/DD) | 10.67 Mb | 8.4 Mb | 8.192 Mb | | Disk Drive Format | | | Bytes<br>per | Number<br>of | | |-------------------|--------|---------|--------------|--------------|--| | Equipment | Tracks | Sectors | Sector | Heads | | | 5½" \$\$/\$D | 40 | 18 | 128 | 1 | | | 51" SS/DD* | 40 | 17 | 256 | 1 | | | 51 DS/SD | 80 | 18 | 128 | 2 | | | 51 DS/DD* | 80 | 17 | 256 | 2 | | | 8" SS/SS | 77 | 26 | 128 | 1 | | | 8" SS/DD** | 77 | 26 | 256 | 1 | | | 8" DS/SD | 154 | 26 | 128 | 2 | | | 8" DS/DD** | 154 | 26 | 256 | 2 | | | 8" Rigid DS/DD | 1,024 | 32 | 256 | 4 | | <sup>\*</sup>Track 0 of $5\frac{1}{4}$ " double density disks has 18 sectors of 128 bytes. For more specific information on disk formats, see the Disk Drive Specifications section. <sup>\*\*</sup>Track 0 of 8" double density disks has 26 sectors of 128 bytes. #### **DISPLAY SPECIFICATION** SIZE: 12 inch, landscape mode TYPE: Aluminized P4 Fluorescence White (W) Phosphorescence White (W) Persistence Short RESOLUTION: • 240 active line raster adjusted to 8.5 x 5.3 inch usable area Brightness level 30 (± 2) foot-lamberts Resolution at centers (within 1" diameter circle) -100 lines/inch minimum CHARACTER CELL: 7x10 BUSINESS GRAPHICS: 4x4 Pixel Resolution CHARACTER SET: 4 sets of 128: (1 U.S. font, 1 Graphics font) (1 U.S. font, Inverse Video font) CHARACTER LINES: 24 CHARACTERS/LINE: 80 VOLTAGE: +12 (± 5.0%) VDC at 2.0 A DC maximum RIPPLE: 50 MV P-P synchronous or nonsynchronous with refresh or power frequency. VIDEO BIT RATE: 10.694 MBPS (93.51 nanoseconds) BITS/HORZ LINE: 560 HORZ SYNC PULSE: 126 (11.78 microseconds) TOTAL BITS/LINE: 686 HORZ RATE: 15.59 KHz (64.14 microseconds) LINES/FIELD: 240 VERT BLANKING LINES: 20 VERT SYNC PULSE: 20(1.28 milliseconds) VERT RETRACE (lines): 8 TYP TOTAL LINES/FIELD: 260 FIELD RATE: 59.95 Hz (16.68 milliseconds) REFRESH RATE: 61 Hz VIDEO RATE: 15 MHz #### FUNCTIONAL DESCRIPTION, XEROX DISPLAY The display has the following functional characteristics: - 24 line display - 80 characters per line - 7x10 dot matrix per character - White characters on black - Software-selectible character attributes - Inverse Video - Blink - Low Intensity - Graphics with 4 x 4 pixel resolution - Brightness adjust #### **DISPLAY CONTROLLER** The Display Controller is based on displaying characters within a 7x10 cell (7 dots horizontally by 10 scan lines vertically). To guarantee spaces between characters, one dot on each side of the cell is blanked by hardware. Also, to guarantee spaces between character lines, the top two scan lines are blanked by hardware. This gives an actual active character size of 5 dots horizontally by 8 scan lines vertically. For Business Graphics, the hardware is configured to eliminate the automatic blanking and allow continuous lines both horizontally and vertically. However, the Display Controller is still based on displaying a character within a 7 x 10 cell. The controller design and available refresh memory allows one byte per character. The maximum number of unique characters that can be defined by any 8 bits is 256. Since the standard text font set contains 128 characters, the limit on unique characters for graphics that can be displayed together with text is 128. The character set for Business Graphics divides the cell into blocks of 4 dots horizontally by 4 scan lines vertically. Since the total number of scan lines per character is 10, the character set actually consists of two sub-sets of 4-4-2 and 2-4-4. Each subset divides the cell into 6 parts requiring 64 possible combinations or unique characters. Therefore, the total number of unique characters for the complete graphics set is 128. With this character set, any combination of adjacent 4 x 4 blocks can be chosen. Also, at the character cell boundary, the 4 x 4 blocks can be set vertically by 2 scan lines. Since the total number of horizontal dots per cell is 7, there will be an overlap of one horizontal dot in the center of the cell for diagonal blocks within the cell. It should be also noted that for the standard text font containing 128 unique characters defined by 7 bits, the eighth bit is used to set the attribute function. For Business Graphics, since both text characters and graphic characters can be displayed simultaneously, it requires all 8 bits to define the character. Consequently, display attributes are not available in graphics mode. #### SYSTEM BUS EXPANSION SLOT #### **ELECTRICAL** The DC system power available at the expansion slot is as follows: | | 5 | 📲 system | 8" or Rigid system | |--------|-------------|----------|--------------------| | PIN 50 | + 5V DC | 1.2A | 2.1 A | | PIN 45 | + 12V DC #1 | 0.3A | 1.75 A | #### **ENVIRONMENTAL** The following temperature, humidity and altitude environmental requirements are specified: | | Temp.<br>(°Celsius) | Rel.Hum.<br>(%) | Altitude<br>(miles) | |---------------|---------------------|-----------------|---------------------| | Operating | 10 to 32 | 20 to 80 | 1830 | | Non-operating | -77 to 66 | 15 to 90 | 7620 | Any optional or additional electronic assembly using the expansion slot must be capable of performing to design specification when the host is subjected to the environmental range, above. Furthermore, the presence of such an assembly in the expansion slot must not degrade performance with regard to the above environmental requirements. 18 ## HARDWARE INTERFACE | <b>820-11</b> J8 P8 | | | RALLE | |----------------------------|------|---------------|-------| | • | PB2 | DATA STROBE | | | -30- | PA0 | DATA BIT 0 | | | <u> </u> | PA1 | DATA BIT 1 | | | — 8 —<br>— 10 — | PA2 | DATA BIT 2 | | | | PA3 | DATA BIT 3 | | | -12- | PA4 | DATA BIT 4 | | | 14 | PA5 | DATA BIT 5 | | | <del>-16 -</del> | PA6 | DATA BIT 6 | | | <del>-18</del> - | PA7 | DATA BIT 7 | | | | PB7 | ACKNOWLEDGE 9 | | | <del>-40</del> - | PB4 | BUSY 10 | | | <del>-34</del> - | PB6 | ON LINE | | | <del>- 38 -</del> | PB0 | AUTO LF | | | -26 -<br>-37 - | GND. | 14- | | | | GND. | 16 | | | -1*- | GND. | | | | | GND. | | | | | GND. | 21- | | | <b>—</b> 9 <b>—</b> | GND. | 22 — | | | 11 | GND. | 23 | | | -13- | GND. | | | | <del></del> 15 <del></del> | GND. | 25 | | | <del></del> 17 | GND. | | | | <del></del> 19 | GND. | 27— | | | —21*— | GND. | 28 | | | <del>-</del> 3 - | GND. | | | | <del>-35</del> - | GND. | <del></del> | | | <del></del> 39 | GND. | 33 | | | <del></del> 28 <b></b> | | | | ## **Power Supplies, and Video Connectors** ## Parallel Port Connector (J8) 10 1 39 0000000000000000000 00000000000000000000 2 40 **J8** Value Pin Port A Strobe 4 Port A Ready 6 Port A Bit 0 Port A Bit 1 8 Port A Bit 2 10 12 Port A Bit 3 Port A Bit 4 14 Port A Bit 5 16 Port A Bit 6 18 20 Port A Bit 7 22 Port B Ready 24 Port B Strobe 26 Port B Bit 0 28 30 32 34 36 38 40 Odd # Pins Port B Bit 1 Port B Bit 2 Port B Bit 3 Port B Bit 4 Port B Bit 5 Port B Bit 6 Port B Bit 7 Ground 23 ## Parallel connector picture ## **COMM Port Strapping Options** | 39 | | 1 | |----|-----------------------------------------|---| | | 000000000000000000000000000000000000000 | | | | 000000000000000000000000000000000000000 | | | 40 | | 2 | 19 | <u>Pin</u> | <u>Value</u> | |------------|---------------------------------------| | 56 | (M) TXD to Pin 3 | | 78 | (T) TXD to Pin 2 | | 910 | (M) RXD from Pin 2 | | 1112 | (T) RXD from Pin 3 | | 1314 | (M) RTS to Pin 5 | | 1516 | (T) RTS to Pin 4 | | 1718 | (M) CTS from Pin 4 | | 1920 | (T) CTS from Pin 5 | | 2122 | (M) DTR to Pin 8 | | 2324 | (T) DTR to Pin 20 | | 2526 | (M) DCD from Pin 20 | | 2728 | (T) DCD from Pin 8 | | 2930 | Clock supplied to Modem as RX Clock | | 3132 | Clock supplied to SIO with RX Clock | | 3334 | Modem supplies SIO with RX Clock | | 3536 | Clock supplied to SIO with TX Clock | | 3738 | Modem supplies SIO with TX Clock | | 3940 | Clock supplied to Modem with TX Clock | The filled-in pins indicate the options as they are jumpered on an 820-II or 16/8. ## Note: (M) indicates modem (data communications equipment) function. (T) indicates terminal data equipment) function. For instance, exercising the (M) strap option will allow communication with a modem; exercising the (T) strap option will allow communication with a terminal. The above shows factory settings for (T). 000000000000000 1 29 | 000 | 000000000000 | |------------|-------------------------------------| | 30 | 2 | | <u>Pin</u> | <u>Value</u> | | 34 | | | 56 | (M) TXD to Pin 3 | | 78 | (T) TXD to Pin 2 | | 910 | (M) RXD from Pin 2 | | 1112 | (T) RXD from Pin 3 | | 1314 | (M) RTS to Pin 5 | | 1516 | (T) RTS to Pin 4 | | 1718 | (M) CTS from Pin 4 | | 1920 | (T) CTS from Pin 5 | | 2122 | (M) DTR to Pin 8 | | 2324 | (T) DTR to Pin 20 | | 2526 | (M) DCD from Pin 20 | | 2728 | (T) DCD from Pin 8 | | 2930 | Clock supplied to Modem as RX Clock | The filled-in pins indicate the options as they are jumpered on an 820-II or 16/8. Note: To change from ASYNC to SYNC on the Etch 2 CPU requires a modification to the operating system rather than moving jumpers. Note: (M) indicates modem (data communications equipment) function. (T) indicates terminal data equipment) function. For instance, exercising the (M) strap option will allow communication with a modem; exercising the (T) strap option will allow communication with a terminal. The above shows factory settings for (T). # System Bus Connector # J13 | D1 | 1 | 2 | /RD | |----------|----|----|----------| | D0 | 3 | 4 | /MEMRQ | | D7 | 5 | 6 | /IORQ | | D2 | 7 | 8 | /WR | | D6 | 9 | 10 | /REFRESH | | D5 | 11 | 12 | /M1 | | D3 | 13 | 14 | Α0 | | D4 | 15 | 16 | A1 | | SYSRESET | 17 | 18 | A2 | | A4 | 19 | 20 | A3 | | A6 | 21 | 22 | A5 | | A15 | 23 | 24 | Α7 | | A13 | 25 | 26 | A14 | | A12 | 27 | 28 | A10 | | Α9 | 29 | 30 | A11 | | A8 | 31 | 32 | /BUSRQ | | WAITRQ | 33 | 34 | /BUSAK | | PCI | 35 | 36 | | | /INTRQ | 37 | 38 | | | /HALT | 39 | 40 | /CLOCK | | SPKR | 41 | 42 | /MEM8 | | | 43 | 44 | /MEM4 | | + 12V | 45 | 46 | | | + 12V | 47 | 48 | GND | | GND | 49 | 50 | + 5V | | | | | | | | Pin | Pin | | |---------------|----------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------| | <u>Symbol</u> | <u>#</u> | <u>Name</u> | <u>Meaning</u> | | D0 | 3 | Data bus | Data Bus (Tri-state, input/output, | | D1 | 1 | Data bus | active high) constitutes an 8-bit | | D2 | 7 | Data bus | bi-directional data exchange | | D3 | 13 | Data bus | with memory and I/O devices. | | D4 | 15 | Data bus | | | D5 | 11 | Data bus | | | D6 | 9 | Data bus | | | D7 | 5 | Data bus | | | Α0 | 14 | Address bus | Address Bus (Tri-state, output, | | A1 | 16 | Address bus | active high) makes up a 16-bit | | A2 | 18 | Address bus | address for up to 65k bytes of | | A3 | 20 | Address bus | memory for I/O devices data | | A4 | 19 | Address bus | exchange. I/O addressing uses | | A5 | 22 | Address bus | the lower 8 bits for direct | | A6 | 21 | Address bus | selection of up to 256 output | | A7 - | 24 | Address bus | ports. A0 is the least significant | | A8 | 31 | Address bus | address bit. During refresh time, | | A9 | 29 | Address bus | the lower 7 bits contain a valid | | A10 | 28 | Address bus | refresh address for dynamic | | A11 | 30 | Address bus | memories. | | A12 | 27 | Address bus | | | A13 | 25 | Address bus | | | A14 | 26 | Address bus | | | A15 | 23 | Address bus | | | /WR | 8 | Write | Write (Tri-state, output, active low) indicates that the CPU data bus holds valid data to be stored in the addressed memory or I/O device. | | /RD | 2 | Read | Read (Tri-state, output, active high) indicates that the CPU wants to read data from memory or an I/O device. The addressed | | /IORQ | 6 | I/O Request | I/O device or memory should use<br>this signal to gate data onto the<br>CPU data bus.<br>Input/Output Request (Tri-state, | | ποιιο | | "O nequest | output, active low) signal indicates that the lower half of | | | | | address for an I/O read or write operation. This signal is also generated with a "/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 "/M1" time, while I/O operations never occur during "/M1" time. | |----------|----|----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | /HALT | 39 | Halt | Halt (Output, active low) signal indicates that the CPU has executed a Halt Software instruction and is awaiting either a non-maskable or maskable interrupt before operation can resume. | | /MEMRQ | 4 | Memory<br>Request | Memory Request (Tri-state, output, active low) signal indicates that the address bus holds a valid address for a memory read or memory write operation. | | /REFRESH | 10 | Refresh | Refresh (Tri-state, output, active low) indicates that the lower 7 bits of the address contain a refresh address for dynamic memories and the "/MEMRQ" signal should be used to perform a refresh cycle for all dynamic RAMs in the system. During the refresh cycle "A7" is a logic zero and the upper 8 bits of the address bus contain the "I" register. | | /M1 | 12 | Machine<br>Cycle One | Machine Cycle One (Tristate, output, active low) indicates that the current machine cycle is in the op-code fetch cycle of an instruction. Note | the address bus holds a valid I/O | | | | that during the execution of two- | |---------|----|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | | | byte op-codes, "/M1" will be<br>generated as each op-code is<br>fetched. These two-byte op- | | | | | codes always begin with a CB, DD, ED, or FD. "/M1" also occurs with "/IORQ" to indicate an interrupt acknowledge cycle. | | /BUSAK | 34 | Bus<br>Acknowledge | Bus Acknowledge (Output, active low) is used to indicate to the requesting device that the CPU address bus, data bus, and control bus signals have been set to their high impedance states and the external device can now | | | | | control the bus. | | /BUSRQ | 32 | Bus Request | Bus Request (Input, active low) signal is used to request the CPU address bus, data bus, and control | | | | | signal bus to go to a high | | | | | impedance state so that other devices can control those buses. | | | | | When "/BUSRQ" is activated, the | | | | | CPU will set these buses to a high | | | | | impedance state as soon as the<br>current CPU machine cycle is | | | | | finished and the "/BUSAK" signal is activated. | | /INTRQ | 37 | Interrupt | Interrupt Request (Input, | | | | Request | active low) 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 "/BUSRQ" signal is not | | /WAITRQ | 33 | Wait Request | active. Wait Request (Input, active low) | | , | | • | indicates to the CPU that the | | | | | addressed memory or I/O device is not ready for a data transfer. The | | | | | CPU continues to enter wait states | | | | | | | /SYSREST | 17 | System Reset | 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. Use of this signal postpones refresh as long as it is held active. System Reset (Output, active low) indicates that a reset has been generated either from push button reset or the power on reset circuit. The system reset will occur only once per reset and will be approximately 10 microseconds in duration. | |----------|-----|----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | /CLOCK | 40 | Processor<br>Clock | Processor Clock (Output, active low) is a single-phase system clock of 4 MHz. | | PCI | 35 | Priority<br>Chain In | Priority Chain In (Input, active high) is used to form a priority-interrupt daisy chain when more than one interrupt-driven device is being used. A high level on this pin indicates that no other devices of higher priority are being serviced by a CPU interrupt service routine. | | /MEM4 | 44 | Memory<br>Expansion | Memory Expansion<br>(Output, active low) signal is low<br>during "/MEMRQ" for a block of<br>addresses from "4000 thru 7FFF"<br>if the Bank Switch is set for the<br>ROM side of memory. | | /MEM8 | 42 | Memory<br>Expansion | Memory Expansion (Output, active low) signal is low during "/MEMRQ" for a block of addresses from "8000 thru BFFF" if the Bank Switch is set for the ROM side of memory. | | /SPKR | .41 | Speaker | Speaker pin provides access to the speaker on the CPU Board. This pin is connected to the open collector output of the speaker | | + 5VDC<br>GND | 50<br>49,48 | DC Power<br>Ground | |---------------|-------------|--------------------| | + 12VD0 | 47,45 | DC Power | | | 36 | Not Used | | | 38 | Not Used | | | 43 | Not Used | | | 46 | Not Used | driver (75451). This output is normally connected thru the speaker and parallel 100 ohm resistor to a + 12 VDC, but can be disconnected by jumper option. + 5VDC system power. Ground-System is signal ground and DC return. + 12VDC system power. ## **Disk Access Connector** ## J12 | D1 | 1 | 2 | /RD | |--------------|----|----|-------------| | D0 | 3 | 4 | /MREQ | | D7 | 5 | 6 | /IORO | | D2 | 7 | 8 | ∕WR ` | | D6 | 9 | 10 | /BUSAK | | D5 | 11 | 12 | /M1 | | D3 | 13 | 14 | A0 | | D4 | 15 | 16 | A1 | | RST | 17 | 18 | A2 | | A4 | 19 | 20 | A3 | | A6 | 21 | 22 | A5 | | A15 | 23 | 24 | Α7 | | A13 | 25 | 26 | A14 | | A12 | 27 | 28 | A10 | | A9 | 29 | 30 | A11 | | A8 | 31 | 32 | /BUSRQ | | 16 MHz Clock | 33 | 34 | /BUSAK1 | | /HALT | 35 | 36 | /1797CS | | INT | 37 | 38 | PRIO | | PP5 | 39 | 40 | 4 MHz Clock | | PP2 | 41 | 42 | PP4 | | PP1 | 43 | 44 | PP0 | | + 12V | 45 | 46 | NM1 | | GND | 47 | 48 | GND | | DSKWAT | 49 | 50 | + 5V | | | 51 | 52 | + 5V | | J1-19 | 53 | 54 | J1-10 | | J1-18 | 55 | 56 | J1-9 | | J1-17 | 57 | 58 | J1-8 | | J1-16 | 59 | 60 | J1-2 | | J1-15 | 61 | 62 | J1-3 | | J1-14 | 63 | 64 | J1-4 | | J1-13 | 65 | 66 | J1-5 | | J1-12 | 67 | 68 | J1-6 | | J1-11 | 69 | 70 | J1-7 | | | 71 | 72 | | | | Pin | Pin | k = k | |---------------|----------|----------------|---------------------------------------------| | <u>Symbol</u> | <u>#</u> | <u>Name</u> | Meaning | | D0 | 3 | Data bus | Data Bus (Tri-state, input/output, | | D1 | 1 | Data bus | active high) constitutes an 8-bit | | D2 | 7 | Data bus | bi-directional data exchange with | | D3 | 13 | Data bus | memory and I/O devices. | | D4 | 15 | Data bus | | | D5 | 11 | Data bus | | | D6 | 9 | Data bus | | | D7 | 5 | Data bus | | | A0 | 14 | Address Bus | Address bus A0-A15 | | A1 | 16 | Address Bus | provides addresses for 65k | | A2 | 18 | Address Bus | bytes of memory. Bit A0 and | | A3 | 20 | Address Bus | A1 while under /RD and /WR | | A4 | 19 | Address Bus | control select the register | | A5 | 22 | Address Bus | to receive transfer of data | | A6 | 21 | Address Bus | on D0-D7: | | A7 | 24 | Address Bus | A1 A0 /RD /WR | | A8 | 31 | Address Bus | 0 0 Status REG Command REG | | A9 | 29 | Address Bus | 0 1 Track REG Track REG | | 2A10 | 8 | Address Bus | 1 0 Sector REG Sector REG | | A11 | 30 | Address Bus | 1 1 Data REG Data REG | | 2A12 | 7 | Address Bus | A5 while under /RD and /WR | | A13 | 25 | Address Bus | Control Select Density: | | A14 | 26 | Address Bus | 0 = double density | | A15 | 23 | Address Bus | 1 = single density | | PP0 | 44 | SYS-PIO Port A | Port A bit 0 | | PP1 | 43 | SYS-PIO Port A | Port A bit 1 | | PP2 | 41 | SYS-PIO Port A | Port A bit 2 | | PP4 | 42 | SYS-PIO Port A | Port A bit 4 | | PP5 | 39 | SYS-PIO Port A | Port A bit 5 | | PRIO | 38 | SYS-PIO | | | /DSKWAT | 49 | Disk Wait | Generates Wait signal to CPU. | | /RD | 2 | Read | Controls input on the data registers D0-D7. | | /MREQ | 4 | Memory | /MREQ indicates that the address | | | | Request | bus holds a valid address for a | | | | | memory read or memory write | | | | | operation. | | * | | | • | | /IORQ | 6 | I/O Request | /IORQ indicates that the lower half of the address bus holds a valid I/O address for an I/O read or write operation. /IORQ is also generated concurrently with /M1 during an interrupt acknowledge cycle to indicate that an interrupt response vector can be placed on the data bus. | |---------|----|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | /WR | 8 | Write | Controls output on the data registers D0-D7. | | /BUSACK | 10 | Bus<br>Acknowledge | /BUSACk indicates to the requesting device that the CPU address bus, data bus, and control signals /MREQ, /IORQ, /RD, /WR have entered the high impedance states. The external circuitry can now control these lines. | | /M1 | 12 | Machine<br>Cycle 1 | /M1, together with /MREQ indicates that the current machine cycle is the op-code fetch cycle of an instruction execution. /M1, together with /IORQ, indicates an interrupt acknowledge cycle. | | /BUSREQ | 32 | Bus Request | /BUSREQ has the highest priority and is always recognized at the end of the current machine cycle. /BUSREQ forces the CPU address bus, data bus, and control signals /MREQ, /IORQ, /RD, and /WR to go to a high impedance state so that other devices can control these lines. | | /BUSAK1 | 34 | Bus<br>Acknowledge | /BUSAK1 is daisy-chained Bus<br>Acknowledge output which<br>indicates to the requesting device<br>that the CPU address bus, data<br>bus, and control signals /MREQ,<br>/IORQ, /RD, /WR have entered the<br>high impedance states. The | | | | | external circuitry can now control | |----------------|----------|-------------------|--------------------------------------------| | /1797CS | 36 | Chip Select | these lines. /1797CS logic low selects the | | /1/3/03 | 30 | Cuib select | Floppy Disk Controller chip and | | | | | enables computer communication | | | | | with the device. | | INT | 37 | Interrupt | INT is generated by I/O devices. | | | | Request | The CPU honors a request at the | | | | | end of the current instruction if | | | | | the internal software controlled | | | | | interrupt enable flip-flop (IFF) is | | | | | enabled. | | NMI | 46 | Non-Maskable | NMI is always recognized at the | | | | Interrupt | end of the current instruction, | | | | | independent of the status of the | | | | | interrupt enable flip-flop and | | | | | automatically forces the CPU to | | | | | restart at location 0066h. | | /HALT | 35 | Halt | /HALT indicates that the CPU has | | | | | executed a Halt instruction and is | | | | | awaiting either a non-maskable | | | | | or a maskable interrupt (with the | | | | | mask enabled) before operation | | | | | can resume. While halted, the | | | | | CPU executes NOPs to maintain | | | | | memory refresh. | | 16MHz | 33 | Clock | 16 MHz clock. | | CLK | 40 | Clock | 4 MHz clock. | | J1-2 | 60 | Device I/O | All interface lines use | | 11.3 | 63 | Interface | negative logic. | | J1-3 | 62 | Device I/O Inter | | | J1-4<br>J1-5 | 64<br>66 | Device I/O Interi | | | J1-5<br>J1-6 | 68 | Device I/O Interi | | | J1-0<br>J1-7 | 70 | Device I/O Interi | | | J1-7<br>J1-8 | 70<br>58 | Device I/O Interi | | | J1-0<br>J1-9 | 56 | Device I/O Interi | | | J1-10 | 54 | Device I/O Interi | | | J1-10<br>J1-11 | 54<br>69 | Device I/O Interi | | | J1-11<br>J1-12 | 67 | Device I/O Interi | | | J1-12<br>J1-13 | 65 | Device I/O Interi | | | J1-13<br>J1-14 | 63 | Device I/O Interi | | | ) i i i i i | 33 | Device NO litter | ucc . | | J1-15 | 61 | Device I/O Inte | erface | |---------|----|-----------------|---------------------------------| | J1-16 | 59 | Device I/O Inte | erface | | J1-17 | 57 | Device I/O Inte | erface | | J1-18 | 55 | Device I/O Inte | erface | | J1-19 | 53 | Device I/O Inte | erface | | + 12VDC | 45 | DC Voltage | + 12 Volts DC | | GND | 47 | Ground | Ground and DC Return | | GND | 48 | Ground | Ground and DC Return | | + 5VDC | 50 | DC Voltage | + 5 Volts DC | | + 5VDC | 52 | DC Voltage | + 5 Volts DC | | RST | 17 | Reset | Reset indicates that a System | | | | | Reset has been generated either | | | | | from push button reset or power | | | | | on reset. | | | 51 | Not Used | | | | 71 | Not Used | | | | 72 | Not Used | | | | L.H. 8" | <del>-</del> | R.H. 8" | |-----------|-------------|---------------|----------------| | MAIN PWA | DISK DRIV | _ | DISK DRIVE | | J1 P1 | NDEX P1 J1 | INDEX P1A | J1 | | - 22 DRIV | E SEL 1 | DRIVE SEL 1 | ō <del>-</del> | | -23 DPI | E SEL 2 13 | DRIVE SEL 2 | 3— | | 34 | 1/ | | ₹ <b>-</b> | | -17-RI | ADY M — | READY | 1- | | 8 _HEA | D LOAD K | HEAD LOAD | <del>\</del> = | | -26 DI | R SEL U | DIR SEL | = | | —27——S | 17 — 17 — V | STEP 1 | 7— | | -28 W/DI | E DATA 18 | WRITE DATA | 8— | | | | WRITE GATE | 9— | | | 00 | | <u>-</u> | | -13-TRA | CK 00 Y | TRACK 00 | ( <u> </u> | | 14 | PROTECT Z | WRITE PROTECT | _ | | 32 REA | D DATA a | READ DATA | 2— | | -33 SII | O SEL 23 | SID SEL 2 | 3— | | -25 | | - | <b>_</b> | | -3<br>-21 | E<br>5 | | _ | | | L | | | Notes ## Theory of Operation The display processor houses the system board, disk drive daughter board, the CRT, the power supply, and one bus expansion slot. The system board has the following: - Central Processing Unit (CPU) - 6 to 8k of Read Only Memory (ROM) - 64k of Random Access (Read/Write) Memory (RAM) - Counter Timer Circuit (CTC) - Serial Input/Output Controller (SIO) - Parallel Input/Output Controller (PIO) - Two RS-232-C Serial I/O Ports - Dual 8-bit Parallel Ports - CRT Controller and CRT Refresh Memory - Speaker - Disk Drive Daughter Board Connector - Bus Expansion Connector - 8086 Co-processor (16/8 system) - Parallel Keyboard Interface #### CPU The CPU is a Zilog Z80-A operating with a clock rate of 4 Mhz. It is initialized to use Interrupt Mode 2 by the ROSR monitor at power on. The Z80-A also provides refresh to the 64k of dynamic memory on the system board. Therefore, the I and R registers should not be altered by an application program. ## **ROM and RAM Memory** The System Board has two banks of memory. Bank 1 has 64k of RAM. Bank 0 has up to 8K of ROM. When power is turned on or RESET is pressed, the Monitor, ROM/CRT RAM (Bank 0), is enabled by the hardware and the contents of the monitor ROM are moved by the CPU to the program memory starting at location F000H. When the move is complete, the CPU transfers control to location F000H and RAM (Bank 1) is enabled. Bank 0 is also enabled when a character is sent to the screen. ### 6-8k ROM The CPU board has provisions for 4-2k x 8 Read Only Memory devices. The first 3 (U33, U34 & U35) store the firmware for the ROSR monitor. The fourth (U36) provides translation tables and related firmware for the position-encoded low profile keyboard. #### 64k RAM The 64k byte (65536 x 8) RAM provides space for a portion of the ROSR monitor (upper 4k F000h - FFFFh), and 60k (0000h - EFFFh) is free for programs to execute in such as an operating system and an application program. This RAM is dynamic and refresh is provided by the Z80-A CPU. ### **Counter Timer Circuit (CTC)** The CTC has four independently-programmable counter/timer channels, each with a readable downcounter and a selectable 16 or 256 prescaler. Downcounters are reloaded automatically at zero. Each channel is programmed with two bytes. Once started, the CTC counts down, reloads its time constant automatically, and resumes counting. Internally, the CTC generates a unique vector for each channel. ## Serial Input/Output Controller (SIO) The Serial I/O Controller has two independent, full-duplex channels with separate control and status lines for modems or other devices. Data rates are from 50 to 19,200 bits/second. Channel A (modem) supports both Asynchronous and Synchronous protocols. Channel B (printer) is dedicated to Asynchronous. The receiver is quadruple-buffered and the transmitter is double-buffered. The controller also supports daisy-chain interrupt vectoring for interrupts without external logic. ### Serial I/O Ports The 820-II CPU board contains a Z80-A SIO that provides two user-accessible serial ports to the 25-pin printer and modem connectors on the rear of the display processor. The Communications port is capable of operating in synchronous or asynschronous modes, while the Printer port is only capable of operating asynchronously. On an Etch 2 CPU, there is a 30-pin connector. Selection of synchronous or asynchronous mode is under program control as opposed to the Etch 1 CPU (with a 40-pin connector) where a physical change is required to make the sync or async selection. ## Parallel Input/Output Controller (PIO) There is a System and a General Purpose Parallel I/O Controller which provides direct interface between the CPU and the peripheral devices. Each controller has two 8-bit I/O ports. The System PIO is dedicated for keyboard input, memory bank and CRT font selection, and floppy disk drive and side selection. The General Purpose PIO provides the user with a dual 8-bit parallel I/O port for interfacing with peripherals. ### Parallel Port The Z80-A General Purpose PIO is accessible on the main CPU board on connector J8. This PIO is programmed by the ROSR monitor at power-on to provide a parallel Centronics-compatible interface for a parallel printer. A transceiver is physically located between the Z80-A PIO and the J8 connector. Jumpers must be installed on option connector J11 to select whether the transceiver will transmit or receive data. See also page 24. #### **CRT Controller** The CPU board contains the 2k of refresh RAM where the characters that are to be displayed on the screen are stored. It also has the necessary electronics to provide the control signals (sync and video) to the CRT monitor. The CPU board has two character font ROMs; each font ROM contains two character sets. U57 Normal white on black font Reverse video font U58 Normal white on black font Graphic character font The CRT driver in the ROSR monitor translates character-level escape sequences into commands as to which of the font ROMs to select and which of the two fonts inside the selected font ROM to select. Basically, characters that are stored in the CRT's refresh memory address the selected font ROM; the font ROM provides dot information to the video input of the CRT so the character can be displayed. The characters on the CRT can have one of the following attributes: Blink Inverse video Graphics Low intensity The most significant bit of the character stored in the CRT's refresh memory determines if the character is to be displayed with its attribute enabled. The ROSR monitor provides a character-oriented command format for controlling the screen and font ROM selection. It is recommended that programs use this method to control the CRT and its attributes. ### **CRT RAM** ## **Memory Allocation** The CRT RAM occupies 3000H - 3FFFH in bank 0 (System Bank). Each 80-character line on the CRT is allocated 128 bytes in the CRT RAM. Listed below are the starting and ending addresses for each of the 24 rows in the CRT RAM. The example (at the bottom) shows some character locations in CRT memory. (Assumes scroll register = 23) | Row | Starting Address | Ending Address | |-----|------------------|--------------------| | 0 | 3000H | 304FH | | 1 | 3080H | 30CFH | | 2 | 3100H | 314FH | | 3 | 3180H | 31CFH | | 4 | 3200H | 324FH | | 5 | 3280H | 32CFH | | 6 | 3300H | 334FH | | 7 | 3380H | 33CFH | | 8 | 3400H | 344FH | | 9 | 3480H | 34CFH | | 10 | 3500H | 354FH | | 11 | 3580H | 35CFH | | 12 | 3600H | 364FH | | 13 | 3680H | 36CFH | | 14 | 3700H | 374FH | | 15 | 3780H | 37CFH | | 16 | 3800H | 384FH | | 17 | 3880H | 38CFH | | 18 | 3900H | 394FH | | 19 | 3980H | 39CFH | | 20 | 3A00H | 3A4FH | | 21 | 3A80H | 3ACFH | | 22 | 3B00H | 3B4FH | | 23 | 3B80H | ЗВСҒН | | Row | Column | CRT Memory Address | | 0 | 0 | 3000H | | 0 | 79 | 304FH | | 1 | 1 | 3081H | 5 0 79 3085H 3B80H 3B81H 3BCFH 1 23 23 23 ## **Scroll Register** To eliminate the delay associated with software scrolling, hardware scrolling is employed. Writing into the scroll register (Port 14h) adds an offset to the line address developed by the line counter. For instance, with an offset of zero (scroll register = 0), the data at location 3000H (in the CRT refresh memory) will be displayed on the bottom row of the display. If the offset is 23, the data at location 3000H will be displayed on the top row of the screen. The scroll register is loaded from A8 to A15 rather than D0 to D7. Therefore, the scroll value must be in the B register if an indirect OUT instruction is used. | Scroll Register | Row 0, Column 0 | Row 23, Column 0 | |-----------------|-----------------|------------------| | 23 | 3000H | 3B80H | | 23 | 3000H | 3B80H | |----|-------|-------| | 22 | 3080H | 3B00H | | 21 | 3100H | 3A80H | | 20 | 3180H | 3A00H | | 19 | 3200H | 3980H | | 18 | 3280H | 3900H | | 17 | 3300H | 3880H | | 16 | 3380H | 3800H | | 15 | 3400H | 3780H | | 14 | 3480H | 3700H | | 13 | 3500H | 3680H | | 12 | 3580H | 3600H | | 11 | 3600H | 3580H | | 10 | 3680H | 3500H | | 9 | 3700H | 3480H | | 8 | 3780H | 3400H | | 7 | 3800H | 3380H | | 6 | 3880H | 3300H | | 5 | 3900H | 3280H | | 4 | 3980H | 3200H | | 3 | 3A00H | 3180H | | 2 | 3A80H | 3100H | | 1 | 3B00H | 3080H | | 0 | 3B80H | 3000H | | | | | ### Speaker The 820-II and 16/8 have an audio speaker connected to two I/O ports (28h and 29h). Outputting to one I/O port causes the speaker cone to be pushed out; outputting to the other I/O port pulls in the speaker cone. The actual value output to these ports has no significance. To generate a beep, the application program can simply send an ASCII Bell character to the CRT. To generate a tone other than the standard bell character, the program must move the speaker cone in and out at the desired frequency. ## **Disk Drive Daughter Board** The disk drive connector on the rear is a "dual personality" connector, depending on which disk drive daughter board is installed on the mother board. Presently, there are two types of disk interface: Shugart SASI interface controller suitable for interfacing to a SA1403D Rigid Disk Controller. Floppy-only interface suitable for interfacing to Shugart SA800/SA400L/SA850/SA450 dual daisy-chained disk configurations. The ROSR monitor detects which daughter board is installed at power-on and selects the appropriate physical disk driver firmware to process physical disk drive requests. ### Caution: If a rigid disk drive unit (U07, U08) is connected to a floppy display/processor (U03/H69, U04), the rigid controller PWB will be destroyed when power is switched on. The rigid disk drive unit must be connected only to a rigid display/processor (U05/H70, U06). Connecting a floppy disk drive unit (929/T66/973/F10, E41/E44/E42/E89) to a rigid display/processor (U05/H70, U06) may cause the processor PWB to fail. Before connecting any disk drive unit to a display/processor, check that the configuration of the display/processor is compatible with the disk drive unit. The configuration can be determined in one of two ways. (1) Check the product code of the display/processor. The product code is the first three digits of the serial number, located on the underside of the display processor. (2) Verify that the proper drive interface PWB is installed by checking the part number. ## System Bus The System Bus contains an 8-bit Data Bus (Tri-state, Input/Output) bidirectional Data exchange with memory and I/O devices. It has a 16-bit Address Bus to address up to 64k of memory for I/O devices data exchange. ## **Keyboard Interface** The keyboard FIFO (Etch 2 CPU only) has space for 16 (decimal) entries. Associated with the keyboard FIFO are input and output position pointers and a count of the number of entries currently in the FIFO. The available memory pointers provide the addresses bounding the available unused RAM in the memory reserved for system use. Although these pointers are a supported feature, there is no guaranteed available memory size. There are two tables used to disk map a logical disk to its physical driver. The first table, Seltab, associates a logical disk number with a physical disk number. The second table, Drvtab, identifies which physical disk driver is appropriate to use with the selected physical disk. The physical driver command block is a collection of all information necessary for the disk system to perform the requested disk activity. The timer and clock variables are a collection of locations used for maintaining the one second timer and the time-of-day clock and calendar. The console command line buffer immediately follows these variables. ## Z8400 Z80° CPU Central Processing Unit ## Product Specification June 1982 #### Fectures - The instruction set contains 158 instructions. The 78 instructions of the 8080A are included as a subset; 8080A software compatibility is maintained. - Six MHz, 4 MHz and 2.5 MHz clocks for the Z80B, Z80A, and Z80 CPU result in rapid instruction execution with consequent high data throughout. - The extensive instruction set includes string, bit, byte, and word operations. Block searches and block transfers together with indexed and relative addressing result in the most powerful data handling capabilities in the microcomputer industry. - The Z80 microprocessors and associated family of peripheral controllers are linked by a vectored interrupt system. This system - may be daisy-chained to allow implementation of a priority interrupt scheme. Little, if any, additional logic is required for daisy-chaining. - Duplicate sets of both general-purpose and flag registers are provided, easing the design and operation of system software through single-context switching, background-foreground programming, and single-level interrupt processing. In addition, two 16-bit index registers facilitate program processing of tables and arrays. - There are three modes of high speed interrupt processing: 8080 compatible, non-Z80 peripheral device, and Z80 Family peripheral with or without daisy chain. - On-chip dynamic memory refresh counter. Figure 1. Pin Functions Figure 2. Pin Assignments #### General Description The Z80, Z80A, and Z80B CPUs are thirdgeneration single-chip microprocessors with exceptional computational power. They offer higher system throughput and more efficient memory utilization than comparable secondand third-generation microprocessors. The internal registers contain 208 bits of read/write memory that are accessible to the programmer. These registers include two sets of six generalpurpose registers which may be used individually as either 8-bit registers or as 16-bit register pairs. In addition, there are two sets of accumulator and flag registers. A group of "Exchange" instructions makes either set of main or alternate registers accessible to the programmer. The alternate set allows operation in foreground-background mode or it may be reserved for very fast interrupt response. The Z80 also contains a Stack Pointer, Program Counter, two index registers, a Refresh register (counter), and an Interrupt register. The CPU is easy to incorporate into a system since it requires only a single +5 V power source. All output signals are fully decoded and timed to control standard memory or peripheral circuits, and it is supported by an extensive family of peripheral controllers. The internal block diagram (Figure 3) shows the primary functions of the Z80 processors. Subsequent text provides more detail on the Z80 I/O controller family, registers, instruction set, interrupts and daisy chaining, and CPU timing. Figure 3. Z80 CPU Block Diagram #### Z80 Microprocessor Family The Zilog Z80 microprocessor is the central element of a comprehensive microprocessor product family. This family works together in most applications with minimum requirements for additional logic, facilitating the design of efficient and cost-effective microcomputer-based externs. Zilog has designed five components to provide extensive support for the Z80 microprocessor. These are: - The PIO (Parallel Input/Output) operates in both data-byte I/O transfer mode (with handshaking) and in bit mode (without handshaking). The PIO may be configured to interface with standard parallel peripheral devices such as printers, tape punches, and keyboards. - The CTC (Counter/Timer Circuit) features four programmable 8-bit counter/timers, - each of which has an 8-bit prescaler. Each of the four channels may be configured to operate in either counter or timer mode. - The DMA (Direct Memory Access) controller provides dual port data transfer operations and the ability to terminate data transfer as a result of a pattern match. - The SIO (Serial Input/Output) controller offers two channels. It is capable of operating in a variety of programmable modes for both synchronous and asynchronous communication, including Bi-Sync and SDLC. - The DART (Dual Asynchronous Receiver/ Transmitter) device provides low cost asynchronous serial communication. It has two channels and a full modem control interface. #### Z80 CPU Registers Figure 4 shows three groups of registers within the 280 CPU. The first group consists of duplicate sets of 8-bit registers: a principal set and an alternate set (designated by '[prime], e.g., A'). Both sets consist of the Accumulator Register, the Flag Register, and six general-purpose registers. Transfer of data between these duplicate sets of registers is accomplished by use of "Exchange" instructions. The result is faster response to interrupts and easy, efficient implementation of such versatile programming techniques as background- foreground date processing. The second set of registers consists of six registers with assigned functions. These are the I (Interrupt Register), the R (Refresh Register), the IX and IY (Index Registers), the SP (Stack Pointer), and the PC (Program Counter). The third group consists of two interrupt status flip-flops, plus an additional pair of flip-flops which assists in identifying the interrupt mode at any particular time. Table 1 provides further information on these registers. Figure 4. CPU Registers | 280 CPU | Res | jister | Size (Bits) | Remarks | |------------|------------------------------------|--------------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------| | Registers | A, A' | Accumulator | 8 | Stores an operand or the results of an operation. | | Continued) | F, F' | Flags | 8 | See Instruction Set. | | | B, B' | General Purpose | 8 | Can be used separately or as a 16-bit register with C. | | | c, c* | General Purpose | 8 | See B, above. | | | D, D' | General Purpose | 8 | Can be used separately or as a 16-bit register with E. | | | E, E' | General Purpose | 8 | See D, above. | | | н, н | General Purpose | 8 | Can be used separately or as a 16-bit register with L. | | | L, L' | General Purpose | 8 | See H, above. | | | | | | Note: The (B,C), (D,E), and (H,L) sets are combined as follows: B — High byte C — Low byte D — High byte E — Low byte H — High byte L — Low byte | | | I | Interrupt Register | 8 | Stores upper eight bits of memory address for vectored interrupt processing. | | | R | Refresh Register | 8 | Provides user-transparent dynamic memory refresh. Automatically incremented and placed on the address bus during each instruction fetch cycle. | | | IX | Index Register | 16 | Used for indexed addressing. | | | IY | Index Register | 16 | Same as IX, above. | | | SP | Stack Pointer | 16 | Holds address of the top of the stack. See Push or Pop in instruction set. | | | PC | Program Counter | 16 | Holds address of next instruction. | | | IFF <sub>1</sub> -IFF <sub>2</sub> | Interrupt Enable | Flip-Flops | Set or reset to indicate interrupt status (see Figure 4). | | | IMFa-IMFb | Interrupt Mode | Flip-Flops | Reflect Interrupt mode (see Figure 4). | #### Table 1. 280 CPU Registers #### Interrupts: General Operation The CPU accepts two interrupt input signals: NMI and INT. The NMI is a non-maskable interrupt and has the highest priority. INT is a lower priority interrupt and it requires that interrupts be enabled in software in order to operate. INT can be connected to multiple peripheral devices in a wired-OR configuration. The Z80 has a single response mode for interrupt service for the non-maskable interrupt. The maskable interrupt, $\overline{\text{INT}}$ , has three programmable response modes available. These are: Mode 0 — compatible with the 8080 microprocessor. - Mode 1 Peripheral Interrupt service, for use with non-8080/Z80 systems. - Mode 2 a vectored interrupt scheme, usually daisy-chained, for use with Z80 Family and compatible peripheral devices. The CPU services interrupts by sampling the $\overline{\text{NM}}$ and $\overline{\text{INT}}$ signals at the rising edge of the last clock of an instruction. Further interrupt service processing depends upon the type of interrupt that was detected. Details on interrupt responses are shown in the CPU Timing Section. Interrupts: General Operation (Continued) Non-Maskable Interrupt (NMI). The nonmaskable interrupt cannot be disabled by program control and therefore will be accepted at all times by the CPU. NMI is usually reserved for servicing only the highest priority type interrupts, such as that for orderly shutdown after power failure has been detected. After recognition of the NMI signal (providing BUSREQ is not active), the CPU jumps to restart location 0066H. Normally, software starting at this address contains the interrupt service routing. Maskable Interrupt (INT). Regardless of the interrupt mode set by the user, the 280 response to a maskable interrupt input follows a common timing cycle. After the interrupt has been detected by the CPU (provided that interrupts are enabled and BUSREQ is not active) a special interrupt processing cycle begins. This is a special fetch (MI) cycle in which IORQ becomes active rather than MREQ, as in normal MI cycle. In addition, this special MI cycle is automatically extended by two WAIT states, to allow for the time required to acknowledge the interrupt request. Mode 0 Interrupt Operation. This mode is compatible with the 8080 microprocessor interrupt service procedures. The interrupting device places an instruction on the data bus. This is normally a Restart Instruction, which will initiate a call to the selected one of eight restart locations in page zero of memory. Mode 1 Interrupt Operation. Mode 1 operation is very similar to that for the NMI. The principal difference is that the Mode 1 interrupt has a restart location of 0038H only. Mode 2 Interrupt Operation. This interrupt mode has been designed to utilize most effectively the capabilities of the Z80 microprocessor and its associated peripheral family. The interrupting peripheral device selects the starting address of the interrupt service routine. It does this by placing an 8-bit vector on the data bus during the interrupt acknowledge cycle. The CPU forms a pointer using this byte as the lower 8-bits and the contents of the I register as the upper 8-bits. This points to an entry in a table of addresses for interrupt service routines. The CPU then jumps to the routine at that address. This flexibility in selecting the interrupt service routine address allows the peripheral device to use several different types of service routines. These routines may be located at any available location in memory. Since the interrupting device supplies the low-order byte of the 2-byte vector, bit 0 (An) must be a zero. Interrupt Priority (Daisy Chaining and Nested Interrupts). The interrupt priority of each peripheral device is determined by its physical location within a daisy-chain configuration. Each device in the chain has an interrupt enable input line (IEO), which is fed to the next lower priority device. The first device in the daisy chain has its IEI input hardwired to a High level. The first device has highest priority, while each succeeding device has a corresponding lower priority. This arrangement permits the CPU to select the highest priority interrupt from several simultaneously interrupting peripherals. The interrupting device disables its IEO line to the next lower priority peripheral until it has been serviced. After servicing, its IEO line is raised, allowing lower priority peripherals to demand interrupt servicing. The Z80 CPU will nest (queue) any pending interrupts or interrupts received while a selected peripheral is being serviced. Interrupt Enable/Disable Operation. Two flip-flops, IFF<sub>1</sub> and IFF<sub>2</sub>, referred to in the register description are used to signal the 'CPU interrupt status. Operation of the two flip-flops is described in Table 2. For more details, refer to the Z80 CPU Technical Manual and Z80 Assembly Language Manual. | Action | IFF <sub>1</sub> | IFF <sub>2</sub> | Comments | |---------------------------------|------------------|------------------|---------------------------------------------------------------------------------------| | CPU Reset | 0 | 0 | Maskable interrupt<br>INT disabled | | DI instruction execution | 0 | 0 | Maskable interrupt<br>INT disabled | | El instruction execution | 1 | 1 | Maskable interrupt<br>INT enabled | | LD A,I instruction execution | • | • , | IFF <sub>2</sub> — Parity flag | | LD A,R instruction<br>execution | • | • | IFF <sub>2</sub> — Parity flag | | Accept NMI | 0 | IFF <sub>1</sub> | IFF <sub>1</sub> - IFF <sub>2</sub><br>(Maskable inter-<br>rupt INT disabled) | | RETN instruction execution | IFF <sub>2</sub> | • | IFF <sub>2</sub> — IFF <sub>1</sub> at<br>completion of an<br>NMI service<br>routine. | Table 2. State of Flip-Flops #### Instruction Set 8-Bit The Z80 microprocessor has one of the most powerful and versatile instruction sets available in any 8-bit microprocessor. It includes such unique operations as a block move for fast, efficient data transfers within memory or between memory and I/O. It also allows operations on any bit in any location in memory. The following is a summary of the Z80 instruction set and shows the assembly language mnemonic, the operation, the flag status, and gives comments on each instruction. The Z80 CPU Technical Manual (03-0029-01) and Assembly Language Programming Manual (03-0002-01) contain significantly more details for programming The instructions are divided into the following categories: - ☐ 8-bit loads - ☐ 16-bit loads - ☐ Exchanges, block transfers, and searches - ☐ 8-bit arithmetic and logic operations - ☐ General-purpose arithmetic and CPU control - ☐ 16-bit arithmetic operations - ☐ Rotates and shifts - ☐ Bit set, reset, and test operations - □ Jumps - ☐ Calls, returns, and restarts - ☐ Input and output operations A variety of addressing modes are implemented to permit efficient and fast data transfer between various registers, memory locations, and input/output devices. These addressing modes include: - ☐ Immediate - □ Immediate extended - ☐ Modified page zero - □ Relative - $\Box$ Extended - □ Indexed - □ Register - ☐ Register indirect - □ Implied - □ Bit | | -, | | | | - | | • • • | | _ | | -, | -, | | | |----------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|-------|---------------|---------------|--------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|----------------------------------| | LD r. r'<br>LD r. n | r - r'<br>r - n | | | | : | X | : | : | : | 01 r r'<br>00 r 110 | 1 2 | 1 2 | 4 7 | r, r' Reg.<br>000 B<br>001 C | | LD r, (HL)<br>LD r, (IX+d) | r (HL)<br>r (DX+d) | : | : | X | : | X | : | : | : | 01 r 110<br>11 011 101 DD | 1<br>3 | 2<br>5 | 7<br>19 | 001 C<br>010 D<br>011 E<br>100 H | | LD r, (IY+d) | r (IY + d) | • | • | x | • | x | | | | 11 111 101 FD<br>01 r 110 | 3 | 5 | 19 | 101 L<br>111 A | | LD (HL), r | (HL) - r | | | x | | x | | | | 01 110 r | 1 | 2 | 7 | | | LD (IX+d), r | (IX + d) - r | • | ٠ | X | • | x | • | • | • | 01 110 r | .3 | 5 | 19 | | | LD (IY+d), r | (IY+d) - r | • | • | x | • | x | ٠ | • | • | 11 111 101 FD<br>01 110 r | 3 | 5 | 19 | | | LD (HL), n | (HL) - n | • | • | X | • | x | ٠ | • | • | 00 110 110 36 | 2 | 3 | 10 | | | LD (IX+d), n | (IX+d) - n | • | • | X | • | X | • | • | • | 11 011 101 DD<br>00 110 110 36 | 4 | 5 | 19 | | | LD (IY+d), n | (IY+d) - n | • | • | x | • | x | • | • | • | 11 111 101 FD<br>00 110 110 36 | 4 | 5 | 19 | | | | | | | | | _ | | | | - n - | | | _ | | | | | • | • | Š | • | | • | • | • | | : | | 4 | | | LD A. (DE) | A - (nn) | : | : | â | : | â | : | : | : | 00 111 010 3A | 3 | 4 | 13 | | | | | | | _ | | _ | | | | - n - | | | _ | | | | | : | : | ź | : | ž | : | : | : | | 1 | 2 | 4 | | | LD (nn), A | (nn) - A | ्रः | : | â | : | Ŷ | : | : | | 00 110 010 32 | 3 | 4 | 13 | | | | LD r, 6H LD r, (IX+d) LD r, (IX+d) LD r, (IX+d) LD r, (IX+d), r LD (IX+d), r LD (IX+d), r LD (IX+d), n LD (IX+d), n LD A, (DB LD A, (DB LD A, (DB LD A, (DB) | LD r, n r - n LD r, (IX + d) r - (IX + d) LD r, (IX + d) r - (IX + d) LD r, (IY + d) r - (IY + d) LD (IX), r (IX + d) - r LD (IX), r (IX + d) - r LD (IX), n (IX + d) - n LD (IX + d), n (IX + d) - n LD (IX + d), n (IX + d) - n LD A, (IX - A) - (IX + d) - n LD A, (IX - A) - (IX + d) - n LD A, (IX - A) - (IX + d) - n LD A, (IX - A) - (IX + d) - n LD A, (IX - A) - (IX + d) - n LD A, (IX - A) - (IX + d) - n LD A, (IX - A) - (IX + d) - n LD A, (IX - A) - (IX + d) - n LD A, (IX - A) - (IX + d) - n LD A, (IX - A) - (IX + d) - n LD A, (IX - A) - (IX + d) - A LD (IX - A) - (IX + d) - A LD (IX - A) - (IX + d) - A LD (IX - A) - (IX + d) - A LD (IX - A) - (IX + d) - A LD (IX - A) - (IX + d) - A LD (IX - A) - (IX + d) - A LD (IX - A) - (IX + d) - A LD (IX - A) - (IX + d) - A LD (IX - A) - (IX + d) - A LD (IX - A) - (IX + d) - A LD (IX - A) - (IX + d) - A LD (IX - A) - (IX + d) - A LD (IX - A) - (IX + d) - A LD (IX - A) - (IX + d) - A LD (IX - A) - (IX + d) - A LD (IX - A) - (IX + d) - A LD (IX - A) - (IX + d) - A LD (IX - A) - (IX + d) - A LD (IX - A) - (IX + d) - A LD (IX - A) - (IX + d) - A LD (IX - A) - (IX + d) - A LD (IX - A) - (IX + d) - A LD (IX - A) - (IX + d) - A LD (IX - A) - (IX + d) - A LD (IX - A) - (IX + d) - A LD (IX - A) - (IX + d) - A LD (IX - A) - (IX + d) - A LD (IX - A) - (IX + d) - A LD (IX - A) - (IX + d) - A LD (IX - A) - (IX + d) - A LD (IX - A) - (IX + d) - A LD (IX - A) - (IX + d) - A LD (IX - A) - (IX + d) - A LD (IX - A) - (IX + d) - A LD (IX - A) - (IX + d) - A LD (IX - A) - (IX + d) - A LD (IX - A) - (IX + d) - A LD (IX - A) - (IX + d) - A LD (IX - A) - (IX + d) - A LD (IX - A) - (IX + d) - A LD (IX - A) - (IX + d) - A LD (IX - A) - (IX + d) - A LD (IX - A) - (IX + d) - A LD (IX - A) - (IX + d) - A LD (IX - A) - (IX + d) - A LD (IX - A) - (IX + d) - A LD (IX - A) - (IX + d) - A LD (IX - A) - (IX + d) - A LD (IX - A) - (IX + d) - A LD (IX - A) - (IX + d) - A LD (IX - A) - (IX + d) - A LD (IX - A) - (IX + d) - A LD (IX - A) - | LD r, n r - n LD r, (RY - d) r - (RY - d) LD r, (RY + d) r - (RY - d) LD r, (RY + d) r - (RY - d) LD (HL), r (HL) - r LD (HY + d), r (RY + d) - r LD (HL), n (HL) - n LD (HL), n (HL) - n LD (HY + d), n (RY + d) - n LD (RY + d), n (RY + d) - n LD A, (RC) A - (RC) (RC), A | LD r, R r - R | LD r, n r - n · x<br>LD r, (IX+d) r - (IKL) · x x<br>LD r, (IX+d) r - (IX+d) · x x<br>LD r, (IY+d) r - (IY+d) · x x<br>LD (IX+d), r (IX+d) - r · x x<br>LD (IX+d), r (IX+d) - r · x x<br>LD (IX+d), n (IX+d) - r · x x<br>LD (IX+d), n (IX+d) - n · x x<br>LD (IX+d), n (IX+d) - n · x x<br>LD (IX+d), n (IX+d) - n · x x<br>LD A, (IX A - (IX C) C) · x x<br>LD A, (IX A - (IX C) C) · x x<br>LD A, (IX A - (IX C) C) · x x<br>LD A, (IX A - (IX C) C) · x x<br>LD A, (IX A - (IX C) C) · x x<br>LD A, (IX A - (IX C) C) · x x<br>LD A, (IX A - (IX C) C) · x x<br>LD (IX A - (IX C) C) · x x<br>LD (IX A - (IX C) C) · x x x<br>LD (IX A - (IX C) C) · x x x<br>LD (IX A - (IX C) C) · x x x<br>LD (IX A - (IX C) C) · x x x<br>LD (IX A - (IX C) C) · x x x<br>LD (IX A - (IX C) C) · x x x x<br>LD (IX A - (IX C) C) · x x x x<br>LD (IX A - (IX C) C) · x x x x<br>LD (IX A - (IX C) C) · x x x x x<br>LD (IX A - (IX C) C) · x x x x x x x x x x x x x x x x x x | LD r, n r - n | Dr. n | LD r, n r - n | LD r, n r - n | LD r, Rt r - Rt | Dr. (Rt - d) | LD r, (lX + d) r - | DP (RH a) | LD r, c r - n | OTES: 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 conset to the PVI flip. LD A, I LD A, R LD I, A LD R, A > For an explanation of flag notation and symbols to mnemonic tables, see Symbolic Notation section following tables | 6-Bit Load<br>Group | Masmonic | Symbolic<br>Operation | | z | | 'n | - | P/4 | | c | Opcodo<br>78 543 216 Ross | He.el<br>Bytes | Ho.ef M<br>Cycles | Ho.el T<br>States | Comments | |---------------------------|---------------------------|----------------------------------------------------------------------------------------------------------------|------------------------|------|------|--------|-------|--------|-------|--------|---------------------------------|----------------|-------------------|-------------------|-------------------------------------| | roup | LD dd, nn | dd - nn | • | • | x | • | x | • | • | • | 00 dd0 001 | 3 | 3 | 10 | dd Pair<br>00 BC | | | 1D.W | W | | | x | | x | | | | - n -<br>- n - | | | 14 | 01 DE | | | LD IX, nn | IX — nn | • | • | × | • | × | • | • | • | 11 011 101 DD<br>00 100 001 21 | • | • | 14 | 10 HL<br>11 SP | | | LD IY, na | IY - nn | | | x | | x | | | | - n -<br>- n -<br>11 111 101 FD | | 4 | 14 | | | | | | | | - | - | - | | - | | 00 100 001 21 | • | • | | | | | LD HL, (nn) | H (nn+1) | | | x | | x | | | | 00 101 010 2A | 3 | 5 | 16 | | | | LD ML, (MI) | L - (nn) | | | • | | • | | | | - n - | • | • | | | | | LD dd, (nn) | ddy - (nn+1)<br>ddy - (nn) | • | ٠ | X | • | X | • | • | • | 11 101 101 ED<br>01 dd1 011 | 4 | 6 | 20 | | | | | | | | | | | | | | - n -<br>- n - | | | | | | | LD IX, (nn) | IXH (nn+1)<br>IXL (nn) | • | • | X | ٠ | X | ٠ | ٠ | ٠ | 11 011 101 DD<br>00 101 010 2A | 4 | 6 | 20 | | | | | | | | | | | | | | - n -<br>- n - | | | | | | | LD IY, (nn) | $\begin{array}{l} IY_{L} \leftarrow (nn+1) \\ IY_{L} \leftarrow (nn) \end{array}$ | • | • | X | • | X | • | • | • | 11 111 101 FD<br>00 101 010 2A | 4 | 6 | 20 | | | | | | | | | | _ | | | | - n -<br>- n - | | _ | | | | | LD (nn), HL | (nn + 1) — H<br>(nn) — L | • | • | x | • | x | • | • | • | 00 100 010 22<br>- n - | 3 | 5 | 16 | | | | LD (nn), dd | (nn + 1) - ddH<br>(nn) - ddL | • | • | x | • | x | • | • | • | 11 101 101 ED<br>01 dd0 011 | 4 | 6 | 20 | | | | | (nn) - ddL | | | | | | | | | - n | | | | | | | LD (nn), IX | (nn + 1) - IXH<br>(nn) - IXL | • | • | x | • | x | • | • | • | 11 011 101 DD<br>00 100 010 22 | 4 | 6 | 20 | | | | | /) - IVE | | | | | | | | | - n -<br>- n - | | | | × . | | | LD (nn), IY | (nn + 1) - IYH<br>(nn) - IYL | • | • | x | • | x | • | • | • | 11 111 101 FD<br>00 100 010 22 | 4 | 6 | 20 | | | | | | | | | | | | | | - n - | | | | | | | LD SP. HL<br>LD SP. IX | SP HL<br>SP IX | : | : | X | : | X | : | : | : | 11 111 001 P9<br>11 011 101 DD | 1 2 | 1 2 | 6<br>10 | | | | LD SP, IY | SP - IY | | | x | | x | | | | 11 111 001 F9<br>11 111 101 FD | 2 | 2 | 10 | | | | PUSH qq | (SP-2) - qqL | | • | x | | x | | | | 11 111 001 F9<br>11 qq0 101 | 1 | 3 | 11 | qq Pair<br>00 BC<br>01 DE | | | | (SP - 1) - qqH<br>SP - SP - 2 | | | _ | | _ | | | | | | | | 10 HL | | | PUSH IX | (SP-2) - IX <sub>L</sub><br>(SP-1) - IX <sub>H</sub> | • | • | x | • | X | • | • | • | 11 011 101 DD<br>11 100 101 ES | 2 | . 4 | 15 | 11 AF | | | PUSH IY | SP - SP - 2<br>(SP - 2) - IYL | • | • | x | • | x | • | • | • | 11 111 101 FD | 2 | 4 | 15 | | | | POP qq | (SP-1) - IYH<br>SP - SP - 2<br>qqH - (SP+1) | _ | _ | x | | x | _ | | | 11 100 101 E5<br>11 qq0 001 | 1 | 3 | 10 | | | | POP qq | qqL - (SP)<br>SP - SP +2 | • | • | ^ | • | ^ | • | • | ٠ | 11 ddn on1 | • | , | 10 | | | | POP IX | | • | • | x | • | x | • | • | • | 11 011 101 DD<br>11 100 001 E1 | 2 | 4 | 14 | | | | POP IY | IX <sub>L</sub> - (SP)<br>SP - SP +2<br>IX <sub>L</sub> - (SP+1) | | | x | | x | | | | 11 111 101 FD | 2 | 4 | 14 | | | | | IYH - (SP+1)<br>IYL - (SP)<br>SP - SP +2 | - | | - | | _ | | | | 11 100 001 E1 | • | • | •• | | | | NOTES: dd is a | | C, DE, HI | . SF | | | | | | | | | | | | | | qq si e<br>(PAIR)<br>e.g. | any of the register pairs Bo<br>any of the register pairs A<br>hg. (PAIR) refer to high o<br>BCL = C, AFH = A. | F, BC, Di<br>order and | low | orde | r engl | ht bu | s of t | he re | gister | peur respectively, | | | | | | xchange. | EX DE, HL | DE HL | | - | x | | x | • | - | | 11 101 011 EB | 1 | 1 | 4 | | | Block | EX AF, AF<br>EXX | AF - AF<br>BC - BC | : | : | X | : | ž | : | : | : | 00 001 000 08<br>11 011 001 D9 | i<br>i | 1 | 4 | Register bank and | | fransier.<br>Block Search | | HT - HT.<br>DE DE. | | | | | | | | | | | | | auxiliary register<br>bank exchange | | Froups | EX (SP), HL | H → (SP+1) | • | • | X | • | X | ٠ | ٠ | • | 11 100 011 E3 | 1 | 5 | 19 | - | | | EX (SP), IX | IXH - (SP+1)<br>IXL - (SP)<br>IYH - (SP+1) | • | • | X | • | X | • | • | • | 11 011 101 DD<br>11 100 011 E3 | 2 | 6 | 23 | | | | EX (SP), IY | IYH (SP+1)<br>IYL (SP) | • | • | X | ٠ | X | • | • | • | 11 111 101 FD<br>11 100 011 E3 | 2 | 6 | 23 | | | | LDI | (DE) - (HT) | | | x | 0 | x | 9 | 0 | | 11 101 101 ED | 2 | 4 | 16 | Load (HL) into | | | | DE - DE+1<br>HL - HL+1 | | | | | | | | | 10 100 000 A0 | | | | (DE), increment<br>the pointers and | | | | BC - BC-1 | | | | | | | | | | | | | decrement the byte<br>counter (BC) | | | LDIR | (DE) (HL)<br>DE DE+1 | • | • | x | 0 | X | 0 | 0 | • | 11 101 101 ED<br>10 110 000 B0 | 2 2 | 5 | 21<br>16 | HBC ≠ 0<br>HBC =0 | | | | | | | | | | | | | | | | | | | | | HL - HL+1<br>BC - BC-1<br>Repest until | | | | | | | | | | | | | | | xchange.<br>lock | Mnemonic | Symbolic<br>Operation | 8 | z | | Fla | 92 | P/V | H | с | Opcode<br>76 543 210 Hex | No.of<br>Bytes | No.of M<br>Cycles | No.of T<br>States | Comments | |-------------------------------|---------------|--------------------------------------------------------------------------|---|---|-------|--------|----|-----|---|---|--------------------------------------|----------------|-------------------|-------------------|-------------------------------------------------------| | ansier,<br>ock Search<br>oups | LDD | (DE) - (HL)<br>DE + DE - 1<br>HL - HL - 1<br>BC - BC - 1 | • | • | х | 0 | х | Θ- | 0 | • | 11 101 101 ED<br>10 101 000 A8 | 2 | 4 , | 16 | | | ontinued) | LDDR | (DE) - (HL)<br>DE - DE - 1<br>HL - HL - 1<br>BC - BC - 1<br>Repeat until | • | • | X | 0 | x | 0 | 0 | • | 11 101 101 ED<br>10 111 000 B8 | 2 2 | 5<br>4 | 21<br>16 | If BC ≠ 0<br>If BC = 0 | | | CPI | BC = 0<br>A - (HL)<br>HL - HL + 1<br>BC - BC - 1 | ı | | X | ı | x | | ı | • | 11 101 101 ED<br>10 100 001 A1 | 2 | 4 | 16 | | | | CPIR | A - (HL) | | 0 | | 1 | х | 0 | 1 | | 11 101 101 ED | 2 | 5 | 21 | If BC ≠ 0 and | | | | HL - HL + 1<br>BC - BC - 1<br>Repeat until<br>A = (HL) or<br>BC = 0 | | | | | | | | | 10 110 001 B1 | 2 | • | 16 | A * (HL) If BC = 0 or A = (HL) | | | CPD | A - (HL)<br>HL - HL - I<br>BC - BC - I | 1 | 2 | X | ı | x | 9- | 1 | • | 11 101 101 ED<br>10 101 001 A9 | 2 | 4 | 16 | | | | CPDR | A - (HL) | | 1 | | 1 | x | 0 | 1 | | 11 101 101 ED | 2 | 5 | 21 | If BC ≠ 0 and | | | | HL - HL - 1<br>BC - BC - 1<br>Repeat until<br>A = (HL) or<br>BC = 0 | | | | | | | | | 10 111 001 B9 | 2 | 4 | 16 | A ≠ (HL) If BC = 0 or A = (HL) | | | | ag is 0 if the result of E<br>is 1 if A = (HL), other | | | herwi | se P/V | - | 1. | | | | | | | | | Bit | ADD A, r | A - A + r | t | t | x | t | x | v | 0 | 1 | 10 <b>000</b> r | 1 | 1 | 4 | r Reg. | | rithmetic<br>nd Logical | ADD A, n | A A + n | ٠ | | X | ٠ | X | ٧ | 0 | 1 | 11 000 110<br>- n - | 2 | 2 | 7 | 000 B<br>001 C<br>010 D | | roup | ADD A. (HL) | A - A + (HL) | | 1 | x | | x | v | 0 | t | 10 000 110 | 1 | 2 | 7 | 011 E | | - | ADD A. (IX+d) | A - A + (IX+d) | | • | X | ľ | X | V | 0 | 1 | 11 011 101 DE<br>10 000 110 | 3 | 5 | 19 | 100 H<br>101 L | | | ADD A, (IY+d) | (b+Y1) + A - A | • | | X | | X | v | 0 | 1 | - d -<br>11 111 101 FE<br>10 000 110 | 3 | 5 | 19 | 111 A | | | ADC A, s | A - A+s+CY | | | × | | x | v | 0 | ı | - d - | | | | s is any of r, n, | | | SUB s | A - A-s | | 1 | X | 1 | X | ٧ | ł | t | 010 | | | | (HL), (IX + d),<br>(IY + d) as shown | | | SBC A, s | A - A -s-CY | 1 | 1 | х | 1 | X | V | 1 | t | OII | | | | for ADD instruction. | | | AND : | A - A ^ s | 1 | t | X | 1 | X | P | 0 | 0 | [100] | | | | The indicated bits replace the (000) in | | | OR s | A - A V s | 1 | ı | X | 0 | X | P | 0 | 0 | 110 | | | | the ADD set above. | | | XOR s | A - A • s | 1 | ı | X | 0 | X | P | 0 | 0 | 001 | | | | | | | CP s | A - s | 1 | 1 | X | 1 | X | V | ì | 1 | 0773 | | | | | | | INC r | r = r + 1 | 1 | | Х | 1 | X | ٧ | 0 | • | 00 r [100] | 1 | . 1 | 4 | | | | INC (HL) | (HL) -(HL) + 1 | 1 | ŧ | X | 1 | X | ٧ | 0 | ٠ | 00 110 100 | 1 | 3 | 11 | | | | | (IX + d) - | | ı | X | 1 | X | v | 0 | • | 00 110 100 DI | 3 | 6 | 23 | | | | INC (IX+d) | (IX+d)+i | • | | | | | | | | | | | | | | | INC (IX+d) | | , | ı | x | ı | x | v | 0 | • | 11 111 101 FE<br>00 110 [00] | 3 | 6 | 23 | | | | | (IX+d)+1<br>(IY+d) - | | 1 | | : | | | | | 11 111 101 FE | 3 | 6 | 23 | m is any of r. (HL), (IX+d), (IY+d) as shown for INC. | | Purpose | Mnomonic | Symbolic<br>Operation | 8 | z | | P) | oge. | P/V | H | С | Opcode<br>78 543 210 Hex | No.el<br>Bytes | No.of M<br>Cycles | | Comments | |---------------------------|----------------------------------|--------------------------------------------------------------------------------------------------------|----------------|-------------|--------|--------|------------------|--------|-----|----|----------------------------------------------------------------------------------------------------------------------|----------------|-------------------|---------|------------------------------------------------------| | Arithmetic<br>and | DAA | Converts acc. content<br>into packed BCD<br>following add or | 1 | 1 | х | , | X | P | • | 1 | 00 100 111 27 | 1 | 1 | 1 | Decimal adjust accumulator. | | CPU Control<br>Groups | CPL | subtract with packed BCD operands. A - A | | | x | 1 | x | • | 1 | | 00 101 111 2F | 1 | 1 | 4 | Complement accumulator (one's | | | NEG | A - 0 - A | 1 | 1 | x | , | x | v | 1 | 1 | 11 101 101 ED<br>01 000 100 44 | 2 | 2 | 8 | complement). Negate acc. (two's complement). | | | CCF | CY - CY | • | • | X | X<br>O | X | • | 0 | 1 | 00 111 111 3F | 1 | 1 | 4 | Complement carry<br>flag. | | | SCF<br>NOP<br>HALT | CY - 1<br>No operation<br>CPU halted | : | : | X<br>X | : | X<br>X<br>X<br>X | : | • | 1 | 00 110 111 37<br>00 000 000 00<br>01 110 110 76 | 1 | i | 1 | Set carry flag. | | | DI * | IFF - 0<br>IFF - 1 | : | : | x | : | ŝ | : | : | : | 11 110 011 F3<br>11 111 011 FB | î | i | 4 | | | | IM 0 | Set interrupt<br>mode 0 | • | • | x | • | x | • | • | • | 11 101 101 ED<br>01 000 110 46 | , 2 | 2 | 8 | | | | IM 1 | Set interrupt<br>mode 1 | ٠ | • | X | • | X | • | • | • | 11 101 101 ED<br>01 010 110 56 | 2 | 2 | 8 | | | | IM 2 | Set interrupt<br>mode 2 | • | • | X | • | X | ٠ | ٠ | • | 11 101 101 ED<br>01 011 110 5E | 2 | 2 | 8 | | | | NOTES: IFF in<br>CY in | dicates the interrupt enable fli<br>dicates the carry flip-flop,<br>licates interrupts are not sample | p-flo<br>led a | p.<br>t the | end | of E( | or DI | | | | | | | | | | 6-Bit | ADD HL, sa | HL - HL+ as | • | • | x | x | x | • | 0 | 1 | 00 ssl 001 | 1 | 3 | 11 | ss Reg.<br>00 BC<br>01 DE | | Arithmetic<br>Group | ADC HL, ss | HL - HL+se+CY | 1 | ı | X | X | X | v | 0 | 1 | 11 101 101 ED<br>01 sal 010 | 2 | 4 | 15 | 01 DE<br>10 HL<br>11 SP | | | SBC HL. ss | HL - HL-ss-CY | 1 | ı | X | X | x | v | 1 | t | 11 101 101 ED<br>01 se0 010 | 2 | 4 | 15 | 11 35 | | | ADD IX. pp | IX - IX + pp | • | • | X | X | X | • | 0 | 1 | 11 011 101 DD<br>01 pp1 001 | 2 | 4 | 15 | pp Reg.<br>00 BC<br>01 DE<br>10 IX | | | ADD IY, rr | IY + IY + rr | • | • | x | x | x | • | 0 | ٠ | 11 111 101 FD<br>00 rrl 001 | 2 | . 4 | 15 | 10 IX<br>11 SP<br>rr Reg.<br>00 BC<br>01 DE<br>10 IY | | | INC ss<br>INC IX | es - es + 1<br>IX - IX + 1 | : | : | X | : | X | : | : | : | 00 ss0 011 | 1 2 | 1 2 | 6 | 11 SP | | | INC IY | IY IY + 1 | | | x | | x | | | | 11 011 101 DD<br>00 100 011 23<br>11 111 101 FD | 2 | 2 | 10 | | | | DEC as<br>DEC IX | ss - ss - 1<br>IX - IX - 1 | : | : | X | : | X | : | : | : | 00 100 011 23<br>00 ssl 011<br>11 011 101 DD | 1 2 | i<br>2 | 6<br>10 | | | | DEC IY | IY - IY - 1 | • | • | X | • | x | • | • | • | 00 101 011 2B<br>11 111 101 FD<br>00 101 011 2B | 2 | 2 | 10 | | | | NOTES: ss is a pp is a rr is a | ny of the register pairs BC, DE<br>iny of the register pairs BC, DE<br>by of the register pairs BC, DE | E. D | SP<br>SP | : | | | | | | | | | | | | lotate and<br>Shift Group | RLCA | CY 7-0 | | • | x | 0 | x | | 0 | , | 00 000 111 0 | 7 1 | 1 | 4 | Rotate left circular accumulator. | | | RLA | CY 7 0 | • | • | X | 0 | x | • | 0 | ı | 00 010 111 1 | 7 1 | 1 | 4 | Rotate left<br>accumulator. | | | RRCA | 7 0 CY | • | • | x | 0 | x | • | 0 | 1 | 00 001 111 0 | 1 | 1 | 4 | Rotate right circular accumulator. | | | RRA | 7-0-CY | • | • | x | 0 | x | • | 0 | 1 | 00 011 111 11 | - 1 | 1 | 4 | Rotate right accumulator. | | | | • | | | | | | | 0 | 1 | 11 001 011 C | В 2 | 2 | 8 | Rotate left circular<br>register r. | | | RLC r | • | ı | 1 | X | 0 | X | P | | | | | | | r Reg. | | | RLC r<br>RLC (HL) | • | : | 1 | x | 0 | x | P | | • | 11 001 011 C: | 8 2 | 4 | 15 | 000 B | | | | CY | : | 1 | | | | | 0 | 1 | 11 001 011 C:<br>00 000 110 D:<br>11 011 101 D:<br>11 001 011 C: | | 6 | 23 | 000 B<br>001 C<br>010 D<br>011 E<br>100 H | | | RLC (HL) | ev 7 0 r.(HL),(IX + d),(IY + d) | | 1 | x | 0 | x | P | 0 | 1. | 11 001 011 C: 00 0000 110 11 011 101 D: 11 001 011 C: - d - 00 0000 110 | 4 | | | 000 B<br>001 C<br>010 D<br>011 E<br>100 H | | | RLC (IY+d) | r.(HL).(IX+d).(IY+d) | | 1 | x<br>x | 0 | x<br>x | P<br>P | 0 | 1. | 11 001 011 C: 00 000 110 11 011 101 D1 11 001 011 C: - d - 00 000 110 11 111 101 FI 11 001 011 C: - d - 00 000 110 | 4 | 6 | 23 | 000 B 001 C 010 D 011 E 100 H 101 L 111 A | | | RLC (IX+d) RLC (IY+d) RLC (IY+d) | (T) | | 1 | x<br>x | 0 | x | P<br>P | 0 0 | 1. | 11 001 011 C: 00 0000 110 11 011 101 D: 11 001 011 C: - d - 00 0000 110 11 111 101 F: 11 001 011 C: - d - | 4 | 6 | 23 | 000 B 001 C 010 D 011 E 100 H 101 L 111 A | | Rotate and<br>Shift Group | Mnemonic | Symbolic<br>Operation | 8 | z | | Fle<br>H | ege. | P/V | H | c | Opcode<br>78 543 210 | Hen | No.of<br>Bytes | No.of M<br>Cycles | No.of T<br>States | Comments | |---------------------------|-----------------|--------------------------------------------------------------|------|-------|-------|----------|------|-----|---|---|----------------------------------------------|----------|----------------|-------------------|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Continued) | RR m | 70-CY<br>m=r,(HL),(IX+d),(IY+d) | ı | t | x | 0 | x | P | 0 | ı | 011 | | | | | | | | SLA m | CY 7-0-0<br>m=r,(HL),(IX+d),(IY+d) | 1 | t | x | 0 | x | P | 0 | : | 100 | | | | | | | | SRA m | 7-0-CY<br>m=r,(HL),(IX+d),(IY+d) | ı | t | x | 0 | x | P | 0 | ı | 101 | | | | | | | | | 0 - 7 - 0 - CY<br>m = r,(HL).(IX + d).(IY + d) | | • | x | 0 | X | P | 0 | ٠ | 1111 | | | | | | | | RLD i | 7-43-0 7-43-0 | • | ٠ | x | 0 | x | P | 0 | • | 11 101 101<br>01 101 111 | ED<br>6F | 2 | 5 | 18 | Rotate digit left and<br>right between<br>the accumulator | | | RRD | 7-4 3-0 | 1 | ı | x | 0 | x | P | 0 | • | 11 101 101<br>01 100 111 | ED<br>67 | 2 | 5 | 18 | and location (HL). The content of the upper half of the accumulator is unaffected. | | Bit Set, Reset | BIT b, r | Z — Tp | x | , | x | 1 | x | x | 0 | • | 11 001 011 | СВ | 2 | 2 | 8 | r Reg. | | and Test | BIT b. (HL) | $Z = (\overline{HL})_b$ | x | 1 | x | 1 | x | x | 0 | ٠ | 01 b r<br>11 001 011 | СВ | 2 | 3 | 12 | 001 C | | Group | BIT b. (IX+d) | $b Z - (\overline{IX + d})_b$ | x | 1 | x | 1 | x | x | 0 | • | 01 Ь 110<br>11 011 101 | DD | 4 | 5 | 20 | 011 E | | | | - | | | | | | | | | 11 001 011<br>- d -<br>01 b 110 | CB | | | | 101 L<br>111 A | | | BIT b, (IY + d) | $b Z \leftarrow (\overline{IY + d})_b$ | x | t | x | ı | x | x | 0 | • | 11 111 101 | FD | 4 | 5 | 20 | b Bit Tested<br>000 0 | | | | | | | | | | | | | 11 001 011<br>- d -<br>01 b 110 | | | | | 001 1<br>010 2<br>011 3<br>100 4<br>101 5<br>110 6 | | | SET b, r | η <sub>b</sub> – 1 | | | x | | х | | | | 11 001 011 | СВ | 2 | 2 | 8 | 111 7 | | | SET b. (HL) | (HL) <sub>b</sub> = 1 | | • | x | • | x | | | • | [1] b r<br>11 001 011<br>[1] b 110 | СВ | 2 | 4 | 15 | | | | SET b, (IX+d) | (IX'+d)b - 1 | • | • | x | • | x | • | ٠ | • | 11 011 101<br>11 001 011 | DD<br>CB | 4 | 6 | 23 | | | | SET b, (IY+d) | $(IY+d)_b-1$ | • | • | x | • | x | • | | • | П ь 110<br>11 111 101<br>11 001 011<br>— d — | FD<br>CB | • | 6 | 23 | | | | RES b, m | $m_b - 0$<br>m = r, (HL),<br>(IX + d),<br>(IY + d) | • | • | x | • | x | • | • | • | <u>П</u> Б 110 | | | | | To form new opcode replace ii) of SET b, s with iii). Flags and time states for SET instruction. | | | NOTES: The n | otation mb indicates bit b (0 to | 7) 0 | r loc | ation | m. | | | | | | | | | | | | Jump<br>Group | IP nn | PC nn | • | • | х | • | x | ٠ | • | • | 11 000 011 | СЗ | 3 | 3 | 10 | | | <b>-</b> | JP ∞, na | If condition cc is<br>true PC — nn,<br>otherwise<br>continue | • | • | X | • | x | • | • | • | 11 cc 010 | • | 3 | 3 | | Condition ON NZ non-zero ON Z zero ON C non-carry ON C carry ON C carry C carry ON C carry ON C carry ON C carry ON | | | JR e | PC - PC+e | • | • | x | • | x | ٠ | • | • | 00 011 000 | 18 | 2 | 3 | 12 | 110 P sign positive<br>111 M sign negative | | | JR C, ● | If C = 0,<br>continue | • | • | x | • | x | • | • | • | 00 111 000<br>- e-2 - | 38 | 2 | 2 | | If condition not met. | | | | If C = 1,<br>PC = PC+• | | | | | | | | | | | 2 | . 3 | | If condition is met. | | | IR NC, • | If C = 1,<br>continue | • | • | X | • | X | • | • | • | 00 110 000<br>- e-2 - | 30 | 2 | 2 | 7 | If condition not met. | | | | If C = 0,<br>PC PC++ | | | | | | | | | | | 2 | 3 | | If condition is met. | | | JP Z, ● | If Z = 0<br>continue | • | • | X | ٠ | X | • | • | • | 00 101 000 | 28 | 2 | 2 | | If condition not met. | | | | If Z = 1. | | | | | | | | | | | 2 | 3 | 12 | If condition is met. | | | JR NZ, • | PC - PC+e If Z = 1, continue | ٠ | ٠ | X | ٠ | X | ٠ | ٠ | ٠ | 00 100 000 | 20 | 2 | 2 | 7 | If condition not met. | | | | HZ = 0,<br>PC - PC++ | | | | | | | | | - 4-2 - | | 2 | 3 | 12 | If condition is met. | | | JP (HL) | PC - HL | • | • | x | • | X | • | ٠ | • | 11 101 001 | E9 | 1 | 1 . | 4 | | | | JP (IX) | PC - IX | • | • | x | • | X | • | • | • | 11 011 101<br>11 101 001 | DD<br>E9 | 2 | 2 . | 8 | | | iump Group<br>(Continued) | Massacale | Symbolic<br>Operation | | 2 | | Fle<br>H | nge | P/V | Į. | c | Opcode<br>76 543 210 Hex | No.oi<br>Bytes | No.of M<br>Cycles | No.of T<br>States | Comments | |---------------------------|----------------|--------------------------------------------------------------------------------------------------------------------------------|--------|------|-----------------|----------|------|------|------|--------|--------------------------------|----------------|-------------------|-------------------|---------------------------------------------------------------------------------------------------------------------------| | Commuca | JP (IY) | PC - IY . | • | • | x | • | x | • | • | • | 11 111 101 FD<br>11 101 001 E9 | 2 | 2 | 8 | | | | DINZ, e | B - B - 1<br>If B = 0. | • | • | X | • | x | • | • | • | 00 010 000 10 | 2 | 2 | 8 | II B = 0. | | | | continue | | | | | | | | | | 2 | 3 | 13 | If B ≠ 0. | | | | If B ≠ 0,<br>PC PC+• | | | | | | | | | | - | • | 13 | II B ♥ 0. | | | NOTES: e repr | esents the extension in the re | iative | eddr | <b>084</b> 8D | g mod | be. | | | | | | | | | | | e - 2 st<br>by | seems the extension in the re<br>signed two's complement num<br>in the opcode provides an eff<br>2 prior to the addition of e. | ective | addn | manag<br>mas of | pc+ | • 44 | PC 1 | incr | remen/ | ed . | | | | | | Call and | CALL nn | (SP-1) PC <sub>H</sub><br>(SP-2) PC <sub>L</sub> | • | | х | • | х | | | | 11 001 101 CD | 3 | 5 | 17 | | | Return Group | | PC nn | | | | | | | | | - n - | | | | | | | CALL cc, nn | If condition<br>oc is false | • | • | X | • | X | • | • | • | 11 ec 100 | 3 | 3 | 10 | If oc is false. | | | | continue,<br>otherwise same as | | | | | | | | | - n - | 3 | 5 | 17 | If oc is true. | | | | CALL nn | | | | | | | | | | | | | | | | RET | $PC_L \leftarrow (SP)$<br>$PC_H \leftarrow (SP + 1)$ | • | ٠ | X | • | X | ٠ | ٠ | ٠ | 11 001 001 C9 | 1 | 3 | 10 | | | | RET ec | If condition | | | x | | x | | | | 11 cc 000 | 1 | 1 | 5 | If oc is false. | | | | cc is false<br>continue, | | | | | | | | | | 1 | 3 | 11 | If cc is true. | | | | otherwise<br>same as | | | | | | | | | | | | | cc Condition 000 NZ non-zero | | | | RET | | | | | | | | | | | | | 001 Z zero<br>010 NC non-carry | | | RETI | Return from<br>interrupt | • | • | X | ٠ | X | ٠ | • | • | 11 101 101 ED<br>01 001 101 4D | 2 | 4 | 14 | 011 C carry<br>100 PO parity odd | | | RETN1 | Return from<br>non-maskable | ٠ | • | X | ٠ | X | • | • | ٠ | 11 101 101 ED<br>01 000 101 45 | 2 | 4 | 14 | 100 PO parity odd<br>101 PE parity even | | | | interrupt | | | | | | | | | 0. 000 101 40 | | | | 101 PE parity even<br>110 P sign positive<br>111 M sign negative | | | RST p | (SP-1) - PCH | • | • | X | ٠ | X | • | • | • | 11 t 111 | 1 | 3 | 11 | t p<br>000 00H | | | | (SP - 2) = PC <sub>L</sub><br>PC <sub>H</sub> = 0<br>PC <sub>L</sub> = p | | | | | | | | | | | | | 001 08H | | | | PCL - p | | | | | | | | | | | | | 010 10H<br>011 18H | | | | | | | | | | | | | | | | | 100 20H<br>101 28H | | | | | | | | | | | | | | | | | 110 30H<br>111 38H | | | NOTE: 'RETN | loads IFF <sub>2</sub> IFF <sub>1</sub> | | | | _ | | | | | | | | | | | nput and | IN A, (n) | A - (n) | • | • | х | • | X | • | • | • | 11 011 011 DB | 2 | 3 | 11 | n to A <sub>O</sub> ~ A <sub>7</sub><br>Acc. to Ae ~ Als | | Output Group | IN r, (C) | r (C)<br>if r = 110 only the | 1 | ı | X | 1 | X | P | 0 | • | 11 101 101 ED<br>01 r 000 | 2 | 3 | 12 | Acc. to A8 ~ A15<br>C to Ac ~ A7<br>B to A8 ~ A15 | | | | flags will be affected | | 0 | | | | | | | 0 000 | | | | 210116 715 | | | INI | (HL) - (C) | X | Ÿ | X | X | x | X | 1 | x | 11 101 101 ED<br>10 100 010 A2 | 2 | 4 | 16 | C to A <sub>0</sub> - A <sub>7</sub><br>B to A <sub>8</sub> - A <sub>15</sub> | | | | B - B - 1<br>HL - HL + 1<br>(HL) - (C) | | | | | | | | | 11 101 101 FD | _ | | 21 | | | | INIR | (HL) - (C)<br>B - B - 1<br>HL - HL + 1 | х | 1 | × | х | х | х | 1 | х | 10 110 010 ED | 2 | 5<br>(HB≠0) | | C to Ac ~ A7<br>B to A8 ~ A15 | | | | HL - HL + 1<br>Repeat until | | | | | | | | | | 2 | 4<br>(If B = 0) | 16 | | | | | B = 0 | | φ | | | | | | | | | | | | | | IND | (HL) - (C)<br>B - B - 1 | X | ĭ | X | X | X | X | ţ | X | 11 101 101 ED<br>10 101 010 AA | 2 | 4 | 16 | C to A <sub>0</sub> ~ A <sub>7</sub><br>B to A <sub>8</sub> ~ A <sub>15</sub> | | | INDR | HL - HL - 1<br>(HL) - (C) | х | 1 | x | x | x | x | 1 | х | 11 101 101 ED | 2 | 5 | 21 | | | | | B - B - 1<br>HL - HL - 1 | | • | - | - | | | ٠ | | 10 111 010 BA | 2 | (Ii B≠0)<br>4 | 16 | C to A <sub>0</sub> ~ A <sub>7</sub><br>B to A <sub>8</sub> ~ A <sub>15</sub> | | | | Repeat until | | | | | | | | | | 2 | (If B = 0) | 10 | | | | OUT (n), A | B = 0<br>(n) - A | • | • | x | ٠ | x | • | ı | X | 11 010 011 D3 | 2 | 3 | 11 | n to A <sub>0</sub> - A <sub>7</sub> | | | OUT (C), r | (C) - r | | | x | • | x | • | ı | x | 11 101 101 ED | 2 | 3 | 12 | Acc. to A <sub>8</sub> ~ A <sub>15</sub><br>C to A <sub>0</sub> ~ A <sub>7</sub><br>B to A <sub>8</sub> ~ A <sub>15</sub> | | | | | | 0 | | | | | | | 01 r 001 | | | | | | | OUTI | (C) (HL)<br>B B-1 | Х | ĭ | X | X | X | X | ı | х | 11 101 101 ED<br>10 100 011 A3 | 2 | 4 | 16 | C to A <sub>0</sub> ~ A <sub>7</sub><br>B to A <sub>8</sub> ~ A <sub>15</sub> | | | OTIR | B - B-1<br>HL - HL + 1<br>(C) - (HL) | х | 1 | х | х | x | x | , | х | 11 101 101 ED | 2 | 5 | 21 | | | | | B - B - 1<br>HL - HL + 1 | | ٠ | | | | - | • | - | 10 110 011 B3 | 2 | (If B≠0) | 16 | C to A <sub>0</sub> ~ A <sub>7</sub><br>B to A <sub>8</sub> ~ A <sub>15</sub> | | | | Repeat until | | | | - | | · | | | | - | (If B = 0) | | | | | | | | | | | | | | | | | | | | | | | | | 0 | | | | | | | | | | | | | | OUTD | (C) = (HL)<br>B = B - 1<br>HL = HL - 1 | x | φ | x | x | x | X | ı | x | 11 101 101 ED<br>10 101 011 AB | 2 | 4 | 16 | C to A <sub>0</sub> ~ A <sub>7</sub><br>B to A <sub>8</sub> ~ A <sub>15</sub> | | Input and<br>Output Group | Mnemonic | Symboli<br>Operatio | | : | 3 Z | : | F)<br>H | ags | p/V | N | c | Opcode<br>78 543 210 Hex | No.of<br>Bytes | No.af M<br>Cycles | | | |---------------------------|------------------------------------------------------|-------------------------------------------------------------|----------------|---------------|-------------|-------------|-------------|-------------|------------------|-------|-----|--------------------------------------------------------------------------------------|----------------|--------------------------------|--------------------|-------------------------------------------------------------------------------| | (Continued) | OTDR | (C) = (HL)<br>B = B-1<br>HL = HL-1<br>Repeat until<br>B = 0 | | | K I | ı x | х | X | х | 1 | х | - 11 101 101 ED<br>10 111 011 | 2 | 5<br>(If B≠0)<br>4<br>(If B=0) | 16 | C to A <sub>0</sub> - A <sub>7</sub><br>B to A <sub>8</sub> - A <sub>15</sub> | | Summary of<br>Flag | Instruction | | D <sub>7</sub> | z | | н | | P/V | N | Do | | Comments | | | | | | Operation | ADD A. s: AI<br>SUB s: SBC A<br>AND s<br>OR s. XOR s | OC A, s<br>A, s: CP s: NEG | ! | - | X<br>X<br>X | 1 | X<br>X<br>X | V<br>V<br>P | 0 | 0 } | | B-bit add or add with<br>B-bit subtract, subtra<br>Logical operations. | | carry, con | spare an | nd negate accumulator. | | | INC s<br>DEC s<br>ADD DD, ss<br>ADC HL, ss | | : | 1 | X<br>X<br>X | t<br>X<br>X | X<br>X<br>X | V . | 0 | | | B-bit increment.<br>B-bit decrement.<br>16-bit add.<br>16-bit add with carry | | | | | | | SBC HL. se<br>RLA. RLCA,<br>RL m; RLC m<br>RRC m; SL | ;RRm;<br>Am; | | : | X<br>X | 0 | X<br>X | V<br>P | 0 | | | 16-bit subtract with c<br>Rotate accumulator.<br>Rotate and shift locat | arry. | | | | | | SRA m: SR<br>RLD; RRD<br>DAA<br>CPL<br>SCF | L m | ! | : | X<br>X<br>X | 0<br>1<br>1 | X<br>X<br>X | P<br>P | 0<br>•<br>1<br>0 | : | į | Rotate digit left and on<br>Decimal adjust accumu<br>Complement accumu<br>Set carry. | ulator. | | | | | | CCF<br>IN r (C)<br>INI, IND, OU<br>INIR: INDR: C | | ı<br>X | : | X<br>X<br>X | X<br>O<br>X | X<br>X<br>X | P<br>X | 0 0 | :} | 1 | Complement carry.<br>Input register indirec<br>Block input and outp | | 0 if B ≠ ! | 0 otherw | rise Z = 0. | | | LDI: LDD<br>LDIR: LDDR<br>CPI: CPIR: C | PD: CPDR | X<br>X<br>X | X | X<br>X | 0<br>X | X<br>X | 0 | 0 | :} | | | ons. Z | = 1 if A = | | , otherwise $P/V = 0$ .<br>otherwise $Z = 0$ . $P/V = 1$ | | | LD A. I. LD A<br>BIT b. s | R | x | ; | X | 0 | X | IFF<br>X | 0 | : | | | errupt - | enable flip | | F) is copied into the P/V flag.<br>e Z flag. | | Symbolic | Symbol | | | | | tion | | | | | | Symbol | | | | Operation | | Notation | | Sign flag. S = | | | | | | | | | | | | lag is af<br>ition. | fected | according to the result of the | | | | Zero flag. Z =<br>Parity or overfl | | | | | | | | | | • | | | chanc | red by the operation. | | | | V) share the sa | | | | | | | | | | | | | | the operation. | | | | his flag with th | | | | | | | | | | ī | | | | ne operation. | | | | rithmetic oper | | | | | | | | | | Х | | lag is a | | | | | | verflow of the | | | | | | | | | = | V | P/V f | lag affec | cted ac | cording to the overflow resu | | | | l if the result o<br>result is odd. If | P/V | ho | lds : | ove | flov | , P | ٧ - | - 11 | if | P | P/V f | operation | ted ac | ecording to the parity result o | | | | he result of the<br>Half-carry flag. | | | | | | | | | OW. | r | | | | Jregisters A, B, C, D, E, H, L | | | c<br>l | peration products 4 of the acc | ıcec | l a c<br>lato | arr<br>r. | y in | 0 0 | · bo | rrov | v fro | | s | Any 8 | 3-bit loc<br>ed for th | ation f<br>ne part | or all the addressing modes<br>ticular instruction. | | | | Add/Subtract fl<br>ion was a subtr | | | : 1 | if th | e pr | evic | us | oper | a- | ss | | | | for all the addressing modes<br>truction. | | | | ion was a subti<br>Hand Nilags a | | | in. | coni | unc | tion | wit | h the | | 11 | | | | index registers IX or IY. | | | | decimal adjust | | | | | | | | | | | | sh coun | | maon regioner in all all | | | ī | ect the result i<br>addition or sub | nto ; | paci<br>tion | ced | BC | ) fo | rma | t fol | lowi | | | 8-bit | value in | range | e < 0, 255 > .<br>ge < 0, 65535 > . | | | | oacked BCD to<br>Carry/Link flag | | | if t | he o | per | atio | n pi | rodu | cee | i | | | | | #### Pin Descriptions A<sub>0</sub>-A<sub>15</sub>. Address Bus (output, active High, 3-state). A<sub>0</sub>-A<sub>15</sub> form a 16-bit address bus. The Address Bus provides the address for memory data bus exchanges (up to 64K bytes) and for I/O device exchanges. BUSACK. Bus Acknowledge (output, active Low). Bus Acknowledge indicates to the requesting device that the CPU address bus, date bus, and control signals MREQ, IORQ, RD, and WR have entered their high-impedance states. The external circuitry can now control these lines. BUSREQ. Bus Request (input, active Low). Bus Request has a higher priority than NMI and is always recognized at the end of the current machine cycle. BUSREQ forces the CPU address bus, data bus, and control signals MREQ, IORQ, RD, and WR to go to a high-impedance state so that other devices can control these lines. BUSREQ is normally wire-ORed and requires an external pullup for these applications. Extended BUSREQ periods due to extensive DMA operations can aprevent the CPU from properly refreshing dynamic RAMs. **D<sub>0</sub>-D<sub>7</sub>.** Data Bus (input/output, active High, 3-state). $D_0$ -D<sub>7</sub> constitute an 8-bit bidirectional data bus, used for data exchanges with memory and I/O. HALT. Halt State (output, active Low). HALT indicates that the CPU has executed a Halt instruction and is awaiting either a non-maskable or a maskable interrupt (with the mask enabled) before operation can resume. While halted, the CPU executes NOPs to maintain memory refresh. INT. Interrupt Request (input, active Low). Interrupt Request is generated by I/O devices. The CPU honors a request at the end of the current instruction if the internal software-controlled interrupt enable flip-flop (IFF) is enabled. INT is normally wire-ORed and requires an external pullup for these applications. IORQ. Input/Output Request (output, active Low, 3-state). IORQ indicates that the lower half of the address bus holds a valid I/O address for an I/O read or write operation. IORQ is also generated concurrently with MI during an interrupt acknowledge cycle to indicate that an interrupt response vector can be placed on the data bus. MI. Machine Cycle One (output, active Low). MI, together with MREQ, indicates that the current machine cycle is the opcode fetch cycle of an instruction execution. MI, together with IORQ, indicates an interrupt acknowledge cycle. MREQ. Memory Reguest (output, active Low, 3-state). MREQ indicates that the address bus holds a valid address for a memory read or memory write operation. NMI. Non-Maskable Interrupt (input, negative edge-triggered). NMI has a higher priority than INT. NMI is always recognized at the end of the current instruction, independent of the status of the interrupt enable flip-flop, and automatically forces the CPU to restart at location 0066H. $\overline{\text{RD}}$ . Read (output, active Low, 3-state). $\overline{\text{RD}}$ indicates that the CPU wants to read data from memory or an I/O device. The addressed I/O device or memory should use this signal to gate data onto the CPU data bus. RESET. Reset (input, active Low). RESET initializes the CPU as follows: it resets the interrupt enable flip-flop, clears the PC and Registers I and R, and sets the interrupt status to Mode 0. During reset time, the address and data bus go to a high-impedance state, and all control output signals go to the inactive state. Note that RESET must be active for a minimum of three full clock cycles before the reset operation is combelet. RFSH. Refresh (output, active Low). RFSH, together with MREQ, indicates that the lower seven bits of the system's address bus can be used as a refresh address to the system's dynamic memories. WAIT. Wait (input, active Low). WAIT indicates to the CPU that the addressed memory or I/O devices are not ready for a data transfer. The CPU continues to enter a Wait state as long as this signal is active. Extended WAIT periods can prevent the CPU from refreshing dynamic memory properly. **WR.** Write (output, active Low, 3-state). WR indicates that the CPU data bus holds valid data to be stored at the addressed memory or I/O location. #### **CPU Timing** The Z80 CPU executes instructions by proceeding through a specific sequence of operations: - Memory read or write - I/O device read or write - Interrupt acknowledge Instruction Opcode Fetch. The CPU places the contents of the Program Counter (PC) on the address bus at the start of the cycle (Figure 5). Approximately one-half clock cycle later, MREQ goes active. When active, RD indicates that the memory data can be enabled onto the CPU data bus. The basic clock period is referred to as a T time or cycle, and three or more T cycles make up a machine cycle (M1, M2 or M3 for instance). Machine cycles can be extended either by the CPU automatically inserting one or more Wait states or by the insertion of one or more Wait states by the user. The CPU samples the $\overline{WAIT}$ input with the falling edge of clock state $T_2$ . During clock states $T_3$ and $T_4$ of an $\overline{M}1$ cycle dynamic RAM refresh can occur while the CPU starts decoding and executing the instruction. When the Refresh Control signal becomes active, refreshing of dynamic memory can take place. NOTE: Tw-Wait cycle added when necessary for slow ancilliary devices. Figure 5. Instruction Opcode Fetch Memory Read or Write Cycles. Figure 6 shows the timing of memory read or write cycles other than an opcode fetch (MI) cycle. The MREQ and RD signals function exactly as in the fetch cycle. In a memory write cycle, MREQ also becomes active when the address bus is stable. The WR line is active when the data bus is stable, so that it can be used directly as an R/W pulse to most semi-conductor memories. Figure 8. Memory Read or Write Cycles **Input or Output Cycles.** Figure 7 shows the timing for an I/O read or I/O write operation. During I/O operations, the CPU automatically inserts a single Wait state $(T_w)$ . This extra Wait state allows sufficient time for an I/O port to decode the address from the port address lines. NOTE: Tw+ = One Wait cycle automatically inserted by CPU. Figure 7. Input or Output Cycles Interrupt Request/Acknowledge Cycle. The CPU samples the interrupt signal with the rising edge of the last clock cycle at the end of any instruction (Figure 8). When an interrupt is accepted, a special $\overline{\rm M}$ l cycle is generated. During this $\overline{\text{M1}}$ cycle, $\overline{\text{IORQ}}$ becomes active (instead of $\overline{\text{MREQ}}$ ) to indicate that the interrupting device can place an 8-bit vector on the data bus. The CPU automatically adds two Wait states to this cycle. NOTE: 1) TL = Last state of previous instruction. 2) Two Wait cycles automatically inserted by CPU(\*). Figure 8. Interrupt Request/Acknowledge Cycle #### Non-Maskable Interrupt Request Cycle. NMI is sampled at the same time as the maskable interrupt input INT but has higher priority and cannot be disabled under software control. The subsequent timing is similar to that of a normal instruction fetch except that data put on the bus by the memory is ignored. The CPU instead executes a restart (RST) operation and jumps to the $\overline{NM}$ service routine located at address 0066H (Figure 9). <sup>\*</sup>Although NMI is an asynchronous input, to guarantee its being recognized on the following machine cycle, NMI's falling edge must occur no later than the rising edge of the clock cycle preceding $T_{LAST}$ . Figure 9. Non-Maskable Interrupt Request Operation Bus Request/Acknowledge Cycle. The CPU samples BUSREQ with the rising edge of the last clock period of any machine cycle (Figure 10). If BUSREQ is active, the CPU sets its address, data, and MREQ, IORQ, RD, and WR lines to a high-impedance state with the rising edge of the next clock pulse. At that time, any external device can take control of these lines, usually to transfer data between memory and I/O devices. NOTE: TL = Last state of any M cycle. Tx = An arbitrary clock cycle used by requesting device. Figure 10. Z-BUS Request/Acknowledge Cycle Halt Acknowledge Cycle. When the CPU receives a Halt instruction, it executes NOP states until either an INT or NMI input is received. When in the Halt state, the $\overline{\text{HALT}}$ output is active and remains so until an interrupt is received (Figure 11). NOTE: INT will also force a Halt exit. \*See note, Figure 9. Figure 11. Halt Acknowledge Cycle Reset Cycle. RESET must be active for at least three clock cycles for the CPU to properly accept it. As long as RESET remains active, the address and data buses float, and the control outputs are inactive. Once RESET goes inactive, three internal T cycles are consumed before the CPU resumes normal processing operation. RESET clears the PC register, so the first opcode fetch will be to location 0000 (Figure 12). Figure 12. Reset Cycle | C<br>harac- | | | _ | Z80<br>Min | CPU<br>Max | Z80A<br>Min | Max | Z80B<br>Min | CPU†<br>Max | |-------------|--------|--------------|--------------------------------------------------------------------------------------------------------------|------------|------------|-------------|---------|-------------|------------------| | ristics | Number | Symbol | Parameter | | | | | | | | | 1 | TcC | Clock Cycle Time | 400° | | 250* | | 165* | | | | 2 | TwCh | Clock Pulse Width (High) | 180° | | 110* | | 65* | | | | 3 | TwCl | Clock Pulse Width (Low) | 180 | 2000 | 110 | 2000 | 65 | 2000 | | | 4 | TfC | Clock Fall Time | | 30 | _ | 30 | _ | 20 | | | 5 | -TrC | Clock Rise Time | | 30 | | 30 | | 20 | | | 6 | TdCr(A) | Clock 1 to Address Valid Delay | _ | 145 | _ | 110 | _ | 90 | | | 7 | TdA(MREQf) | Address Valid to MREQ I Delay | 125* | - | <b>6</b> 5* | - | 35* | _ | | | 8 | TdCf(MREQf) | Clock I to MREQ I Delay | _ | 100 | _ | 85 | _ | 70 | | | 9 | TdCr(MREQr) | Clock 1 to MREQ 1 Delay | _ | 100 | _ | 85 | - | 70 | | | 10 | -TwMREQh | - MREQ Pulse Width (High)- | 170° | | 110* | | 65*· | | | | 11 | TwMREQ1 | MREQ Pulse Width (Low) | 360* | _ | 220* | _ | 135* | _ | | | 12 | TdCf(MREQr) | Clock I to MREQ 1 Delay | _ | 100 | _ | 85 | | 70 | | | 13 | TdCf(RDf) | Clock ↓ to RD ↓ Delay | | 130 | _ | 95 | _ | 80 | | | 14 | TdCr(RDr) | Clock 1 to RD 1 Delay | _ | 100 | - | 85 | _ | 70 | | | 15 | -TsD(Cr) | - Data Setup Time to Clock 1- | 50 | | 35 | | 30 - | | | | 16 | ThD(RDr) | Data Hold Time to RD † | _ | 0 | _ | 0 | _ | 0 | | | 17 | TsWAIT(Cf) | WAIT Setup Time to Clock | 70 | _ ' | 70 | _ | 60 | | | | 18 | ThWAIT(Cf) | WAIT Hold Time after Clock | | 0 | _ | 0 | | . 0 | | | 19 | TdCr(Mlf) | Clock ↑ to MI ↓ Delay | | 130 | _ | 100 | _ | 80 | | | 20 | -TdCr(Mlr) | -Clock 1 to MI 1 Delay | | 130 | | _ 100 _ | | 80- | | | 21 | TdCr(RFSHf) | Clock 1 to RFSH Delay | | 180 | | 130 | | 110 | | | 22 | TdCr(RFSHr) | Clock 1 to RFSH 1 Delay | | 150 | _ | 120 | _ | 100 | | | 23 | TdCf(RDr) | Clock I to RD 1 Delay | _ | 110 | _ | 85 | _ | 70 | | | 24 | TdCr(RDf) | Clock 1 to RD Delay | _ | 100 | _ | 85 | _ | 70 | | | 25— | -TsD(Cf) | -Data Setup to Clock I during —<br>M <sub>2</sub> , M <sub>3</sub> , M <sub>4</sub> or M <sub>5</sub> Cycles | 60 | | 50 | | 40 | | | | 26 | TdA(IORQf) | Address Stable prior to IORQ | 320* | | 180* | _ | 110* | | | | 27 | TdCr(IORQf) | Clock 1 to IORQ Delay | _ | 90 | _ | 75 | _ | 65 | | | 28 | TdCf(IORQr) | Clock I to IORQ † Delay | _ | 110 | _ | 85 | - | 70 | | | 29 | TdD(WRf) | Data Stable prior to WR | 190* | _ | 80* | _ | 25* | _ | | | 30 | -TdCf(WRf) | Clock I to WR I Delay | | 90 | | - 80- | | <del> 7</del> 0- | | | 31 | TwWR | WR Pulse Width | 360* | _ | 220* | _ | 135* | | | | 32 | TdCf(WRr) | Clock ↓ to WR ! Delay | _ | 100 | | 80 | _ | 70 | | | 33 | TdD(WRf) | Data Stable prior to WR | 20* | _ | -10* | | -55° | _ | | | 34 | TdCr(WRf) | Clock † to WR Delay | _ | 80 | _ | 65 | _ | 60 | | | 35 | -TdWRr(D) | - Data Stable from WR 1 | —120° | | 60*- | | 30*- | | | | 36 | TdCf(HALT) | Clock I to HALT 1 or I | _ | 300 | | 300 | _ | 260 | | | 37 | TwNMI | NMI Pulse Width | 80 | | 80 | _ | 70 | | | | 38 | TsBUSREQ(Cr) | BUSREQ Setup Time to Clock 1 | 80 | _ | 50 | _ | 50 | | For clock periods other than the minimums shown in the table, calculate parameters using the expressions in the table on the following page. Units in nanoseconds (ns). All timings are preliminary and subject to change. | : | | | | | CPU | | CPU | | CPU† | |--------------|--------|----------------|-----------------------------------------------------------------------|-------|-----|---------------|-----------------|----------------|------| | rac-<br>tics | Number | Symbol | Parameter | Min | Max | Min | Max | Min | Max | | ntinued) | 39 | ThBUSREQ(Cr) | BUSREQ Hold Time after Clock 1 | 0 | _ | 0 | _ | 0 | | | | 40 | -TdCr(BUSACKf) | -Clock 1 to BUSACK Delay | | 120 | | 100 <del></del> | | 90- | | | 41 | TdCf(BUSACKr) | Clock I to BUSACK Delay | | 110 | - | 100 | | 90 | | | 42 | TdCr(Dz) | Clock 1 to Data Float Delay | _ | 90 | _ | 90 | _ | 80 | | | 43 | TdCr(CTz) | Clock † to Control Outputs Float<br>Delay (MREQ, IORQ, RD,<br>and WR) | _ | 110 | - | 80 | _ | 70 | | | 44 | TdCr(Az) | Clock 1 to Address Float Delay | _ | 110 | - | 90 | _ | 80 | | | 45 — | - TdCTr(A) | - MREQ t, IORQ t, RD t, and | 160* | | 80 <b>*</b> - | | 35 <b>*</b> | | | | 46 | TsRESET(Cr) | RESET to Clock Setup Time | 90 | _ | 60 | | 60 | | | | 47 | ThRESET(Cr) | RESET to Clock ! Hold Time | _ | 0 | _ | 0 | _ | 0 | | | 48 | TsINTf(Cr) | INT to Clock † Setup Time | 80 | _ | 80 | _ | 70 | _ | | | 49 | ThINTr(Cr) | INT to Clock † Hold Time | | 0 | _ | 0 | | 0 | | | 50 | -TdM1f(IORQf)- | -MI ↓ to IORQ ↓ Delay | -920° | | 565° | <del></del> | 365 <b>*</b> - | | | | 51 | TdCf(IORQf) | Clock I to IORQ I Delay | _ | 110 | | 85 | | 70 | | | 52 | TdCf(IORQr) | Clock 1 to IORQ 1 Delay | _ | 100 | | 85 | | 70 | Clock I to Data Valid Delay ### Footnotes to AC Characteristics TdCf(D) 53 | Number | Symbol | Z80 | Z80A | Z80B | |--------|----------------|--------------------------------------------------------------------------------|--------------------------------------------------------------------------------|--------------------------------------------------------------------------------| | 1 | TeC | TwCh + TwCl + TrC + TfC | TwCh + TwCl + TrC +TfC | TwCh + TwCl + TrC + TfC | | 2 | TwCh | Although static by design,<br>TwCh of greater than 200 µs<br>is not guaranteed | Although static by design,<br>TwCh of greater than 200 μs<br>is not guaranteed | Although static by design,<br>TwCh of greater than 200 μs<br>is not guaranteed | | 7 — | - TdA(MREQf) - | -TwCh + TfC - 75 | -TwCh + TfC - 65 | -TwCh + TfC - 50 | | 10 | TwMREQh | TwCh + TfC - 30 | TwCh + TfC - 20 | TwCh + TfC - 20 | | 11 | TwMREQ1 | TcC - 40 | TcC - 30 | TcC - 30 | | 26 | TdA(IORQf) | TcC - 80 | TcC - 70 | TcC - 55 | | 29 | TdD(WRf) | TcC - 210 | TcC - 170 | TcC - 140 | | 31 | TwWR | TcC - 40 | -TcC - 30 | -TcC - 30 | | 33 | TdD(WRf) | TwC1 + TrC - 180 | TwCl + TrC - 140 | TwC1 + TrC - 140 | | 35 | TdWRr(D) | TwC1 + TrC - 80 | TwCl + TrC - 70 | TwC1 + TrC - 55 | | 45 | TdCTr(A) | TwCl + TrC - 40 | TwCl + TrC - 50 | TwC1 + TrC - 50 | | 50 | TdM1f(IORQf) | 2TcC + TwCh + TfC - 80 | 2TcC + TwCh + TfC - 65 | 2TcC + TwCh + TfC - 50 | | | | | | | 230 150 130 <sup>\*</sup> For clock periods other than the minimums shown in the table, calculate parameters using the following expressions. Calculated values above assumed TC = TIC = 20 ns. \*\*Units\* in nanoeconds (ns). All timings are preliminary and subject to change. All timings assume equal loading on pins with 50 pf. AC Test Conditions: VIH = 2.0 V VIL = 0.8 V VIHC = VCC -0.6 V VILC = 0.45 V V<sub>OH</sub> = 2.0 V V<sub>OL</sub> = 0.8 V FLOAT = ±0.5 V | Absolute<br>Maximum<br>Ratings | Storage Temperature65°C to +150°C Temperature under Bias Specified operating range Voltages on all inputs and outputs with respect to ground0.3 V to +7 V Power Dissipation | Stresses greater than those listed under Absolute Maximum Ratings may cause permanent damage to the device. This is a stress rating only; operation of the device at any condition above those indicated in the operational sections of these specifications is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability. | |--------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Standard | The characteristics below apply for the | All ac parameters assume a load capacitance | ## Conditions following standard test conditions, unless otherwise noted. All voltages are referenced to GND (0 V). Positive current flows into the referenced pin. Available operating temperature ranges are: ■ S\* = 0°C to +70°C, $+4.75 \text{ V} \leq \text{V}_{CC} \leq +5.25 \text{ V}$ $E^* = -40^{\circ}C \text{ to } +85^{\circ}C,$ $+4.75 \text{ V} \leq \text{V}_{CC} \leq +5.25 \text{ V}$ $M^* = -55^{\circ}C \text{ to } + 125^{\circ}C,$ $+4.5 \text{ V} \leq \text{ V}_{\text{CC}} \leq +5.5 \text{ V}$ \*See Ordering Information section for package temperature range and product number. of 100 pF. Add 10 ns delay for each 50 pF increase in load up to a maximum of 200 pF for the data bus and 100 pF for address and control | DC | Symbol | Parameter | Min | Max | Unit | Test Condition | |----------------------|------------------|-----------------------------------------------|-------------------|---------------------------------------------|----------------|---------------------------------| | Character-<br>istics | V <sub>ILC</sub> | Clock Input Low Voltage | -0.3 | 0.45 | V | | | | $v_{\text{IHC}}$ | Clock Input High Voltage | V <sub>CC</sub> 6 | V <sub>CC</sub> + .3 | v | | | | $v_{iL}$ | Input Low Voltage | -0.3 | 0.8 | v | | | | $v_{IH}$ | Input High Voltage | 2.0 | V <sub>CC</sub> | v | | | | $v_{ol}$ | Output Low Voltage | | 0.4 | . A | $I_{OL} = 1.8 \text{ mA}$ | | | $v_{OH}$ | Output High Voltage | 2.4 | | v | $I_{OH} = -250 \mu A$ | | | I <sub>CC</sub> | Power Supply Current<br>280<br>280 A<br>280 B | | 150 <sup>1</sup><br>200 <sup>2</sup><br>200 | mA<br>mA<br>mA | | | | ILI | Input Leakage Current | | 10 | μĀ | $V_{IN} = 0 \text{ to } V_{CC}$ | | | ILEAK | 3-State Output Leakage Current in Float | -10 | 10 <sup>3</sup> | μA | $V_{OUT} = 0.4$ to $V_{O}$ | For military grade parts, I<sub>CC</sub> is 200 mA. Typical rate for Z80A is 90 mA. 3. A<sub>15</sub>-A<sub>0</sub>, D<sub>7</sub>-D<sub>0</sub>, MREQ, TORQ, RD, and WR. | Capacitance | Symbol | Parameter | Min | Max | Unit | Note | |-------------|--------------------|--------------------|-----|-----|------|---------------------------------------| | | C <sub>CLOCK</sub> | Clock Capacitance | | 35 | рF | | | | CIN | Input Capacitance | | 5 | рF | Unmeasured pins<br>returned to ground | | | COUT | Output Capacitance | | 10 | pF | returned to ground | TA = 25°C, f = 1 MHz. ### Z8420 Z80° PIO Parallel Input/Output Controller ### Product Specification status conditions. #### June 1982 #### Features - Provides a direct interface between Z-80 microcomputer systems and peripheral devices. - Both ports have interrupt-driven handshake for fast response. - Four programmable operating modes: byte input, byte output, byte input/output (Port A only), and bit input/output. - Programmable interrupts on peripheral - Standard Z-80 Family bus-request and prioritized interrupt-request daisy chains implemented without external logic. - The eight Port B outputs can drive Darlington transistors (1.5 mA at 1.5 V). #### General Description The Z-80 PIO Parallel I/O Circuit is a programmable, dual-port device that provides a TTL-compatible interface between peripheral devices and the Z-80 CPU. The CPU configures the Z-80 PIO to interface with a wide range of peripheral devices with no other external logic. Typical peripheral devices that are compatible with the Z-80 PIO include most keyboards, paper tape readers and punches, printers, PROM programmers, etc. One characteristic of the Z-80 peripheral controllers that separates them from other interface controllers is that all data transfer between the peripheral device and the CPU is accomplished under interrupt control. Thus, the interrupt logic of the PIO permits full use of the efficient interrupt capabilities of the Z-80 CPU during I/O transfers. All logic necessary to implement a fully nested interrupt structure is included in the PIO. Another feature of the FiO is the ability to interrupt the CPU upon occurrence of specified status conditions in the peripheral device. For example, the PIO can be programmed to interrupt if any specified peripheral alarm conditions should occur. This interrupt capability reduces the time the processor must spend in polling peripheral status. Figure 1. Pin Functions Figure 2. Pin Assignments ## General Description (Continued) The Z-80 PIO interfaces to peripherals via two independent general-purpose I/O ports, designated Port A and Port B. Each port has eight data bits and two handshake signals, Ready and Strobe, which control data transfer. The Ready output indicates to the peripheral that the port is ready for a data transfer. Strobe is an input from the peripheral that indicates when a data transfer has occurred. Operating Modes. The Z-80 PIO ports can be programmed to operate in four modes: byte output (Mode 0), byte input (Mode 1), byte input/output (Mode 2) and bit input/output (Mode 3). In Mode O, either Port A or Port B can be programmed to output data. Both ports have output registers that are individually addressed by the CPU; data can be written to either port at any time. When data is written to a port, an active Ready output indicates to the external device that data is available at the associated port and is ready for transfer to the external device. After the data transfer, the external device responds with an active Strobe input, which generates an interrupt, if enabled. In Mode I, either Port A or Port B can be configured in the input mode. Each port has an input register addressed by the CPU. When the CPU reads data from a port, the PIO sets the Ready signal, which is detected by the external device. The external device then places data on the I/O lines and strobes the I/O port, which latches the data into the Port Input Register, resets Ready, and triggers the Interrupt Request, if enabled. The CPU can read the input data at any time, which again sets Ready. Mode 2 is bidirectional and uses Port A, plus the interrupts and handshake signals from both ports. Port B must be set to Mode 3 and masked off. In operation, Port A is used for both data input and output. Output operation is similar to Mode 0 except that data is allowed out onto the Port A bus only when ASTB is Low. For input, operation is similar to Mode 1, except that the data input uses the Port B handshake signals and the Port B interrupt (if enabled). Both ports can be used in Mode 3. In this mode, the individual bits are defined as either input or output bits. This provides up to eight separate, individually defined bits for each port. During operation, Ready and Strobe are not used. Instead, an interrupt is generated if the condition of one input changes, or if all inputs change. The requirements for generating an interrupt are defined during the programming operation; the active level is specified as either High or Low, and the logic condition is specified as either one input active (OR) or all inputs active (AND). For example, if the port is programmed for active Low inputs and the logic function is AND, then all inputs at the specified port must go Low to generate an interrupt. Data outputs are controlled by the CPU and can be written or changed at any time. - Individual bits can be masked off. - The handshake signals are not used in Mode 3; Ready is held Low, and Strobe is disabled. - When using the Z-80 PIO interrupts, the Z-80 CPU interrupt mode must be set to Mode 2. Figure 3. PIO in a Typical Z80 Family Environment #### Internal Structure The internal structure of the Z-80 PIO consists of a Z-80 CPU bus interface, internal control logic, Port A I/O logic, Port B I/O logic, and interrupt control logic (Figure 4). The CPU bus interface logic allows the Z-80 PIO to interface directly to the Z-80 CPU with no other external logic. The internal control logic synchronizes the CPU data bus to the peripheral device interfaces (Port A and Port B). The two I/O ports (A and B) are virtually identical and are used to interface directly to peripheral devices. Port Logic. Each port contains separate input and output registers, handshake control logic, and the control registers shown in Figure 5. All data transfers between the peripheral unit and the CPU use the data input and output registers. The handshake logic associated with each port controls the data transfers through the input and the output registers. The mode control register (two bits) selects one of the four programmable operating modes. The control mode (Mode 3) uses the remaining registers. The input/output control register specifies which of the eight data bits in the port are to be outputs and enables these bits; the remaining bits are inputs. The mask register and the mask control register control Mode 3 interrupt conditions. The mask register specifies which of the bits in the port are active and which are masked or inactive. The mask control register specifies two conditions: first, whether the active state of the input bits is High or Low, and second, whether an interrupt is generated when any one unmasked input bit is active (OR condition) or if the interrupt is generated when all unmasked input bits are active (AND condition). Interrupt Control Logic. The interrupt control logic section handles all CPU interrupt protocal for nested-priority interrupt structures. Any device's physical location in a daisy-chain configuration determines its priority. Two lines (IEI and IEO) are provided in each PIO to form this daisy chain. The device closest to the CPU has the highest priority. Within a PIO. Port A interrupts have higher priority than those of Port B. In the byte input, byte output, or bidirectional modes, an interrupt can be generated whenever the peripheral requests a new byte transfer. In the bit control mode, an interrupt can be generated when the peripheral status matches a programmed value. The PIO provides for complete control of nested interrupts. That is, lower priority devices may not interrupt higher priority devices that have not had their interrupt service routines completed by the CPU. Higher priority devices may interrupt the servicing of lower priority devices Figure 4. Block Diagram Internal Structure (Continued) If the CPU (in interrupt Mode 2) accepts an interrupt, the interrupting device must provide an 8-bit interrupt vector for the CPU. This vector forms a pointer to a location in memory where the address of the interrupt service routine is located. The 8-bit vector from the interrupting device forms the least significant eight bits of the indirect pointer while the I Register in the CPU provides the most significant eight bits of the pointer. Each port (A and B) has an independent interrupt vector. The least significant bit of the vector is automatically set to 0 within the PIO because the pointer must point to two adjacent memory locations for a complete 16-bit address. Unlike the other Z-80 peripherals, the PIO does not enable interrupts immediately after programming. It waits until MI goes Low (e.g., during an opcode fetch). This condition is unimportant in the Z-80 environment but might not be if another type of CPU is used. The PIO decodes the RETI (Return From Interrupt) instruction directly from the CPU data bus so that each PIO in the system knows at all times whether it is being serviced by the CPU interrupt service routine. No other communication with the CPU is required. CPU Bus I/O Logic. The CPU bus interface logic interfaces the Z-80 PIO directly to the Z-80 CPU, so no external logic is necessary. For large systems, however, address decoders and/or buffers may be necessary. Internal Control Logic. This logic receives the control words for each port during programming and, in turn, controls the operating functions of the Z-80 PIO. The control logic synchronizes the port operations, controls the port mode, port addressing, selects the read/write function, and issues appropriate commands to the ports and the interrupt logic. The Z-80 PIO does not receive a write input from the CPU; instead, the RD, CE, C/D and IORQ signals generate the write input internally. Figure 5. Typical Port I/O Block Diagram Programming Mode 0. 1. or 2. (Byte Input, Output, or Bidirectional). Programming a port for Mode 0, 1, or 2 requires two words per port. These words are: > A Mode Control Word. Selects the port operating mode (Figure 6). This word may be written any time. An Interrupt Vector. The Z-80 PIO is designed for use with the Z-80 CPU in interrupt Mode 2 (Figure 7). When interrupts are enabled, the PIO must provide an interrupt vector Mode 3. (Bit Input/Output). Programming a port for Mode 3 operation requires a control word, a vector (if interrupts are enabled), and three additional words, described as follows: I/O Register Control. When Mode 3 is selected, the mode control word must be followed by another control word that sets the I/O control register, which in turn defines which port lines are inputs and which are outputs (Figure 8). used. Interrupts are generated as a logic function of the input signal levels. The interrupt control word sets the logic conditions and the logic levels required for generating an interrupt. Two logic conditions or functions are available: AND (if all input bits change to the active level, an interrupt is triggered), and OR (if any one of the input bits changes to the active level, an interrupt is triggered). Bit D6 sets the logic function, as shown in Figure 9. The active level of the input bits can be set either High or Low. The active level is controlled by Bit D5. Mark Control Word. This word sate the mask control Interrupt Control Word. In Mode 3, handshake is not register, allowing any unused bits to be masked off. If any bits are to be masked, then D<sub>4</sub> must be set. When D<sub>4</sub> is set, the next word written to the port must be a mask control word (Figure 10). Interrupt Disable. There is one other control word which can be used to enable or disable a port interrupt. It can be used without changing the rest of the interrupt control word (Figure 11). Figure 6. Mode Control Word Figure 9. Interrupt Control Word Figure 7. Interrupt Vector Word Figure 10. Mask Control Word Figure 8. I/O Register Control Word Figure 11. Interrupt Disable Word #### Pin Description A<sub>0</sub>-A<sub>7</sub>. Port A Bus (bidirectional, 3-state). This 8-bit bus transfers data, status, or control information between Port A of the PIO and a peripheral device. A<sub>0</sub> is the least significant bit of the Port A data bus. **ARDY.** Register A Ready (output, active High). The meaning of this signal depends on the mode of operation selected for Port A as follows: Output Mode. This signal goes active to indicate that the Port A output register has been loaded and the peripheral data bus is stable and ready for transfer to the peripheral daying. Input Mode. This signal is active when the Port A input register is empty and ready to accept data from the peripheral device. Bidirectional Mode. This signal is active when data is available in the Port A output register for transfer to the peripheral device. In this mode, data is not placed on the Port A data bus, unless $\overline{ASTB}$ is active. Control Mode. This signal is disabled and forced to a Low state. ASTB. Port A Strobe Pulse From Peripheral Device (input, active Low). The meaning of this signal depends on the mode of operation selected for Port A as follows: Output Mode. The positive edge of this strobe is issued by the peripheral to acknowledge the receipt of data made available by the PIO. Input Mode. The strobe is issued by the peripheral to load data from the peripheral into the Port A input register. Data is loaded into the PIO when this signal is active. Bidirectional Mode. When this signal is active, data from the Port A output register is gated onto the Port A bidirectional data bus. The positive edge of the strobe acknowledges the receipt of the data. Control Mode. The strobe is inhibited internally. Bg-By. Port B Bus (bidirectional, 3-state). This 8-bit bus transfers data, status, or control information between Port B and a peripheral device. The Port B data bus can supply 1.5 mA at 1.5 V to drive Darlington transistors. Bg is the least significant bit of the bus. **B/A.** Port B Or A Select (input, High = B). This pin defines which port is accessed during a data transfer between the CPU and the PIO. A Low on this pin selects Port A; a High selects Port B. Often address bit A<sub>0</sub> from the CPU is used for this selection function. BRDY. Register B Ready (output, active High). This signal is similar to ARDY, except that in the Port A bidirectional mode this signal is High when the Port A input register is empty and ready to accept data from the peripheral device. BSTB. Port B Strobe Pulse From Peripheral Device (Input, active Low). This signal is similar to ASTB, except that in the Port A bidirectional mode this signal strobes data from the peripheral device into the Port A input register. C/D. Control Or Data Select (input, High = C). This pin defines the type of data transfer to be performed between the CPU and the PIO. A High on this pin during a CPU write to the PIO causes the Z-80 data bus to be interpreted as a command for the port selected by the B/A Select line. A Low on this pin means that the Z-80 data bus is being used to transfer data between the CPU and the PIO. Often address bit A<sub>1</sub> from the CPU is used for this function. CE. Chip Enable (input, active Low). A Low on this pin enables the PIO to accept command or data inputs from the CPU during a write cycle or to transmit data to the CPU during a read cycle. This signal is generally decoded from four I/O port numbers for Ports A and B, data, and control. **CLK.** System Clock (input). The Z-80 PIO uses the standard single-phase Z-80 system clock. **D<sub>0</sub>-D<sub>7</sub>.** Z-80 CPU Data Bus (bidirectional, 3-state). This bus is used to transfer all data and commands between the Z-80 CPU and the Z-80 PIO. D<sub>0</sub> is the least significant bit. IEI. Interrupt Enable In (input, active High). This signal is used to form a priority-interrupt daisy chain when more than one interrupt-driven device is being used. A High level on this pin indicates that no other devices of higher priority are being serviced by a CPU interrupt service routine. IEO. Interrupt Enable Out (output, active High). The IEO signal is the other signal required to form a daisy chain priority scheme. It is High only if IEI is High and the CPU is not servicing an interrupt from this PIO. Thus this signal blocks lower priority devices from interrupting while a higher priority device is being serviced by its CPU interrupt service routine. **INT.** Interrupt Request (output, open drain, active Low). When INT is active the Z-80 PIO is requesting an interrupt from the Z-80 CPU. IORQ. Input/Output Request (input from Z-80 CPU, active Low). IORQ is used in conjunction with B/A, C/D, CE, and RD to transfer commands and data between the Z-80 CPU and the Z-80 PIO. When CE, RD, and IORQ are active, the port addressed by B/A transfers data to the CPU (a read operation). Conversely, when CE and IORQ are active but RD is not, the port addressed by B/A is written into from the CPU with either data or control information, as specified by C/D. Also, if IORO and MI are active simultaneously, the CPU is acknowledging an interrupt; the interrupting port automatically places its interrupt vector on the CPU data bus if it is the highest priority device requesting an interrupt. 75 #### Pin Description (Continued) MI. Mochine Cycle (input from CPU, active Low). This signal is used as a sync pulse to control several internal PIO operations. When both the MI and RD signals are active, the Z-80 CPU is fetching an instruction from memory. Conversely, when both MI and IORQ are active, the CPU is acknowledging an interrupt. In addition, MI has two other functions within the Z-80 PIO: it synchronizes the PIO interrupt <u>logic</u>; when $\overline{M1}$ occurs without an active $\overline{RD}$ or $\overline{IORQ}$ signal, the PIO is reset. $\overline{RD}$ . Read Cycle Status (input from Z-80 CPU, active Low). If $\overline{RD}$ is active, or an I/O operation is in progress, $\overline{RD}$ is used with B/ $\overline{A}$ , C/ $\overline{D}$ , $\overline{CE}$ , and $\overline{IORQ}$ to transfer data from the Z-80 PIO to the Z-80 CPU. #### Timing The following timing diagrams show typical timing in a Z-80 CPU environment. For more precise specifications refer to the composite ac timing diagram. Write Cycle. Figure 12 illustrates the timing for programming the Z-80 PIO or for writing data to one of its ports. No Wait states are allowed for writing to the PIO other than the automatically inserted TwA. The PIO does not receive a specific write signal; it internally generates its own from the lack of an active RD signal. Figure 12. Write Cycle Timing **Read Cycle.** Figure 13 illustrates the timing for reading the data input from an external device to one of the Z-80 PIO ports. No Wait states are allowed for reading the PIO other than the automatically inserted TyM. Output Mode (Mode 0). An output cycle (Figure 14) is always started by the execution of an output instruction by the CPU. The WR\* pulse from the CPU latches the data from the CPU data bus into the selected port's output register. The WR\* pulse sets the Ready flag after a Low-going edge of CLK, indicating data is available. Ready stays active until the positive edge of the .trobe line is received, indicating that data was taken by the peripheral. The positive edge of the strobe pulse generates an INT if the interrupt enable flipflop has been set and if this device has the highest priority. Figure 13. Read Cycle Timing Figure 14. Mode 0 Output Timing Input Mode (Mode 1). When STROBE goes Low, data is loaded into the selected port input register (Figure 15). The next rising edge of strobe activates INT, if Interrupt Enable is set and this is the highest-priority requesting device. The following falling edge of CLK resets Ready to an inactive state, indicating that the input register is full and cannot accept any more data until the CPU completes a read. When a read is complete, the positive edge of $\overline{\text{RD}}$ sets Ready at the next Low-going transition of CLK. At this time new data can be loaded into the PIO. Figure 15. Mode 1 Input Timing Bidirectional Mode (Mode 2). This is a combination of Modes 0 and 1 using all four handshake lines and the eight Port A I/O lines (Figure 16). Port B must be set to the bit mode and its inputs must be masked. The Port A handshake lines are used for output control and the Port B lines are used for input control If interrupts occur, Port A's vector will be used during port output and Port B's will be used during port input. Data is allowed out onto the Port A bus only when $\overline{ASTB}$ is Low. The rising edge of this strobe can be used to latch the data into the peripheral. Figure 16. Mode 2 Bidirectional Timing Bit Mode (Mode 3). The bit mode does not utilize the handshake signals, and a normal port write or port read can be executed at any time. When writing, the data is latched into the output registers with the same timing as the output mode (Figure 17). When reading the PIO, the data returned to the CPU is composed of output register data from those port data lines assigned as outputs and input register data from those port data lines assigned as inputs. The input register contains data that was present immediately prior to the falling edge of RD. An interrupt is generated if interrupts from the port are enabled and the data on the port data lines satisfy the logical equation defined by the 8-bit mask and 2-bit mask control registers. However, if Port A is programmed in bidirectional mode. Port B does not issue an interrupt in bit mode and must therefore be polled. Figure 17. Mode 3 Bit Mode Timing Interrupt Acknowledge Timing. During MI time, peripheral controllers are inhibited from changing their interrupt enable status, permiting the Interrupt Enable signal to ripple through the daisy chain. The peripheral with IEI High and IEO Low during INTACK places a preprogrammed 8-bit interrupt vector on the data bus at this time (Figure 18). IEO is held Low until a Return From Interrupt (RETI) instruction is executed by the CPU while IEI is High. The 2-byte RETI instruction is decoded internally by the PIO for this purpose. Figure 18. Interrupt Acknowledge Timing Return From Interrupt Cycle. If a Z-80 peripheral has no interrupt pending and is not under service, then its IEO = IEI. If it has an interrupt under service (i.e., it has already interrupted and received an interrupt acknowledge) then its IEO is always Low, inhibiting lower priority devices from interrupting. If it has an interrupt pending which has not yet been acknowledged, IEO is Low unless an "ED" is decoded as the first byte of a 2-byte opcode (Figure 19). In this case, IEO goes High until the next opcode byte is decoded, whereupon it goes Low again. If the second byte of the opcode was a "AD," then the opcode was an RETI instruction. After an "ED" opcode is decoded, only the peripheral device which has interrupted and is currently under service has its IEI High and its IEO Low. This device is the highest-priority device in the daisy chain that has received an interrupt acknowledge. All other peripherals have IEI = IEO. If the next opcode byte decoded is "4D." this peripheral device resets its "interrupt under service" condition. Figure 19. Return From Interrupt | _ | | * | Min | PIO<br>Max | Min | Nax | Min | PIO(9)<br>Max | | |------|--------------|----------------------------------------------------------------------------|---------|------------------|---------|------|------------------|---------------|------------| | | r Symbol | Parameter | (ns) | (ns) | (ns) | (ns) | (ns) | (ns) | Comment | | 1 | TcC | Clock Cycle Time | 400 | [1] | 250 | [1] | 165 | [1] | | | 2 | TwCh | Clock Width (High) | 170 | 2000 | 105 | 2000 | 65 | 2000 | | | 3 | TwC1 | Clock Width (Low) | 170 | 2000 | 105 | 2000 | <b>6</b> 5 | 2000 | | | 4 | TÍC | Clock Fall Time | | 30 | | 30 | | 20 | | | 5 — | -TrC | Clock Rise Time | | 30 | | 30 - | | 20 | | | 6 | TsCS(RI) | CE, B/Ā, C/D to RD,<br>IORQ ↓ Setup Time | 50 | | 50 | | 50 | | [6] | | 7 | Th | Any Hold Times for Specified<br>Setup Time | 0 | | 0 | | 0 | 0 | | | 8 | TsRI(C) | RD, TORQ to Clock 1 Setup<br>Time | 115 | | 115 | | 70 | | | | 9 — | -TdRI(DO) | — RD, TORQ I to Data Out Delay — | | <del> 4</del> 30 | | 380 | | 300 | [2] | | 10 | TdRI(DOs) | RD, IORQ † to Data Out Float<br>Delay | | 160 | | 110 | | 70 | | | 11 | TsDI(C) | Data In to Clock 1 Setup Time | 50 | | 50 | | 40 | | CL = 50 pF | | 12 | TdIO(DOI) | IORQ I to Data Out Delay<br>(INTACK Cycle) | 340 | | 160 | | 120 | | [3] | | 13 | -TsM1(Cr) | — Mi ↓ to Clock † Setup Time —— | -210 - | | 90 | | <del></del> 70 - | | | | 14 | TsM1(Cf) | Ml to Clock Setup Time<br>(Ml Cycle) | 0 | | 0 | | 0 | | [8] | | 15 | TdM1(IEO) | M1 ↓ to IEO ↓ Delay (Interrupt<br>Immediately Preceding M1 ↓) | | 300 | | 190 | | 100 | [5, 7] | | 16 | TsIEI(IO) | IEI to IORQ Setup Time<br>(INTACK Cycle) | 140 | | 140 | | 100 | | [7] | | 17 — | -TdIEI(IEOf) | - IEI I to IEO I Delay | | 190 - | | 130 | | — 120 — | CL = 50 pF | | 18 | TdIEI(IEOr) | IEI 1 to IEO 1 Delay (after ED Decode) | | 210 | | 160 | | 160 | [5] | | 19 | TcIO(C) | IORQ 1 to Clock 1 Setup Time<br>(To Activate READY on Next<br>Clock Cycle) | 220 | | 200 | | 170 | | | | 20 — | -TdC(RDYr) | - Clock to READY Delay | - 200 - | | —190 — | | —170 ~ | | [5] | | 20 | -1dC(ND11) | - Clock : to READ! Delay | - 200 - | | — 190 — | | 170 | | CL = 50 pF | | 21 | TdC(RDYf) | Clock I to READY † Delay | 150 | | 140 | | 120 | | [5] | | 22 | TwSTB | STROBE Pulse Width | 150 | | 150 | | 120 | | [4] | | 23 | TsSTB(C) | STROBE I to Clock I Setup Time (To Activate READY on | 220 | | 220 | | 150 | | [5] | | 24 — | TdIO(PD) | Next Clock Cycle) — IORQ 1 to PORT DATA Stable — | 220 | 200 | | 180 | | 160 | [5] | | 25 | TsPD(STB) | Delay (Mode 0) PORT DATA to STROBE 1 Setup Time (Mode 1) | 260 | 200 | 230 | 100 | 190 | 100 | (J) | | 26 | TdSTB(PD) | STROBE I to PORT DATA Stable (Mode 2) | 200 | 230 | 250 | 210 | 130 | 180 | [5] | | 27 — | -TdSTB(PDr) | STROBE 1 to PORT DATA Float<br>Delay (Mode 2) | | 200 | | 180 | | 160 | CL = 50 pF | | 28 | TdPD(INT) | PORT DATA Match to INT I Delay (Mode 3) | | 540 | | 490 | | 430 | 02 = 05 pt | | 29 | TdSTB(INT) | STROBE 1 to INT Delay | | 490 | | 440 | | 350 | | <sup>[6]</sup> TsCS(RI) may be reduced. However, the time subtracted from TsCS(RI) will be added to TdRI(DO). 72.2.5 TeC > No-27dER(REO) + TdMI(REO) + TalE(RO) + TTI. Buffer Delay, if any. 80 MI must be active for a minimum of two clock cycles to reset the PIO. 7200 PIO numbers are preliminary and subject to change. | Absolute | |----------| | Maximum | | Ratings | Voltages on all inputs and outputs with respect to GND.....-0.3 V to +7.0 V Operating Ambient Temperature ...... As Specified in Ordering Information Storage Temperature .....-65 °C to +150 °C Stresses greater than those listed under Absolute Maximum Ratings may cause permanent damage to the device. This is a stress rating only: operation of the device at any condition above those indicated in the operational sections of these specifications is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability. #### Test Conditions The characteristics below apply for the following test conditions, unless otherwise noted. All voltages are referenced to GND (0 V). Positive current flows into the referenced pin. Available operating temperature ranges are: All ac parameters assume a load capacitance of 100 pF max. Timing references between two output signals assume a load difference of 50 pF max. ■ S\* = 0°C to +70°C, +4.75 V $\leq$ V<sub>CC</sub> $\leq$ +5.25 V ■ $E^* = -40^{\circ}\text{C to} + 85^{\circ}\text{C},$ + 4.75 V ≤ $V_{CC}$ ≤ +5.25 V ■ $M^* = -55^{\circ}C$ to $+125^{\circ}C$ , +4.5 $V \le V_{CC} \le +5.5$ V \*See Ordering Information section for package temperature range and product number. | DC | Symbol | Parameter | Min | Max | Unit | Test Condition | |----------------------|------------------|-----------------------------------------------|----------------------|-------|------|---------------------------| | Charac-<br>teristics | V <sub>ILC</sub> | Clock Input Low Voltage | -0.3 | +0.45 | V | | | | VIHC | Clock Input High Voltage | V <sub>CC</sub> -0.6 | +5.5 | v | | | | $v_{iL}$ | Input Low Voltage | -0.3 | +0.8 | v | | | | $v_{ih}$ | Input High Voltage | + 2.0 | +5.5 | v | | | | v <sub>ol</sub> | Output Low Voltage | | +0.4 | V | $I_{OL} = 2.0 \text{ mA}$ | | | $v_{oh}$ | Output High Voltage | +2.4 | | v | $I_{OH} = -250 \mu A$ | | | ILI | Input Leakage Current | -10.0 | +10.0 | μA | $0 < V_{IN} < V_{CC}$ | | | $I_Z$ | 3-State Output/Data Bus Input Leakage Current | -10.0 | +10.0 | μA | $0 < V_{IN} < V_{CC}$ | | | I <sub>CC</sub> | Power Supply Current | | 100.0 | mA | $V_{OH} = 1.5V$ | | | I <sub>OHD</sub> | Darlington Drive Current | -1.5 | 3.8 | mĀ | $R_{EXT} = 390 \Omega$ | Over specified temperature and voltage range. ### Capacitance | Symbol | Parameter | Min | Max | Unit | Test Condition | |----------|--------------------|-----|-----|------|----------------------------| | С | Clock Capacitance | | 10 | рF | Unmeasured | | $C_{IN}$ | Input Capacitance | | 5 | рF | pins returned<br>to ground | | COUT | Output Capacitance | | 10 | рF | to ground | Over specified temperature range; f = 1MH<sub>2</sub> ### Z8430 Z80° CTC Counter/ Timer Circuit ## Product Specification #### June 1982 #### Features - Four independently programmable counter/timer channels, each with a readable downcounter and a selectable 16 or 256 prescaler. Downcounters are reloaded automatically at zero count. - Three channels have Zero Count/Timeout outputs capable of driving Darlington transistors. - Selectable positive or negative trigger initiates timer operation. - Standard Z-80 Family daisy-chain interrupt structure provides fully vectored, prioritized interrupts without external logic. The CTC may also be used as an interrupt controller. - Interfaces directly to the Z-80 CPU or—for baud rate generation—to the Z-80 SIO. #### General Description The Z-80 CTC four-channel counter/timer can be programmed by system software for a broad range of counting and timing applications. The four independently programmable channels of the Z-80 CTC satisfy common microcomputer system requirements for event counting, interrupt and interval timing, and general clock rate generation. System design is simplified because the CTC connects directly to both the Z-80 CPU and the Z-80 SIO with no additional logic. In larger systems, address decoders and buffers may be required. Programming the CTC is straightforward: each channel is programmed with two bytes; a third is necessary when interrupts are enabled. Once started, the CTC counts down, reloads its time constant automatically, and resumes counting. Software timing loops are completely eliminated. Interrupt processing is simplified because only one vector need be specified; the CTC internally generates a unique vector for each channel. The Z-80 CTC requires a single +5 V power supply and the standard Z-80 single-phase system clock. It is fabricated with n-channel silicon-gate depletion-load technology, and packaged in a 28-pin plastic or ceramic DIP. Figure 1. Pin Functions Figure 2. Pin Assignments #### Functional Description The Z-80 CTC has four independent counter/ timer channels. Each channel is individually programmed with two words: a control word and a time-constant word. The control word selects the operating mode (counter or timer), enables or disables the channel interrupt, and selects certain other operating parameters. If the timing mode is selected, the control word also sets a prescaler, which divides the system clock by either 16 or 256. The time-constant word is a value from 1 to 256. During operation, the individual counter channel counts down from the preset time constant value. In counter mode operation the counter decrements on each of the CLE/TRG input pulses until zero count is reached. Each decrement is synchronized by the system clock. For counts greater than 256, more than one counter can be cascaded. At zero count, the down-counter is automatically reset with the time constant value. The timer mode determines time intervals as small as 4 $\mu s$ (Z-80A) or 6.4 $\mu s$ (Z-80) without additional logic or software timing loops. Time intervals are generated by dividing the system clock with a prescaler that decrements a preset down-counter. Thus, the time interval is an integral multiple of the clock period, the prescaler value (16 or 256) and the time constant that is preset in the down-counter. A timer is triggered automatically when its time constant value is programmed, or by an external CLK/TRG input. Three channels have two outputs that occur at zero count. The first output is a zero-count/timeout pulse at the ZC/TO output. The fourth channel (Channel 3) does not have a ZC/TO output; interrupt request is the only output available from Channel 3. The second output is Interrupt Request ((INT), which occurs if the channel has its interrupt enabled during programming. When the Z-80 CPU acknowledges Interrupt Request, the Z-80 CTC places an interrupt vector on the data bus. The four channels of the Z-80 CTC are fully prioritized and fit into four contiguous slots in a standard Z-80 daisy-chain interrupt structure. Channel 0 is the highest priority and Channel 3 the lowest. Interrupts can be individually enabled (or disabled) for each of the four channels. #### Architecture The CTC has four major elements, as shown in Figure 3. - CPU bus I/O - Channel control logic - Interrupt logic - Counter/timer circuits **CPU Bus I/O.** The CPU bus I/O circuit decodes the address inputs, and interfaces the CPU data and control signals to the CTC for distribution on the internal bus. Internal Control Logic. The CTC internal control logic controls overall chip operating functions such as the chip enable, reset, and read/write logic. Interrupt Logic. The interrupt control logic ensures that the CTC interrupts interface properly with the Z-80 CPU interrupt system. The logic controls the interrupt priority of the CTC as a function of the IEI signal. If IEI is High, the CTC has priority. During interrupt Figure 3. Functional Block Diagram Architecture (Continued) processing, the interrupt logic holds IEO Low, which inhibits the interrupt operation on lower priority devices. If the IEI input goes Low, priority is relinquished and the interrupt logic drives IEO Low. If a channel is programmed to request an interrupt, the interrupt logic drives IEO Low at the zero count, and generates an IMT signal to the Z-80 CPU. When the Z-80 CPU responds with interrupt acknowledge (MI and IORQ), then the interrupt logic arbitrates the CTC internal priorities, and the interrupt control logic places a unique interrupt vector on the data bus. If an interrupt is pending, the interrupt logic holds IEO Low. When the Z-80 CPU issues a Return From Interrupt (RETI) instruction, each peripheral device decodes the first byte (ED<sub>16</sub>). If the device has a pending interrupt, it raises IEO (High) for one MI cycle. This ensures that all lower priority devices can decode the entire RETI instruction and reset properly. Figure 4. Counter/Timer Block Diagram Counter/Timer Circuits. The CTC has four independent counter/timer circuits, each containing the logic shown in Figure 4. Channel Control Logic. The channel control logic receives the 8-bit channel control word when the counter/timer channel is programmed. The channel control logic decodes the control word and sets the following operating conditions: - Interrupt enable (or disable) - Operating mode (timer or counter) - Timer mode prescaler factor (16 or 256) - Active slope for CLK/TRG input - Timer mode trigger (automatic or CLK/TRG input) - Time constant data word to follow - Software reset Time Constant Register. When the counter/timer channel is programmed, the time constant register receives and stores an 8-bit time constant value, which can be anywhere from 1 to 256 (0 = 256). This constant is automatically loaded into the down-counter when the counter/timer channel is initialized, and subsequently after each zero count. Prescaler. The prescaler, which is used only in timer mode, divides the system clock frequency by a factor of either 16 or 256. The prescaler output clocks the down-counter during timer operation. The effect of the prescaler on the down-counter is a multiplication of the system clock period by 16 or 256. The prescaler factor is programmed by bit 5 of the channel control word. **Down-Counter.** Prior to each count cycle, the down-counter is loaded with the time constant register contents. The counter is then decremented one of two ways, depending on operating mode: - By the prescaler output (timer mode) - By the trigger pulses into the CLK/TRG input (counter mode) Without disturbing the down-count, the Z-80 CPU can read the count remaining at any time by performing an I/O read operation at the port address assigned to the CTC channel. When the down-counter reaches the zero count, the ZC/TO output generates a positive-going pulse. When the interrupt is enabled, zero count also triggers an interrupt request signal (IRT) from the interrupt logic. #### Programming Each Z-80 CTC channel must be programmed prior to operation. Programming consists of writing two words to the I/O port that corresponds to the desired channel. The first word is a control word that selects the operating mode and other parameters; the second word is a time constant, which is a binary data word with a value from I to 256. A time constant word must be preceded by a channel control word. After initialization, channels may be reprogrammed at any time. If updated control and time constant words are written to a channel during the count operation, the count continues to zero before the new time constant is loaded into the counter. If the interrupt on any Z-80 CTC channel is enabled, the programming procedure should also include an interrupt vector. Only one vector is required for all four channels, because the interrupt logic automatically modifies the vector for the channel requesting service. A control word is identified by a 1 in bit 0. A 1 in bit 2 indicates a time constant word is to follow. Interrupt vectors are always addressed to Channel 0, and identified by a 0 in bit 0. Addressing. During programming, channels are addressed with the channel select pins CS<sub>1</sub> and CS<sub>2</sub>. A 2-bit binary code selects the appropriate channel as shown in the following table. | Channel | $CS_1$ | CS <sub>0</sub> | | |---------|--------|-----------------|--| | <br>0 | 0 | 0 | | | 1 | 0 | 1 | | | 2 | 1 | 0 - | | | | | | | Reset. The CTC has both hardware and software resets. The hardware reset terminates all down-counts and disables all CTC interrupts by resetting the interrupt bits in the control registers. In addition, the ZC/TO and Interrupt outputs go inactive. IEO reflects IEI, and D<sub>0</sub>-D<sub>7</sub> go to the high-impedance state. All channels must be completely reprogrammed after a hardware reset. The software reset is controlled by bit 1 in the channel control word. When a channel receives a software reset, it stops counting. When a software reset is used, the other bits in the control word also change the contents of the channel control register. After a software reset a new time constant word must be written to the same channel. If the channel control word has both bits $D_1$ and $D_2$ set to 1, the addressed channel stops operating, pending a new time constant word. The channel is ready to resume after the new constant is programmed. In timer mode, if $D_3=0$ , operation is triggered automatically when the time constant word is loaded. Channel Control Word Programming. The channel control word is shown in Figure 5. It sets the modes and parameters described below. Interrupt Enable. $D_7$ enables the interrupt, so that an interrupt output ( $\overline{INT}$ ) is generated at zero count. Interrupts may be programmed in either mode and may be enabled or disabled at any time. Operating Mode. D<sub>6</sub> selects either timer or counter mode. Prescaler Factor. (Timer Mode Only). D<sub>5</sub> selects factor—either 16 or 256. Trigger Slope. D<sub>4</sub> selects the active edge or slope of the CLK/TRG input pulses. Note that reprogramming the CLK/TRG slope during operation is equivalent to issuing an active edge. If the trigger slope is changed by a control word update while a channel is pending operation in timer mode, the result is the same as a CLK/TRG pulse and the timer starts. Similarly, if the channel is in counter mode, the counter decrements. Figure 5. Channel Control Word (Continued) Programming Trigger Mode (Timer Mode Only). D<sub>3</sub> selects the trigger mode for timer operation. When Da is reset to 0, the timer is triggered automatically. The time constant word is programmed during an I/O write operation, which takes one machine cycle. At the end of the write operation there is a setup delay of one clock period. The timer starts automatically (decrements) on the rising edge of the second clock pulse (T2) of the machine cycle following the write operation. Once started, the timer runs continuously. At zero count the timer reloads automatically and continues counting without interruption or delay, until stopped by a reset. When D<sub>3</sub> is set to 1, the timer is triggered externally through the CLK/TRG input. The time constant word is programmed during an I/O write operation, which takes one machine cycle. The timer is ready for operation on the rising edge of the second clock pulse (T2) of the following machine cycle. Note that the first timer decrement follows the active edge of the CLK/TRG pulse by a delay time of one clock cycle if a minimum setup time to the rising edge of clock is met. If this minimum is not met, the delay is extended by another clock period. Consequently, for immediate triggering, the CLK/TRG input must precede T2 by one clock cycle plus its minimum setup time. If the minimum time is not met, the times will start on the third clock cycle (T2). Once started the timer operates continuously, without interruption or delay, until stopped by a reset. Time Constant to Follow. A 1 in D2 indicates that the next word addressed to the selected channel is a time constant data word for the time constant register. The time constant word may be written at any time. A 0 in D2 indicates no time constant word is to follow. This is ordinarily used when the channel is already in operation and the new channel control word is an update. A channel will not operate without a time constant value. The only way to write a time constant value is to write a control word with Do set. Figure 6. Time Constant Word Software Reset. Setting D1 to 1 causes a software reset, which is described in the Reset section. Control Word. Setting Do to 1 identifies the word as a control word Time Constant Programming. Before a channel can start counting it must receive a time constant word from the CPU. During programming or reprogramming, a channel control word in which bit 2 is set must precede the time constant word to indicate that the next word is a time constant. The time constant word can be any value from 1 to 256 (Figure 6). Note that 0016 is interpreted as 256. In timer mode, the time interval is controlled by three factors: - The system clock period (φ) - The prescaler factor (P), which multiplies the interval by either 16 or 256 - The time constant (T), which is programmed into the time constant register Consequently, the time interval is the product of $\phi \times P \times T$ . The minimum timer resolution is $16 \times \phi$ (4 µs with a 4 MHz clock). The maximum timer interval is $256 \times \phi \times 256$ (16.4 ms with a 4 MHz clock). For longer intervals timers may be cascaded. Interrupt Vector Programming. If the Z-80 CTC has one or more interrupts enabled, it can supply interrupt vectors to the Z-80 CPU. To do so, the Z-80 CTC must be pre-programmed with the most-significant five bits of the interrupt vector. Programming consists of writing a vector word to the I/O port corresponding to the Z-80 CTC Channel 0. Note that Do of the vector word is always zero, to distinguish the vector from a channel control word. D1 and D2 are not used in programming the vector word. These bits are supplied by the interrupt logic to identify the channel requesting interrupt service with a unique interrupt vector (Figure 7). Channel 0 has the highest priority. Figure 7. Interrupt Vector Word #### Pin Description CE. Chip Enable (input, active Low). When enabled the CTC accepts control words, interrupt vectors, or time constant data words from the data bus during an I/O write cycle; or transmits the contents of the down-counter to the CPU during an I/O read cycle. In most applications this signal is decoded from the eight least significant bits of the address bus for any of the four I/O port addresses that are mapped to the four counter-timer-channels. CLK. System Clock (input). Standard single-phase Z-80 system clock. CLE/TRG<sub>0</sub>-CLE/TRG<sub>3</sub>. External Clock/Timer Trigger (input, user-selectable active High or Low). Four pins corresponding to the four Z-80 CTC channels. In counter mode, every active edge on this pin decrements the down-counter. In timer mode, an active edge starts the timer. CS<sub>0</sub>-CS<sub>1</sub>. Channel Select (inputs active High). Two-bit binary address code selects one of the four CTC channels for an I/O write or read (usually connected to A<sub>0</sub> and A<sub>1</sub>). **D<sub>0</sub>-D<sub>7</sub>.** System Data Bus (bidirectional, 3-state). Transfers all data and commands between the Z-80 CPU and the Z-80 CTC. Figure 8. A Typical Z-80 Environment - IEI. Interrupt Enable In (input, active High). A High indicates that no other interrupting devices of higher priority in the daisy chain are being serviced by the Z-80 CPU. - IEO. Interrupt Enable Out (output, active High). High only it IEI is High and the Z-80 CPU is not servicing an interrupt from any Z-80 CTC channel. IEO blocks lower priority devices from interrupting while a higher priority interrupting device is being serviced. - INT. Interrupt Request (output, open drain, active Low). Low when any Z-80 CTC channel that has been programmed to enable interrupts has a zero-count condition in its down-counter. - IORQ. Input/Output Reguest (input from CPU, active Low). Used with ČE and RD to transfer data and channel control words between the Z-80 CPU and the Z-80 CTC. During a write cycle, [ORQ and ČE are active and RD inactive. The Z-80 CTC does not receive a specific write signal; rather, it internally generates its own from the inverse of an active RD signal. In a read cycle, [ORQ, CE and RD are active; the contents of the down-counter are read by the Z-80 CPU. If IORQ and MI are both true, the CPU is acknowledging an interrupt request, and the highest priority interrupting channel places its interrupt vector on the Z-80 data bus. - Mi. Machine Cycle One (input from CPU, active Low). When Mi and IORQ are active, the Z-80 CPU is acknowledging an interrupt. The Z-80 CTC then places an interrupt vector on the data bus if it has highest priority, and if a channel has requested an interrupt (INT). - RD. Read Cycle Status (input, active Low). Used in conjunction with IORQ and CE to transfer data and channel control words between the Z-80 CPU and the Z-80 CTC. - RESET. Reset (input active Low). Terminates all down-counts and disables all interrupts by resetting the interrupt bits in all control registers; the ZC/TO and the Interrupt outputs go inactive: IEO reflects IEI; D<sub>0</sub>-D<sub>7</sub> go to the high-impedance state. - ZC/TO<sub>9</sub>-ZC/TO<sub>2</sub>. Zero Count/Timeout (output, active High). Three ZC/TO pins corresponding to Z-80 CTC channels 2 through 0 (Channel 3 has no ZC/TO pin). In both counter and timer modes the output is an active High pulse when the down-counter decrements to zero. #### Timing Read Cycle Timing. Figure 9 shows read cycle timing. This cycle reads the contents of a down-counter without disturbing the count. During clock cycle T2, the Z-80 CPU initiates a read cycle by driving the following inputs Low: RD, IORO, and CE. A 2-bit binary code at inputs CS1 and CS0 selects the channel to be read. MI must be High to distinguish this cycle from an interrupt acknowledge. No additional wait states are allowed. Figure 9. Read Cycle Timing Write Cycle Timing. Figure 10 shows write cycle timing for loading control, time constant or vector words. The CTC does not have a write signal input, so it generates one internally when the read (RD) input is High during T<sub>1</sub>. During T<sub>2</sub> IORQ and CE inputs are Low. MI must be High to distinguish a write cycle from an interrupt acknowledge. A 2-bit binary code at inputs CS<sub>1</sub> and CS<sub>0</sub> selects the channel to be addressed, and the word being written is placed on the Z-80 data bus. The data word is Figure 10. Write Cycle Timing latched into the appropriate register with the rising edge of clock cycle T<sub>3</sub>. Figure 11. Timer Mode Timing Timer Operation. In the timer mode, a CLK/TRG pulse input starts the timer (Figure 11) on the second succeeding rising edge of CLK. The trigger pulse is asynchronous, and it must have a minimum width. A minimum lead time (210 ns) is required between the active edge of the CLK/TRG and the next rising edge of CLK to enable the prescaler on the following clock edge. If the CLK/TRG edge occurs closer than this, the initiation of the timer function is delayed one clock cycle. This corresponds to the startup timing discussed in the programming section. The timer can also be started automatically if so programmed by the channel control word. Figure 12. Counter Mode Timing Counter Operation. In the counter mode, the CLK/TRG pulse input decrements the down-counter. The trigger is asynchronous, but the count is synchronized with CLK. For the decrement to occur on the next rising edga of CLK, the trigger edge must precede CLK by a minimum lead time as shown in Figure 12. If the lead time is less than specified, the count is delayed by one clock cycle. The trigger pulse must have a minimum width, and the trigger period must be at least twice the clock period. The ZC/TO output occurs immediately after zero count, and follows the rising CLK edge. #### Interrupt Operation The Z-80 CTC follows the Z-80 system interrupt protocol for nested priority interrupts and return from interrupt, wherein the interrupt priority of a peripheral is determined by its location in a daisy chain. Two lines—IEI and IEO—in the CTC connect it to the system daisy chain. The device closest to the +5 V supply has the highest priority (Figure 13). For additional information on the Z-80 interrupt structure, refer to the Z-80 CPU Product Specification and the Z-80 CPU Product Specification and the Z-80 CPU Prechical Manual. Figure 13. Daisy-Chain Interrupt Priorities Within the Z-80 CTC, interrupt priority is predetermined by channel number: Channel 0 has the highest priority, and Channel 3 the lowest. If a device or channel is being serviced with an interrupt routine, it cannot be interrupted by a device or channel with lower priority until service is complete. Higher priority devices or channels may interrupt the servicing of lower priority devices or channels. A Z-80 CTC channel may be programmed to request an interrupt every time its down-counter reaches zero. Note that the CPU must be programmed for interrupt mode 2. Some time after the interrupt request, the CPU sends an interrupt acknowledge. The CTC interrupt control logic determines the highest priority channel that is requesting an interrupt. Then, if the CTC IEI input is High (indicating that it has priority within the system daisy chain) it places an 8-bit interrupt vector on the system data bus. The high-order five bits of this vector ming process; the next two bits are provided by the CTC interrupt control logic as a binary code that identifies the highest priority channel requesting an interrupt; the low-order bit is always zero. Interrupt Acknowledge Timing. Figure 14 shows interrupt acknowledge timing. After an interrupt request, the Z-80 CPU sends an interrupt acknowledge ( $\overline{\rm M1}$ and $\overline{\rm IORO}$ ). All channels are inhibited from changing their interrupt request status when $\overline{\rm M1}$ is active—about two clock cycles earlier than $\overline{\rm IORO}$ . $\overline{\rm RD}$ is High to distinguish this cycle from an instruction fetch. The CTC interrupt logic determines the highest priority channel requesting an interrupt. If the CTC interrupt enable input (IEI) is High, the highest priority interrupting channel within the CTC places its interrupt vector on the data bus when $|\overline{\text{ORQ}}|$ goes Low. Two wait states ( $T_{WA}$ ) are automatically inserted at this time to allow the daisy chain to stabilize. Additional wait states may be added. Return from Interrupt Timing. At the end of an interrupt service routine the RETI (Return From Interrupt) instruction initializes the daisy chain enable lines for proper control of nested priority interrupt handling. The CTC decodes the 2-byte RETI code internally and determines whether it is intended for a channel being serviced. Figure 15 shows RETI timing. If several Z-80 peripherals are in the daisy chain, IEI settles active (High) on the chip currently being serviced when the opcode ED<sub>16</sub> is decoded. If the following opcode is 4D<sub>16</sub>, the peripheral being serviced is released and its IEO becomes active. Additional wait states are allowed. Figure 14. Interrupt Acknowledge Timing Figure 15. Return From Interrupt Timing | Absolute<br>Maximum<br>Ratings | Stresses greater than those listed under Absolute Maxi-<br>mum Retings may cause permanent damage to the device.<br>This is a stress rating only, operation of the device at any<br>condition above those indicated in the operational section<br>of these specifications is not implied. Exposure to absolute<br>maximum rating conditions for extended periods may affect<br>device reliability. | | | | | | | |--------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------|----------------------------|----------|----------------|--| | Test<br>Conditions | following noted. All (0 V). Posenced pin ranges are \$5^* = 0 + 4.75 E E* = - + 4.75 M* = | paracteristics below apply for the test conditions, unless otherwise voltages are referenced to GND titive current flows into the refer. Available operating temperature s: $^{\circ}\text{C to } + 70^{\circ}\text{C}, \\ \text{V} \leq \text{V}_{\text{CC}} \leq + 5.25 \text{ V} \\ + 40^{\circ}\text{C to } + 85^{\circ}\text{C}, \\ \text{V} \leq \text{V}_{\text{CC}} \leq + 5.25 \text{ V} \\ -55^{\circ}\text{C to } + 125^{\circ}\text{C}, \\ \leq \text{V}_{\text{CC}} \leq + 5.5 \text{ V} \\ \end{cases}$ | *See Ordering I:<br>temperature rai | | duct nun | | | | DC<br>Character | Symbol | Parameter | Min | Max | Unit | Test Condition | | | Character-<br>istics | V <sub>ILC</sub> | Clock Input Low Voltage | -0.3 | +0.45 | v | | | | | $v_{IHC}$ | Clock Input High Voltage | V <sub>CC</sub> 6 | $V_{\rm CC}$ + .3 | V | | | | | $v_{iL}$ | Input Low Voltage | -0.3 | +0.8 | V | | | | | $v_{ih}$ | Input High Voltage | +2.0 | $\mathbf{v}_{\mathrm{cc}}$ | V | | | | | 17 | Output Law Voltage | | . 0 4 | 37 | T 2 - 8 | | | Capacitance | Symbol | Parameter Max Unit | Cox | dition | | | |-------------|------------------|-----------------------------------------|-------------------|----------------------------|----|------------------------------------------------| | | LOHD | Darlington Drive Current | -1.5 | | mA | $V_{OH} = 1.5 \text{ V}$ $R_{EXT} = 390\Omega$ | | | I <sub>LOL</sub> | 3-State Output Leakage Current in Float | | -10 | μA | $V_{OUT} = 0.4 V$ | | | I <sub>LOH</sub> | 3-State Output Leakage Current in Float | | + 10 | μÅ | $V_{OUT} = 2.4 \text{ to } V_{CC}$ | | | $I_{LI}$ | Input Leakage Current | | + 10 | μĀ | $V_{IN} = 0 \text{ to } V_{CC}$ | | | I <sub>CC</sub> | Power Supply Current | | +120 | mA | | | | $v_{oh}$ | Output High Voltage | +2.4 | | v | $I_{OH} = 250 \mu \text{Å}$ | | | $v_{ol}$ | Output Low Voltage | | +0.4 | V | $I_{OL} = 2 \text{ mÅ}$ | | | $v_{ih}$ | Input High Voltage | +2.0 | $\mathbf{v}_{\mathrm{cc}}$ | V | | | | $v_{iL}$ | Input Low Voltage | -0.3 | +0.8 | v | | | | $v_{IHC}$ | Clock Input High Voltage | V <sub>CC</sub> 6 | $V_{CC} + .3$ | V | | | Capacitance | Symbol | Symbol Parameter Max Unit Condition | | | | | | | |-------------|--------|-------------------------------------|----|----|--------------------|--|--|--| | | CLK | Clock Capacitance | 20 | рF | Unmeasured pins | | | | | | CIN | Input Capacitance | 5 | рF | returned to ground | | | | | | COUT | Output Capacitance | 10 | рF | | | | | $T_A = 25$ °C, f = 1 MHz | Number | Symbol | Parameter | Z-80<br>Min<br>(ns) | CTC<br>Max<br>(ns) | Z-80.<br>Min<br>(ns) | A CTC<br>Max<br>(ns) | Z-80<br>Min<br>(ns) | B CTC<br>Max<br>(ns) | Notes* | |--------|-------------|-------------------------------------------------------------------------------------|---------------------|--------------------|----------------------|----------------------|---------------------|-------------------------|------------| | 1 | TcC | Clock Cycle Time | 400 | [1] | 250 | [1] | 165 | [1] | | | 2 | TwCH | Clock Width (High) | 170 | 2000 | 105 | 2000 | 65 | 2000 | | | 3 | TwCl | Clock Width (Low) | 170 | 2000 | 105 | 2000 | 65 | 2000 | | | . 4 | TíC | Clock Fall Time | | 30 | | 30 | | 20 | | | 5 | TrC | - Clock Rise Time - | | 30 | | <del> 30</del> - | | 20 | | | 6 | Th | All Hold Times | 0 | | 0 | | 0 | | | | 7 | TsCS(C) | CS to Clock † Setup Time | 250 | | 160 | | 100 | | | | 8 | TsCE(C) | CE to Clock † Setup Time | 200 | | 150 | | 100 | | | | 9 | TsIO(C) | IORQ I to Clock 1 Setup Time | 250 | | 115 | | 70 | | | | 10 | TsRD(C) | - RD ↓ to Clock ↑ Setup Time — | <b>- 24</b> 0 - | | <del></del> 115 - | | <del> 7</del> 0 - | | | | 11 | TdC(DO) | Clock 1 to Data Out Delay | | 240 | | 200 | | 130 | [2] | | 12 | TdC(DOz) | Clock I to Data Out Float Delay | | 230 | | 110 | | 90 | | | 13 | TsDI(C) | Data In to Clock † Setup Time | 60 | | 50 | | 40 | | | | 14 | TsM1(C) | MI to Clock † Setup Time | 210 | | 90 | | 70 | | | | 15 | TdM1(IEO)- | - MI to IEO Delay (Interrupt immediately preceding MI) | | 300 | | 190 | | 130 | [3] | | 16 | TdIO(DOI) | IORQ I to Data Out Delay<br>(INTA Cycle) | | 340 | | 160 | | 110 | [2] | | 17 | TdIEI(IEOf) | IEI ↓ to IEO ↓ Delay | | 190 | | 130 | | 100 | [3] | | 18 | TdIEI(IEOr) | IEI 1 to IEO 1 Delay<br>(After ED Decode) | | 220 | | 160 | | 110 | [3] | | 19 | TdC(INT) | Clock 1 to INT Delay | (TcC | + 200) | | (TcC+ | 140) | TcC + 120 | [4] | | 20 — | TdCLK(INT)— | - CLK/TRG 1 to INT1<br>tsCTR(C) satisfied<br>tsCTR(C) not satisfied | (TcC | | ( | (TcC+ | | TeC + 130<br>2TeC + 280 | [5]<br>[5] | | 21 | TcCTR | CLK/TRG Cycle Time | (2TcC) | | (2TcC) | 1 | 2TcC | | [5] | | 22 | TrCTR | CLK/TRG Rise Time | | 50 | | 50 | | 40 | | | 23 | TICTR | CLK/TRG Fall Time | | 50 | | 50 | | 40 | | | 24 | TwCTRI | CLK/TRG Width (Low) | 200 | | 200 | | 120 | | | | 25 — | TwCTRh | - CLK/TRG Width (High) | <b>— 200 —</b> | | 200 - | | 120 - | | | | 26 | TsCTR(Cs) | CLK/TRG 1 to Clock 1 Setup<br>Time for Immediate Count | 300 | | 210 | | 150 | | [5] | | 27 | TsCTR(Ct) | CLK/TRG 1 to Clock 1 Setup<br>Time for enabling of Prescaler<br>on following clock1 | 210 | | 210 | | 150 | | [4] | | 28 | TdC(ZC/TOr) | Clock 1 to ZC/TO 1 Delay | | 260 | | 190 | | 140 | | | 29 | TdC(ZC/TOf) | Clock I to ZC/TO I Delay | | 190 | | 190 | | 140 | | <sup>[</sup>A] 2.5 TcC > (n-2) TdIEI(IEO!) + TdM1(IEO) + TsIEI(IO) + TTL buffer delay, if any. [B] RESET must be active for a minimum of 3 clock cycles. NOTES: III ToC = TwCh + TwCl + TrC + TrC. III ToC = TwCh + TwCl + TrC + TrC. III ToC = TwCh + TwCl + TrC + TrC. III ToC = TwCh + TwCl + TrC + TrC. III ToC = TwCh + TwCl + TrC + TrC. III ToC = TwCh + TwCl + TrC + TrC. <sup>[3]</sup> Increase delay by 2 ns for each 10 pF increase in loading, 100 pF maximum. [4] Timer mode. [5] Counter mode. [6] RESET must be active for a minimum of 3 clock cycles. \* All timings are preliminary and subject to change. ## Z8440 Z80°SIO Serial Input/Output Controller ## Product Specification #### June 1982 #### Features - Two independent full-duplex channels, with separate control and status lines for modems or other devices. - Data rates of 0 to 500K bits/second in the x1 clock mode with a 2.5 MHz clock (Z-80 SIO), or 0 to 800K bits/second with a 4.0 MHz clock (Z-80A SIO). - Asynchronous protocols: everything necessary for complete messages in 5, 6, 7 or 8 bits/character. Includes variable stop bits and several clock-rate multipliers; break generation and detection; parity; overrun and framing error detection. - Synchronous protocols: everything necessary for complete bit- or byte-oriented messages in 5, 6, 7 or 8 bits/character, including IBM Bisync, SDLC, HDLC, CCITT-X.25 and others. Automatic CRC generation/checking, sync character and zero insertion/deletion, abort genera- - Receiver data registers quadruply buffered, transmitter registers doubly buffered. - Highly sophisticated and flexible daisychain interrupt vectoring for interrupts without external logic. tion/detection and flag insertion. #### General Description The Z-80 SIO Serial Input/Output Controller is a dual-channel data communication interface with extraordinary versatility and capability. Its basic functions as a serial-to-parallel, parallel-to-serial converter/controller can be programmed by a CPU for a broad range of serial communication applications. The device supports all common asynchronous and synchronous protocols, byte-or bit-oriented, and performs all of the functions traditionally done by UARTs, USARTs and synchronous communication controllers combined, plus additional functions traditionally performed by the CPU. Moreover, it does this on two fully-independent channels, with an exceptionally sophisticated interrupt structure that allows very fast transfers. Full interfacing is provided for CPU or DMA \_\_\_ Figure 1. Z-80 SIO/2 Pin Functions Figure 2. Z-80 SIO/2 Pin Assignment ## General Description (Continued) control. In addition to data communication, the circuit can handle virtually all types of serial I/O with fast (or slow) peripheral devices. While designed primarily as a member of the Z-80 family, its versatility makes it well suited to many other CPUs. The Z-80 SIO is an n-channel silicon-gate depletion-load device packaged in a 40-pin plastic or ceramic DIP. It uses a single +5 V power supply and the standard Z-80 family single-obase clock. #### Pin Description Figures 1 through 6 illustrate the three pin configurations (bonding options) available in the SIO. The constraints of a 40-pin package make it impossible to bring out the Receive Clock (RxC), Transmit Clock (TxC), Data Terminal Ready (DTR) and Sync (SYNC) signals for both channels. Therefore, either Channel B lacks a signal or two signals are bonded together in the three bonding options offered: - Z-80 SIO/2 lacks SYNCB - Z-80 SIO/1 lacks DTRB - Z-80 SIO/0 has all four signals, but TxCB and RxCB are bonded together The first bonding option above (SIO/2) is the preferred version for most applications. The pin descriptions are as follows: **B/Ā.** Channel A Or B Select (input, High selects Channel B). This input defines which channel is accessed during a data transfer between the CPU and the SIO. Address bit Ao from the CPU is often used for the selection function. **C/D.** Control Or Data Select (input, High selects Control). This input defines the type of information transfer performed between the CPU and the SIO. A High at this input during a CPU write to the SIO causes the information on the data bus to be interpreted as a command for the channel selected by B/Ā. A Low at C/D means that the information on the data bus is data. Address bit A<sub>1</sub> is often used for this function. CE. Chip Enable (input, active Low). A Low level at this input enables the SIO to accept command or data input from the CPU during write cycle or to transmit data to the CPU during a read cycle. **CLK.** System Clock (input). The SIO uses the standard Z-80 System Clock to synchronize internal signals. This is a single-phase clock. CTSA. CTSB. Clear To Send (inputs, active Low). When programmed as Auto Enables, a Low on these inputs enables the respective transmitter. If not programmed as Auto Enables, these inputs may be programmed as general-purpose inputs. Both inputs are Schmitt-trigger buffered to accommodate slow risetime signals. The SIO detects pulses on these inputs and interrupts the CPU on both logic level transitions. The Schmitt-trigger buffering does not guarantee a specified noise-level margin. **D<sub>0</sub>-D<sub>7</sub>.** System Data Bus (bidirectional, 3-state). The system data bus transfers data and commands between the CPU and the Z-9I SIO. D<sub>0</sub> is the least significant bit. DCDA, DCDB. Data Carrier Detect (inputs, active Low). These pins function as receiver enables if the SIO is programmed for Auto Enables; otherwise they may be used as general-purpose input pins. Both pins are Schmitt-trigger buffered to accommodate slorisetime signals. The SIO detects pulses on these pins and interrupts the CPU on both logic level transitions. Schmitt-trioger buffere or before the signals. Figure 3. Z-80 SIO/1 Pin Functions Figure 4. Z-80 SIO/1 Pin Assignments escription Continued) ing does not guarantee a specific noise-level margin. DTRA. DTRB. Data Terminal Ready (outputs, active Low). These outputs follow the state programmed into Z-80 SIO. They can also be programmed as general purpose outputs. grammed as general-purpose outputs. In the Z-80 SIO/1 bonding option, DTRB is omitted. IEI. Interrupt Enable In (input, active High). This signal is used with IEO to form a priority daisy chain when there is more than one interrupt-driven device. A High on this line indicates that no other device of higher priority is being serviced by a CPU interrupt service routine. IEO. Interrupt Enable Out (output, active High). IEO is High only if IEI is High and the CPU is not servicing an interrupt from this SIO. Thus, this signal blocks lower priority devices from interrupting while a higher priority device is being serviced by its CPU interrupt service routine. **INT.** Interrupt Request (output, open drain, active Low). When the SIO is requesting an interrupt, it pulls INT Low. IORQ. Input/Output Request (input from CPU, active Low). IORQ is used in conjunction with B/A, C/D, CE and RD to transfer commands and data between the CPU and the SIO. When CE, RD and IORQ are all active, the channel selected by B/Ā transfers data to the CPU (a read operation). When CE and IORQ are active but RD is inactive, the channel selected by B/Ā is written to by the CPU with either data or control information as specified by CD. It IORQ and MI are active simultane. ously, the CPU is acknowledging an interrupt and the SIO automatically places its interrupt vector on the CPU data bus if it is the highest priority device requesting an interrupt. MI. Machine Cycle (input from Z-80 CPU, active Low). When MI is active and RD is also active, the Z-80 CPU is fetching an instruction from memory; when MI is active while IORO is active, the SIO accepts MI and IORO as an interrupt acknowledge if the SIO is the highest priority device that has interrupted the Z-80 CPU. RxCA. RxCB. Receiver Clocks (inputs). Receive data is sampled on the rising edge of RxC. The Receive Clocks may be 1, 16, 32 or 64 times the data rate in asynchronous modes. These clocks may be driven by the 2-80 CTC Counter Timer Circuit for programmable baud rate generation. Both inputs are Schmittrigger buffered (no noise level margin is specified). In the Z-80 SIO/0 bonding option, RxCB is bonded together with TxCB. $\overline{RD}$ . Read Cycle Status (input from CPU, active Low). If $\overline{RD}$ is active, a memory or I/O read operation is in progress. $\overline{RD}$ is used with $\overline{SVA}$ , $\overline{CE}$ and $\overline{IORO}$ to transfer data from the SIO to the CPU. **RxDA. RxDB.** Receive Data (inputs, active High). Serial data at TTL levels. RESET. Reset (input, active Low). A Low RESET disables both receivers and transmitters, forces TxDA and TxDB marking, forces the modem controls High and disables all interrupts. The control registers must be Figure 5. Z-80 SIO/0 Pin Functions Figure 6. Z-80 SIO/0 Pin Assignments #### Pin Description (Continued) rewritten after the SIO is reset and before data is transmitted or received. RTSA.RTSB. Request To Send (outputs, active Low). When the RTS bit in Write Register 5 (Figure 14) is set, the RTS output goes Low. When the RTS bit is reset in the Asynchronous mode, the output goes High after the transmitter is empty. In Synchronous modes, the RTS pin strictly follows the state of the RTS bit. Both pins can be used as general-purpose outputs. SYNCA, SYNCB, Synchronization (inputs/outputs, active Low). These pins can act either as inputs or outputs. In the asynchronous receive mode, they are inputs similar to CTS and DCD. In this mode, the transitions on these lines affect the state of the Sync/Hunt status bits in Read Register 0 (Figure 13), but have no other function. In the External Sync mode. these lines also act as inputs. When external synchronization is achieved. SYNC must be driven Low on the second rising edge of RxC after that rising edge of RxC on which the last bit of the sync character was received. In other words, after the sync pattern is detected, the external logic must wait for two full Receive Clock cycles to activate the SYNC input. Once SYNC is forced Low, it should be kept Low until the CPU informs the external synchronization detect logic that synchronization has been lost or a new message is about to start. Character assembly begins on the rising edge of RxC that immediately precedes the falling edge of SYNC in the External Sync In the internal synchronization mode (Monosync and Bisync), these pins act as outputs that are active during the part of the receive clock (RxC) cycle in which sync characters are recognized. The sync condition is not latched, so these outputs are active each time a sync pattern is recognized, regardless of character boundaries. In the Z-80 SIO/2 bonding option, SYNCB is omitted. TxCA. TxCB. Transmitter Clocks (inputs). In asynchronous modes, the Transmitter Clocks may be 1, 16, 32 or 64 times the data rate; however, the clock multiplier for the transmitter and the receiver must be the same. The Transmit Clock inputs are Schmitt-trigger buffered for relaxed rise- and fall-time requirements (no noise level margin is specified). Transmitter Clocks may be driven by the Z-80 CTC Counter Timer Circuit for programmable baud rate generation. In the Z-80 SIO/0 bonding option, $\overline{TxCB}$ is bonded together with $\overline{RxCB}$ . **TxDA. TxDB.** Transmit Data (outputs, active High). Serial data at TTL levels. TxD changes from the falling edge of $\overline{\text{TxC}}$ . W/RDYA. W/RDYB. Wait/Ready A, Wait/ Ready B (outputs, open drain when programmed for Wait function, driven High and Low when programmed for Ready function). These dual-purpose outputs may be programmed as Ready lines for a DMA controller or as Wait lines that synchronize the CPU to the SIO data rate. The reset state is open drain. Figure 7. Block Diagram #### Functional Description The functional capabilities of the Z-80 SIO can be described from two different points of view: as a data communications device, it transmits and receives serial data in a wide variety of data-communication protocols; as a Z-80 family peripheral, it interacts with the Z-80 CPU and other peripheral circuits, sharing the data, address and control buses, as well as being a part of the Z-80 interrupt struce. As a peripheral to other microprocessors, the SIO offers valuable features such as nonvectored interrupts, polling and simple handshake capability. Figure 8 illustrates the conventional devices that the SIO replaces. The first part of the following discussion covers SIO data-communication capabilities; the second part describes interactions between the CPU and the SIO. Figure 8. Conventional Devices Replaced by the Z-80 SIO Data Communication Capabilities The SIO provides two independent full-duplex channels that can be programmed for use in any common asynchronous or synchronous data-communication protocol. Figure 9 illustrates some of these protocols. The following is a short description of them. A more detailed explanation of these modes can be found in the 2-80 SIO Technical Manual. Asynchronous Modes. Transmission and reception can be done independently on each channel with five to eight bits per character, plus optional even or odd parity. The transmitters can supply one, one-and-a-half or two stop bits per character and can provide a break output at any time. The receiver breakdetection logic interrupts the CPU both at the start and end of a received break. Reception is protected from spikes by a transient spikerejection mechanism that checks the signal one-half a bit time after a Low level is detected on the receive data input (RxDA or RxDB in Figure 5). If the Low does not persist-as in the case of a transient—the character assembly process is not started. Framing errors and overrun errors are detected and buffered together with the partial character on which they occurred. Vectored interrupts allow fast servicing of error conditions using dedicated routines. Furthermore, a built-in checking process avoids interpreting a framing error as a new start bit: a framing error results in the addition of one-half a bit time to the point at which the search for the next start bit is begun. The SIO does not require symmetric transmit and receive clock signals—a feature that allows it to be used with a Z-80 CTC or many other clock sources. The transmitter and receiver can handle data at a rate of 1, 1/16, 1/32 or 1/64 of the clock rate supplied to the receive and transmit clock inputs. In asynchronous modes, the SYNC pin may be programmed as an input that can be used for functions such as monitoring a ring indicator. **Synchronous Modes.** The SIO supports both byte-oriented and bit-oriented synchronous communication. Synchronous byte-oriented protocols can be handled in several modes that allow character synchronization with an 8-bit sync character (Monosync), any 16-bit sync pattern (Bisync), or with an external sync signal. Leading sync Data Communication Capabilities (Continued) characters can be removed without interrupting the CPU. Five-, six- or seven-bit sync characters are detected with 8- or 16-bit patterns in the SIO by overlapping the larger pattern across multiple in-coming sync characters, as shown in Figure 10. CRC checking for synchronous byteoriented modes is delayed by one character time so the CPU may disable CRC checking on specific characters. This permits implementation of protocols such as IBM Bisync. Both CRC-16 (X16 + X15 + X2 + 1) and CCITT ( $X^{16} + X^{12} + X^5 + 1$ ) error checking polynomials are supported. In all non-SDLC modes, the CRC generator is initialized to 0's; in SDLC modes, it is initialized to 1's. The SIO can be used for interfacing to peripherals such as hard-sectored floppy disk, but it cannot generate or check CRC for IBM-compatible soft-sectored disks. The SIO also provides a feature that automatically transmits CRC data when no other data is available for transmission. This allows very high-speed transmissions under DMA control with no need for CPU intervention at the end of a message. When there is no data or CRC to send in synchronous modes, the transmitter inserts 8- or 16-bit sync characters regardless of the programmed character length. The SIO supports synchronous bit-oriented protocols such as SDLC and HDLC by performing automatic flag sending, zero insertion and CRC generation. A special command can be used to abort a frame in transmission. At the end of a message the SIO automatically transmits the CRC and trailing flag when the transmit buffer becomes empty. If a transmit underrun occurs in the middle of a message, an external/status interrupt warns the CPU of this status change so that an abort may be issued. One to eight bits per character can be sent, which allows reception of a message with no prior information about the character structure in the information field of a frame. The receiver automatically synchronizes on the leading flag of a frame in SDLC or HDLC. and provides a synchronization signal on the SYNC pin; an interrupt can also be programmed. The receiver can be programmed to search for frames addressed by a single byte to only a specified user-selected address or to a global broadcast address. In this mode, frames that do not match either the user-selected or broadcast address are ignored. The number of address bytes can be extended under software control. For transmitting data, an interrupt on the first received character or on every character can be selected. The receiver automatically deletes all zeroes inserted by the transmitter during character assembly. It also calculates and automatically checks the CRC to validate frame transmission. At the end of transmission, the status of a received frame is available in the status registers. The SIO can be conveniently used under DMA control to provide high-speed reception for transmission. In reception, for example, the SIO can interrupt the CPU when the first character of a message is received. The CPU then enables the DMA to transfer the message to memory. The SIO then issues an end-of-frame interrupt and the CPU can check the status of the received message. Thus, the CPU is freed for other service while the message is being received. Figure 9. Some Z-80 SIO Protocols Figure 10. #### I/O Interface Capabilities The SIO offers the choice of polling, interrupt (vectored or non-vectored) and blocktransfer modes to transfer data, status and control information to and from the CPU. The block-transfer mode can also be implemented under DMA control. Polling. Two status registers are updated at appropriate times for each function being performed (for example, CRC error-status valid at the end of a message). When the CPU is operated in a polling fashion, one of the SIO's two status registers is used to indicate whether the SIO has some data or needs some data. Depending on the contents of this register, the CPU will either write data, read data, or just go on. Two bits in the register indicate that a data transfer is needed. In addition, error and other conditions are indicated. The second status register (special receive conditions) does not have to be read in a polling sequence, until a character has been received. All interrupt modes are disabled when operating the device in a polled environment. Interrupts. The SIO has an elaborate interrupt scheme to provide fast interrupt service in real-time applications. A control register and a status register in Channel B contain the interrupt vector. When programmed to do so, the SIO can modify three bits of the interrupt vector in the status register so that it points directly to one of eight interrupt service routines in memory, thereby servicing conditions in both channels and eliminating most of the needs for a status-analysis routine. Transmit interrupts, receive interrupts and external/status interrupts are the main sources of interrupts. Each interrupt source is enabled under program control, with Channel A having a higher priority than Channel B, and with receive, transmit and external/status interrupts prioritized in that order within each channel. When the transmit interrupt is enabled, the CPU is interrupted by the transmit buffer becoming empty. (This implies that the transmitter must have had a data character written into it so it can become empty.) The receiver can interrupt the CPU in one of two ways: - Interrupt on first received character - Interrupt on all received characters Interrupt-on-first-received-character is typically used with the block-transfer mode. Interrupt-on-all-received-characters has the option of modifying the interrupt vector in the event of a parity error. Both of these interrupt modes will also interrupt under special receive conditions on a character or message basis (end-of-frame interrupt in SDLC, for example). This means that the special-receive condition can cause an interrupt only if the interrupt-onfirst-received-character or interrupt-on-allreceived-characters mode is selected. In interrupt-on-first-received-character, an interrupt can occur from special-receive conditions (except parity error) after the first-receivedcharacter interrupt (example: receive-overrun interrupt). The main function of the external/status interrupt is to monitor the signal transitions of the Clear To Send (CTS), Data Carrier Detect (DCD) and Synchronization (SYNC) pins (Figures 1 through 6). In addition, an external/status interrupt is also caused by a CRCsending condition or by the detection of a break sequence (asynchronous mode) or abort sequence (SDLC mode) in the data stream. The interrupt caused by the break/abort sequence allows the SIO to interrupt when the break/abort sequence is detected or terminated. This feature facilitates the proper termination of the current message, correct initialization of the next message, and the accurate timing of the break/abort condition in external logic. #### I/O Interface Capabilities (Continued) In a Z-80 CPU environment (Figure 11), SIO interrupt vectoring is "automatic": the SIO passes its internally-modifiable 8-bit interrupt vector to the CPU, which adds an additional 8 bits from its interrupt-vector (I) register to form the memory address of the interrupt-routine table. This table contains the address of the beginning of the interrupt routine itself. The process entails an indirect transfer of CPU control to the interrupt routine, so that the next instruction executed after an interrupt acknowledge by the CPU is the first instruction of the interrupt routine itself. CPU/DMA Block Transfer. The SIO's blocktransfer mode accommodates both CPU block transfers and DMA controllers (2-80 DMA or other designs). The block-transfer mode uses the Wait/Ready output signal, which is selected with three bits in an internal control register. The Wait/Ready output signal can be programmed as a WAIT line in the CPU blocktransfer mode or as a READY line in the DMA block-transfer mode. To a DMA controller, the SIO READY output indicates that the SIO is ready to transfer data to or from memory. To the CPU, the WAIT output indicates that the SIO is not ready to transfer data, thereby requesting the CPU to extend the I/O cycle. Figure 11. Typical Z-80 Environment #### Internal Structure The internal structure of the device includes a Z-80 CFU interface, internal control and interrupt logic, and two full-duplex channels. Each channel contains its own set of control and status (write and read) registers, and control and status logic that provides the interface to modems or other external devices. The registers for each channel are designated as follows: WR0-WR7 — Write Registers 0 through 7 RR0-RR2 — Read Registers 0 through 2 The register group includes five 8-bit control registers, two sync-character registers and two status registers. The interrupt vector is written into an additional 8-bit register (Write Register 2) in Channel B that may be read through another 8-bit register (Read Register 2) in Channel B. The bit assignment and functional grouping of each register is configured to simplify and organize the programming process. Table 1 lists the functions assigned to each read or write register. #### Read Register Functions - RRO Transmit/Receive buffer status, interrupt status and external status - RR1 Special Receive Condition status - RR2 Modified interrupt vector (Channel B only) ### Write Register Functions - WRO Register pointers, CRC initialize, initialization commands for the various modes, etc. - WR1 Transmit/Receive interrupt and data transfer mode definition. - WR2 Interrupt vector (Channel B only) - WR3 Receive parameters and control - WR4 Transmit/Receive miscellaneous parameters and modes - WR5 Transmit parameters and controls - WR6 Sync character or SDLC address field - WR7 Sync character or SDLC flag # Internal Structure (Continued) The logic for both channels provides formats, synchronization and validation for data transferred to and from the channel interface. The modem control inputs, Clear To Send (CTS) and Data Carrier Detect (DCD), are monitored by the external control and status logic under program control. All external control-and-status-logic signals are general-purpose in nature and can be used for functions other than modem control. Data Path. The transmit and receive data path illustrated for Channel A in Figure 12 is identical for both channels. The receiver has three 8-bit buffer registers in a FIFO arrangement, in addition to the 8-bit receive shift register. This scheme creates additional time for the CPU to service an interrupt at the beginning of a block of high-speed data. Incoming data is routed through one of several paths (data or CRC) depending on the selected mode and—in asynchronous modes—the character length. The transmitter has an 8-bit transmit data buffer register that is loaded from the internal data bus, and a 20-bit transmit shift register that can be loaded from the sync-character buffers or from the transmit data register Depending on the operational mode, outgoing data is routed through one of four main paths before it is transmitted from the Transmit Data output (TxD). Figure 12. Transmit and Receive Data Path (Channel A) #### Programming The system program first issues a series of commands that initialize the basic mode of operation and then other commands that qualify conditions within the selected mode. For example, the asynchronous mode, character length, clock rate, number of stop bits, even or odd parity might be set first; then the interrupt mode; and finally, receiver or transmitter neable. Both channels contain registers that must be programmed via the system program prior to operation. The channel-select input ( $B/\bar{A}$ ) and the control/data input ( $C/\bar{D}$ ) are the command-structure addressing controls, and are normally controlled by the CPU address bus. Figures 15 and 16 illustrate the timing relationships for programming the write registers and transferring data and status. Read Registers. The SIO contains three read registers for Channel B and two read registers for Channel A (RRO-RR2 in Figure 13) that can be read to obtain the status information; RR2 contains the internally-modifiable interrupt vector and is only in the Channel B register set. The status information includes error conditions, interrupt vector and standard communications-interface signals. To read the contents of a selected read register other than RRO, the system program must first write the pointer byte to WRO in exactly the same way as a write register operation. Then, by executing a read instruction, the contents of the addressed read register can be read by the CPU. The status bits of RRQ and RRI are carefully grouped to simplify status monitoring. For example, when the interrupt vector indicates that a Special Receive Condition interrupt has occurred, all the appropriate error bits can be read from a single register (RRI). Write Registers. The SIO contains eight write registers for Channel B and seven write registers for Channel A (WRO-WR7 in Figure 14) that are programmed separately to configure the functional personality of the channels; WR2 contains the interrupt vector for both channels and is only in the Channel B register set. With the exception of WR0, programming the write registers requires two bytes. The first byte is to WR0 and contains three bits (Do-D2) that point to the selected register; the second byte is the actual control word that is written into the register to configure the SIO. WRO is a special case in that all of the basic commands can be written to it with a single byte. Reset (internal or external) initializes the pointer bits $D_0$ – $D_2$ to point to WRO. This implies that a channel reset must not be combined with the pointing to any register. †Used With Special Receive Condition Mod Figure 13. Read Register Bit Functions Figure 14. Write Register Bit Functions #### Timing The SIO must have the same clock as the CPU (same phase and frequency relationship, not necessarily the same driver). Read Cycle. The timing signals generated by a Z-80 CPU input instruction to read a data or status byte from the SIO are illustrated in Figure 15. Write Cycle. Figure 16 illustrates the timing and data signals generated by a Z-80 CPU output instruction to write a data or control byte into the SIO. Interrupt-Acknowledge Cycle. After receiving an interrupt-request signal from an SIO (INT pulled Low), the Z-80 CPU sends an interrupt-acknowledge sequence (MI Low, and IORQ Low a few cycles later) as in Figure 17. The SIO contains an internal daisy-chained interrupt structure for prioritizing nested interrupts for the various functions of its two channels, and this structure can be used within an external user-defined daisy chain that prioritizes several peripheral circuits. The IEI of the highest-priority device is terminated High. A device that has an interrupt pending or under service forces its IEO Low. For devices with no interrupt pending or under service, IEO = IEI. To insure stable conditions in the daisy chain, all interrupt status signals are prevented from changing while MI is Low. When IORQ is Low, the highest priority interrupt requestor (the one with IEI High) places its interrupt vector on the data bus and sets its internal interrupt-under-service latch. Return From Interrupt Cycle. Figure 18 illustrates the return from interrupt cycle. Normally, the Z-80 CPU issues a RETI (Return From Interrupt) instruction at the end of an interrupt service routine. RETI is a 2-byte opcode (ED-4D) that resets the interrupt under-service latch in the SIO to terminate the interrupt that has just been processed. This is accomplished by manipulating the daisy chain in the following way. The normal daisy-chain operation can be used to detect a pending interrupt; however, it cannot distinguish between an interrupt under service and a pending unacknowledged interrupt of a higher priority. Whenever "ED" is decoded, the daisy chain is modified by forcing High the IEO of any interrupt that has not yet been acknowledged. Thus the daisy chain identifies the device presently under service as the only one with an IEI High and an IEO Low. If the next opcode byte is "4D," the interrupt-under-service latch is reset. The ripple time of the interrupt daisy chain (both the High-to-Low and the Low-to-High transitions) limits the number of devices that can be placed in the daisy chain. Ripple time can be improved with carry-look-ahead, or by extending the interrupt-acknowledge cycle. For further information about techniques for increasing the number of daisy-chained devices, refer to the Z-80 CPU Product Specification. Figure 15. Read Cycle Figure 16. Write Cycle Figure 18. Return from Interrupt Cycle | Absolute<br>Maximum<br>Ratings | Voltages on all inputs and outputs with respect to GND0.3 V to +7.0 V | | | | | | |--------------------------------|-----------------------------------------------------------------------|----------------------------------------|--|--|--|--| | | Operating Ambient Temperature | As Specified in . Ordering Information | | | | | Stresses greater than those listed under Absolute Maximum Ratings may cause permanent damage to the device. This is a stress rating only; operation of the device at any condition above those indicated in the operational sections of these specifications is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability. #### Test Conditions The characteristics below apply for the following test conditions, unless otherwise noted. All voltages are referenced to GND (0 V). Positive current flows into the referenced pin. Available operating temperature ranges are: Storage Temperature . . . . . . -65°C to +150°C ■ $$S^{\bullet} = 0^{\circ}C$$ to $+70^{\circ}C$ , $$+4.75 \text{ V} \le \text{V}_{CC} \le +5.25 \text{ V}$$ ■ $$E^* = -40^{\circ}C$$ to $+85^{\circ}C$ , $$+4.75 \text{ V} \le \text{V}_{CC} \le +5.25 \text{ V}$$ ■ $$M^{\bullet} = -55^{\circ}\text{C to} + 125^{\circ}\text{C},$$ + 4.5 $V \le V_{\text{CC}} \le +5.5 \text{ V}$ \*See Ordering Information section for package temperature range and product number. | DC<br>Charac- | Symbol | Parameter | Min | Max | Unit | Test Condition | |---------------|--------------------|-----------------------------------------------|----------------------|-------|------|---------------------------------------| | teristics | V <sub>ILC</sub> | Clock Input Low Voltage | -0.3 | +0.45 | v | | | | VIHC | Clock Input High Voltage | V <sub>CC</sub> -0.6 | +5.5 | v | | | | V <sub>IL</sub> | Input Low Voltage | -0.3 | +0.8 | v | | | | V <sub>IH</sub> | Input High Voltage | +2.0 | +5.5 | v | | | | v <sub>ol</sub> | Output Low Voltage | | +0.4 | v | $I_{Ol} = 2.0 \text{ mÅ}$ | | | v <sub>oh</sub> | Output High Voltage | +2.4 | | v | I <sub>OH</sub> = -250 μA | | | $I_{LI}$ | Input Leakage Current | -10 | + 10 | μA | 0 < V <sub>IN</sub> < V <sub>CC</sub> | | | $I_{Z}$ | 3-State Output/Data Bus Input Leakage Current | -10 | + 10 | μA | $0 < V_{IN} < V_{CC}$ | | | I <sub>L(SY)</sub> | SYNC Pin Leakage Current | -40 | + 10 | μΑ | $0 < V_{IN} < V_{CC}$ | | | $I_{CC}$ | Power Supply Current | | 100 | mĀ | | Over specified temperature and voltage range | Capacitance | Symbol | Parameter | Min | Max | Unit | Test Condition | |-------------|--------|--------------------|-----|-----|------|----------------| | | Ç | Clock Capacitance | | 40 | pF | Unmeasured | | | CIN | Input Capacitance | | 5 | рF | pins returned | | | COUT | Output Capacitance | | 10 | pF | to ground | Over specified temperature range; f = 1MHz AC Electrical Character-istics | Number | Symbol | Parameter | Z-80<br>Min | SIO<br>Max | | A SIO<br>Max | Z-80B<br>Min | SIO*†<br>Max | |--------|----------------|----------------------------------------------|-------------|------------|-------|--------------|------------------|--------------| | 1 | TcC | Clock Cycle Time | 400 | 4000 | 250 | 4000 | 165 | 4000 | | 2 | TwCh | Clock Width (High) | 170 | 2000 | 105 | 2000 | 70 | 2000 | | 3 | TfC | Clock Fall Time | | 30 | | 30 | | 15 | | 4 | TrC | Clock Rise Time | | 30 | | 30 | | 15 | | 5 | TwCl | Clock Width (Low) | 170 - | - 2000 - | 105 - | -2000 - | <del> 70 -</del> | -2000 - | | 6 | TsAD(C) | CE, C/D, B/Ā to Clock † Setup Time | 160 | | 145 | | 60 | | | 7 | TsCS(C) | IORQ, RD to Clock † Setup Time | 240 | | 115 | | 60 | | | 8 | TdC(DO) | Clock 1 to Data Out Delay | | 240 | | 220 | | 150 | | 9 | TsDI(C) | Data In to Clock † Setup (Write or MI Cycle) | 50 | | 50 | | 30 | | | 10 | -TdRD(DOz) | RD t to Data Out Float Delay | | 230 | | 110 | | 90 - | | 11 | TdIO(DOI) | IORQ I to Data Out Delay (INTACK Cycle) | | 340 | | 160 | | 100 | | 12 | TsM1(C) | MI to Clock † Setup Time | 210 | | 90 | | 75 | | | 13 | TsIEI(IO) | IEI to IORQ ↓ Setup Time (INTACK Cycle) | 200 | | 140 | | 120 | | | 14 | TdM1(IEO) | MI ↓ to IEO ↓ Delay (interrupt before MI) | | 300 | | 190 | 160 | | | 15 | - TdIEI(IEOr)- | · IEI † to IEO † Delay (after ED decode) | | 150 | | 100 | | 70 - | | 16 | TdIEI(IEOf) | IEI ↓ to IEO ↓ Delay | | 150 | | 100 | | 70 | | 17 | TdC(INT) | Clock † to INT Delay | | 200 | | 200 | | 150 | | 18 | TdIO(W/RWf) | IORQ ↓ or CE ↓ to W/RDY ↓ (Delay Wait Mode) | | 300 | | 210 | | 175 | | 19 | TdC(W/RR) | Clock † to W/RDY † Delay (Ready Mode) | | 120 | | 120 | | 100 | | 20 | - TdC(W/RWz)- | - Clock I to W/RDY Float Delay (Wait Mode) | | 150 | | 130 | | 110- | | 21 | Th | Any unspecified Hold when Setup is specified | 0 | | 0 | | 0 | | <sup>\*</sup> Z-80 SIO timings are preliminary and subject to change. † Units in nanoseconds (ns). AC Electrical Character-istics (Continued) | Number | Symbol | Parameter | Z-80<br>Min | SIO<br>Max | Z-80A<br>Min | SIO<br>Max | Z-80B<br>Min | SIO:<br>Max | Notes | |--------|--------------|---------------------------------------------|--------------------|------------|-----------------|------------|--------------|-------------|-------| | 1 | TwPh | Pulse Width (High) | 200 | | 200 | | 200 | | 2 | | 2 | TwPl | Pulse Width (Low) | 200 | | 200 | | 200 | | 2 | | 3 | TcTxC | TxC Cycle Time | 400 | 00 | 400 | 00 | 330 | 00 | 2 | | 4 | TwTxCl | TxC Width (Low) | 180 | œ | 180 | 00 | 100 | 00 | 2 | | 5 | TwTxCh | TxC Width (High) | <del>-</del> 180 - | | 180 | | 100 | | 2 | | 6 | TdTxC(TxD) | TxC to TxD Delay (x1 Mode) | | 400 | | 300 | | 220 | 2 | | 7 | TdTxC(W/RRf) | TxC to W/RDY Delay (Ready Mode) | 5 | 9 | 5 | 9 | 5 | 9 | 3 | | 8 | TdTxC(INT) | TxC to INT Delay | 5 | 9 | 5 | 9 | 5 | 9 | 3 | | 9 | TcRxC | RxC Cycle Time | 400 | • | 400 | 00 | 330 | 00 | 2 | | 10- | TwRxC1 | RxC Width (Low) | 180 | | <del></del> 180 | - 🕳 | 100 | | 2- | | 11 | TwRxCh | RxC Width (High) | 180 | œ | 180 | 00 | 100 | œ | 2 | | 12 | TsRxD(RxC) | RxD to RxC 1 Setup Time (x1 Mode) | 0 | | 0 | | 0 | | 2 | | 13 | ThRxD(RxC) | RxC t to RxD Hold Time (x1 Mode) | 140 | | 140 | | 100 | | 2 | | 14 | TdRxC(W/RRf) | RxC 1 to W/RDY Delay (Ready Mode) | 10 | 13 | 10 | 13 | 10 | 13 | 3 | | 15 | TdRxC(INT) | RxC 1 to INT Delay | 10 | 13 | 10 | 13 | 10 | 13 | 3 | | 16 | TdRxC(SYNC) | RxC ↑ to SYNC ↓ Delay (Output Modes) | 4 | 7 | 4 | 7 | 4 | 7 | 3 | | 17 | TsSYNC(RxC) | SYNC I to RxC 1 Setup (External Sync Modes) | -100 | | -100 | | | 100 | 2 | NOTES: 1 In all modes, the System Clock rate must be at least five times the maximum data rate. 1. 2-80 SIO timings are preliminary and subject to change. Units in nanoseconds (ns). Units equal to System Clock Periods. Notes -- Schematics ~ Schematics SCHEMATIC-BOBL PROCESSOR Schematics #### How the ROM Works When power is first applied or the RESET button is pressed, the system bank (Bank 0) is enabled by hardware and the Z80-A's program counter is set to 0000H. The first 8k of address space in the system bank consists of ROM sockets U33-U36. An 820-II with the ASCII keyboard will have 6k of ROM occupying U33-U35 (6k). With the Low Profile keyboard, another 2k ROM is added to U36 bringing the total system ROM size to 8k. The firmware contained in the system ROMs will be referred to as the ROSR (ROM Operating System Routines). The ROSR provides instructions for the Z80-A to do several things at power-on. They are: Do a checksum test of the firmware contained in the first 6k of ROM. Do confidence test on RAM memory that will be used by the ROSR (F000H-FFFFH). Initialize programmable devices and variable memory area starting at address FF00H. Move resident portion of monitor to RAM starting at address F000H. Compute checksum of the ROM in socket U36; if correct, call the first address of U36 (1800H). Check type of disk controller daughter board that is installed and load appropriate disk driver into high memory. Provide an initial system command level for the user. This provides such options as: Host terminal mode, Typewriter mode, Load system, Dump memory, etc. Additionally, ROSR provides character I/O, disk I/O, and other hardware-related services for the operating system and /or an application program. One of the first things that the ROSR is responsible for is the initialization of the programmable devices on the CPU board. These devices are: CTC (Counter Timer Circuit), PIOs (Parallel Input Output controllers), SIO (Serial Input Output controller), and the Baud rate generator. At power on, these devices are initialized as described below. ## Counter Timer Circuit (CTC) Base interrupt vector = 0H Channel 0 Not initialized Channel 1 Timer mode, no interrupts, period = 1 msec. Channel 2 Timer mode, no interrupts, period = 8 msec. Channel 3 Counter mode, interrupts enabled, down counter value = 125. Channel 0 of the CTC is not used by the system. Channel 1 is initialized but interrupts are not enabled until the screen print command is given from the keyboard. At this time, 1 msec. interrupts begin occurring until the last character has been printed from the CRT's refresh memory. Then, the interrupts from CTC-1 will be disabled. Channel 2 is initialized as a timer also. Its job is to divide the system clock and to generate a pulse to CTC-3 every 8 msec. Channel 3 is initialized as a counter; it counts pulses from CTC-2 and generates an interrupt to the system every 125 pulses (1 second). ## System Parallel Input/Output Controller (PIO) Base interrupt vector = 1AH Port A Bit Mode Bits 0-5 input, Bits 6-7 output, interrupts disabled Port B Input Mode Interrupts enabled Port A of the system PIO is used for the bank switching, floppy disk drive and side selects, and CRT font selection. Port B is used as the keyboard input channel. ## General Purpose Parallel Input/Output Controller (PIO) Base interrupt vector = Not initialized Port A Output Mode Interrupts disabled Port B Mode 3 Bits 0-3 output, bits 4-7 input, interrupts disabled The general purpose parallel PIO is initialized to provide an interface to a Centronics-compatible parallel printer. Port A serves as the data channel and port B bit 2 provides the strobe to the printer. Port B bit 4 is for connection to the printer's ready signal. The parallel interface option connector (J11) must have jumpers installed between the following pins: 5-6, 9-10, and 17-18. This selects the direction for the transceiver; that is, between the PIO and the parallel I/O connector J8. If the GP PIO is to be used for something other than a parallel printer, the user can re-program the PIO and re-jumper J11 to suit the needs of the application. ## Serial Input/Output Controller (SIO) Base interrupt vector = 00 Channel A Asynchronous mode modem port Interrupts disabled, 7 bits per character, x16 clock mode, 1 stop bit per character, even parity enabled, Data Terminal Ready (DTR) and Request To Send (RTS) outputs from the SIO are active. Wired as RS-232 DTE (Data Terminal Equipment). Note: The 4.03 ROM initializes DTR and RTS outputs to an inactive state. Channel B Printer port Interrupts disabled, 7 bits per character, x16 clock mode, 1 stop bit per character, even parity enabled, Data Terminal Ready (DTR) and Request To Send (RTS) outputs from the SIO are active. Wired as RS-232 DCE (Data Communication Equipment). Hardware handshake is available on pins 20 and 5. Channel A Baud Rate Generator (Modem) 300 Baud Channel B Baud Rate Generator (Printer) 1200 Baud #### MONITOR COMMANDS The 820-II and 16/8's resident monitor is capable of executing several commands directly from the keyboard. The table below summarizes the monitor's command set. Under the heading "Format", the items enclosed in parentheses represent required numeric parameters. The items in square brackets represent optional parameters. Detailed information on each of the commands follows the table. | Command | Format | |-----------------------|-----------------------------------------------| | D(isplay memory) | D [start addr] [end addr] | | M(odify memory) | M (addr) | | X(tended memory test) | X (start addr) (end addr) | | F(ill memory) | F (start addr)(end addr)(fill data) | | C(opy memory) | C (start addr)(end addr)(dest addr) | | V(erify memory block) | V (start addr)(end addr)(with addr) | | G(oto) | G (addr)[HL, DE, BC registers] | | I(nput) | I (16-bit port addr) | | O(utput) | O (16-bit port addr)(8-bit data) | | L(oad from disk) | L [disk drive unit value] | | R(ead disk sector) | R (drive unit)(track)(sector)(addr) | | W(rite disk sector) | W (drive unit) (track) (sector) (addr) | | B(aud rate) | B (baud rate)[channel] | | T(ypewriter) | T [baud rate] | | H(ost terminal) | H [ch.] [baud] [data bits] [par.] [stop bits] | | P(rinter protocol) | P (Xon/Xoff)[status mask] [status value] | ### 1) D - DISPLAY MEMORY COMMAND This command displays the contents of memory in hexadecimal and ASCII representation. Each display line has the following format: AAAA is the starting memory address of the line in hexadecimal, the DD's are the hex values of the 16 bytes of data starting at location AAAA, and the C's are ASCII characters equivalent to each data byte. Bytes with a value less than 20 hex are displayed with their appropriate display character codes as shown in the ASCII code chart. Bytes with a value greater than 7F hex are displayed in low intensity. The display memory command accepts one, two, or no address parameters. If two addresses are specified, the block of memory between those two locations will be displayed. Entering only one address will display 256 bytes of memory starting at the specified location. Entering D<return> with no parameters will display the 256 byte block of memory starting one location past the last address displayed. The display can be stopped temporarily by touching the space bar. Touching the space bar again continues the display. ## 2) M - MODIFY MEMORY COMMAND The modify memory command allows the contents of individual memory locations to be changed. This command accepts one parameter representing the first memory address to modify or examine. The display format is: AAAA DD AAAA is the current memory address and DD is the hexadecimal value of the data in that location. After displaying the contents of a memory location, the routine waits for one of the following parameters to be entered from the keyboard: Touching < return > does not modify the memory data at the currently displayed memory address, but will display the contents of the next memory address. - Typing a minus sign has a similar effect, except the address is decremented instead of incremented. - Typing a hexadecimal number will replace the data at the currently displayed address with the number entered. The new data is stored as soon as the second digit is entered, with no terminating character required. If only one digit is entered, touching <return> will cause the single digit hex number to replace the previous data. - Typing a quote sign will cause the ASCII value of the next key typed to be stored at the currently displayed address. - Typing any character other than <return>, a minus sign, a quote sign, or a hexadecimal digit will terminate the command. ### 3) X - EXTENDED MEMORY TEST COMMAND This command tests the specified range of memory for errors. Any portion of memory may be tested except the read/write area reserved for ROSR (F000 to FFFF hex). At least two parameters are required: the starting address and the ending address. Only the high-order eight bits of the addresses entered are actually used. If no errors are detected, the test will display a plus sign. When errors are detected an error line will be displayed in the following format: AAAADD should = X ## 4) F - FILL MEMORY COMMAND The fill command allows blocks of memory to be filled with a fixed data value. Three parameters are required: a starting address, an ending address, and a fill-data value. Each location in the specified block of memory has the constant written into it and then read back again to check for memory errors. An error line (like the one described for the Xtended Memory Test) is printed for any locations that fail to verify. ### 5) C - COPY MEMORY COMMAND The copy command allows blocks of data to be moved in memory. Three parameters are required: a starting memory address, an ending address, and a destination address. The contents of the block of memory in between the first two addresses are copied to the block starting at the third address. Like the Fill Memory command, a test is made to verify that each byte of the destination block, when read back, is the same as the corresponding byte in the source block. ## 6) V - VERIFY MEMORY BLOCK COMMAND This command is similar to the Copy Memory command except that data is not moved, but simply checked to see if it is the same as data located at a different address in memory. Three parameters are required: a starting memory address, an ending address, and the first address of the memory block to be compared. #### G - GO TO COMMAND The go to command controls the CPU to start executing at a particular memory location. It requires a single parameter, (the address at which to begin execution). Three optional parameters may also be specified so the HL, DE, and BC register pairs may be preset before execution begins. Each of these optional parameters is a 16-bit (four-digit hexadecimal) number. The optional parameters would be entered as: G1000 AAFF DDEE BBCC 1000 is the hexadecimal address at which to begin execution, AA is placed in the H register, FF is placed in the L register, DD is placed in the D register, EE is loaded into the E register, BB is transferred to the B register, and CC is put into the C register. In addition, FF (the value specified for the L register) will also be placed into the A register. Thus, a shortened command line (using only a single optional parameter) would be entered as: GF00C 0024 In the example, the hex value 24 will be loaded into both the L and A registers before executing the CRT output driver at memory address F00C hex. (This example displays a '\$' on the screen.) ROSR actually passes control to the specified address by simulating a CALL instruction. This makes it possible for the external program to return to ROSR by doing a RET, (assuming it does not re-load the stack pointer or lose the return address to ROSR). After the routine returns, ROSR displays the contents of the A register and the HL register pair. ### 8) I - INPUT COMMAND This command allows data to be read from input ports. It works very much like the Modify Memory command, except input ports are being examined instead of memory locations. A single parameter representing a port number is required. Since many of the I/O ports are accessed using the unique Z80-A I/O instruction, the parameter can be a 16-bit port address. The BC register pair is loaded with the parameter, and then an IN A,(C) instruction is executed. An example of full parameter specification would be: IAA55 AA represents the contents of the B register, which is placed on the highorder address lines (A8-A15), and 55 represents the contents of the C register, which is placed on the low-order address lines (A0-A7). Using only an 8-bit parameter will place a zero in the B register. Touching the space bar will display data from the same port address again. The contents of adjacent ports can be examined by touching <return> or the minus sign (like the Modify command). Typing any other key terminates the command. # 9) O - OUTPUT COMMAND The output command allows a specified data value to be written to output ports. Two parameters are required: a 16-bit port address (see Input command), and an 8-bit data value that is to be written to that port. After outputting the specified data to the port, the command returns to ROSR instead of stepping to the next output port like the input command. This makes it possible to use the output command to initialize Z80-A peripheral devices like the SIO, PIO, and CTC. Since a 16-bit port address is specified, special ports such as the scroll port register can be modified directly from ROSR. Some of these special ports require that their "data" value be placed on the high-order address lines. A sample command to alter the scroll port register is: #### O1014FF 10 represents the contents of the B register which is placed on the highorder address lines and is the actual "data" that will be written to the scroll port register. The 14 represents the value that is placed in the C register and is output as the low-order address lines to actually select the scroll port. The data value FF hex is output on the data lines, but the data is not looked at by this type of special port. ### 10) L - LOAD FROM DISK The load system command is used to read a one-sector program from track 0, sector 1 of the specified disk drive. The load command accepts one optional parameter to specify from which physical disk to load. If this optional parameter is omitted, the load is from physical drive unit 0 (drive A). Floppy disk configurations have valid disk parameters of A through D. The usual load-from-disk-command for floppy drives will be L or LA, to load from drive A. Rigid disk configurations can have valid disk parameters of A through H. **Note**: The drive that is loaded from becomes logical drive A. Thus, when the operating system is loaded from drive E on the rigid (the LE command), physical disk E will be referenced as A and the physical floppy A is referenced as logical drive E. The disk loader reads the first logical sector into memory at location 80h and starts execution at that address. Normally, the program will be a small loader that in turn reads in a larger program. This two-level bootstrap process makes the boot command application independent. The only requirements are that the first sector of the disk be reserved for a loader, the first byte of this loader not be an E5h, and the first 256 bytes of memory not be overwritten by the program being loaded. #### 11) R - READ DISK SECTOR COMMAND This command allows one physical sector to be read from the specified disk drive to a designated address in memory (must be above 66H). The drive unit is a number between 0 and F hex, with 0 corresponding to physical drive A. It should be noted that different disks may not have the same sector size. The read sector command will always read one physical sector, no matter what its length. Typically, single density disks will have 128-byte sectors, and double density disks will have 256-byte sectors. The sector size for rigid disk drives will always be 256 bytes or larger. Even though one physical sector is read, 256 bytes will be displayed after the read. Thus, when reading single density disks, only the first 128 bytes of the 256 bytes displayed on the screen are valid. Physically, all floppy disks used with the 820-II and 16/8 begin with sector #1. However, when using the Monitor's R command, the first physical sector is accessed by specifying sector 0 in the command line. ### 12) W - WRITE DISK SECTOR COMMAND A "W" and a <return> is required with the Write Disk Sector command before parameters will be accepted. A second "W" and parameters and a <return> is then required. The write disk sector command allows one physical sector to be written to the specified disk drive from the designated address in memory. The drive unit is a number between 0 and F hex, with 0 corresponding to physical drive A. Note that different disks may not have the same physical sector size. The write sector command will always write one physical sector, no matter what its length. In general, single density disks will have 128-byte sectors, and double density disks will have 256-byte sectors. The sector size for the rigid disk drive will also be 256 bytes. Physically, all floppy disks used with the 820-II and 16/8 begin with sector #1. However, when using the Monitor's W command, the first physical sector on double density and rigid disks is accessed by specifying sector 0 in the command line. #### 13) B - BAUD RATE COMMAND This command sets the baud rate for the designated serial I/O channel, (printer or communications port). An optional parameter is required to change the baud rate from the default (1200-Printer, 300-Comm). If a second optional parameter is not specified, then the baud rate is set for the printer port (channel B). Specifying channel A will cause the designated or default baud rate to be set for the communications port. At power-on or reset, both serial ports are set for 7 data bits and even parity with one stop bit. See also the Host Terminal Mode section. ## 14) T - TYPEWRITER COMMAND In Typewriter Mode, any information typed on the standard 96-character keyboard will be sent to the serial printer port. To use Typewriter Mode, type the following parameters (in bold): ``` T or T# ``` ``` T = Typewriter Mode # = Baud Rate (1200) ``` #### For example: ``` T Typewriter Mode ``` T5 Typewriter Mode 300 Baud (from Chart, Appendix K-1) #### 15) H - HOST TERMINAL ``` Host Terminal H (channel) (baud rate) (data bits) (parity) (stop bits) ``` The Xerox 820-II or 16/8 may be used as a terminal to a Host. By typing an H at power-on, the firmware initializes software in ROM that permits communication with a host computer. ## Options (default settings are bolded): Channel A (communications port) B (printer port) Baud rate Channel A - 300 Channel B - 1200 (For other Baud Rate options, see Appendix K) Data bits 7 or 8 Parity Odd, Even, or None Stop bits 1 or 2 ### For example, typing H<space>B<space>8<space>None<space>2<return> would put your system in Host Mode with 2 stop bits, no parity, 8 data bits, at 1200 baud on the Printer port. Options may be altered using the Monitor Output command **before** typing an H < return > to load host terminal mode. It is important to note that these settings will remain in effect until the the system is turned off, the RESET button in the rear is pressed, or a disk is loaded that has had the CONFIGUR program run on it. To change to odd parity: O06 04 meaning Output to the SIO Channel A control port (06) selecting internal register 4 (04) O06 45 Output a 45h to the SIO Channel A control port (06) which sets internal SIO register 4 to enable odd parity To change to no parity: O06 04 Output to the SIO Channel A control port (06) selecting internal register 4 (04) O06 44 Output a 44h to the SIO Channel A control port (06) which sets internal SIO register 4 to enable no parity To change to 8 data bits (receiver and transmitter): Output to the SIO Channel A control port (06) selecting internal register 3 (03) Output a C1h to the SIO Channel A control port (06) which sets internal SIO register 3 to 8 data bits for the receiver Output to the SIO Channel A control port (06) selecting internal register 5 (05) Output an EAh to the SIO Channel A control port (06) which sets internal SIO register 5 to 8 data bits for the transmitter For example, to change to no parity, 8 data bits, and set the baud rate to 1200, the following parameters should be entered at power-on: O06<space>04<return> O06<space>44<return> sets no parity O06 < space > 03 < return > O06 < space > C1 < return > sets 8 data bits receiver O06<space>05<return> O06<space>EA<return> sets 8 data bits transmitter B<space>07<space>A<return> sets 1200 baud, comm port **H<return>** loads Host Mode with the above parameters ## **Host Terminal Command Set** Host mode has a command set that can be used by pressing the <CTRL> key and one of the **Numeric Pad** keys. Note: Scroll up and Scroll down ( $\uparrow$ and $\downarrow$ ) do not require the <CTRL> key when using the 16/8. | <ctrl></ctrl> | Meaning | |---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | <b>†</b> | <b>Scroll up.</b> Up-arrow scrolls up text on the screen with wrap around. | | 1 | <b>Scroll down.</b> Down-arrow scrolls down text on the screen with wrap around. | | DEL | Enable local echo. Characters typed on the keyboard are displayed on the screen and transmitted through the serial port. Touching <ctrl> + DEL again disables local echo mode.</ctrl> | | Line<br>Feed | Enable local auto line feed. When < return > is touched, a line feed is sent to the local screen display but not transmitted through the serial port. Touching < CTRL > + LF again disables local line feed mode. | | 1 | Enable remote echo. Characters received through the serial port are echoed back to the transmitting device. In this mode, the 820-II or 16/8 may act as a host to another terminal. Touching <ctrl> + 1 again disables remote echo mode.</ctrl> | | 2 | Enable remote auto line feed. Carriage return codes received through the serial port are echoed to the remote device as carriage return/line feed codes. Touching <ctrl> + 2 again disables remote auto line feed.</ctrl> | | (period) | Transmit BREAK. When <ctrl> and the period key on the numeric keypad are touched, a break condition is enabled on the serial port until: 1. <ctrl> + . is touched again 2. Any other character is typed.</ctrl></ctrl> | ### <CTRL> ### Meaning "Toggling" the break function allows the length of the break condition to be determined by the user. Some host computers require a very short break condition, while some communications control devices require a long break condition. #### **ESC** **Exit Host Terminal Mode.** **Note:** In Host Mode, the 820-II or 16/8 will respond to the special Display Control Codes listed in the CRT Control & Interface section. ## 16) P - PROTOCOL COMMAND The protocol command alters the method used to control the transmission of characters to the printer (for different types of serial printers). Normally, XON/XOFF protocol is enabled to allow efficient communications with a Xerox 20 or 40 CPS printer. Since this is a "transparent" protocol, it will not interfere with printers that don't use XON/XOFF. The protocol command requires at least one parameter to enable or disable the XON/XOFF protocol. P1 enables this protocol, while P0 disables it. A second type of protocol is used for printers that control the transmission of characters by means of "reverse channel" or other hardware signals. Two signals may be used to control the transmission of characters to the printer: CTS (Clear To Send) Printer connector Pin 5 DTR (Data Terminal Ready) Printer connector Pin 20 Two parameters are used to specify how these signals will be used for "hardware handshaking"; the first designates which signals are to be checked, and the second indicates which logical state will be used to enable the transmission of data. The most commonly-used modes are shown below. The voltage level is the EIA RS- 232 level measured at the printer connector: ## P1<space>28<space>28<return> Check CTS and DTR, pins 5 and 20. If either changes to false (-12), stop transmission. ## P1<space>8<space>8<return> Check DTR, pin 20. If false (-12), stop transmission. ## P1<space>20<space>20<return> Check CTS, pin 5. If false (-12), stop transmission. The following examples show the values for some less-common printers that require transmission be stopped with signals of the opposite sense. Notice these examples also enable the XON/XOFF protocol by specifying a 1 as the first parameter. ## P1<space>28<space>0<return> Check CTS and DTR, pins 5 and 20. If either changes to true (+12), stop transmission. ## P1<space>8<space>0<return> Check DTR, pin 20. If true (+12), stop transmission. # P1 < space > 20 < space > 0 < return > Check CTS, pin 5. If true (+12), stop transmission. Notes ## **Operating System Interface** The preferred method of accessing the resources of the 820-II and 16/8 is through one of the operating systems (CP/M-80, CP/M-86, or MS-DOS). The operating system functions available are documented in the manuals listed below. CP/M-80 Interface Guide section of Digital Research's CP/M 2.2 Operating System Reference Manual. CP/M-86 Digital Research's CP/M-86 User's Guide, System Guide, and Programmer's Guide. MS-DOS MS-DOS Programmers Guide. ## Accessing CP/M-80 and CP/M-86 BIOS CP/M-80/CP/M-86 also provide a BIOS (Basic Input/Output System) interface that is available to the programmer. The BIOS interface is described in the following manuals: CP/M-80 Alteration Guide section of Digital Research's CP/M 2.2 Operating System Reference Manual. CP/M-86 Digital Research's CP/M-86 User's Guide, System Guide, and Programmer's Guide. CP/M-86 has an operating system function (#50) that provides access to the CP/M-86 BIOS. The BIOS interface for CP/M-80 version 2.2 is not supported as an operating system function. An application program may call 16 of the 17 BIOS vectors; the first vector Cold boot may not be called. Because the BIOS jump table is not anchored to any fixed memory locations, application programs must not directly call any of the jump vectors without first calculating the address of the desired vector. At address 0000H is a jump instruction to the second BIOS vector -wboot. The application program should read the address stored at address 0001H and 0002H, then add the offset of the desired BIOS jump vector and call this "calculated" address. For example, suppose an application program needed to determine whether or not the list device is busy. This is not supported with an operating system function call under CP/M-80 2.2. ``` ;Users program ``` call biolsts ;get status of list device or a ;result is returned in a ;00 = not ready ;else = ready ;Continue ### **Biolsts:** Id hI,(0001H) ;Get address of wboot Id I.15\*3 :15th vector 3 bytes per vector ip (hl) The reason that the biolsts label was "called" from the main program is to put a return address on the stack. Remember, all BIOS routines end with a return instruction ### **Additional BIOS Information** The following describes parameters for some of the BIOS functions that are not described in the Alteration Guide. Sectran - The sector translate vector is documented to receive a logical sector number in the BC register pair, and the address of a logical-to-physical translate table in the DE register pair, returning the physical sector number from the table in the HL register. In the 820-II and 16/8, when a double density disk or a rigid disk is being accessed, the DE register pair contains a 0000H indicating no logical-to-physical skew table. When this occurs, the logical sector number is returned in the HL register. **Seldsk** - If bit 0 of the E register is 0, the BIOS recognizes this as a first-time select of the disk and will request the physical disk driver to determine the type of media currently in the drive. Write - The C register contains the write type. 0 = Write to an allocated data block 1 = Write to directory 2 = Write to an unallocated data block ## CP/M Logical - 820-II Physical Device Mapping The IOBYTE has been partially implemented in the 820-II to enable optional re-assignment of CP/M character devices (console and list) to different physical devices on the 820-II (CRT/keyboard, serial modem port, serial printer port, and parallel printer port). This logical-to-physical device mapping can be changed either under program control or with CP/M's transient command, STAT. | CP/M Logical device names | Physical device names | | | | | |---------------------------|-----------------------|------|------|------|--| | CON: | TTY: | CRT: | BAT: | UC1: | | | RDR: | TTY: | PTR: | UR1: | UR2: | | | PUN: | TTY: | PTP: | UP1: | UP2: | | | LST: | TTY: | CRT: | LPT: | UL1: | | The chart above lists the CP/M logical device names in the left column and the valid physical devices for each logical device is listed to the right of the logical device name. For example the logical console device can be mapped to the physical TTY:, CRT:, BAT:, or UC1:, but not PTR:. The chart below shows the mapping of physical device names to physical devices on the 820-II. | 820-II Physical | |-------------------------| | devices | | Serial printer port | | 820-II CRT and keyboard | | Serial printer port | | Serial modem port | | Serial modem port | | Serial modem port | | Serial printer port | | Parallel printer port | | Serial modem port | | Serial modem port | | Serial modem port | | Serial modem port | | | ## CP/M Logical - 16/8 Physical Device Mapping The IOBYTE has been fully implemented on the 16/8. The tables below describe the logical to physical device mapping for CP/M-80 and CP/M-86. | CP/M-80 Logical<br>device names<br>CON:<br>RDR:<br>PUN:<br>LST: | Physic<br>device<br>TTY:<br>TTY:<br>TTY:<br>TTY: | names<br>CRT:<br>PTR: | BAT:<br>UR1:<br>UP1:<br>LPT: | UC1:<br>UR2:<br>UP2:<br>UL1: | |-----------------------------------------------------------------|-------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------|------------------------------| | CP/M-86 Logical | Physical device | | | | | device name | names | ; | | | | CON: | TTY: | CRT: | BAT: | UC1: | | AXI: | TTY: | PTR: | UR1: | UR2: | | AXO: | TTY: | PTP: | UP1: | UP2: | | LST: | TTY: | CRT: | LPT: | UL1: | | | | | | | | CP/M physical | 16/8 PI | nysical | | | | CP/M physical device names | 16/8 PI<br>device | nysical<br>s | | | | | device | | oort | | | device names | device<br>Serial | s<br>printer p | oort<br>ceyboard | d | | device names<br>BAT: | device<br>Serial<br>16/8 C | s<br>printer p | ceyboar | d | | device names<br>BAT:<br>CRT: | device<br>Serial<br>16/8 C<br>Serial | s<br>printer p<br>RT and b<br>printer p | ceyboar | | | device names BAT: CRT: LPT: | device<br>Serial <br>16/8 Cl<br>Serial <br>16/8 Cl | s<br>printer p<br>RT and b<br>printer p<br>RT and b | ceyboar<br>oort | d | | device names BAT: CRT: LPT: PTP: | device<br>Serial<br>16/8 C<br>Serial<br>16/8 C | s<br>printer p<br>RT and b<br>printer p<br>RT and b | ceyboard<br>oort<br>ceyboard<br>ceyboard | d | | device names BAT: CRT: LPT: PTP: PTR: | device<br>Serial<br>16/8 C<br>Serial<br>16/8 C<br>Serial | s<br>printer p<br>RT and b<br>printer p<br>RT and b<br>RT and b<br>modem | ceyboard<br>oort<br>ceyboard<br>ceyboard<br>port | d | | device names BAT: CRT: LPT: PTP: PTR: TTY: | device<br>Serial<br>16/8 Cl<br>16/8 Cl<br>16/8 Cl<br>Serial<br>Inter-p | s<br>printer p<br>RT and b<br>printer p<br>RT and b<br>RT and b<br>modem | ceyboard<br>ceyboard<br>ceyboard<br>ceyboard<br>port<br>r comm | d<br>d | | device names BAT: CRT: LPT: PTP: PTR: TTY: UC1: | device<br>Serial <br>16/8 Cl<br>Serial <br>16/8 Cl<br>Serial <br>Inter-p | s<br>printer p<br>RT and b<br>printer p<br>RT and b<br>RT and b<br>modem<br>processo | ceyboard<br>ceyboard<br>ceyboard<br>ceyboard<br>port<br>r comm<br>r port | d<br>d | | device names BAT: CRT: LPT: PTP: PTR: TTY: UC1: UL1: | device<br>Serial<br>16/8 Cl<br>Serial<br>16/8 Cl<br>16/8 Cl<br>Serial<br>Inter-p<br>Paralle<br>Serial | printer printer printer printer printer processories printer p | ceyboard<br>ceyboard<br>ceyboard<br>port<br>r comm<br>r port<br>port | d<br>d | | device names BAT: CRT: LPT: PTP: PTR: TTY: UC1: UL1: UP1: | device<br>Serial<br>16/8 Cl<br>Serial<br>16/8 Cl<br>Serial<br>Inter-p<br>Paralle<br>Serial<br>Inter-p | printer printer printer printer printer printer processo printer printer processo | ceyboard<br>ceyboard<br>ceyboard<br>port<br>r comm<br>r port<br>port<br>r comm | d<br>d<br>unication channel | In the 16/8 configuration, an application program running on the 8086 can communicate with an application program running on the Z80-A through the inter-processor communication channel by changing the I/OBYTE value and using console input and console output functions. INPUT A0 = Stop 8086 A1 = Start 8086 OUTPUT A0, D7 = 1 : Lock 8086 ### I/O PORT ASSIGNMENTS These input/output ports are accessible by the Z80-A only. The 8086 microprocessor on the 16/8 cannot access these I/O ports. Note: | Port # | Assignment | |------------|------------------------------------------------| | (hex) | | | 00 | Channel A Baud Rate (Modem) (write only) | | 01 | Channel A Baud Rate (Modem) (write only) | | 02 | Channel A Baud Rate (Modem) (write only) | | 03 | Channel A Baud Rate (Modem) (write only) | | 04 | SIO Channel A (Modem) Data | | 05 | SIO Channel B (Printer) Data | | 06 | SIO Channel A (Modem) Control | | 07 | SIO Channel B (Printer) Control | | 80 | GP-PIO Channel A Data | | 09 | GP-PIO Channel A Control | | 0A | GP-PIO Channel B Data | | 0B | GP-PIO Channel B Control | | 0C | Channel B Baud Rate (Printer) (write only) | | 0D | Channel B Baud Rate (Printer) (write only) | | 0E | Channel B Baud Rate (Printer) (write only) | | 0F | Channel B Baud Rate (Printer) (write only) | | 10 | Floppy Disk Controller Status/Command Register | | | Fixed Disk PIO Channel A Data | | 11 | Floppy Disk Controller Track Register | | | Fixed Disk PIO Channel A Control | | 12 | Fixed Disk PIO Channel B Data | | | Floppy Disk Sector Register | | 13 | Fixed Disk PIO Channel B Control | | | Floppy Disk Data Register | | 14 | CRT Scroll Register (write only) | | 15 | CRT Scroll Register (write only) | | 16 | CRT Scroll Register (write only) | | 17 | CRT Scroll Register (write only) | | 18 | CTC Channel 0 | | 19 | CTC Channel 1 | | 1 <b>A</b> | CTC Channel 2 | ## I/O PORT ASSIGNMENTS continued | | I/O PORT ASSIGNMENTS COntinued | |---------|-------------------------------------------------| | Port # | Assignment | | (hex) | | | 1B | CTC Channel 3 | | 1C | System PIO Channel A Data | | 1D | System PIO Channel A Control | | 1E | System PIO Channel B Data (keyboard) | | 1F | System Pio Channel B Control (keyboard) | | (20-27 | not used and not available) | | 28 | Speaker cone push (write only) | | 29 | Speaker cone pull (write only) | | (2A-2F | not used and not available) | | 30 | Select Single Density | | 31 | Select Double Density | | (32-33 | not used and not available) | | 34 | Reset CRT Font Generator to ROM #1 (write only) | | 35 | Reset CRT Font Generator to ROM #2 (write only) | | 36 | Set Low-Light Video Mode (write only) | | (37-67 | not used and not available) | | 68 | Asynchronous Communications (write only) | | 69 | Synchronous Communications (write only) | | 80 - 9F | Reserved | | FE - FF | Reserved | | A0 - A3 | 16/8 CPU Board | | A4 - AF | Reserved | | B0 - BF | Reserved | | | | ## **ROM Operating System Interface** The 820-II and 16/8 also provide a series of ROM operating system jump vectors that can be accessed by a program executing on the Z80-A for other functions available on the 820-II and 16/8. It is important to note that these should be used only when the necessary service is not provided by the operating system. Use of these ROM services makes the program un-transportable to most other computers. Also, use of the ROM operating system I/O services may make the program inoperable under the dual CP/M-80/86 system. ### **CRT Overview** The CRT functions involve the moving of characters to the CRT RAM and character display. (The entry points described in this section are in the Monitor; see IOBYTE, starting on page 167 for BIOS display-related calls). CRTOUT simply displays a character at the cursor position and increments the cursor. FASTCRT also displays a character at the cursor position, but keeps track of and returns information about characters lost at the end of a line, deleted characters, etc. SETCUR stores a CRT RAM address; OUTCUR then stores a character at this address. CRTLDIR will move a block of memory (or group of characters to or from CRT RAM). **CRT Output** Entry Point: F00CH Function(s) At the current cursor position, display the character in register A or perform the special function defined by the character sequence supplied in consecutive calls to CRTOUT. Arguments: (A) =the character to display Value(s) Returned: None Registers Saved: All Errors Returned: None Fast CRT Output **Entry Point:** FOOFH Function(s): At the current cursor position, display the character in register C or perform the special function defined by the character sequence supplied in consecutive calls to FASTCRT. Arguments: = the character to display Value(s) Returned: Normal display character: (A) = character under the cursor (HL) = CRT RAM address of the cursor The special functions will return the following: Character Insert = character that was lost off the end (A) 1R 51h of the line Character Delete (A) = character that was deleted 1B 57h Line Insert 1B 45h The line that was lost off of the bottom of the screen is moved to the Command Processor's line buffer. This buffer is located immediately after the Time-of-Day clock variables, whose address is obtained by calling F039. Line Delete 1B 52h The line that was deleted is moved to the line buffer as in Line Insert Line Feed 0Ah whether or not the line feed caused the top line to be lost (scrolled) (A = 0 - scrolled, A $\neq 0$ - not scrolled). If so, the line may be found in The A register returns a flag indicating the line buffer as in Line Delete Registers Saved: Errors Returned: None None Set Direct CRT Cursor **Entry Point:** F02DH Function(s): Store the address passed in registers HL for use in successive calls to Direct CRT Display. Arguments: (HL) = CRT RAM address Value(s) Returned: Registers Saved: **Errors Returned:** None None None **Direct CRT Display** **Entry Point:** F030H Function(s): Store the character in C in the CRT RAM at the Direct Cursor location. The normal cursor is Direct Cursor location. The normal cursor is unaffected. The direct cursor address is incremented, however line/screen overflow is not processed. Arguments: (C) = character to display (HL) = CRT RAM address Value(s) Returned: None None Registers Saved: None **CRT Memory Block Move** **Entry Point:** F033H Function(s): This entry point moves a memory block to/from or within the alternate memory bank. It functions like the Z80-A LDIR instruction except that it also takes care of switching memory banks. When data is transferred between Bank 0 and Bank 1, source data is first moved to the internal line buffer, then the memory bank is switched and the data saved in the internal buffer is transferred to its destination. This sequence of operations is repeated until all source data has been transferred. When data is transferred within the CRT RAM, there is no internal buffering performed. Arguments: (HL) = source address (DE) = destination address (BC) = number of bytes to move (A) = type of move 0 if move CRT RAM to CRT RAM0 if move system RAM to CRT RAM (i.e., A = FFH) > 0 if move CRT RAM to System RAM (i.e., A = 1) Value(s) Returned: HL, DE, BC updated as in LDIR instruction Registers Saved: Errors Returned: None None ## **Execute Physical Driver** This entry point is the heart of the disk system. Upon entry, register HL must point to a nine-byte block of memory called the Physical Driver Request Block (PDRB) which must be formatted as shown below: | 00: | db | command | ;FF = Select | |-----|----|---------|---------------------------------------| | | | | ;00 = Write | | | | | ;01 = Read | | 01: | ds | 1 | ; for system use | | 02: | db | Ldrive | ;Logical Drive for request (00 - 0F) | | 03: | dw | Track | ;Track number for request | | 05: | dw | Sector | ;Sector number for request | | 07: | dw | Address | :Address of sector buffer for request | The byte holding the Logical Drive (HL + 02) is used to select the appropriate physical disk driver by indexing into the Select Table to obtain the driver unit as well as the driver entry point address. Byte (HL + 01) is filled with the physical unit number for this physical driver, then control is passed directly to the physical disk driver. User-written disk drivers may be linked into the Select Table if these drivers conform to the virtual interface described. The following command values (HL + 00) must be supported by any user generated physical driver. **Entry Point:** F02AH Function(s): **FF - Select Media Format** - This command causes the disk driver to identify the media in the physical unit. Registers HL return pointing to a CP/M-compatible Disk Parameter Header if the media was successfully identified. Otherwise HL contains zero. This command may cause several disk accesses because it must determine the disk's density and the number of sides. Therefore, it should not be issued repeatedly, or system performance may be affected. Xerox's CP/M issues this command whenever a disk drive is 'logged in'. **00 -- Write Sector** - This command causes the physical sector identified by bytes 03 through 06 of the PDRB to be written from the buffer addressed by bytes 07 and 08. The acceptable values for Track and Sector vary with different physical disk drivers. 01 -- Read Sector - This command causes the physical sector identified by bytes 03 through 06 of the PDRB to be read into the buffer addressed by bytes 07 and 08. The acceptable values for Track and Sector vary with different physical disk drivers. Note: On read/write sector requests, the first physical sector number on double density floppies is actually 1; however, the PDRB must request sector 0 for the first physical sector. The second physical sector can be accessed with a request for sector 1, etc. Single density floppies access physical sector 1 by requesting sector 1. Arguments: HL = address of Physical Driver Request Block (PDRB) Value(s) Returned: If SELECT command: HL = address of a CP/M-compatible Disk Parameter Header if the media was successfully identified HL = 0 otherwise If READ or WRITE command: (A) = 00 if no error (A) = FFiferror Registers Saved: ### **Printer Overview** The Monitor printer entries SIOST, SIOIN, SIOOUT, and SIORDY are those functions which check status and provide for input and output for SIO Channel B, a serial printer. Printer protocols are processed only by the SIO Channel B entries. ### **SIO-B Input Ready Status** **Entry Point:** F012H Function(s): Get SIO Channel B input ready status. Arguments: None Value(s) Returned: (A) = 00 if no data available (A) = FF if data available Registers Saved: Errors Returned: All except AF None **SIO-B Input Data** **Entry Point:** F015H Function(s): Get S Get SIO Channel B input character. If an input character is not ready, IDLE is called repeatedly until one is ready. Arguments: None Value(s) Returned: (A) = character Registers Saved: Errors Returned: All except AF **SIO-B Output Data** **Entry Point:** F018H Function(s): Wait until the SIO Channel B transmitter is ready (by calling SIORDY), then transmit the character in (A). IDLE is called while the transmitter is not ready. Arguments: (A) = character to transmit Value(s) Returned: Registers Saved: None None Errors Returned: ## **SIO-B Output Ready Status** Entry Point: F03FH Function(s): Determine if the device connected to SIO Channel B is ready to receive data. SIORDY supports the configured printer protocol and the DC1/DC3 (XON/XOFF) sequence. Arguments: Value(s) Returned: None (A) = 00 if not ready (A) = FFifready Registers Saved: All except AF Errors Returned: #### **Communications Overview** Monitor entries for status and input/output are also provided for SIO Channel A, which is generally used as a communications port. These entries are COMINS, COMINP, COMOUT, AND COMOTS. ## **Communications Input Ready Status** **Entry Point:** F05AH Function(s): Arguments: None Value(s) Returned: (A) = 00 if not ready (A) = FF if ready Registers Saved: All except AF Errors Returned: None ### **Communications Input Data** Entry Point: F05DH Function(s): Input character from SIO Channel A. Get the SIO Channel A input ready status. Arguments: Value(s) Returned: None (A) = character Registers Saved: None Errors Returned: None # **Communications Output Status** Entry Point: F060H Function(s): Determine if the SIO Channel A transmitter is ready to accept data. Arguments: None Value(s) Returned: Registers Saved: (A) = 00 if ready All except AF Errors Returned: None Note: IDLE is not called by the Channel A drivers. Therefore, these entries may be called by a user-written IDLE procedure. In this manner, you may drive Channel A while other I/O (disk, printer, etc.) is pending. ## **Keyboard Overview** The Monitor keyboard entries, KBDST and KBDIN, provide for keyboard status and input. A 16 (decimal) key type-ahead FIFO is maintained for the keyboard on an Etch 2 CPU. **Keyboard Status** **Entry Point:** F006H Function(s): Arguments: Determine if a keystroke is available. None (A) = 00 if no character available Value(s) Returned: (A) = FF if character available Registers Saved: All except AF Errors Returned: None **Keyboard Input** **Entry Point:** Function(s): F009H Wait for keyboard input data. IDLE is called while input is not available. Arguments: Value(s) Returned: (A) = character All except AF Registers Saved: **Errors Returned:** None #### **IOBYTE Directed I/O** The IOBYTE function allows for physical-to-logical device mapping. This mapping capability provides flexibility and device isolation for the user. If IOBYTE-directed I/O is used, a program does not have to know which devices are currently active; the Operating System will perform the logical-to-physical I/O mapping. The mapping is based on the contents of IOBYTE, location 0003, which defines the assignment of devices to the CONSOLE, READER, PUNCH, and LIST devices. Monitor entries IOCONS, IOCONI, and IOCONO provide for status of and input/output to the CONSOLE device. IOLIST and IOLSTS provide for status of and output to the LIST device. In addition, the BIOS has entries PUNCH and READER to access the Communications Channel. ## **Console Status through IOBYTE** **Entry Point:** F04BH Function(s): Get status of the assigned CONSOLE device by dispatching request based upon the current (bit) values of IOBYTE as follows: 00 - Comins 01 - Kbdst 10 - Siost Arguments: None Value(s) Returned: (A) = 00 if not ready (A) = FF if ready Registers Saved: Errors Returned: None None # Console Input through IOBYTE Entry Point: E04EH Function(s): Get input from the assigned CONSOLE device by dispatching request based upon the current (bit) values of IOBYTE as follows: 00 - Cominp 01 - Kbdin 10 - Sioin 11 - Sioin Arguments: Value(s) Returned: (A) = character Registers Saved: None None **Console Output through IOBYTE** **Entry Point:** F051H Function(s): Send output to the assigned CONSOLE device by dispatching request based upon the current (bit) values of IOBYTE as follows: 00 - Comout 01 - Fastcrt 10 - Sigout 11 - Comout Arguments: (C) = character to transmit Value(s) Returned: Registers Saved: None None Errors Returned: None ## **Printer Output through IOBYTE** **Entry Point:** F054H Function(s): Send output to the assigned LIST device by dispatching request based upon the current (bit) values of IOBYTE as follows: 00 - Comout 01 - Fastcrt 10 - Sigout 11 - Pioout (parallel printer) = character to transmit Arguments: None Value(s) Returned: Registers Saved: None (C) Errors Returned: # **Printer Status through IOBYTE** Entry Point: Function(s): Get status of the assigned LIST device by dispatching request based upon the current (bit) values of IOBYTE as follows: 00 - Comots 01 - Return ready 10 - Siordy 11 - Piosto (parallel printer) Arguments: None Value(s) Returned: (A) = 00 if not ready (A) = FF if ready Registers Saved: All except AF Errors Returned: None ## **Programmable Functions** The following are system exit points. They are provided to allow application-specific activities on a 1-second interrupt, when an I/O request is pending or when a soft disk error occurs. In order for the ROSR Monitor to call these functions, the address of your routine must be patched into the appropriate Monitor vector table entry. A vector table entry is in the following format (LSB/MSB means Least/Most Significant Byte of address): Byte 1 Byte 2 Byte 3 Jump Instruction LSB MSB For example, a jump to location F048H would look like: Byte 1 Byte 2 Byte 3 C3 48 F0 The application must first retrieve and save the address portion of the appropriate vector table entry. (The saved address must be restored when the application terminates.) After the vector table contents are saved, the application must store the address of its programmed function into the vector table entry (overwriting the previous contents). You must be careful to replace only the address portion of the jump instruction and to put the address bytes in the proper order. # A sample code sequence for patching (using Z80-A assembly language): ## Example | | .z80 | | | |--------|----------|----------------------------------------|------------------------------------------------| | Secvec | equ | 0f048h | ;accessible 1-second interrupt vector | | Commrm | equ | 0c000h | start of common memory; | | Syspio | equ | 1ch | ;system pio data | | Banksw | equ | 7 | ;bank switch bit | | | aseg | | | | | org | 100h | | | ; | Initial | ization | | | ; | | | | | Start: | ld | hl,(6) | ;get highest available address under bdos | | | ld | de,usrrou + usrsiz | | | | or | <b>a</b> . | | | | sbc | hl,de | ;if end of driver > highest available address | | | jp | c,erext | ;then exit with error message | | | ld | hl,usrst | ;if there is enough space, move user's routine | | | ld | de,commrm | ;to common memory. | | | ld | bc,usrsiz | | | | ldir | | | | | call | swap | ;swap clock vector with value at swpvec | | ; | Now th | ne accessible 1-second | interrupt has been changed | | ; | to jum | p to the routine contai | ned in the application program. | | ; | The rea | mainder of the applica | tion program would be here branching | | ; | to the e | exit routine when it is | time to go back to the operating | | ; | system | ı <b>.</b> | | | ; | | | | | | | .*********** | ****** | | | | ; | • | | | | ;* Your Progra | am goes here * | | | | ; * | • | | | | ,************************************* | ******** | | ; | On exit | t, swap clock vector ag | ain to restore original value. | | ; | | _ | | | | | | | ;swap vectors back ;return to operating system swap 0 call jp Exit: .280 | TO .4 | 1.1 | 1 | | |---------|----------|--------------------------|---------------------------------------------| | Erext: | ld | de,ermsg | ;give error message | | | ld<br>,, | c,9 | print string function | | | call | 5 | | | | jp | 0 | | | Usrst | equ | \$ | | | Obibe | cqu | Ψ | | | | .phase | commrm | | | ; | This rot | atine is executed as p | art of the 1-second interrupt | | ; | service | routine. It is possible | e for the CRT bank to be | | ; | enabled | l; this routine forces t | he RAM bank to be selected. | | ; | Also, be | cause this is execute | d as part of an interrupt service | | ; | routine | , the interrupts do no | t need to be disabled during bank | | ; | switchi | ng. | | | ; | | | | | Usrrou: | in | a,(syspio) | ;read current value of system port | | | push | af | ;& save current value away | | | res | banksw,a | force bank switch to ram bank | | | out | (syspio),a | | | | ld | hl,(clkval) | ;get current value of clkval | | | inc | hl | ;increment & save new value | | | ld | (clkval),hl | | | | ld | hl,(swpvec) | ;hl = previous address of clock vector | | | pop | af | get previous value of system port | | | out | (syspio),a | & restore it | | | jp | (hl) | ;instead of returning so clock routines can | | | | | ;be chained | | | .dephas | Δ | | | | .ucpnus | | | | Usrsiz | equ | \$-usrst | | | | | | | | ; | Swap ac | ddress at location Sw | pvec with address in jump vector | | ; | | | | | Swap: | ld | hl,secvec+1 | ;point hl to one second vector | | | ld | bc,(swpvec) | ;bc = address new value for clock vector | | | di | | ;disable interrupts while changing vector | | | ld | e,(hl) | | | | ld | (hl),c | | | | inc | hl | | | | ld | d,(hl) | | ld (hl),b ;Clock vector = users Clock routine ld (swpvec),de ;Save original vector for exit ei ;interrupts ok now ret dw 0 ;Flag to be checked by program defw userou ;Save system's 1-second vector here for exit Ermsg: db 'Not enough Space in common memory for program\$' end Clkval: Swpvec: ## Accessible 1-second interrupt Entry Point: F048H Function(s): This exit point is called by the real time clock interrupt service routine once each second. This user-programmed function <u>must</u> follow the rules of interrupt service processing. Only registers HL and AF may be used. Any other registers must be saved/restored on the five level stack provided. The address of your 1-second interrupt processing routine must be patched at F049-F04A. Your routine should terminate with a jump to the address that was in this vector table entry (F049-F04A) prior to patching. Currently, this function simply returns. Arguments: HL = 16-bit seconds counter Value(s) Returned: N/A Registers Saved: The service routine must preserve all registers Errors Returned: N/A # Processing While I/O Pending Entry Point: F066H Function(s): This exit point is called by SIOIN, SIOOUT, KBDIN, and by the WD1797 and SA1403 disk interrupts. drivers when an I/O request cannot be satisfied because the device is busy or not ready. It provides the capability of performing other activities while waiting for I/O. This entry must function as an interrupt service routine. That is, it must: switch to a local stack (no system stack space may be used), save ALL modified registers (including flag register), perform its function, restore all saved registers, and enable The address of the idle processing routine must be patched at F067- F068. (When complete, the idle processing routine should jump to the contents of the vector table entry, F067-F068, prior to patching. This has effect of chaining all idle processors together and ensures that each one has an opportunity to execute.) The original contents of this vector should be restored when the application completes. Currently this function simply returns. Arguments: N/A N/A Value(s) Returned: You must save all registers Registers Saved: Errors Returned: N/A ## **Soft Error Recording** **Entry Point:** F069H Function(s): This exit point is called by the WD1797 and SA1403 disk drivers when a soft error occurs. It provides you with the opportunity to record and/or process occurrences of soft errors. The address of your soft error processing routine must be patched at F06A-F06B. The address of the idle processing routine must be patched at F067- F068. (When complete, the idle processing routine should jump to the contents of the vector table entry, F067-F068, prior to patching. This has the effect of chaining all idle processors together and ensures that each one has an opportunity to execute.) The original contents of this vector must be restored when the application completes. Currently this entry returns a non-zero condition Arguments: For WD1797: HL = address of Physical Driver Request Block (for Xadyr) (B) = current retry down counter For SA1403: HL = address of Physical Driver Request Block (for Xqdvr) command block + 1 (B) = current retry down counter Value(s) to be Returned by You: (B) = number of retries desired If (B) = 1 (no more retries) (A) = 00 and Z(ero) Flag Set no error returned to CP/M = FF and Z(ero) Flag Reset FF and Z(ero) Flag Reset error returned to CP/M Currently, (B) is unchanged (A) = FF and Z(ero) Flag is Reset Registers Saved: Errors Returned: All except AF None #### Miscellaneous Functions Other Monitor entries are COLD which provides a software reset and WARM which is an exit point from the system. GETSEL will return the address of the logical-to-physical disk mapping table. DAYTIM returns the address of the timer variables. CONFIG returns the system configuration. SSP will initiate a screen print. ## **Cold Start** **Entry Point:** F000H Function(s): This entry point may be called at any time to cause a Software Reset. The system is reloaded from ROM and all I/O devices are re-initialized. Arguments: None None Value(s) Returned: Registers Saved: SP. HL. (SP) are saved at FFEO in RAM Errors Returned: No Return ## **Warm Start** **Entry Point:** F003H Function(s): This system exit point is called by the keyboard interrupt service routine when <CTRL> + <ESC> is touched. When executing the power-on commands, (Typewriter, Host Terminal, etc.), this exit point is set to the address of the Command Processor Line Scanner. Thus, <CTRL> + <ESC> is used to exit the various command processors. When the L(oad) command enters the boot loader, it directs the exit point to the Cold Start entry point. This causes <CTRL> + <ESC> to act similar to pressing the RESET button. You may load the address of your own software-abort routine into locations F004-F005. This routine must be located in the upper 16k of RAM (above C000). Only the HL, BC, and AF registers are available for use if the routine RETurns to the keyboard interrupt driver. Any other registers used must be saved. Only five levels of stack space are available. All rules of interrupt service processing must be followed. For example, no calls may be made to the system I/O drivers. Typically, a routine will set an abort flag that is monitored by the application and then exit with a return instruction. When the application sees the flag set, it should proceed with its own abort sequence. To disable this function, simply patch a return instruction at location F003 (overwriting the jump operation code). The original contents of this vector should be restored when your application completes. Arauments: N/A Value(s) Returned: Registers Saved: N/A N/A Errors Returned: N/A ## **Get Disk Map Table Address** **Entry Point:** F036H Function(s): The address of the Logical to Physical disk mapping table (see Appendix C) is returned in registers HL. If register H is non-zero on entry, the table address is stored in the two-byte variable pointed to by HL. This allows easy access by high level programming languages. The table consists of two sections. The first section contains sixteen two byte entries - one for each logical CP/M drive. The first byte of each pair indicates which physical disk driver to activate for an I/O request; the second byte specifies which physical unit within that physical driver to access. These byte pairs may be carefully rearranged with other byte pairs in the table. They may even be removed or overwritten, but they must not be duplicated elsewhere in the table. The second part of the table holds the addresses of eight physical disk driver entry points. By convention, driver number 0 always returns an error. It is used to force Select Errors on undefined logical drives. Driver number 1 controls all of the standard disk systems. Additional virtual disk drivers linked into this table, with appropriate values in the first section, may be accessed through the normal CP/M disk I/O facilities. Arguments: H = - OR - HL HL = address of integer variable where the disk map table address will be stored Value(s) Returned: address of the disk map table If the H register was non-zero on entry, the address of the disk map table will also have been stored in the address contained in HL on entry to GETSEL. Registers Saved: None Errors Returned: None ## **Get Address of Time-of-Day Variables** **Entry Point:** F039H Function(s): This entry is used to gain access to the timer variables maintained by the system. As in GETSEL, if register H is non-zero on entry, it is used as the address of an integer variable in which to store the result. In any case, HL holds the timer address on exit. The return address points into the following structure (numbers are decimal): Milsec: ds 2 :Location incremented by CTC1 interrupt (if enabled) ds 2 :(unused) Ticker: ds 2 Increments once per second Steprt: ds 1 :WD1797 step rate Motor: ds 1 ;Disk Motor/Select timeout (1Hz) HL → Dav: Month: ds 1 :01-31 ds 1 :01-12 Year. Hour: ds 1 :80-99 :00-23 ds 1 Minute: ds 1 :00-59 Second: ds 1 :00-59 ds 80 Linbuf: :Line buffer referred to in **FASTCRT and CRTLDIR** Arguments: Н = - OR - ٥ HL address of integer variable where the address of the time of day variables will be stored Value(s) Returned: HL address of the time of day variables If the H register was non-zero on entry, the address of the time of day variables will also have been stored in the addressed contained in HL on entry to DAYTIM. Registers Saved: None Errors Returned: None ## **Get Configuration Status** Entry Point: F03CH Function(s): This entry point returns current configuration. This function should be used to get the system Revision level and status information such as: what kind of disk system is present, the current keyboard mask state, or other variable information concerning the 820-II or 16/8. Only four status bits are currently defined (all zero bits are reserved for system use), but more may be added in later releases. = 0 Arguments: Н -OR- HL = address of integer variable where the address of the configuration status will be stored = dvvvvvvv (Revision level)\*100 - 400 Value(s) Returned: Н > = 1 means CP/M-86 is loaded d = 0 means CP/M-86 is not loaded For example: vvvvvv is ROM Version # -400: i.e., 4.03 ROM returns the value 3 in bits 0-6 Monitor level 4.03 (H) = (4.03)\*100-400 =3 = kddfl 000 where: 1 7-bit keyboard data k 1 8-bit keyboard data Rigid disk not present dd 00 = 10 8" 8-megabyte rigid disk present f 8" floppies present 5½" floppies present = 1 L Low Profile keyboard present ASCII keyboard present = (revision level)\*100 - 400 Н = configuration status L > If the H register was non-zero on entry, the configuration status will also have been stored in the address. contained in HL on entry to CONFIG. Registers Saved: None Errors Returned: None #### **Start Screen Print** **Entry Point:** F045H Function(s): This entry point initiates background screen print. Don't change the screen during printing or the printout won't be what you expect. Arauments: None Value(s) Returned: Registers Saved: None None **Errors Returned:** None # **Documented System Storage and Structures** The documented system variables and structures include keyboard FIFO, available memory pointers, disk mapping and driver selection tables, disk command block and timer and clock variables. A listing of each of these variables and structures is provided in Appendix C. #### SYSTEM DISPLAY ## **Modes of Operation** The display has two modes of operation, Display Character Mode and Graphics Mode. The CPU Board is equipped with a CRT display controller for use with a video monitor as the system console output device. The refresh memory for the CRT is bank-switchable from the system's 64k byte memory space and includes a hardware address translation circuit for high speed scrolling. The Character Mode contains an output driver routine for the CRT that emulates the characteristics of a typical stand-alone video terminal. All character codes between 00 and 7F hex are directly displayable on the screen. Each character is formed in a 5x8 dot matrix. When the most significant bit of the character is set to "1", the attribute function is turned ON. One of three attributes may be chosen: Blink, Low Intensity, or Inverse Video. Only one attribute can be displayed at a time, and only those characters with the most significant bit set will show the selected attribute To display an up arrow (09h) with an attribute, output a 09h character using the CP/M function "Direct I/O" #6. A low-intensity up arrow (89h) is displayed like all the other codes described above. For more information on the CRT, see pages 15 to 17. # **Text Character set** | | 1 | | | | | | | LEAST | SIGNIE | FICANT I | DIGIT | | | | | | | |-------------|-------|-----|---|------|-----|----|-----|-------|----------|----------|-------|----|-----|-----|---|----------------|---| | | HEX - | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | Ĥ | В | C | D | E | F | | Γ | 0 | | ¢ | • | • | 9 | 1/2 | ¥ | <u>:</u> | e | + | + | + | + " | ī | 0 | ÷ | | l | 1., | 3 | 2 | ٥, . | - | ¥ | 11 | ÷ | Ц | ŧ | ii | ęl | * | G | H | H <sub>1</sub> | 9 | | DIGIT | 2 | | 1 | 5 | # | \$ | 7, | 8. | 1 | . ( | `) | * | + | ) | - | | 1 | | SIGNIFICANT | 3 | 0 | 1 | 2 | 3 | 4 | 5 | , 6 | 7 | 8 | 9 | | j | < | = | > | ? | | T SIGNI | 4 | (8) | Ĥ | В | C | D | Ε | F | G | Н | I | J | K - | L | М | · N | 0 | | MOST | 5 | Φ. | Q | R | S | T | U | V | М | Х | Υ | Z | [ | \ | ] | ^ . | - | | | 6 | ` | à | Ь | 0 | d | е | f | 9 | h | i | j | k | 1 | m | n | 0 | | | 7 | ۵. | q | r | 'on | t | u | V | W | Х | y | Z | { | ı | } | - | H | # **Graphics Character Set** | | 1 | | | | | | | LEAST | SIGNIF | ICANT I | DIGIT | | | | | | | |-------------|-------|--------|---|---|---|---|---|-------|--------|---------|-------|---|---|---|---|---|---| | | HEX - | Ø | 1 | 2 | 3 | 4 | 5 | -6 | 7 | 8 | 9 | A | В | C | D | Ε | F | | | 0 | | | | | | | | | | | | | | | | | | ı | 1 | | | | Ţ | | | | | | 5 | | 7 | | | | | | DIGIT | 2 | "<br>· | | | | | | | | | | | 1 | | | | | | SIGNIFICANT | 3 | $\Box$ | | | | | | H | | | | | | | | | | | | 4 | | | | | | | | | | | | | | | | | | MOST | 5 | | | | | | | 7 | H | | H. | | | | | | | | | 6 | | | | | | | | | | | | | | | | | | | 7- | | | | | | | | F | | | | - | | E | | | # **Programming Considerations** ## **Display Character Mode** New characters are stored on the screen at the locations occupied by the cursor. The cursor is then moved one space to the right. If the cursor is positioned at a screen location occupied by a non-blinking character, the presence of the cursor will be indicated by making the overlaid character blink. If a line feed (0Ah = LF) is output when the cursor is on the bottom line of the screen, the entire display is scrolled up one line and a new blank line is created on the bottom. If the displayed character is output when the cursor is in the right-most column of the screen, an automatic carriage return and line feed are generated. All characters codes between 20h and 7Fh are directly displayable on the screen. All character codes between 00h and 1Fh are interpreted as control characters. The video display may be controlled by these control codes and escape sequences to perform screen manipulations. ## Display Manipulation through CTRL codes ## **CONTROL SEQUENCES** | Code<br>(hex) | <u>Function</u> | |---------------|----------------------------------------| | 05 | Set cursor character as next character | | 06 | Restore previous attribute mode | | 07 | Bell | | 08 | Backspace or cursor left | | 09 | Horizontal tab | | 0A | Line feed or cursor down | | OB | Cursor up | | 0C | Cursor right | | 0D | Carriage return | | 11 | Clear to end of screen | | 18 | Clear to end of line | | 1A | Clear screen and home cursor | | 1B | Escape | | 1 E | Home | | 1F | Display next character direct | #### DISPLAY CODE DESCRIPTION The display control codes of the 820-II and 16/8 PCs are downwardly compatible with the original 820 with several advanced editing features added. The following summarizes the effect of each of the display codes. ## **CONTROL CODES** | 05h | Set cursor character. After receiving this code, the next character is interpreted as the code to be used as the cursor. Only codes between 0 and 20 hex will be accepted. The normal cursor code is 02h. The "space" character (20h) is a special case used to eliminate the | |-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | display of a cursor. This is useful for displaying a screen without a large, visibly-moving cursor for special effects. | | 06h | Restore previous attribute mode. Whenever the attribute mode is changed, the previous mode is remembered. In this way, a program can set its own attributes for unique display requirements, and then restore the mode that was in effect before the program was run. Since the user may set a default attribute mode with CP/M's CONFIGUR program, it is desirable to restore the default mode after if has been temporarily changed. | | 07h | Bell. This code will sound a short tone to alert the operator. | | 08h | Backspace or cursor left. Moves the cursor one column position to the left without altering the character under the cursor. | | 09h | Horizontal tab. Moves the cursor to the next tab stop. Tabs are pre-set for every eighth column. | | 0Ah | Line feed or cursor down. Moves the cursor down one row without affecting the current column position. | | 0Bh | Cursor up. Moves the cursor up one row without affecting the current column position. | | 0Ch | Cursor right. Moves the cursor one column position to the right without altering the character under the cursor. | 0Dh Carriage return. Returns the cursor to the first column position of the current row. 11h Clear to the end of the screen. Changes all characters to spaces beginning with the current cursor position to the end of the screen. The position of the cursor remains unchanged. Characters before the cursor remain unchanged. 18h Clear to the end of line. Changes all characters from the current cursor position to the end of the current line to spaces. The cursor position is unchanged. Characters before the cursor are unchanged. 1Ah Clear screen and home cursor. Clears the entire screen and places the cursor in the home position (column 0, row 0). 1Bh **Escape**. The first character of an escape sequence. These sequences are explained on this page and the next. 1Eh Home Cursor. Moves the cursor to the home position (column 0, row 0) without otherwise affecting the screen display. 1Fh Display next character direct. After receiving this code, the next character is displayed directly on the screen without interpreting it as a special display function code. This code is usually used to display control characters that are not normally displayed by the ROSR. # **Display Manipulation through ESC codes** Listed below is a summary table of the multi-character sequences used to manipulate the display. Each sequence's effect is more fully described in the text following the table. Note that all of these sequences are all preceded by the escape character 1Bh. ## **ESCAPE SEQUENCES** | <esc></esc> | <u>Function</u> | |-------------|----------------------------------| | followed by | | | 28h | Disable attribute display | | 29h | Enable attribute display | | 2Ah | Clear screen | | 30h | Pass 7-bit keyboard data | | 31h | Pass 8-bit keyboard data | | 34h | Set blink attribute mode | | 35h | Set graphics attribute mode | | 36h | Set blink attribute mode | | 37h | Set inverse video attribute mode | | 38h | Set low intensity attribute mode | | 3Dh | XY cursor position lead-in | | 45h | Line insert | | 51h | Character insert | | 52h | Line delete | | 57h | Character delete | | | | | 28h | Disable attribute display. Will cause all succeeding | |-----|-----------------------------------------------------------------| | | characters displayed on the screen to unconditionally | | | have the upper bit reset, so that the selected attribute | | | mode will not be displayed. Display will continue in this | | | mode until changed by the <esc> 29h sequence code.</esc> | | 29h | Enable attribute display. Setting this mode will cause all | | | following characters displayed on the screen to | | | unconditionally have the upper bit set, thereby causing | | | the selected attribute mode to be displayed. This mode | | | will continue in effect until the <esc> 28h code disables</esc> | | | it. | 2Ah Clear screen. This function clears the screen to spaces with the cursor at the home position. 30h Pass only 7 bits of data from the keyboard. This is the default setting at power-on (or reset), and is compatible with the 820. This mode of operation does not allow many of the unique codes generated by the keyboard to be used by applications software. A corollary effect is also automatically engaged in the 7-bit mode. Only 7 bits of data will be passed to the video display screen. ASCII characters with the upper bit set will normally cause one of the four attributes to be displayed (blink, lowlight, inverse video, or graphics characters). The <ESC> 30h code prevents this sometimes undesired feature. 31h Pass the upper bit of data from the keyboard. Using the <CTRL> key along with certain keys will set the upper (eighth) bit of that key, allowing these codes to be processed as special function keys by applications programs. The following 30 keys produce unique codes. | Ctrl + Key | Numeric Pad | |-------------|-------------| | | (hex) | | 0 | В0 | | 1 | B1 | | 2 | B2 | | 3 | B2 | | 4 | В4 | | 5 | B5 | | 6 | В6 | | 7 | В7 | | 8 | B8 | | 9 | В9 | | period | AE | | plus sign | AB | | minus sign | AD | | up arrow | 81 | | down arrow | 82 | | right arrow | 83 | | left arrow | 84 | | line feed | 8A | | DEL | FF Reserved | | | | | Ctrl + Key | Main Keyl | ooard | |------------|-----------|----------| | | (hex) | | | 1 | 91 | · | | 2 | 92 | | | 3 | 93 | | | 4 | 94 | | | 5 | 95 | | | 6 | 96 | | | 7 | 97 | | | 8 | 98 | | | 9 | 99 | | | = | 9A | | | backspace | 88 | Reserved | | tab | 89 | | | return | 8D | Reserved | ## 34h or 36h Set blinking attribute mode. This code will not actually begin displaying blinking characters on the screen. Note: All the "set attribute mode" code sequences work in the same manner. An < ESC> 29h sequence is used to enable the display of the attribute characters, or storing characters on the screen with the upper bit set, as described above. Thus, any of the different attribute modes can be selected without affecting the screen display as long as there are NO characters on the screen with the upper bit set. If there ARE characters displayed on the screen with upper bit set, changing attribute modes will cause an IMMEDIATE change in the way the upper bit characters are displayed, depending on the attribute mode selected. | | attribute mode selected. | | | | | | |-----|------------------------------------------------------------|--|--|--|--|--| | 35h | Set graphic character attribute mode. See Note: above. | | | | | | | 37h | Set inverse video attribute mode. See Note: above. | | | | | | | 38h | Set low intensity attribute mode. See Note: above. | | | | | | | | It should be noted that low intensity is the default | | | | | | | | attribute mode. The CP/M CONFIGUR program allows | | | | | | | | you to select your own default attribute mode. | | | | | | | 3Dh | Position the cursor to the location indicated by the | | | | | | | | following two row and column codes. The "home" | | | | | | | | position is designated as row 0, column 0. An offset of 20 | | | | | | | | | | | | | | hex must be added to the X and Y position codes. The positioning formula is: ESC = (X + 20h) (Y + 20h) where legal X (row) values are between 0 and 23 and legal Y (column) values are between 0 and 79. Line insert. Will move the entire line on which the cursor resides down one line, filling the cursor line with spaces, and causing the line on the bottom of the screen to disappear. (It is actually moved to the internal command line buffer for the monitor so that applications programs wishing to preserve the bottom line are able to do so.) The actual position of the cursor will not change. Character insert. Will insert a space at the current cursor position, causing the character under the cursor and all characters after the cursor to be shifted one position to the right. The last character on the line will disappear. The cursor position will remain unchanged and the character under the cursor will be the inserted space. No other lines will be affected. The character that was "lost" at the end of the line will actually be placed into the A register and the HL register will be pointing to the current cursor position upon return from the Fast CRT jump vector entry point (0F00Fh) so that applications programs can preserve this character. Line delete. Similar to the line insert function except that the line on which the cursor resides will be deleted from the screen (and moved to the line buffer as described above), and all lines below it will be moved up one line. The position of the cursor will be unchanged. Character delete. This function will delete the character under the cursor and cause all characters to the right of the cursor to move one position to the left. The last character position of the line will be replaced by a space. The cursor position will be unchanged and the character under the cursor will now be the character that was to the immediate right of the cursor before the character delete operation. The deleted character will be placed into the A register and the HL register will be pointing to the current cursor position upon return from the Fast CRT jump vector entry point (0F00Fh) so that applications programs can preserve this character. 45h 51h 52h 57h 54h Clear to End of Line. Changes all characters from the current cursor position to the end of the current line to current cursor position to the end of the current line to spaces. The cursor position is unchanged. Characters before the cursor position are unchanged. 59h Clear to End of Screen. Changes all characters to spaces beginning with the current cursor position to the end of the screen. The position of the cursor remains the screen. The position of the cursor remains unchanged. Characters before the cursor position remain unchanged. ## **Notes** ## **ASCII Keyboard** Main Key Array: 50 50 keys plus 3 modifier keys (Alpha Lock, Shift, and Control) Numeric Key Pad: 20 keys to the right of the main array Cursor Keys: 4 keys on numeric key pad Interface U.S. ASCII-Coded Parallel Interface Engraving: U.S. Standard ASCII Keycaps The electronic keyboard uses a standard 96-character ASCII keyboard. A ten-key numeric pad is included for typing statistical material. Parallel output is standard. A list of the output codes (in hex) for the Unshifted, Shifted, and CTRL + sequences for this keyboard begins on page 198. ## **Auto-Repeat** When an auto-repeat key is pressed, the following will be generated: - internal code output - pause of 0.5 ( ± 0.1) seconds - repeat code output at rate of 16 ( ± 1) characters per second - code output terminates immediately upon release of key | Repeat Keys | Keystation | |-------------|------------| | - (minus) | 12 | | = (equal) | 13 | | backspace | 14 | | delete | 15 | | return | 50 | | line feed | 51 | | up arrow | 52 | | × | 58 | | . (period) | 65 | | / (slash) | 66 | | left arrow | 68 | | down arrow | 69 | | right arrow | 70 | | space bar | 74 | | | | # **Function Key Priority** When more than one function key is pressed, the output will use the function key with the highest priority. The priority of the function keys in descending order is: Shift, CTRL, Lock, Unshifted. ## **Function Key Uses** The Shift function (keystations 56 and 57) causes production of shift-keycodes. Affected keystations are: | Key | Keystation | Key | Keystation | |-----------|------------|----------------|------------| | 1 | 2 | A | 39 | | 2 | 3 | <b>S</b> - | 40 | | 3 | 4 | D | 41 | | 4 | 5 | 4 <b>F</b> | 42 | | 5 | 6 | G | 43 | | 6 | 7 | Н | 44 | | 7 | 8 | j | 45 | | 8 | 9 | K | 46 | | 9 | 10 | L | 47 | | 0 | 11 | ; (semi-colon) | 48 | | - (minus) | 12 | ' (apostrophe) | 49 | | = (equal) | 13 | | | | • | | Z | 57 | | Q | 21 | X | 58 | | W | 22 | C | 59 | | E | 23 | V | 60 | | R | 24 | В | 61 | | T | 25 | N | 62 | | Υ | 26 | M | 63 | | U | 27 | , (comma) | 64 | | 1 | 28 | . (period) | 65 | | 0 | 29 | ِ / (slash) | 66 | | Р | 30 | | | | [ | 31 | | | | •] | 32 | | | ## Alpha Lock The Alpha Lock key (keystation 38) mechanically locks in the down position when first pressed and releases when pressed a second time. The Alpha Lock key activates the Shift key function for the keystations listed below. | Key | Keystation | Key | Keystation | |-----|------------|-----|------------| | Q | 21 | F | 42 | | w | 22 | G | 43 | | E | 23 | Н | 44 | | R | 24 | J | 45 | | T | 25 | K | 46 | | Υ | 26 | Ł | 47 | | U | 27 | Z | 57 | | ı | 28 | X | 58 | | 0 | 29 | C | 59 | | Р | 30 | V | 60 | | Α | 39 | В | 61 | | S | 40 | N | 62 | | D | 41 | M | 63 | #### CTRL The CTRL key (keystations 73 and 75) allows almost every key on the board to have a second or third output code. The CTRL key is used in conjunction with the alphabetic keys as function keys and to access the complete set of ASCII codes. The chart beginning on the next page lists the output codes in hex for the Unshifted, Shifted, and CTRL + sequences for the ASCII keyboard. Bolding indicates a Reserved key. Keyboards 197 | Key | # | Unshifted | Shifted | CTRL + | |-----------------|----|-----------|---------|--------| | Help | 01 | 1E | 1E | 9E | | 1 | 02 | 31 | 21 | 91 | | 2 | 03 | 32 | 40 | 92 | | 3 | 04 | 33 | 23 | 93 | | 4 | 05 | 34 | 24 | 94 | | 5 | 06 | 35 | 25 | 95 | | 6 | 07 | 36 | 5E | 96 | | 7 | 08 | 37 | 26 | 97 | | 8 | 09 | 38 | 2A | 98 | | 9 | 10 | 39 | 28 | 99 | | 0 | 11 | 30 | 29 | 90 | | - (Minus) | 12 | 2D | 5F | 1F | | = (Equal) | 13 | 3D | 2B | 9A | | Backspace | 14 | 08 | 08 | 88 | | Del | 15 | 7F | 7F | FF | | - (Minus - pad) | 16 | 2D | 2D | AD | | 7 (pad) | 17 | 37 | 37 | В7 | | 8 (pad) | 18 | 38 | 38 | В8 | | 9 (pad) | 19 | 39 | 39 | В9 | | Tab | 20 | 09 | 09 | 89 | | | | | | | | q | 21 | 71 | . 51 | 11 | | w | 22 | 77 | 57 | 17 | | e | 23 | 65 | 45 | 05 | | r | 24 | 72 | 52 | 12 | | t | 25 | 74 | 54 | 14 | | <b>y</b> . | 26 | 79 | 59 | 19 | | u | 27 | 75 | 55 | 15 | | i | 28 | 69 | 49 | 09 | | 0 | 29 | 6F | 4F | OF , | | p | 30 | 70 | 50 | 10 | | [ | 31 | 5B | 7B | 1B | | ] | 32 | 5D | 7D | 1D | | ESC | 33 | 1B | 1B | 9B | | + (Plus - pad) | 34 | 2B | 2B | AB | | 4 (pad) | 35 | 34 | 34 | B4 | | 5 (pad) | 36 | 35 | 35 | B5 | | 6 (pad) | 37 | 36 | 36 | В6 | | Lock | 38 | | | | | a | 39 | 61 | 41 | 01 | | <b>s</b> | 40 | 73 | 53 | 13 | | Key | # | Unshifted | Shifted | CTRL + | |------------------|----|------------|---------|--------| | d | 41 | 64 | 44 | 04 | | f | 42 | 66 | 46 | 06 | | | 43 | 67 | 47 | 07 | | g<br>h | 44 | 68 | 48 | 08 | | j | 45 | 6A | 4A | 0A | | k | 46 | 6B | 4B | 0В | | ï | 47 | 6C | 4C | 0C | | ; (Semi Colon) | 48 | 3B | 3A | 7E | | (Apostrophe) | 49 | 27 | 22 | 60 | | Return | 50 | 0D | 0D | 8D | | Line Feed | 51 | 0 <b>A</b> | 0A | 8A | | Up Arrow | 52 | 81 | 81 | 01 | | 1 | 53 | 31 | 31 | B1 | | 2 | 54 | 32 | 32 | B2 | | 3 | 55 | 33 | 33 | В3 | | Left Shift | 56 | | | | | Z | 57 | 7A | 5A | 1A | | x | 58 | 78 | 58 | 18 | | c | 59 | 63 | 43 | 03 | | <b>V</b> | 60 | 76 | 56 | 16 | | b | 61 | 62 | 42 | 02 | | n | 62 | . 6E | 4E | 0E | | m | 63 | 6D | 4D | 0D | | . (Comma) | 64 | 2C | 3C | 1C | | . (Period) | 65 | 2E | 3E | 7C | | / (Slash) | 66 | 2F | 3F | 5C | | Right Shift | 67 | | | | | Left Arrow | 68 | 84 | 84 | 04 | | Down Arrow | 69 | 82 | 82 | . 02 | | Right Arrow | 70 | 83 | 83 | 03 | | 0 | 71 | 30 | 30 | В0 | | . (Period - pad) | 72 | 2E | 2E | ΑE | | Left CTRL | 73 | | | | | Space | 74 | 20 | 20 | 00 | | Right CTRL | 75 | | | | | | | | | | --- = Function key Bolding = Reserved key ## Low Profile Keyboard Main Key Array: 50 keys plus 3 modifier keys (Alpha Lock, Shift, and Control) Numeric Key Pad: 18 keys to the right of the main array Function Keys 12 keys above main array key pad labelled F1 through F12 Cursor Keys: 5 keys to the right of the main array including Home key Other Keys: 7 keys to the right of main array such as Help, Accept, Delete, etc. Interface U.S. ASCII-Coded Parallel Interface Engraving: U.S. Standard ASCII Keycaps The electronic keyboard uses 97 key positions, follows the standard 96-character ASCII keyboard layout, and has one level of position-encoding. All keys generate their own unique position code on both the up and downstroke. Two bytes of data, command status and position, are output for each unique key motion. Parallel output is standard. The standard output is two bytes of serial data. (A third byte will be used for mouse data.) Each byte is composed of a start bit, eight data bits, and a stop bit. The bytes are spaced 700 ( $\pm$ 150) microseconds apart. The first byte, or command status word, defines the status of the keyboard and the meaning of the data in the next byte. The second byte, or position word number one, defines the position of the key. If mouse data is present, this byte defines the X movement of the mouse. The third byte, or position word number two, defines the Y movement of the mouse. Note that the third byte is present only for mouse data. #### **Data Format** Command Status Word Bit 0 Alpha Lock Bit 1 Shift - Left or Right Bit 2 Control - Left or Right Bit 3 Mouse Data Bit 4 -X if set; + X or 0 if not set Bit 5 -Y if set; + Y or 0 if not set Bit 5 -Y if set; +Y or 0 if not set Bit 6 Up/Downstroke (up = set) Bit 7 Always Set (indicates command staus word) **Data Format** continued Position Word Number One Bit 0-6 XY position or mouse travel (ΔX Magnitude) Bit 7 Never Set - Indicates Data Word Position Word Number Two (Only if mouse data) Bit 0-6 Mouse Travel ( $\Delta Y$ Magnitude) Bit 7 Never Set - Indicates Data Word ## Keyboard Handler The 16/8 operating system comes standard with the ASCII keyboard handler. This handler is not compatible with the optional position-encoded Low Profile Keyboard. The position-encoded keyboard handler and translation tables are located in the fourth ROM. The 16/8 system, when booting, identifies the position-encoded keyboard by checking the presence of the fourth ROM. If detected, a subroutine call is made to the fourth ROM to move the position-encoded keyboard handler and translation tables to RAM. The position-encoded keyboard handler inputs the keyboard command bytes and key-station codes. The command bytes identify the required action to be taken by the handler, and the valid keystation codes are used to index into the translation tables to recover the translated hexadecimal codes. The position-encoded handler returns the translated code to the ASCII keyboard handler to queue. The keyboard handler has three keyboard translation tables. Each table consisits of 102 decimal bytes. The tables are RAM resident, and define the unshifted, shifted, and control + sequence states. The output codes for these three states begin on the next page (bolding indicates a Reserved key). The position-encoded keyboard handler listing can be found in Appendix J. The exception tables identify the repeat keys, inhibited keys, shift-lock status, additional alpha lock codes, and mouse status. The mouse interrupt handler translates the mouse movement into display coordinates. The repeat key interrupt handler provides the timing for the repeat key functions. The default keyboard table recovery restores the ROM keyboard tables to RAM. The ROM tables contain only the U.S. ASCII translation codes. Keyboards 201 | Key | # | Unshifted | Shifted | CTRL 4 | |----------------|----|-----------|---------|--------| | ESC | 01 | 1B | 1B | 9B | | 1 | 02 | 31 | 21 | 91 | | 2 | 03 | 32 | 40 | 92 | | <b>3</b> | 04 | 33 | 23 | 93 | | 4 | 05 | 34 | 24 | 94 | | 5 | 06 | 35 | 25 | 95 | | 6 | 07 | 36 | 5E | 96 | | 7 | 08 | 37 | 26 | 97 | | 8 | 09 | 38 | 2A | 98 | | 9 | 10 | 39 | 28 | 99 | | 0 | 11 | 30 | 29 | 90 | | - (Minus) | 12 | 2D | 5F | 1F | | = (Equal) | 13 | 3D | 2B | 9A | | Backspace | 14 | 08 | 80 | 88 | | Tab | 15 | 09 | 09 | 89 | | q | 16 | 71 | 51 | 11 | | w | 17 | 77 | 57 | - 17 | | e | 18 | 65 | 45 | 05 | | r | 19 | 72 | 52 | 12 | | t | 20 | 74 | 54 | 14 | | у | 21 | 79 | 59 | 19 | | u | 22 | 75 | 55 | 15 | | i | 23 | 69 | 49 | 09 | | 0 | 24 | 6F | 4F | 0F | | р | 25 | 70 | 50 | 10 | | [ | 26 | 5B | 7B | 1B | | 1 | 27 | 5D | 7D | 1D | | Return | 28 | 0D | 0D | 8D | | Left CTRL | 29 | | | | | a | 30 | 61 | 41 | 01 | | S | 31 | 73 | 53 | 13 | | d | 32 | 64 | 44 | 04 | | f | 33 | 66 | 46 | 06 | | g | 34 | 67 | 47 | 07 | | h | 35 | 68 | 48 | 80 | | j | 36 | 6A | 4A | 0A | | k | 37 | 6B | 4B | OB | | 1 | 38 | 6C | 4C | 0C | | ; (Semi Colon) | 39 | 3B | 3A | 7E | | Key<br>' (Apostrophe) | #<br>40 | Unshifted<br>27 | Shifted<br>22 | CTRL 4 | |-----------------------|---------|-----------------|---------------|------------| | Line Feed | 41 | 0A | 0A | <b>8A</b> | | Left Shift | 42 | | | | | . (Period 10-key) | 43 | 2E | 2E | ΑE | | Z | 44 | 7A | 5A | 1A | | x | 45 | 78 | 58 | 18 | | c | 46 | 63 | 43 | 03 | | V | 47 | 76 | 56 | 16 | | b | 48 | 62 | 42 | 02 | | n · | 49 | <b>6</b> E | 4E | 0E | | m | 50 | 6D | 4D | 0D | | . (Comma) | 51 | 2C | 3C | 1C | | . (Period) | 52 | 2E | 3E | 7C | | / (Slash) | 93 | 2F | 3F | 5C | | Right Shift | 54 | | | | | Help | 55 | 1 E | 1E | 9E | | Right CTRL | 56 | | | | | Space | 57 | 20 | 20 | 00 | | Lock | 58 | | | | | F1 | 59 | F1 | F1 | D1 | | F2 | 60 | F2 | F2 | D2 | | F3 | 61 | F3 | F3 | D3 | | F4 | 62 | F4 | F4 | D4 | | F5 | 63 | F5 | F5 | D5 | | F6 | 64 | F6 | F6 | D6 | | F7 | 65 | F7 | F7 | D7 | | F8 | 66 | F8 | F <b>8</b> | D8 | | F9 | 67 | F9 | F9 | D9 | | F10 | 68 | FA | FA | DA | | F11 | 69 | FB | FB | DB | | F12 | 70 | FC | FC | DC | | 7 | 71 | 37 | 37 | В7 | | 8 | 72 | 38 | 38 | B8 | | 9 | 73 | 39 | 39 | В9 | | , (Comma) | 74 | 2C | 2C | AC | | 4. | 75 | 34 | 34 | В4 | | 5 | 76 | 35 | 35 | <b>B</b> 5 | Keyboards 203 | Key | # | Unshifted | Shifted | CTRL - | |--------------|----|-----------|---------|------------| | 6 | 77 | 36 | 36 | В6 | | Enter | 78 | 0D | 0D | 3D | | 1 | 79 | 31 | 31 | B1 | | 2 | 80 | 32 | 32 | B2 | | 3 | 81 | 33 | 33 | В3 | | 0 | 82 | 30 | 30 | В0 | | Next | 83 | E7 | E7 | <b>C</b> 7 | | Down Arrow | 84 | 82 | 82 | 02 | | Left Arrow | 85 | 84 | 84 | 04 | | Right Arrow | 86 | 83 | 83 | 03 | | Home | 87 | 80 | 80 | 1E | | Up Arrow | 88 | 81 | 81 | 01 | | Prev | 89 | E6 | E6 | C6 | | Accept | 90 | FD | FD | DD | | Del | 91 | 7F | 7F | FF | | + (Plus) | 92 | 2B | 2B | АВ | | - (Minus) | 93 | 2D | 2D | AD | | x (Multiply) | 94 | 2A | 2A | AA | | ÷ (Divide) | 95 | 2F | 2F | AF | | Blank Key | 96 | F0 | F0 | D0 | | Undo | 97 | 18 | 18 | DE | | Mouse: | | | | | | Switch 1 | 98 | 8E | 8E | 8E | | Switch 2 | 99 | 8F | 8F: | 8F | --- = Function key Bolding = Reserved key #### Note: Approximately 1,000 of the first-issued Low Profile keyboards will generate a unique code for the Enter key (10-key pad). These keyboards can be identified by reading the ROM sign-on message when you turn on the display. If your monitor displays a (V13) message you have one of the first 1,000 units and the Enter key output codes are BDh, BDh, and FEh. With (V16) and higher ROM levels, the Enter Key generates the codes listed above. ## **Auto-Repeat** When an auto-repeat key is pressed, the following will be generated: - internal code output - pause of 0.5 ( ± 0.1) seconds - repeat code output at rate of 16 (± 1) characters per second - code output terminates immediately upon release of key | Repeat Keys - (minus) | Keystation | |-----------------------|------------| | = (equal) | 13 | | backspace | 14 | | return | 28 | | line feed | 41 | | x | 45 | | . (period) | 52 | | / (slash) | 53 | | space bar | 57 | | down arrow | 84 | | left arrow | 85 | | right arrow | 86 | | up arrow | 88 | | delete | 91 | # **Function Key Uses** The Shift function (keystations 42 and 54) causes production of shift-key-codes. Since every keystation is position-encoded, almost all keys output a unique hex code. For a complete list, refer to the Low Profile Keyboard Keystation chart beginning on page 202. The Alpha Lock key (keystation 58) locks in the down position when first pressed (the red led light comes on), and releases when pressed again. The Alpha Lock key activates the Shift key function for the keystations listed in the chart on the next page. | Key | Keystation | Key | Keystation | |-----|------------|-----|------------| | Q | 16 | F | 33 | | W | 17 | G | 34 | | E | 18 | Н | 35 | | R | 19 | J | 36 | | Т | 20 | K | 37 | | Υ | 21 | L | 38 | | U | 22 | Z | 44 | | 1 | 23 | X | 45 | | 0 | 24 | C | 46 | | Р | 25 | V | 47 | | Α | 30 | В | 48 | | S | 31 | N | 49 | | D | 32 | M | 50 | The CTRL keys (keystations 73 and 75) allow almost every key on the board to have a second or third output code. The CTRL keys are used in conjunction with the alphabetic keys as function keys and to allow access to the complete set of ASCII codes. ### **Disk Drive Specifications** | | Single<br>Density | Double<br>Density | |----------------------------|-------------------|-------------------| | Capacity | • | - | | Unformatted | 125 k bytes | 250 k bytes | | Formatted | 90 k bytes | 168 k bytes | | Usable | 81 k bytes | 155 k bytes | | Transfer Rate | 125 k bits/sec | 250 k bits/sec | | Latency (average) | 100 Ms | 100 Ms | | Access Time | | | | Track to Track | 20 Ms | 20 Ms | | Average | 275 Ms | 275 Ms | | Settling Time | 20 Ms | 20 Ms | | Rotational Speed | 300 RPM | 300 RPM | | Recording Density | 2768 BPI | 5536 BPI | | Flux Density | 5536 FCI | 5536 FCI | | Track Density | 48 TPI | 48 TPI | | Tracks | 40 | 40 | | R/W Heads | 1 | 1 | | Physical Sectors per track | 18 | 17 | | Bytes per Sector | 128 | 256 | | Encoding Method | FM | MFM | | | | | ### **DC Voltage Requirements** - + 12 V dc ± 5% @1.80A Maximum, 0.9A Typical - + 5 V dc ± 5% @0.70A Maximum, 0.5A Typical ### **Power Dissipation** - 13.3 Watts (45.3 BTU/Hr) Continuous (Typical) - 7.3 Watts (24.9 BTU/Hr) Standby (Typical) ### SA450 (51/4 Double-sided floppy) | | Single<br>Density | Double<br>Density | |----------------------------|-------------------|-------------------| | Capacity | | , | | Unformatted | 250 k bytes | 508 k bytes | | Formatted | 180 k bytes | 338 k bytes | | Usable | 172 k bytes | 322 k bytes | | Transfer Rate | 125 k bits/sec | 250 k bits/sec | | Latency (average) | 100 Ms | 100 Ms | | Access Time | | | | Track to Track | 20 Ms | 20 Ms | | Average | 275 Ms | 275 Ms | | Settling Time | 15 Ms | 15 Ms | | Rotational Speed | 300 RPM | 300 RPM | | Recording Density | 2938 BPI | 5876 BPI | | Flux Density | 5876 FCI | 5876 FCI | | Track Density | 48 TPI | 48 TPI | | Tracks | 40 | 40 | | R/W Heads | 2 | 2 | | Physical Sectors per track | 18 | 17 | | Bytes per Sector | 128 | 256 | | Encoding Method | FM | MFM | ### **DC Voltage Requirements** - + 12 V dc ± 5% @1.80A Maximum - + 5 V dc ± 5% @0.70A Maximum ### **Power Dissipation** - 11.5 Watts (40 BTU/Hr) Continuous (Typical) - 7.3 Watts (25 BTU/Hr) Standby (Typical) ### SA800 (8" Single-sided floppy) | in the state of th | Single<br>Density | Double<br>Density | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------|-------------------| | Capacity | • | • | | Unformatted | 400 k bytes | 800 k bytes | | Formatted | 250 k bytes | 497 k bytes | | Usable | 241 k bytes | 482 k bytes | | Transfer Rate | 250 k bits/sec | 500 k bits/sec | | Latency (average) | 83 Ms | 83 Ms | | Access Time | | | | Track to Track | 8 Ms | 8 Ms | | Average | 210 Ms | 210 Ms | | Settling Time | 8 Ms | 8 Ms | | Head Load Time | 35 Ms | 35 Ms | | Rotational Speed | 360 RPM | 360 RPM | | Recording Density (inside track) | 3268 BPI | 6536 BPI | | Flux Density | 6536 FCI | 6536 FCI | | Track Density | 48 TPI | 48 TPI | | Tracks | 77 | 77 | | R/W Heads | 1 | 1 | | Physical Sectors per track | 26 | 26 | | Bytes per Sector | 128 | 256 | | Encoding Method | FM | MFM | # **AC Power Requirements** 60 Hz ± 0.5 Hz 115 V ac 85 to 127 V @ 0.4 A typical ### **DC Voltage Requirements** - + 24 V dc ± 5% 1.3 A typical - + 5 V dc ± 5% 0.8 A typical - $5 V dc \pm 5\% 0.5 A typical$ Heat Dissipation = 274 BTU/hr typical (80 watts) ### SA850 (8" Double-sided floppy) | SA630 (6 Double-sided Hoppy) | | | |----------------------------------|-------------------|-------------------| | | Single<br>Density | Double<br>Density | | Capacity | • | • | | Unformatted | 800 k bytes | 1.6 M bytes | | Formatted | 500 k bytes | 1 M byte | | Usable | 490 k bytes | 980 k bytes | | Transfer Rate | 250 k bits/sec | 500 k bits/sec | | Latency (average) | 83 Ms | 83 Ms | | Access Time | | | | Track to Track | 3 Ms | 3 Ms | | Average | 91 Ms | 91 Ms | | Settling Time | 15 Ms | 15 Ms | | Head Load Time | 50 Ms | 50 Ms | | Rotational Speed | 360 RPM | 360 RPM | | Recording Density (inside track) | 3408 BPI | 6816 BPI | | Flux Density | 6816 FCI | 6816 FCI | | Track Density | 48 TPI | 48 TPI | | Cylinders | 77 | 77 | | Tracks | 154 | 154 | | R/W Heads | 2 | 2 | | Physical Sectors per track | 26 | 26 | | Bytes per Sector | 128 | 256 | | Encoding Method | FM | MFM | ### **AC Power Requirements** 60 Hz ± 0.5 Hz 115 V ac 85 to 127 V @ 0.35 A Max ### **DC Voltage Requirements** - + 24 V dc ± 10% 1.0 A Max - +5 V dc ± 5% 1.1 A Max Heat Dissipation = 200 BTU/hr typical (60 watts) #### **SA1004** (8" Rigid) | _ | | ٠. | | |----|----|------|--| | Ca | กล | citv | | Unformatted 10.67 M bytes Formatted 8.4 M bytes Usable 8.192 M bytes Transfer Rate 4.34 M bits/sec Latency (average) 9.6 Ms Access Time 1 Ms Track to Track 52 Ms Average Maximum Settling Time 132 Ms 18 Ms Rotational Speed 3125 ± 3% RPM Rotational Speed Recording Density Flux Density Track Density Tracks Cylinders 6270 BPI 6270 FCI 172 TPI 1024 R/W Heads Physical Sectors per track 256 4 32 Bytes per Sector 32 256 ## **AC Power Requirements** 60 Hz ± 0.5 Hz 115 V ac 90 to 127 V @ 1.1 A typical ### DC Voltage Requirements - + 24 V dc ± 2.4V 2.8A Typical 3.3A Maximum 1000mv ripple P-P - 24 V dc ± 2.4V 2.8A Typical 3.3A Maximum 1000mv ripple P-P - + 5 V dc $\pm$ 0.25V 2.0A Typical 2.5A Maximum 50mv ripple P-P - 5 V dc ± 0.25V .20 A Typical .25A Maximum 50mv ripple P-P Heat Dissipation = 321 BTU/hr typical (94 watts) #### Floppy Disk Parameter Header (DPH) When the physical disk driver is requested to identify the type of media presently installed in the disk drive, it returns the address of a CP/M 2.2-compatible disk parameter header in the HL register if the identification was successful. The first word (address) of this data structure is the address of the sector translate table. If the media is a single density disk there will be an address in the first field; if the media type is double density (or a rigid disk), the sector translate field of the disk paramater header will be 0000. This is because the sectors are physically skewed on the disk and the translate table is not necessary. #### Single Density Logical/Physical Translate Tables 5<sup>1</sup>/<sub>4</sub>" Single density 1,6,11,16,3,8,13,18,5,10,15,2,7,12,17,4,9,14 8" Single density 1,7,13,19,25,5,11,17,23,3,9,15,21,2,8,14,20,26,6,12,18,24,4,10,16,22 ### The Disk Parameter Block (DPB) The sixth address field in the disk parameter header (DPH) is the address for a disk parameter block to describe the physical disk. Listed below are the disk parameter blocks. ### 51" Single-Sided Single Density | Sectors Per Track (SPT) | 18 | |------------------------------------|-----| | Block Shift Factor (BSH) | 3 | | Max. Rec. # in blk (BLM) | 7 | | Extent Mask (EXM) | 0 | | Total Storage capacity (DSM) | 82 | | Total # of directory entries (DRM) | 31 | | Allocation mask (ALO) | 80H | | Allocation mask (AL1) | 0 | | Size of dir check vector (CKS) | 8 | | Reserved tracks (OFF) | 3 | ### 5<sup>1</sup>/<sub>4</sub>" Single-Sided Double Density | Sectors Per Track (SPT) | 34 | |------------------------------------|-----| | Block Shift Factor (BSH) | 3 | | Max. Rec. # in blk (BLM) | 7 | | Extent Mask (EXM) | 0 | | Total Storage capacity (DSM) | 156 | | Total # of directory entries (DRM) | 63 | | Allocation mask (ALO) | C0H | | Allocation mask (AL1) | 0 | | Size of dir check vector (CKS) | 16 | | Reserved tracks (OFF) | 3 | ### 51 Double-Sided Single Density | Sectors Per Track (SPT) | 18 | |------------------------------------|-----| | Block Shift Factor (BSH) | 3 | | Max. Rec. # in blk (BLM) | 7 | | Extent Mask (EXM) | 0 | | Total Storage capacity (DSM) | 172 | | Total # of directory entries (DRM) | 31 | | Allocation mask (ALO) | 80H | | Allocation mask (AL1) | 0 | | Size of dir check vector (CKS) | 8 | | Reserved tracks (OFF) | 3 | ### 51" Double-Sided Double Density | Sectors Per Track (SPT) | 34 | |------------------------------------|-----| | Block Shift Factor (BSH) | 4 | | Max. Rec. # in blk (BLM) | 15 | | Extent Mask (EXM) | . 1 | | Total Storage capacity (DSM) | 162 | | Total # of directory entries (DRM) | 63 | | Allocation mask (ALO) | C0H | | Allocation mask (AL1) | 0 | | Size of dir check vector (CKS) | 16 | | Reserved tracks (OFF) | 3 | # 8" Single-Sided Single Density | Sectors Per Track (SPT) | 26 | |------------------------------------|-----| | Block Shift Factor (BSH) | 3 | | Max. Rec. # in blk (BLM) | 7 | | Extent Mask (EXM) | 0 | | Total Storage capacity (DSM) | 242 | | Total # of directory entries (DRM) | 63 | | Allocation mask (ALO) | СОН | | Allocation mask (AL1) | 0 | | Size of dir check vector (CKS) | 16 | | Reserved tracks (OFF) | 2 | ### 8" Single-Sided Double Density | Sectors Per Track (SPT) | 52 | |------------------------------------|-----| | Block Shift Factor (BSH) | 4 | | Max. Rec. # in blk (BLM) | 15 | | Extent Mask (EXM) | 1 | | Total Storage capacity (DSM) | 242 | | Total # of directory entries (DRM) | 127 | | Allocation mask (ALO) | C0H | | Allocation mask (AL1) | 0 | | Size of dir check vector (CKS) | 32 | | Reserved tracks (OFF) | 2 | ### 8" Double-Sided Single Density | Sectors Per Track (SPT) | 26 | |------------------------------------|-----| | Block Shift Factor (BSH) | 4 | | Max. Rec. # in blk (BLM) | 15 | | Extent Mask (EXM) | - 1 | | Total Storage capacity (DSM) | 246 | | Total # of directory entries (DRM) | 127 | | Allocation mask (AL0) | C0H | | Allocation mask (AL1) | 0 | | Size of dir check vector (CKS) | 16 | | Reserved tracks (OFF) | 2 | ### 8" Double-Sided Double Density | Sectors Per Track (SPT) | 52 | |------------------------------------|-----| | Block Shift Factor (BSH) | . 5 | | Max. Rec. # in blk (BLM) | 31 | | Extent Mask (EXM) | 3 | | Total Storage capacity (DSM) | 246 | | Total # of directory entries (DRM) | 127 | | Allocation mask (AL0) | C0H | | Allocation mask (AL1) | 0 | | Size of dir check vector (CKS) | 32 | | Reserved tracks (OFF) | . 2 | ### 8" 8 Mb Rigid - Partition 1 - 4Mb | Sectors Per Track (SPT) | 512 | |------------------------------------|------| | Block Shift Factor (BSH) | 5 | | Max. Rec. # in blk (BLM) | 31 | | Extent Mask (EXM) | 1 | | Total Storage capacity (DSM) | 3EFH | | Total # of directory entries (DRM) | 511 | | Allocation mask (AL0) | FFH | | Allocation mask (AL1) | 0 | | Size of dir check vector (CKS) | 0 | | Reserved tracks (OFF) | 1 | ### 8" 8 Mb Rigid - Partition 2 - 2Mb | Sectors Per Track (SPT) | 512 | |------------------------------------|------| | Block Shift Factor (BSH) | 5 | | Max. Rec. # in blk (BLM) | 31 | | Extent Mask (EXM) | 1 | | Total Storage capacity (DSM) | 1EFH | | Total # of directory entries (DRM) | 511 | | Allocation mask (AL0) | FFH | | Allocation mask (AL1) | 0 | | Size of dir check vector (CKS) | 0 | | Reserved tracks (OFF) | 41H | # 8" 8 Mb Rigid - Partition 3 - 1Mb | Sectors Per Track (SPT) | 512 | |------------------------------------|-----| | Block Shift Factor (BSH) | 5 | | Max. Rec. # in blk (BLM) | 31 | | Extent Mask (EXM) | 1 | | Total Storage capacity (DSM) | EFH | | Total # of directory entries (DRM) | 511 | | Allocation mask (ALO) | FFH | | Allocation mask (AL1) | 0 | | Size of dir check vector (CKS) | 0 | | Reserved tracks (OFF) | 61H | # 8" 8 Mb Rigid - Partition 4 - 1Mb | Sectors Per Track (SPT) | 512 | |------------------------------------|-----| | Block Shift Factor (BSH) | 5 | | Max. Rec. # in blk (BLM) | 31 | | Extent Mask (EXM) | 1 | | Total Storage capacity (DSM) | EFH | | Total # of directory entries (DRM) | 511 | | Allocation mask (AL0) | FFH | | Allocation mask (AL1) | 0 | | Size of dir check vector (CKS) | 0 | | Reserved tracks (OFF) | 71H | ### Floppy Disk Physical Format 5½" Single Density floppy disk track format. <sup>\*</sup> This field is repeated 18 times. ### $5\frac{1}{4}$ " Double Density floppy disk track format. | | | Number of bytes | Hex Value of byte written | |---|-----|-----------------|---------------------------| | | | 50 | 4E | | | ſ | 12 | 00 | | | | 3 | F5 (Writes A1) | | | | 1 | FE (I.D. Address Mark) | | | 1 | 1 | Track Number | | | - | 1 | Side Number (00 or 01) | | | - 1 | 1 | Sector Number | | * | | 1 | 01 (Sector length) | | | 1 | 1 | F7 (2 CRC's written) | | | - 1 | 22 | 4E | | | l | 12 | 0 | | | - 1 | 1 | FB (Data Address Mark) | | | - 1 | 256 | E5 (Data field) | | | | 1 | F7 (2 CRC's written) | | | | 32 | 4E | | | | 284 | 4E | <sup>\*</sup> This field is repeated 17 times. 8" Single Density floppy disk track format. | | Number of bytes | Hex Value of byte written | |---|---------------------|-------------------------------------------------------------------------| | | 40<br>6<br>1 | FF<br>00<br>FC (Index mark) | | | 26 | FF | | | 6<br>1<br>1 | 00<br>FE (I.D. Address Mark)<br>Track Number | | | 1<br>1<br>1 | Side Number (00 or 01) Sector Number 00 (Sector length) | | * | 1<br>11<br>6 | F7 (2 CRC's written)<br>FF<br>0 | | | 1<br>128<br>1<br>27 | FB (Data Address Mark)<br>E5 (Data field)<br>F7 (2 CRC's written)<br>FF | | İ | 247 | FF | <sup>\*</sup> This field is repeated 26 times. # 8 " Double Density floppy disk track format. | | Number of bytes | Hex Value of byte written | |---|-------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | 80<br>12<br>3<br>1<br>50 | 4E<br>00<br>F6 (Writes C2)<br>FC (Index mark)<br>4E | | * | 12<br>3<br>1<br>1<br>1<br>1<br>1<br>1<br>22<br>12<br>3<br>1<br>256<br>1<br>54 | 00 F5 (Writes A1) FE (I.D. Address Mark) Track Number Side Number (00 or 01) Sector Number 01 (Sector length) F7 (2 CRC's written) 4E 0 F5 (Writes A1) FB (Data Address Mark) E5 (Data field) F7 (2 CRC's written) 4E | | | 247 | FF | <sup>\*</sup> This field is repeated 26 times. #### **Physical Disk Interleave** All double-density CP/M-formatted floppy disks have **Track 0**, **Side 0** formatted in single density. Also, double density floppies have the sectors physically skewed on the disk. This is done when the disk is formatted with the CP/M-80 program INIT.COM. Listed below are various physical sector placements for different system configurations and different options formatted with the INIT program. MS-DOS format information is listed on the next page. 5<sup>1</sup>/<sub>4</sub>" Single Density 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18 54" Double Density 1, 7, 13, 2, 8, 14, 3, 9, 15, 4, 10, 16, 5, 11, 17, 6, 12 8" Single Density 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26 8" Double Density (820-II option with WD1797 disk controller) 1, 14, 8, 21, 2, 15, 9, 22, 3, 16, 10, 23, 4, 17, 11, 24, 5, 18, 12, 25, 6, 19, 13, 26, 7, 20 8" Double Density (16/8 option with WD1797 disk controller) 1, 22, 17, 12, 7, 2, 23, 18, 13, 8, 3, 24, 19, 14, 9, 4, 25, 20, 15, 10, 5, 26, 21, 16, 11, 6 8" Double Density (820-II option with SA1403D disk controller) 1, 10, 19, 2, 11, 20, 3, 12, 21, 4, 13, 22, 5, 14, 23, 6, 15, 24, 7, 16, 25, 8, 17, 26, 9, 18 8" Double Density (16/8 option with SA1403D disk controller) 1, 7, 13, 19, 25, 2, 8, 14, 20, 26, 3, 9, 15, 21, 4, 10, 16, 22, 5, 11, 17, 23, 6, 12, 18, 24 Disk Formats 223 When the disk is formatted under the MS-DOS operating system, the gaps and skews apply to both single- and double-sided disks. #### 51" IBM PC Format 512 bytes per sector x 8 sectors per track GAP1 = 50 GAP2 = 22 GAP3 = 96 Interleave = 1:1 (1, 2, 3, 4, 5, 6, 7, 8) #### 51" IBM XT Format 512 bytes per sector x 9 sectors per track GAP1 = 50 GAP2 = 22 GAP3 = 96 Interleave = 1:1 (1, 2, 3, 4, 5, 6, 7, 8, 9) #### 8" Microsoft Format 256 bytes per sector x 26 sectors per track GAP1 = 50 GAP2 = 22 GAP3 = 24 Interleave = 1:2 (1, 14, 2, 15, 3, 16, 4, 17, 5, 18, 6, 19, 7, 20, 8, 21, 9, 22, 10, 23, 11, 24, 12, 25, 13, 26) ### **Configuration Sector** The CONFIGUR.COM program writes the information listed below on track 0 of double density disks only. 8" floppy: Track 0, Sectors 2 and 3 $5\frac{1}{4}$ " floppy: Track 0, Sectors 2 and 3 8" rigid: Track 0, Sector 20<sub>16</sub> 8" rigid (2nd copy): Track 0, Sector 40<sub>16</sub> #### Byte offset | 00-0e | Partition 1 | (E:) DPB | |----------|---------------------------|-------------------------------------------------------------------------------------------------------------------------------| | 0f | 01H | (256 byte/sector) | | 10-1e | Partition 2 | (F:) DPB | | 1f | 01H | (256 byte/sector) | | 20-2e | Partition 3 | (G:) DPB | | 2f | 01H | (256 byte/sector) | | 30-3e | Partition 3 | (G:) DPB | | 3f | 01H | (256 byte/sector) | | 40-de | | (Reserved for Rank Xerox language use) | | df | Screen Attributes: | 35h = Graphics, 36h = Blink,<br>37h = Inverse, 38h = Hi/lo Light | | e0 | Disk Head Step Rate: | $0 = 3 \text{ msec}, 1 = 6 \text{ msec}, 2 = 10 \text{ msec}, 3 = 15 \text{ msec} \text{ (msec x2 if } 5\frac{1}{4}\text{")}$ | | e1 | .83h | | | e2 | Keyboard bit mask | 30h = 7-bit, 31h = 8-bit | | e3-e7 | Comm PIO command | 08 06 00 18 03 | | e8<br>e9 | Comm Rec. Wd Length<br>04 | 41h = 7-bit, c1h = 8-bit | | | | | ``` Stop Bit & Parity xx = 01 1 stop bit 0100 xx yy ea = 11 2 stop bits = 00 no parity ٧V = 01 odd parity = 10 no parity = 11 even parity eb 05 Comm Transmit 1xx01010 xx = 01 7 hit ec = 11 8 bit DTR CTS ed-f1 Printer PIO Table 08 07 00 18 03 f2 Receive 41h = 7 bit, c1h = 8 bits/character f3 04 f4 Stop Bit & Parity 0100 xx vv xx = 01 1 stop bit = 11 2 stop bits = 00 уу no parity = 01 odd parity = 10 no parity = 11 even parity f5 05 f6 Transmit 1 \times 01010 \times x = 01 7 bit = 11 8 bit f7 Clear-to-Send 00 = \text{lanore}, 01 = \text{Low}, 10 = \text{High} f8 80 f9 Carrier Detect 00 = Ignore, 01 = Low, 10 = High fa 81 Protocol fb ca = none, 00 = Xon/Xoff fc 82 fd Comm Baud 0xh (x = baud rate, see Appendix K for complete list) fe Printer Baud 0xh (x = baud rate, see Appendix K) for complete list) ff IOBYTE (Z80-A) xx 0000 vv Default 00 01 10 11 xx = List Device LPT CRT LPT yy = Console CRT TTY CRT ---- ---- ``` #### 20 CPS Printer The 20 CPS Printer (Diablo 620) is a serial printer designed for low-speed, low-to-moderate output requirements of standalone word and data processing business systems. The printer uses conventional data interchange techniques and protocol at speeds up to 1200 Baud. This printer produces a "typewriter" quality output of fully-formed characters at a maximum of 20 Characters Per Second when printing average English (Shannon) text at 10 pitch. It includes operating features such as page formatting, graphics, positive and negative full and half line feed, absolute horizontal and vertical tabbing, as well as 12 and 15 pitch and proportional spacing. The 20 CPS printer features a new 98-character plastic printwheel with automatic recognition of printwheel type and language. A "drop-in" printwheel exchange system is also featured (printwheels may be exchanged without removing the ribbon cartridge). The 20 CPS printer features quick-change film ribbon cartridges and has printwheels available in many languages and type styles. #### Set the Switches Under the Front Cover Check to be sure that the operating mode switches have been properly set for use. These switches set the printer parameters when printer power is turned on. If the switch settings are changed with the printer turned on, the changes will not have any effect until the power to the printer is turned off and then on again. The switches are located to the left of the external control panel and are covered when the front cover is in place. These switches control operating modes and ordinarily do not require attention once they have been set. When using a 20 CPS Printer with your personal computer, all the operating mode switches should be positioned to the right (off) except for switch #8. It should be positioned to the left (on). **Note:** When using single strike ribbons, the 20 CPS Printer single strike mode <u>must</u> be enabled. If single strike mode is not enabled, the print quality will be unacceptable. See the Xerox 620 Printer (20 CPS) 630 Printer (40 CPS) Operators Guide, Order #610P72115, page 13, for instructions on using single strike ribbons. #### **Using the Control Panel Switches** These four switches are located to the right of the Control Panel where they are accessible to the operator with all covers on the machine. These are momentary-action switches activated by a touch of the finger. RESET: This switch will clear an "error" indication and return the printer to operation. It will also return the printer to operation following a PAUSE command. PAUSE: Touching this switch will cause the printer to stop printing without any loss of data, and the power indicator will go out. Printing is continued by pressing the RESET switch. LINE FEED: Touching this switch initiates a single line feed. Action is repeated if the switch is held activated longer than 1/2 second. A line feed code will not, however, be transmitted. FORM FEED: Touching this switch initiates a form feed to the next topof-form position. A form feed code is not, however, transmitted. #### The POWER Indicator The power indicator glows whenever power is turned on to the printer and will flash for the following conditions: - A parity error was detected with the PARITY switch on. - The printer buffer (memory) has overflowed. - The printer didn't receive a "Data Set Ready" signal. ### **Operating Mode Switches** The following information is a brief explanation for each of the 20 CPS Printer operating mode switches. | SWITCH | EXPLANATION | |--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 1 | 110-300 BAUD: This switch selects 110 or 300 Baud as the speed at which the printer will receive and transmit data. If 1200 Baud is selected (#8 1200/OPT switch ON), switch #1 doesn't have any effect. | | 2 | PARITY ODD-EVEN: This is used in conjunction with Parity ON-OFF to determine the nature of parity information handling. | | 3 | PARITY ON-OFF: This switch enables parity checking and parity information transmission when on. | | 4 | DC1/DC3: This switch is used to allow the printer to operate with much faster host systems without loss of data. When ON, special characters (DC1/DC3) are transmitted between the printer and the host automatically whenever the print buffer (512 bytes) is either nearly empty (DC1) or nearly full (DC3). | | 5 | SELF TEST: If this switch is in the ON position when the printer is turned on, the printer will enter a self test mode and begin sequencing through its self test program. The Control Panel PAUSE and RESET switches may be used to interrupt the self test sequence. To exit the mode, the SELF TEST switch must be moved to OFF and the power to the 20 CPS must be turned off momentarily. | | 6 | AUTO/LF: When ON, this switch enables the printer to automatically advance the paper one line with each carriage return. This relieves the host system of the need to send a line feed command with each carriage return command. | | SWITCH | EXPLANATION | |--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7 | PAGE SIZE: This switch enables setting page size, used in the Top Of Form/Form Feed function, to either the US standard 11" or the European standard 12" page length. | | 8 | 1200/OPT: This switch, when ON, enables the | # Horizontal Motion Index (HMI) /Vertical Motion Index (VMI) Horizontal Motion Indexing refers to the horizontal distance that the carriage moves for each character (or space) print command. Each increment is 1/120" and standard HMI values for 10, 12, and 15 pitch are: of 1200 Baud Vertical Motion Indexing (VMI) refers to the vertical distance that the paper moves for each line feed command. Each increment is 1/48". Proportional Space provides its own HMI on a character to character basis as shown in the following example: $$HMI = ESC US (n)$$ $VMI = ESC RS (n)$ In the example above, (n) is the decimal value of an ASCII character selected from the chart to produce the desired index value of (n-1). The minimum index value is 0 and the maximum index value is 125 in either the horizontal or vertical direction. ### 20 CPS Printer Operating Codes The 20 CPS Printer uses two types of code to control the exchange and storage of information and the format of the printout. They are escape (ESC) codes, and control (CTRL) codes. The ESC code (character) is used to pre-condition the printer logic to recognize the characters following the ESC code and preceding a carriage return as a command rather than print data. #### 20 CPS Printer Command Codes | MARGINS AND FORMATTING | | | | |-----------------------------------------|-------------|------|-----| | Set Top Page Margin | ESC | Т | (n) | | (at current position)** | | | | | Set Left Margin | ESC | 9 | | | (at current position)** | | | | | Set Right Margin | ESC | 0 | | | (at current position)** | | | | | Set Lines Per Page to (n)* | ESC | FF | (n) | | Set Bottom Page Margin | ESC | L | | | (at current position)** | | | | | Clear Top and Bottom Margins | ESC | C | | | Set Horizontal Motion Index to (n - 1)* | ESC | US | (n) | | Set Vertical Motion Index to (n - 1)* | ESC | RS | (n) | | Return HMI control to internal progra | m ESC | S | | | CARRIAGE MOVEMENT | | | | | Absolute HT to print column (n)* | ESC | HT | (n) | | Enable Auto Backward Printing | ESC | 1 | - | | Disable Auto Backward Printing | ESC | ١ | | | Forward Print Mode ON | ESC | 5 | | | Backward Print Mode ON | ESC | 6 | | | (Forward Print Mode OFF) (clear w | vith < retu | rn>) | | | PAPER MOVEMENT | | | | | Absolute VT to line (n)* | ESC | VT | (n) | | | | | | | Absolute VT to line (n)* | ESC | VT | (n) | |---------------------------------|-----|----|-----| | Perform Negative Line Feed | ESC | LF | | | Perform Half-Line Feed | ESC | U | | | Perform Negative Half-Line Feed | ESC | D | | Note: the bolded characters indicate a control code. See ASCII Chart, page 234. - \* (n) represents the decimal value of an ASCII character. - \*\* The Left and Right Margin positions must be set by using SPACE and BACKSPACE commands from the Carriage Home (RESET) position. The Top and Bottom Margin positions must be set by using Line Feed commands or < return > from the manually-set Top of Form postion. ### **20 CPS Printer Command Codes continued** | 20 CPS Printer Command Code | s cont | inuea | | |------------------------------------------|--------|-------------|----------------| | PRINTING | | | | | Graphics Mode ON (clear w/< return >) | ESC | 3 | | | Graphics Mode OFF | ESC | 4 | | | WORD PROCESSING COMMANDS | | | | | Proportional Space ON | ESC | Р | | | (clear with < return >) | | | | | Proportional Space OFF | ESC | Q | | | Program Mode ON (clear with ESC X or SI) | ESC | SO | M | | Program Mode OFF | ESC | X | | | MISCELLANEOUS COMMANDS | | | | | Initiate Remote RESET | ESC < | <ret></ret> | P | | Print, Printwheel Character 20h | ESC | Υ | | | Print, Printwheel Character 7Fh | ESC | Z . | | | Print, Printwheel Character 80h | ESC | а | | | Print, Printwheel Character 81h | ESC | b | | | Print, Printwheel Character 82h | ESC | c | | | Print, Printwheel Character 83h | ESC | d | | | Enable Download of | ESC | SO | DC2 | | Printwheel Conversion Table | | | | | Enter Remote Diagnostic Mode | ESC | SUB | (enter option) | | (see next page also) | | | | | When selecting the remote diagnostic r | node, | enter | one of the | | following options: | | | | | Remote Initialization | I | | | | Remote Error Reset | R . | | | | STATUS 1 Request | 1 | | | | RAM/ROM TEST | SO | | | | Enter TEST MODE | ENQ | | | | | | | | Note: the bolded characters indicate a control code. See ASCII Chart, page 234. ### **Remote Diagnostics** | Status 1 "Word" | RAM/ROM Test "Word" | Test Mode "Word" | |---------------------|---------------------|-----------------------------| | 0 - (unassigned) | 0 - 8041 RAM is bad | @, data byte | | 1 - 10 Pitch | 1 - 8041 ROM is bad | - 8041 RAM data * | | 2 - (unassigned) | 2 - 6803 RAM is bad | A - Perform RAM/ROM | | 3 - (unassigned) | 3 - 6803 ROM is bad | check | | 4 - (unassigned) | (upper half 4K) | B - Print 1 line swirltest | | 5 - Printer idle** | 4 - 6803 ROM is bad | C - Print swirltest | | 6 - (unassigned) | (lower half 4K) | continuously | | 7 - UART Parity Bit | 5 - (unassigned) | D - Stop printing swirltest | | | 6 - (unassigned) | \$40, data byte- 6803 RAM | | | 7 - UART Parity Bit | data* | | | • | DEL - Exit Test Mode | <sup>\*</sup> The Data Byte defines the RAM data address in ASCII code. The response is two bytes: 1) STX, (\$02); and 2) contents of the RAM address requested. <sup>\*\*</sup>Print buffer empty and all printer motion complete. | COMMAND | CONTR | OL CODE | EQUIV. | HEX CODE | |---------|-------|------------------------|--------|----------| | ACK | CTRL | F | | 06 | | BEL | CTRL | G | | 07 | | BS | CTRL | BACKSPACE or | Н | 08 | | CAN | CTRL | X | | 18 | | CR | CTRL | <return> or N</return> | Λ | 0D | | DC1 | CTRL | Q | | 11 | | DC3 | CTRL | S | | 13 | | DC4 | CTRL | T | | 14 | | DEL | CTRL | DEL | | 7F | | DLE | CTRL | Р | | 10 | | EM | CTRL | Υ | | 19 | | ENQ | CTRL | E | | 05 | | EOT | CTRL | D | | 04 | | ESC | CTRL | <del>1</del> or[ | | 1B | | ETB | CTRL | W | | 17 | | ETX | CTRL | С | | 03 | | FF | CTRL | L | | 0C | | FS | CTRL | \ | | 1C | | GS | CTRL | è | | 1D | | HT | CTRL | TAB or I | | 09 | | LF | CTRL | LF or J | | 0A | | NAK | CTRL | U | | 15 | | NUL | CTRL | 1-8 | | 00 | | RS | CTRL | = | | 1E | | SI | CTRL | 0 | | 0F | | SO | CTRL | N | | 0E | | SOH | CTRL | Α | | 02 | | SP | CTRL | <space></space> | | 20 | | STX | CTRL | В | | 02 | | SUB | CTRL | Z | | 1A | | SYN | CTRL | V | | 16 | | US | CTRL | • | | 1F | | VT | CTRL | , <b>K</b> | | 0B | | { | CTRL | 9 | | 7B | | } | CTRL | 0 | | 7D | | é | CTRL | é | | 2C | | • | CTRL | • | | 2E | | ; | CTRL | ; | | 3B | | / | CTRL | 1 | | 2F | | • | CTRL | • | | 27 | #### **Specifications** Print Speed: Up to 20 characters per second printing average English (Shannon) text at 10 pitch. Character Set: 98 character spaces consisting of 82 standard or common character segments. The printer supports several English and several foreign language printwheels. Printwheels: Plastic 98 character ASCII Xerox. The printer will automatically recognize printwheel pitch and language requirements. Character Spacing: 10-pitch = 10 characters/inch (3.94 ch/cm) 12-pitch = 12 characters/inch (4.72 ch/cm) 15-pitch = 15 characters/inch (5.91 ch/cm) Column Spacing: 1/120 inch (.21mm) minimum. Print Line: 13.2 inches (335.3mm) 132 columns 10 pitch 158 columns 12 pitch 197 columns 15 pitch Print Buffer: 512 bytes. Paper Width: 13.2 inches (387.4mm) maximum - friction feed platen. Carriage Speed: 1.7 seconds maximum for 13.2 inches (332.77mm) of motion. Tabulation: Left or right. Line Spacing: 1/48 inch (.53mm) minimum. Paper Feed: Bidirectional. Paper Thickness: 1 to 5 part forms; maximum overall thickness .024" (.61mm). Sensors: End of ribbon, paper out, and cover open. Other Features: Self test; host program control through escape sequences; data receive/transmit speed selection. Power Requirements: Operation from nominal 120/220-240 volt AC inputs, 50-60 Hz. 120W maximum power consumption. Check your printer's serial plate for proper input power. ### **Cabling Requirements** A standard RS-232-C interface cable is required for connection between the screen and the printer. This cable must be equipped with DB-25P connectors with the following pins connected: | PIN<br>NO. | CCITT<br>DESIG. | TELCO<br>DESIG. | DESCRIPTION | |------------|-----------------|-----------------|---------------------| | 1 | 101 | AA | Protective Ground | | 2 | 103 | BA | Transmitted Data | | 3 | 104 | BB | Received Data | | 4 | 105 | CA | Request To Send | | 6 | 107 | CC | Data Set Ready * | | 7 | 102 | AB | Signal Ground | | 20 | 108 | CD | Data terminal Ready | <sup>\*</sup> Pin 6 must be HI to receive or transmit data. #### **40 CPS Printer** The 40 CPS Printer (Diablo 630) is a medium-speed, daisy wheel serial printer. The 40 CPS printer is capable of producing typewriter quality output at speeds up to 40 characters per second with 88, 92, or 96 character metal printwheels (or 96 character plastic printwheel). The version sold by Xerox Corporation for use with the 820-II or 16/8 is a Model 630R132 which has the HPR05 PWA interface. #### **40 CPS Printer Versions** The 40 CPS Printer has three versions: Basic, Expanded, and Word Processor. The feature differences among the three versions of the HPR05 terminal are primarily a function of the firmware installed on the HPR05 circuit board in the form of the programmed ROM (Read Only Memory) devices and a nonvolatile RAM (Random Access Memory). The version offered by Xerox for use with the 820-II and 16/8 product uses the basic configuration of the HPR05 since printer control is taken by the 820-II and 16/8 system software for such applications as Word Processing. #### **HPR05 Communications Protocol** DC1/DC3 (XON/XOFF) protocol transmit a DC3 control code character from the 40 CPS Printer under any of the following conditions: - Print buffer (2688 bytes) nearly full (within 64 bytes) - Cover Open - Paper Out (only when printing is attempted) - End of Ribbon (only when printing is attempted) - Printer in CHECK condition - PAUSE switch depressed A NAK character will be transmitted (in addition to the DC3) for: Cover Open, Paper Out, End of Ribbon, and CHECK condition if the HPR05 firmware is level -03 or later, and if both DC1/DC3 and EXT/ACK are enabled. The NAK character thus distinguishes the "error" condition from Buffer Full and PAUSE. NAK is also sent when a parity error is detected if parity checking is enabled. The error condition with the NAK can be cleared by pressing RESET. The BUFFER FULL DC3 control character when transmitted by the 40 CPS Printer will be followed by a DC1 control character when the printer buffer (2688 bytes) is nearly empty (within 64 characters). #### **Setting the Switches Under the Access Cover** Check to be sure the printer has been set to the proper switch positions for use with a Xerox Personal Computer. Printwheel Select Switch. Set this switch to match the particular type of printwheel being used. This ensures your text will print correctly and prevents possible printwheel damage or excessive wear. Check your printwheel to determine if it's plastic or metal and which pitch it is. The available printwheel settings are: - 0: 88 Metal - 2: 92 Metal - 3: 96 Metal - 4: 96D Metal - 5: APL Metal - 6: APL Plastic - 7: Plastic (Normally shipped with the printer) - 1,8,9: Optional - Spacing Select Switch. This switch selects the horizontal spacing for character printout. Set this switch to 1 for 10 Pitch or 2 for 12 Pitch. The available spacing settings are: - 0: Proportional - 1: 10 (Normally shipped with the printer) - 2: 12 - 3: 15 - 4-9: Self Test - Operating Mode Switches. When connecting the printer to a Xerox Personal Computer, the switches to the right of the Printwheel and Spacing switches should be positioned toward the front of the printer, except for the BAUD switch marked 120. It should be positioned toward the back of the printer. #### The Power Indicator The power Indicator should glow; the carriage should move to the left slowly, and then back to the right, to stop at the first print position; the printwheel should rotate and stop at its "home" position (i.e., the "flag" on metal printwheels should be at the top if the Printwheel Select switch - under the access cover - has been properly set). This entire process is called the INITIALIZATION, RESET, or RESTORE sequence. It clears all volatile memory, resets all position counters, and sets the printer to print the first character. #### **Using The Operating Switches** These six switches are located in the right-hand area of the control panel where they are accessible to the operator with all covers on the machine. These are membrane-type, momentary-action switches activated by a touch of the finger. RESET Switch - This switch will restore the printer to normal operating status following a printer check or an error condition, and clears all error indicators. SCROLL Switch - Touching this switch advances the paper a small amount to give the operator a clear view of the last printed line. The paper is automatically returned to the last printing position when the switch is released. LINE FEED Switch - Touching this switch initiates a single or a double line feed operation, as selected by the DOUBLE L.F. MODE SWITCH. Action is repeated if the switch is held activated longer than 600 msec. A line feed code is not transmitted. FORM FEED Switch - Touching this switch initiates a form feed to the next top-of-form position. A form feed code is not transmitted. HERE IS Switch - Touching this switch causes a special "Here Is..." message of up to 31 characters to be transmitted over the communications link when operating in remote ASCII mode with the fully featured HPRO5 option installed. This is not used with the 820, 820-II, or the 16/8. BREAK Switch - Touching this switch causes a break (250 msec space) to be transmitted over the communications link when operating in remote mode #### **Reading The Control Panel Indicators** POWER - Indicates that AC power is applied to the 40 CPS Printer. PRINT CHK\* - Indicates that a print operation has been called for while the printer is in a "check" condition. A check condition occurs when a printwheel or carriage movement command has been received but cannot be successfully completed due to a malfunction. This condition disables the printer until a restore sequence clears the check condition. RESET - Note that if the problem causing the check condition has not been corrected when a restore sequence has been initiated, the check will reappear as soon as printing is attempted. PARITY - This indicator functions only if the PARITY ENABLE switch (under the access cover) is ON. It indicates detection of any of the following types of errors: - Incorrect parity sensed on received character. - A framing error (no stop bit) detected on a received non-break character. - A serial data character detected with an excess number of bits. When a parity error is detected, a DEL character is substituted for the erroneous character. OVERFLOW\* - Indicates that the printer's print input memory (buffer) is too full (has overflowed). Protocol has not been used properly. RIBBON/PAPER\* - Indicates end of ribbon has been reached or that the printer is out of paper, and printing has been attempted. COVER\* - Indicates that printing was attempted with the cover open. These errors cause a break to be transmitted when the 40 CPS Printer is in Remote mode if DC1/DC3 protocol has not been selected. # Horizontal Motion Index (HMI) /Vertical Motion Index (VMI) Horizontal Motion Indexing refers to the horizontal distance that the carriage moves for each character (or space) print command. Each increment is 1/120" and standard HMI values for 10, 12, and 15 pitch are: Vertical Motion Indexing (VMI) refers to the vertical distance that the paper moves for each line feed command. Each increment is 1/48". Proportional Space provides its own HMI on a character to character basis as shown in the following example: $$HMI = ESCUS(n)$$ $$VMI = ESC RS (n)$$ In the example above, (n) is the decimal value of an ASCII character selected from the chart to produce the desired index value of (n-1). The minimum index value is 0 and the maximum index value is 125 in either the horizontal or vertical direction. #### **40 CPS Printer Operating Codes** The 40 CPS Printer uses two types of codes to control the exchange and storage of information and the format of the printout. They are escape (ESC) codes, and control (CTRL) codes. The ESC code (character) is used to pre-condition the printer logic to recognize the characters following the ESC code and preceding a carriage return as a command rather than print data. The CTRL key is used simultaneously with another key to generate an ASCII control signal to be used either internally or transmitted to the receiving system. #### **40 CPS Printer Command Codes** | 40 CP3 Printer Command | Codes | • | | |-----------------------------------------|--------|----|-----| | MARGINS AND FORMATTING | | | | | Set Top Page Margin | ESC | T | | | (at current position)** | | | | | Set Left Margin | ESC | 9 | | | (at current position)** | | | | | Set Horizontal Tab Stop (HT) | ESC | 1 | | | (at current position)** | | | | | Set Right Margin | ESC | 0 | | | (at current position)** | | | | | Set Vertical Tab Stop (VT) | ESC | - | | | (at current position)** | | | | | Set Lines Per Page to (n)* | ESC | FF | (n) | | Set Bottom Page Margin | ESC | L | | | (at current position)** | | | | | Clear Top and Bottom Margins | ESC | C | | | Clear Horizontal Tab Stop (HT) | ESC | 8 | | | (at current position)** | | _ | | | Clear all HT and VT stops | ESC | 2 | | | Set Horizontal Motion Index to (n - 1)* | ESC | US | (n) | | Set Vertical Motion Index to (n - 1)* | ESC | RS | (n) | | Return HMI control to internal program | ESC | S | | | CARRIAGE MOVEMENT | | | | | Absolute HT to print column (n)* | ESC | HT | (n) | | Enable Auto Backward Printing | ESC | 1 | | | Disable Auto Backward Printing | ESC | 1 | | | Reverse Printing Mode | ESC | < | | | Normal Printing Mode | ESC | > | | | Forward Print Mode ON | ESC | 5 | | | Backward Print Mode ON | ESC | 6 | | | (Forward Mode OFF) (clear with < ret | turn>) | | | | | | | | Note: the bolded characters indicate a control code. See page 245. - \* (n) represents the decimal value of an ASCII character. - \*\* The Left and Right Margin positions must be set by using SPACE and BACKSPACE commands from the Carriage Home (RESET) position. The Top and Bottom Margin positions must be set by using Line Feed commands from the manually-set Top Of Form position. # 40 CPS Printer Command Codes continued | 40 CPS Printer Command Code: | s conti | inued | | |----------------------------------------------|---------|-------------|---------------| | PAPER MOVEMENT | | | | | Absolute VT to line (n)* | ESC | VT | (n) | | Perform Negative Line Feed | ESC | LF | | | Perform Half-Line Feed | ESC | U | | | Perform Negative Half-Line Feed | ESC | D | | | PRINTING | | | | | Graphics Mode ON (clear with < return >) | ESC | 3 | | | Graphics Mode OFF | ESC | 4 | | | WORD PROCESSING COMMANDS | | | | | Proportional Space ON (clear with ESC S) | ESC | Ρ | | | Proportional Space OFF | ESC | Q | | | Auto Underscore ON | ESC | Ε | | | Auto Underscore OFF | ESC | R | | | Bold Print ON (clear with < return >) | ESC | 0 | | | Shadow Print ON (clear with < return >) | ESC | W | | | Bold/Shadow Print OFF | ESC. | & | | | Backspace 1/120" | ESC | BS | | | Program Mode ON (clear with SI) | ESC | SO | M | | Program Mode OFF | ESC | Х | | | MISCELLANEOUS COMMANDS | | | | | Initiate Remote RESET | ESC < | <ret></ret> | Р | | Print, Printwheel Character 20h | ESC | Υ | | | Print, Printwheel Character 7Fh | ESC | Z | | | Print, Printwheel Character 80h | ESC | а | | | Print, Printwheel Character 81h | ESC | b . | | | Print, Printwheel Character 82h | ESC | c | | | Print, Printwheel Character 83h | ESC | d | | | Enable Download of | ESC | SO | DC2 | | Printwheel Conversion Table | | | | | Enter Remote Diagnostic Mode (see next page) | ESC | SUB ( | enter option) | Note: the bolded characters indicate a control code. See page 245. When selecting the remote diagnostic mode, enter one of the following options: Remote Initialization I Remote Error Test R Remote STATUS 1 Request 1 Remote RAM/ROM TEST SO Remote TEST MODE ENQ Note: the bolded characters indicate a control code. See page 245. | Status 1 "Word" | RAM/ROM Test "Word" | Test Mode "Word" | | |---------------------|---------------------|-----------------------------|--| | 0 - (unassigned) | 0 - 8041 RAM is bad | @, data byte | | | 1 - 10 Pitch | 1 - 8041 ROM is bad | - 8041 RAM data * | | | 2 - (unassigned) | 2 - 6803 RAM is bad | A - Perform RAM/ROM | | | 3 - (unassigned) | 3 - 6803 ROM is bad | check | | | 4 - (unassigned) | (upper half 4K) | B - Print 1 line swirltest | | | 5 - Printer idle** | 4 - 6803 ROM is bad | C - Print swirltest | | | 6 - (unassigned) | (lower half 4K) | continuously | | | 7 - UART Parity Bit | 5 - (unassigned) | D - Stop printing swirltest | | | | 6 - (unassigned) | \$40, data byte- 6803 RAM | | | | 7 - UART Parity Bit | data* | | | | · · | DEL - Exit Test Mode | | <sup>\*</sup> The Data Byte defines the RAM data address in ASCII code. The response is two bytes: 1) STX, (\$02); and 2) contents of the RAM address requested. <sup>\*\*</sup>Print buffer empty and all printer motion complete. | COMMAND | CONTR | ROL CODE | EQUIV. | HEX CODE | |---------|-------|------------------------|--------|----------| | ACK | CTRL | F | | 06 | | BEL | CTRL | Ġ | | 07 | | BS | CTRL | BACKSPACE or | н | 08 | | CAN | CTRL | X | •• | 18 | | CR | CTRL | <return> or N</return> | | 0D | | DC1 | CTRL | Q | •. | 11 | | DC3 | CTRL | Š | | 13 | | DC4 | CTRL | T | | 14 | | DEL | CTRL | DEL | | 7F | | DLE | CTRL | P | | 10 | | EM | CTRL | Y | | 19 | | ENQ | CTRL | E | | 05 | | EOT | CTRL | D | | 04 | | ESC | CTRL | 1/2 or[ | | 1B | | ETB | CTRL | w | | 17 | | ETX | CTRL | С | | 03 | | FF · | CTRL | L | | 0C | | FS | CTRL | \ | | 1C | | GS | CTRL | è | | 1D | | HT | CTRL | TAB or I | | 09 | | LF | CTRL | LF or J | | 0A | | NAK | CTRL | U | | 15 | | NUL | CTRL | 1-8 | | 00 | | RS | CTRL | = | | 1E | | SI | CTRL | 0 | | OF | | SO | CTRL | N | | 0E | | SOH | CTRL | Α | | 02 | | SP | CTRL | <space></space> | | 20 | | STX | CTRL | В | | 02 | | SUB | CTRL | Z | | 1A | | SYN | CTRL | V | | 16 | | US | CTRL | - | | 1F | | VT | CTRL | K | | ОВ | | { | CTRL | 9 | | 7B | | } | CTRL | 0 | | 7D | | é | CTRL | é | | 2C | | • | CTRL | • | | 2E | | ; | CTRL | | | 3B | | 1 | CTRL | / | | 2F | | • | CTRL | • | | 27 | # **Electrical Interface Xerox 40 CPS Printer** # **EIA Interface Connector Pin Assignments** | Pin | # Signal | Meaning | |-----|-------------------|---------------------------------------------------------------------------------| | 1 | Chassis | Connects to chassis ground within the 40 CPS | | | Ground | printer. | | 2 | -Transmitted | This connector is the serial ASCII-coded digital | | | Data | data being transmitted by the 40 CPS printer. | | | | This signal is in the "mark" state (LOW) | | | | between characters, rises for logic 0 and drops for logic 1. | | 3 | -Received | This connector is the serial ASCII-coded digital | | | Data | data being received by the 40 CPS printer. This | | | | signal must be held in "mark" state (LOW) | | | | between characters. It should go HIGH for | | | | logic 0, and LOW for logic 1. | | 4 | + Request to Send | Held HIGH (+ 12VDC) whenever power is ON. | | 5 | + Clear to Send | (unused) | | 6 | + Data Set Ready | This connector must be ON (HIGH) for 40 CPS | | | | printer operation in Remote Mode. If OFF | | | | (LOW), no data can be received. | | 7 | Signal to Ground | Ground reference for all interface signals. | | 8 . | + Carrier | The ON state of this signal is presented to the | | | Detect | 40 CPS printer when the data communication | | | | equipment (DCE) is receiving a carrier signal | | | | suitable for demodulation. The OFF state | | | | indicates that no signal is being received by the | | | | DCE, or that the received signal is unsuitable | | | | for demodulation. In its present design, the 40 | | | | CPS printer ignores the Carrier Detect input | | | | signal. | | 11 | + Printer | Goes LOW if any of the following conditions | | | Ready | occur: | | | | <ul> <li>Print Buffer (2688 bytes) nearly full (within<br/>64 bytes)</li> </ul> | | | | Cover Open | | | | Paper Out | | | | End of Ribbon | | | | Printer in CHECK | | | | Pause switch depressed | | | | Fause switch depressed | | Pin # | # Signal | <u>Meaning</u> | |-------|----------------|-----------------------------------------------| | | | With Paper Out or End of Ribbon, + Printer | | | | Ready goes LOW only if printing is attempted. | | | | It returns HIGH when the buffer becomes | | | | nearly empty, and/or conditions have been | | | | corrected. | | 20 | + Data | ON (HIGH) whenever power is ON. | | | Terminal Ready | | | | | | # **HPR05 Circuit Board Jumpers** # Dipswitch Module A | # | Function | | Meaning | |---|------------------|------|-------------------------------------------------------------------------------------------------------------------------------------------------| | 1 | Double Line Feed | ON- | Gives double line feed on every line feed command, and on every carriage return | | | | | if switch 3 is ON. | | | | OFF- | Gives single line feed on every line feed command, and on every carriage return if switch 3 is ON. | | 2 | (Unused) | | | | 3 | Auto Line Feed | ON- | Gives automatic line feed (single or double on every carriage return. | | | | OFF- | | | 4 | (Unused) | | | | 5 | Uppercase Only | ON- | Converts all lowercase alpha characters (a-z) entered from the keyboard to uppercase. | | | | OFF- | Both uppercase and lowercase character selection, through the use of the shift key. | | 6 | (Unused) | | | | 7 | Message Load | ON- | Enables keyboard entry of "Here Is" message into non- volatile memory. (Functional only on expanded printer configuration with jumper A60 (3-4) | | _ | | | installed on HPR05 PCB) | | 8 | (Unused) | | | | | | | | # Dipswitch Module B | # | Function | | Meaning | g | | |-----|------------------|--------|------------|-----------|------------------------| | 1 | Full Duplex | ON | Operate | s in full | -duplex mode. | | | • | OFF | Operate | s in hal | f-duplex mode. | | 2 | Parity Enable | ON | Enables | parity o | hecking and parity | | | • | | transmis | ssion. | | | 3,5 | BAUD | | 3 | 5 | Baud Rate | | | | | on | on | 110 | | | | | on | off | 300 | | | | | off | on | 1200 | | | | | off | off | Option Baud Rate | | | | | | | per switches 3, 4, & 5 | | | | | | | on HPR05 PCB. | | 4 | (Unused) | | | | | | 6 | Parity | This s | witch is u | sed in c | onjunction with the | | | | parity | y enable s | witch. | | | | | ON | Selects E | ven pai | rity check and | | | | | transmis | sion | | | | | OFF | Selects C | Odd par | rity check and | | | | | transmis | sion | | | 7 | Paper Out Defeat | ON | Paper O | ut sensi | ng ignored. | | 8 | (Unused) | | | | | # **A66 Control Switch Functions** | # | Function | | Mear | | | | | |----|----------|-----------------------------------------------------------------------------------------------------------------------------------|--------|-----------------------------------|--------------------------------------------|---------|--| | 1 | ETX/ACK | | | | ON, an ACK characte | | | | | | | | | enever an ETX charact<br>print buffer. ETX | er is | | | | | | | | printed. When the swi | itch is | | | | | | | | are ignored. | tci is | | | 2 | DC1/DC3 | • | | | ON, a DC3 code will b | oe . | | | | | | | | h the interface if prin | | | | | | | npted. | | | • | | | 3, | BAUD | These | three | switche | es set the optional bai | ud | | | 4, | | | | | o BAUD switches on tl | | | | 5 | | operator control panel are set to OFF, the baud | | | | | | | | | rate selected by switches 3, 4, & 5 is used as th | | | | | | | | | data communication speed. To prevent print | | | | | | | | | buffer overflow, when operating at rates<br>above 300 baud, the system must use DC1/D<br>or ETX/ACK protocol, or must monitor and | | | | | | | | | | | | | | | | | | | | the Printer Ready interface line. | | | | | | | 3 | 4 | 5 | Baud Rate | ic. | | | | | off | off | off | 150 | | | | | | on | off | off | 600 | | | | | | off | on | off | 1800 | | | | | | on | on | off | 2000 | | | | | | off | off | on | 2400 | | | | | | on | off | on | 4800 | | | | | | off | on | on | 7200 | | | | | | on | on | on | 9600 | | | # **A66 Control Switch Functions continuea** | # | Function | | Mean | ing | | |----|----------|-------|---------|---------|----------------------------| | 6, | Font | These | switch | nes con | dition the printer to | | 7, | | recog | nize a | particu | lar language font for data | | 8 | | | | | ough the communications | | | | | | | e font selection, whether | | | | • | | | ches or by keyboard | | | | | - | | be temporarily overridden | | | | • | e seque | ence ES | C SYN (n). | | | | 6 | 7 | 8 | Meaning | | | | off | off | off | Default Typewriter | | | | | | | Paired | | | | on | off | off | Typewriter Paired | | | | off | on | off | Logical Bit Paired | | | | on | on | off | APL | | | | off | off | on | French AZERTY | | | | on | off | on | German | | | | off | on | on | Scandinavian | | | | on | on | on | NORSK | # **Specifications** Print Speed: Up to 40 characters per second with metalized printwheels. Character Set: 88, 92, or 96 printable characters per printwheel. Switch-selectable program support for APL and all English language printwheels. Printwheels: 88, 92, 96 character Xerox - Metal 96 character Diablo - Plastic Character Spacing: 10-pitch = 10 characters/inch (3.94 ch/cm) 12-pitch = 12 characters/inch (4.72 ch/cm) 15-pitch = 15 characters/inch (5.91 ch/cm) Proportional Space (PS) - see HMI, page 241. Column Spacing: 1/120 inch (.21mm) minimum. Print Line: 13.2 inches (335.3mm) 132 columns 10-pitch 158 columns 12-pitch 198 columns 15-pitch Print Buffer: 2688 bytes. Paper Width: 16.53 inches (419.9mm) maximum - friction feed without Top Paper Out switch. 16.00 inches (406.4mm) maximum - friction feed with Top Paper Out switch. 15.25 inches (387.4mm) maximum - full width with optional forms tractor (14.75 inches/-374.7mm between holes). 3.25 inches (82.55mm) minimum with forms tractor (2.75 inches/69.85mm between holes). Carriage Speed: 400 msec maximum for 13.1 inches (332.77mm) of motion. Tabulation: Left or right. Line Spacing: 1/48 inch (.53mm) minimum. Paper Feed: Bidirectional, except with unidirectional forms tractor and unidirectional pin feed platen. Paper Feed Speed: 4 inches (101.6mm) per second plus 40 msec (typical) settling delay time. Paper Thickness: .000 - .010 inch (.254mm) at low setting (1-3 part forms) .010 - .027 inch (.254 - .686mm) at high setting (4- 6 part forms). Sensors: End of ribbon, paper out, and cover open. Other Features: Self test; host program control through escape sequences; data receive/transmit speed selection. Power Requirements: Strappable for operation from nominal 100, 120, 220, or 240 volt (+10%/-15%) AC inputs, 49-61 Hz. 350W maximum power consumption. Factory preset for 120 VAC. Check your printer's serial plate for proper input power. # **Cabling Requirements** A standard RS-232-C interface cable is required for connection between the screen and the printer. This cable must be equipped with DB-25P connectors with the following pins connected: | PIN | CCITT | TELCO | | |-----|--------|--------|---------------------| | NO. | DESIG. | DESIG. | DESCRIPTION | | 1 | 101 | AA | Protective Ground | | 2 | 103 | BA | Transmitted Data | | 3 | 104 | BB | Received Data | | 4 | 105 | CA | Request To Send | | 6 | 107 | CC | Data Set Ready * | | 7 | 102 | AB | Signal Ground | | 20 | 108 | CD | Data terminal Ready | | | | | | <sup>\*</sup> Pin 6 must be HI to receive or transmit data. #### 1.0 INTRODUCTION The SA1403D Controller consists of a microprocessor based controller with on-board data separator logic and is able to control a maximum of four drives. The drives can be any combination of Shugart SA1000 fixed disk drives, SA800 floppy disk drives, or SA850 floppy disk drives. The floppy disk track formats are compatible with IBM 1D/2D track formats. The SA1403D can be mounted on the SA1000 drive. Commands are issued to the controller over a bidirectional bus connected to the host computer. The data separator/"serdes" logic serializes bytes and converts to FM/MFM data, and deserializes FM/MFM data into 8-bit bytes. Due to the microprogrammed approach utilized in the controller, limited diagnostic capabilities are implemented. This methodology increases fault isolation efficiency and reduces system down time. Error detection and correction will tolerate media imperfections up to 4-bit burst errors. NOTE: This device utilizes negative logic (i.e., 0V = logical 1) #### 1.1 SA1403D CONTROLLER FEATURES | OVERLAPPED SEEK | In multiple drive configurations the host can issue seeks to different drives | |-----------------|-------------------------------------------------------------------------------| | | without waiting for the first drive to complete its seek. | | AUTOMATIC SEEK | A seek command is implied in every data transfer command (READ, WRITE | |----------------|---------------------------------------------------------------------------------| | AND VERIFY | CHECK, etc.). If the heads are not positioned over the correct cylinder, a seek | | | is initiated and a cylinder verification is performed after the seek completes. | | FAULT DETECTION | Three classes of fault detection are provided for fault dia | agnosis: | |-----------------|-------------------------------------------------------------|----------| - Disk related faults. - 2) Controller related faults. - 3) Host command or I/O timing faults. Fault detection is available from the interface as a status message and is also visibly displayed on a row of status LED's on the controller PCB. | AUTOMATIC HEAD<br>AND CYLINDER<br>SWITCHING | If during a multi-block data transfer the end of a track is reached, the controller automatically switches to the next track. If the end of a cylinder is reached, the controller issues a seek and resumes the transfer. | |---------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | | DATA ERROR If a data error is detected during a disk data transfer, the controller indicates SENSING AND CORRECTION CORRECTION If a data error is detected during a disk data transfer, the controller indicates whether or not it is correctable. If correctable, it can be automatically corrected. (This applies to the SA1000 only. CRC error detection is used on floopy disc drives.) LOGICAL TO Logic2, Unit Number (LUN's) are independent of physical port numbers. All PHYSICAL DRIVE CORRELATION ON BOARD SECTOR A sector buffer is provided on the controller to eliminate the possibility of data overruns during a data transfer. EFFICIENT HOST A bidirectional bus between the controller and host provides a simple, yet effiINTERFACE cient communication path. In addition, a high level command set permits effective command initiation SECTOR Sector interleaving is programmable with up to a 16 way interleave. INTERLEAVE ODD PARITY The 8 data bits on the interface bus can have odd parity. Depending on user preference, parity can be disabled. FIXED SECTOR SIZE The sector size is fixed at 256 bytes of data for the SA1000. NUMBER OF DRIVES The controller will connect to a maximum of four (4) drives. The drives can be any combination of SA1000's and/or SA850's and/or SA800's #### 1.1.1 OPTIONAL FEATURES MICRO DIAGNOSTICS A set of diagnostic PROM's are available to allow stand alone diagnostic testing of both drive and controller. Reference Appendix A. ## 1.1.2 SYSTEM CONFIGURATION The controller and data separator comprise a single PCB that can be mounted onto the SA1000 drive. A maximum of four (4) drives may be connected as shown in Figure 2. # 1.2 TRACK FORMATS AND CAPACITY - 32 sectors of 256 bytes per sector (SA1000only). - 26 sectors of 256 bytes per sector (Floppy only). - D) 26 sectors of 128 bytes per sector (Floppy only.) IBM 1D/2D TRACK FORMAT Track format for Floppy Disk drives can be selected under program control - in real time. The track formats are: - 1) Single density, single sided 2) Single density, double sided - 3) Double density, single sided - 4) Double density, double sided | | 26 SECTOR | 32 SECTOR | |--------|-----------|-----------| | SA800 | 2001 | N/A | | SA850 | 4003 | N/A | | SA1002 | N/A | 16383 | | SA1004 | N/A | 32767 | TABLE I. Format/Capacity Relationship Maximum Logical Sector Address Shown ## 2.0 SPECIFICATION SUMMARY # 2.1 ENVIRONMENTAL LIMITS | | Operating | Storage | |-------------------|------------------------|------------------------| | Temperature F/C | 32º/0º to 131º/55º | -40%-40% to 167%75% | | Max. Wet Bulb | 85°F | non condensing | | Relative Humidity | 10% to 95% | 10% to 95% | | Altitude | Sea level to 10,000 ft | Sea level to 15,000 ft | #### 2.2 POWER REQUIREMENTS Three power supply voltages are required for the SA1400 series controllers. The maximum current requirements are as follows: - +5VDC ± 5% at 4.6 Amps - -5VDC ± 5% at 0.5 Amps - +24VDC ± 10% at 0.1 Amps Power is applied to the SA1400 series controller via J10 which is a 6 pin AMP Mate-N-Lok connector (P/N 1-38099-0) mounted on the component side of the board. The recommended mating connector, P10, is an AMP P/N 1-480270-0 utilizing AMP pins P/N 60619-1. The J10 pins are labeled on the connector. Figure 1 shows the pin assignments. FIGURE 1. J10 DC POWER CONNECTOR ### 2.3 PHYSICAL PARAMETERS Length: 13.7 inches (34.8cm) ± .030" (.076 cm) Width: 8.25 inches (21cm) ± .010" (.025 cm) Height: 0.5 inches (1.3cm) ± .030" (.076 cm) Weight: 1.12 lbs (0.5Kg) ± .010 lbs (0.25 g) # 3.0 SA1403D DISK DRIVE INTERFACE Shugart SA1000 and SA800/850 disk drives are interfaced to the controller via J1, J2, J3, J4 and J5. Refer to Figure 2 for connection block diagram. FIGURE 2. SA1403D INTERCONNECT DIAGRAM NOTE: The last physical device on the control cable (drive to be terminated) must be an SA1000. J1 is a 50 pin edge type connector which connects all drives in a daisy chain configuration. This connector carries control and data information for the floppy disk drives and control information only for the SA1000 disk drive. Maximum cable length should not exceed 20 feet (6 meters). The recommended mating connector for J1 is a 3M Scotchflex ribbon connector P/N 3415-0001. J2 through J5 are 20 pin socket type connectors used to radially connect the SA1000 data lines to the controller. Maximum cable length should not exceed 20 feet (6 meters). The recommended mating connector for J2 through J5 is a 3M Scotchflex P/N 3421-3000. Figure 3 shows the pinouts for J1 and J2 through J5. FIGURE 3. SA1403D DRIVE CONNECTOR PINOUTS #### 3.1 CABLE TERMINATION The last physical drive at the end of J1 (50 pin) cable must be properly terminated. Termination networks are provided on the drives (refer to SA1000, SA800 or SA850 OEM manuals for location of termination networks). Termination networks must be removed from all drives except the last drive on the cable to avoid multiple termination. NOTE: If a combination of fixed and floppy drive are used, the last drive at the end of the control cable must be an SA1000. #### 4.0 HOST CPU INTERFACE The SA1400 series controller interface is a general purpose 8 bit parallel DMA. The Host CPU is interfaced to the controller via connector J6, J6 is a 50 pin socket type connector. The recommended mating connector for J6 is a 3M Scotchflex ribbon connector P/N 3425-3000. The J6 interface cable should not exceed 20 feet (6 meters). #### 4.1 HOST CPU ELECTRICAL INTERFACE All Host CPU interface signals are negative true. The signals are "Asserted" at 0 VDC to 0.4 VDC. The signals are "Deasserted" or inactive at 2.5 VDC to 5.25 VDC. ## 4.1.1 HOST CPU INTERFACE TERMINATION All Host CPU interface timing lines are terminated with a 220/330 ohm network. The Host CPU adapter should be terminated in a similar fashion (see Figure 4). The devices driving the controller inputs should be open collector devices capable of sinking at least 48 milliamps to a voltage level of less than 0.5 VDC (7438 or equivalent). The devices receiving the controller outputs should be of the SCHMITT trigger type to improve the noise margin (74LS240, 74LS14, or equivalent). The Host adaptor should not load the bus with more than 1 standard TTL input load per line. FIGURE 4. HOST ADAPTOR BUS TERMINATION ## 4.1.2 HOST CPU SIGNAL INTERFACE The Host CPU signals are interfaced via J6. See figure 5 for J6 pinouts. NOTE: ALL SIGNALS ARE TTL NEGATIVE TRUE FIGURE 5. J6 HOST INTERFACE CONNECTOR PINOUT ## 4.2 SA1403D HOST BUS ## 4.2.1 THEORY OF OPERATIONS Disk commands are issued to the SA1403D via the host bus following a defined protocol. The host initiates a command sequence by selecting the controller on the bus. If the controller is not busy, it requests command bytes from the host for task execution. (Command structure is described in 4.5). Depending on the type of command, the controller will request either 6 or 10 bytes. Upon reception of the last command byte, the controller begins execution of the command. For the data transfer commands, a check is performed on the disk address and status flagged if it exceeds the drive limits. The data is stored in a sector buffer before transfer to the host or disk drive. This buffer eliminates any possibility of data overruns between the host and the disk. Upon completion of the command, the controller will send completion status to the host. Further delineation of the completion status may be requested by issuing the appropriate sense commands. Odd parity is generated by the SA1403D for all information that it puts on the I/O bus. If enabled, the SA1403D checks all information that it receives for odd parity. #### 4.3 SIGNAL DEFINITION Unidirectional Signals Driven By Controller - I/O Input/Output. When asserted, the data on the bus is driven by the controller; when deasserted, the data on the bus is driven by the host adapter. The host adapter will use this line to enable its drivers onto the data bus. - C/D Control/Data. When asserted the data transmitted across the bus will be the command or status bytes; when deasserted the data will be the disk data bytes. - BUSY This bit is asserted as a \*response to the SEL line from the host adapter and to indicate that the host bus is currently in use. - MSG Message. When asserted indicates that the command is completed and status has been transferred. The assertion of this bit is always followed with the assertion of I/O, and the assertion of REO, to cause a message byte transfer. - REQ Request. This bit operates in conjunction with I/O, C/D, & MSG. When asserted and I/O is asserted, REO will mean that the data on the host bus is driven by the controller. When asserted and I/O is deasserted, REQ will mean that the data is driven by the host adaptor (H/A). | 1/0 | C/D | MSG | Meaning | |-----------------------|-----------|---------|-----------------------------------------------------------------------------------------------------------------| | d<br>d<br>a<br>a<br>a | а d d а а | d d d a | Get command from H/A<br>Get data from H/A<br>Send data to H/A<br>Send status byte to H/A<br>Command done to H/A | ## TABLE 2. a = asserted, d = deasserted, H/A = host adaptor ## 4.4 UNIDIRECTIONAL SIGNALS DRIVEN BY HOST ADAPTOR ACK Acknowledge. This bit is asserted as a response to REO from the controller. The timing requirements on this signal with respect to the data is described in REQuest section. ACK must be returned for each REQ assertion - RST Reset. Assertion by the Host causes the controller to cease all operations and return to an idle condition. This signal is normally used during a power up sequence. A reset during a write operation would cause incorrect data to be written on the selected disk. The controller may take a maximum of 2 seconds to respond to the select sequence following deassertion of the RESET line. - SEL Select. When asserted indicates the beginning of the command transaction. The H/A asserts SEL to gain the attention of the controller. Data bit zero on the host bus must also be asserted during SEL time to select the controller address. The controller will return BUSY within approximately 1 µs. ## 4.4.1 DATA BUS BITS 0-7 (DB) These bidirectional data lines are used to transfer 8 bit parallel data to/from the Host adaptor. Bit 7 is most signifant bit. NOTE: All I/F lines utilize negative logic. #### 4.4.2 PARITY BIT This bit is asserted to maintain odd parity on all data and status information transfered to the Host. If enabled, the controller will test for odd parity on all command and data information transfered to the controller (see section 91). #### 4.5 HOST INTERFACE PROTOCOL There are 4 sequences required to initiate and complete a command to the SA1403D series controller: - 1) Controller Selection Sequence - 2) Command Transfer Squence - 3) Data Transfer Sequence - 4) Status and Message Transfer Sequence #### 4.5.1 CONTROLLER SELECTION SEQUENCE In order to gain the attention of the controller it is necessary to perform a selection sequence. Refer also to Figure 6. The Host must first test BSY to determine if the controller is available. If BSY is deasserted, the Host will assert data bit 0 (controller ID) and then assert SEL. The controller will then respond by asserting BSY. At this point the Host must deassert SEL and data bit 0. I/O will remain deasserted throughout the selection sequence. #### 4.5.2 COMMAND TRANSFER SEQUENCE Following the selection sequence the controller will assert REQ (see Figure 6). The Host will then place the first byte of the command descriptor block (see section 5.0) on the data bus. The Host will then assert ACK (if ACK is not asserted within 256 microseconds after the assertion of REQ, the controller will abort the command transfer sequence and attempt to transfer a status byte). The controller will respond by reading the byte on the data bus and then deasserting REQ. The Host then must deassert ACK to begin the next REQ/ACK handshake. This handshake must be completed to assure that all command and data bytes are transferred. FIGURE 6. SELECT SEQUENCE TIMING ## 4.5.3 DATA TRANSFER SEQUENCE Following the command transfer sequence, the controller will respond on one of four ways: - 1) Begin seeking the drive. - 2) Begin accepting write data from the Host. - 3) Begin transferring read data to the Host. - 4) Return status to the Host. If the command sent to the controller involves a data transfer (see Figure 7), the controller will deassert the C/D line to indicate a data transfer. If the data transfer is from the Host to the controller (write data) the I/O line will be deasserted. If the data transfer is from the controller to the Host (read data) the I/O line will be asserted. The controller will then set the REO line to request a byte transfer. The Host will respond by transferring a byte across the data bus and then asserting ACK (if ACK is not asserted within 256 microseconds after the assertion of REQ, the controller will abort the data transfer sequence and attempt to transfer a status byte - see section 4.5.4). The Host will then deassert ACK and wait for the next assertion of REQ. This handshake continues until all data has been transferred READ DATA TRANSFER SEQUENCE (CONTROLLER TO HOST) WRITE DATA TRANSFER SEQUENCE (HOST TO CONTROLLER) FIGURE 7. DATA TRANSFER SEQUENCE TIMING #### 4.5.4 STATUS AND MESSAGE TRANSFER SEQUENCE Following a command transfer or data transfer, the controller will initiate a status byte and completion message transfer. When a status byte transfer is required, the controller will assert C/D and I/O (see Figure 8). The controller will then assert REQ. The Host must then read the status byte on the data bus and then assert ACK (if ACK is not asserted within 256 microseconds after the assertion of REQ, REQ will be deasserted. REQ will then be asserted again). The controller will then deassert REQ. The host will then deassert ACK. Following the status byte transfer, a completion message byte of all zero's will be transfered to indicate operation complete. The controller will assert the MSG line (along with I/O and C/D) and then assert REO. The Host may read the completion message byte on the data bus and assert ACK (if ACK is not asserted within 256 microseconds, the controller will deassert the MSG line and attempt to transfer a status byte). The controller will respond by deasserting REO. The Host will then deassert ACK. At this point BSY and all other controller I/O lines will be deasserted and the controller will return to an IDLE LOOP awaiting the next selection sequence. FIGURE 8. STATUS AND COMPLETION SEQUENCE TIMING #### 5.0 CONTROLLER COMMAND DESCRIPTOR BLOCK Following the controller selection sequence the controller will request a command descriptor block (CDB) which, depending on the class of command, may be either 6 or 10 bytes in length. The first byte of the CDB contains the command class and the command operation code. The remaining bytes specify the drive logical unit number (LUN), logical sector address, number of sectors to be transfered or a destination device (Copy Command), and a control field byte. Commands are categorized into four classes as indicated: Class 0 - Utility, Data Transfer and Status Commands Class 1 - Disk Copy Commands Class 2-5.7 - Reserved Class 6 - Floppy Disk Track Format Selection The command descriptor blocks in Command Class 0 and 6 are 6 bytes long, and those in Class 1 are 10 bytes long. The controller will check all incoming command descriptor blocks for validity and will also check (if enabled) all CDB's and data for odd parity (see section 9.1). A parity error will cause an immediate halt of the command or data transfer. This will not cause incorrect data to be written because the write does not occur until the sector buffer has been filled. An error in the command structure will cause a status byte transfer to occur upon completion of the CDB transfer. ### 5.1 COMMAND DESCRIPTION (CLASS 0) #### \*\*WARNING!\*\* Commands READ and WRITE require that the floppy diskette used be formatted. If unformatted, the controller will appear to "hang" - i.e., continue waiting for a data address mark. (Reset to clear this condition if it should occur). ## Opcode (Hex) #### Description - Test drive ready Selects the drive and verifies drive ready. The ready condition is indicated by the status byte. A not-ready drive will cause bit 1 of the status byte to be set. - 01 Recalibrate. Positions the R/W of selected drive arm to Track 00, clears error status in the drive. - Request Syndrome returns two bytes of error offset and syndrom to the Host System for Host error correction capability (see Table 3). The first byte is offset in the data field of the error location. The most significant 3 bits of the second byte point to the beginning of the error location. The least significant 4 bits of the second byte are the syndrome which is a data correction mark to be exclusive or ed with the faulty data. This command is only valid of the automatic data correction has been disabled. TABLE 3 - Request Sense. This command must be issued immediately after an error. It returns 4 bytes of drive and controller sense for the specified LUN. (See copy block for exception) - O4 Format Drive. Formats all blocks with ID field set according to interleave code. The data field contains E5 Hex. - 05 Spare. 06 - Format Track. \*Formats the specified track with bad block flag cleared in all blocks of that track. Writes F5 Hex in the data fields - 07 Format Bad Track \*(bad block flag). Formats the specified track with bad block flag set in the ID fields (bit 7 of the Head Address byte set). Writes E5 Hex in the data fields. - Read. Reads the specified number of blocks starting from initial block address given in the CDB. (See Warning above!) - 09 Reserved. - 0A Write. Writes the specified number of blocks starting from initial block address given in the CDB. (See Warning above!) - 0B Seek. Initiates seek to specified block and immediately returns completion status before the seek is complete for those drives capable of overlap seek. The track is addressed via the logical sector address, which may be any address within the desired track. ## 5.1.2 COMMAND DESCRIPTION (CLASS 1) ### Opcode (Hex) Description Copy Blocks. Copies the specified number of blocks from Source LUN starting at the specified Logical address to Destination LUN starting at the specified Logical address. The number of sectors transferred may be from 1 to 256. The completion status byte will indicate the source LUN. If an error occurs, a Request Sense command is issued to the source LUN. The sense will indicate the type of error for the appropriate LUN. Note the data in the blocks will be truncated or appended with undefined data if the Source and Destination block sizes are not the same (e.g. Source block size - 128 bytes/sector, and Destination block size - 256 bytes/sector). #### 5.1.3 COMMAND DESCRIPTION (CLASS 6) | Opcode | | |--------|-------------| | (Hex) | Description | 01 02 03 Switch Define Floppy Disk Track Format. The Track format code in byte 6 of the CDB defines the track format for the LUN. The Track Format Codes are as follows: # Track Format Code (Hex) Description | 00 | Single Density, Single Sided. All tracks - FM recording, 128 bytes/sector, 26 | |----|-------------------------------------------------------------------------------| | | sectors/track | Single Density, Double Sided. All tracks - FM recording, 128 bytes/sector, 26 sectors/track. Double Density, Single Sided. Side 0, Cylinder 0 - FM Recording, 128 bytes/sector, 26 sectors/track. All other tracks - MFM recording, 256 bytes/sector, 26 sectors/track. Double Density, Double Sided. Side 0, Cylinder 0 - FM recording, 128 bytes/sector, 26 sectors/track. All other track - MFM recording, 256 bytes/sector, 26 sectors/track. NOTE: If track format information for floppy is not specified after each reset or power-on, the default mode will be taken from the drive type selection dipswitch as follows: | Setting | Mode | |---------|-------------------------------------------------------------| | OFF-ON | Single density, single sided (same as track format code 00) | | OFF-OFF | Single density, double sided (same as track format code 01) | Refer to Section 9.2 for switch setup instructions. ## 5.2 COMMAND FORMAT ## 5.2.1 CLASS 0 COMMANDS | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | |---------|---------------------|-----|---|--------|----|------|---|---|--| | byte #1 | C | 0 0 | ) | opcode | | | | | | | byte #2 | | LUN | | | •• | (MS) | | | | | byte #3 | logical adr1 • • | | | | | | | | | | byte #4 | logical adr0** (LS) | | | | | | | | | | byte #5 | number of blocks* | | | | | | | | | | byte #6 | control*** | | | | | | | | | - \* Interleave factor for Format, Check Track Format commands. - \*\*Refer to Section 5.5 Logical Address. - \*\*\*The control field is defined as follows: CONTROL FIELD ## 5.2.2 CLASS 1 COMMANDS where 's' indicates the source device and 'd' indicates the destination device. <sup>\*</sup>Refer to Section 5.5 Logical Address ## 5.2.3 CLASS 6 COMMANDS | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | |---------|-------------------|-----|---|--------|---|---|---|---|--|--|--| | byte #1 | 1 | 1 | 0 | opcode | | | | | | | | | byte #2 | L | .UN | | N/A | | | | | | | | | byte #3 | N/A | | | | | | | | | | | | byte #4 | N/A | | | | | | | | | | | | byte #5 | N/A | | | | | | | | | | | | byte #6 | Track Format Code | | | | | | | | | | | NOTE: See Class 6 Command Description for more information and default modes for floppy drives. ## **5.3 STATUS FORMAT** ## 5.3.1 Completion Status Byte Format At the normal termination of a command or following a fatal error, the controller will cause a status byte to be transferred from the controller to the Host. Bit 0, the least significant bit of the status byte, will be set equal to 1 if the controller detects a parity error during a command or data transfer to the controller. Bit 1 will be set = 1 if the controller detects an error condition. Bits 5 and 6 represent the LUN of the device where the error occured. If no error occurs, bit 0 - 4 will be set equal to 0. Following the transfer of the status byte, the MSG line will be asserted to indicate a completion message. At this time the message consists of a single byte transfer with all bits set = 0. Prior to an error condition the controller, unless diabled (see section 5.2.1 Control Field), will retry 3 times before posting the error. - Bit 0 Parity error during transfer from host to controller. - Bit 1 Error occured during command execution. - Bit 2-4 Spare (set to zero). - Bit 5-7 Logical unit number of the drive. #### 5.3.2 DRIVE AND CONTROLLER SENSE BLOCK Following an error indication from the status byte, the Host may perform a REQUEST SENSE command to obtain more detailed information about the error. The REQUEST SENSE command will transfer a block of 4 bytes to the Host system. \*Refer to Section 5.5 Logical Address ## **5.4 ERROR CODES** ## 5.4.1 TYPE 0 (DRIVE) ERROR CODES - 0 No error - No Index signal No Seek Complete - Write Fault (SA1000 only) - 4 Drive not ready - Drive not selected (SA1000 only) - 6 No Track 00 ## 5.4.2 TYPE 1 (CONTROLLER) ERROR CODES - 0 ID read error. ECC or CRC (floppy) error in the ID field (uncorrectable). - Uncorrectable data error during a read. - 2 ID Address Mark not found (possibly unformated disk). - 3 Data Address Mark not found. - 4 Record not found. Found correct cylinder and head but not sector. - 5 Seek error. R/W head positioned on a wrong cylinder and/or selected a wrong head. - 6 DMA Data time out error. No Host acknowledge within 256μs. - 7 Write protected. (SA800/850 only) 8 Correctable data field error. ECC - Correctable data field error. ECC error (automatic correction if not disabled). - 9 Bad track found - A Format Error. The controller detected that during the Check Track command, the format on the drive was not as expected. # 5.4.3 TYPE 2 (COMMAND) ERROR CODES 0 Invalid Command received from the host. Illegal logical sector address. Address is beyond the maximum address for the type of drive. 2 Illegal function for the specified drive. ## 5.5.4 TYPE 3 (MISC) ERROR CODES 0 RAM error. Data error detected during Sector buffer RAM diagnostic. ## 5.5 LOGICAL ADDRESS The logical address is computed as follows: Logical adr = (CYADR \* HDCYL + HDADR) \* SETRK + (SEADR) Where: CYADR = cylinder address HDADR = head address SEADR = sector address HDCYL = number of heads per cylinder SETRK = number of neads per cylinder SETRK = number of sectors per track Bit 0 of Logical adr 0 = the least significant bit. Bit 4 of Logical adr 2 = the most significant bit. Note: All addresses begin with 00. ### **6.0 SECTOR INTERLEAVE CODES** In order to tailor host system data transfer speed to the disk rotational speed, sector interleaving is offered. Sixteen interleave codes are offered numbered 1 to 16. Not all interleave codes will result in optimum sector interleave, therefore the interleave should be chosen carefully. In order to maintain IBM floppy disk compatibility in interleave code of 1 should be used. This will result in a non-interleave condition. # 6.1 SELECTING THE RIGID DISK INTERLEAVE CODE The interleave code given during the format command is used to calculate the logical sector number for the rigid disk as follows: Logical Sector = (Physical Sector × Interleave code) (mod 32). Note: when the logical sector number exceeds 31 the next logical sector is the lowest available physical sector. This does not always create a true modulo function. Two examples of interleave codes are shown: | Interleave code | e of 2: | | | | | | | | | | | | | | | | |-----------------|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----| | Physical: | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | | Logical: | 0 | 2 | 4 | 6 | 8 | 10 | 12 | 14 | 16 | 18 | 20 | 22 | 24 | 26 | 28 | 30 | | | | | | | | | | | | | | | | | | | | Physical: | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 | | Logical: | 1 | 3 | 5 | 7 | 9 | 11 | 13 | 15 | 17 | 19 | 21 | 23 | 25 | 27 | 29 | 31 | | Interleave code | e of 11: | | | | | | | | | | | | | | | | | Physical: | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | | Logical: | 0 | 11 | 22 | 1 | 12 | 23 | 2 | 13 | 24 | 3 | 14 | 25 | 4 | 15 | 26 | 5 | | _ | | | | | | ٠. | | | | | | | | | | | | Physcial: | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 | | Logical: | 16 | 27 | 6 | 17 | 28 | 7 | 18 | 29 | 8 | 19 | 30 | 9 | 20 | 31 | 10 | 21 | | Code | Number of Disk Revolutions<br>Required to Read One Track | | | | | | | |----------|----------------------------------------------------------|--------|----|--|--|--|--| | $\cap$ 1 | 3 | 4.7μs | 2 | | | | | | 8 | 4 | 7.0µs | 3 | | | | | | 6 | 6 | ′9.4µs | 4 | | | | | | 5 , | 7 | 11.7µs | 5 | | | | | | 4 | 8 | 16.4μs | 7 | | | | | | 3 | 11 | 23.4μs | 10 | | | | | | 2 | 16 | 35.1µs | 15 | | | | | | 1 | 32 | 72.5µs | 31 | | | | | <sup>(</sup>for SA1400 series controllers operating with SA1000 series drives - double density, 32 sectors, 256 bytes/sector.) Note: Other codes will work, but require more revolutions of the disk to read all sectors of one track. TABLE 3. INTERLEAVE CODE SELECTION CHART\* # 7.0 DIAGNOSTIC PHILSOPHY ## 7.1 BOARD RESIDENT MICRODIAGNOSTIC Fault Isolation Microdiagnostic (Optional) The controller can be further checked out off-line by initiating explicit microdiagnostic routines via optional firmware diagnostic sets. The routines are initiated by a set of control switches. Errors will be dislayed in a set of LED's. Each microdiagnostic checks the funtionality of a particular section of the controller and is able to isolate failures in the following major categories: ALU Registers Sector Buffer ECC Logics Fault-isolation techniques can be concentrated on the failing section. ## **8.0 STATUS LED ERROR INTERPRETATION** Drive/controller error conditions are displayed on the 8 LED display lights provided near the J10 DC power connector (see Figures 11). The following list of hexadecimal numbered error codes describe error meanings. Note that these error codes do not necessarily match the request sense block error codes. LED number 7 is the MSB. | 01 | No Index Detected | |------------|--------------------------------------------------------------------------------------| | 02 | No Track Zero Detected | | 03 | Illegal Logical Sector Address - beyond maximum sectors available for type of drive | | 04 | Drive Not Selected (SA1000 only) | | 05 | No Seek Complete Detected | | 06 | ID Address Mark Not found (unformatted) | | 07 | Data Address Mark Not found | | 08 | Seek Error - R/W head not positioned on correct track | | 09 | Record Not found - found correct cylinder and head but not sector | | 0 <b>A</b> | ID ECC or CRC error (uncorrectable) | | 0B | DMA Timeout Error - no Host acknowledge within 256μsec after request. | | 0C | Invalid Command Received from Host | | 0D | Incorrect Data Address Mark | | 0E | Incorrect ID Address Mark | | OF | Incorrect Cylinder Address | | 10 | Incorrect Sector Address | | 11 | Incorrect Head Address | | 12 | Uncorrectable Data Field ECC or CRC error | | 13 | Correctable Data Field ECC error | | 14 | Drive Not Ready | | 15 | Write Fault (SA1000 and SA4000/4100 only) | | 16 | Spare | | 17 | Write Protected (SA800/850 only) | | 18 | RAM Diagnostic Error | | 19-1F | Spare | | 20 | Parity Error | | 21 | Bad Sector found - a sector within a track that has been flagged bad has been found. | | | | 22 Invalid function for this drive type. ## 9.0 CONTROLLER OPTION SELECTION #### 9.1 PARITY SELECT JUMPERS Odd parity may be used by the Host system for data integrity verification. The controller will always output odd parity to the Host system. Odd parity checking by the controller may be allowed or inhibited by moving a 3 position jumper plug at W2 located near the J6 Host connector (see Figure 11). With jumper at position A + B the controller will test for odd parity on all data input to the controller. With jumper at position B + C the controller will not check for parity (normally shipped in A + B). # 9.2 DRIVE TYPE SELECTION DIPSWITCH The dipswitch settings for various types of drives for the SA1403D are shown below: Prom Set AS30 - I, II, III, IV CUSTOMER FIRMWARE: (DIP SWITCH set-up procedure) Location: 2H | Switch Bits | 8 | 7 | 6 | 5 | 4 | 3 | | |---------------------|------------------------|---|------------------|----|--------------------|----|--| | Field<br>Definition | LUN 0<br>Drive<br>Type | | LU<br>Dri<br>Typ | ve | LUI<br>Driv<br>Typ | ve | | | Drive<br>Type | Swi<br>Sett | | Description | | |------------------|------------------------|------------------------|------------------------------------|--| | Турс | Even | Odd | Description | | | 0<br>1<br>2<br>3 | on<br>on<br>off<br>off | on<br>off<br>on<br>off | SA1002<br>SA1004<br>SA800<br>SA850 | | 2 heads, 256 cylinders 4 heads, 256 cylinders 1 head, 77 cylinders 2 heads, 77 cylinders 2 LUN 3 Drive Type 1 O F F 0 EXAMPLE: LOCATION: 23 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | |------------------------|---|------------------------|----|------------------------|-----|------------------------|---| | LUN 0<br>Drive<br>Type | | LUN 1<br>Drive<br>Type | | LUN 2<br>Drive<br>Type | | LUN 3<br>Drive<br>Type | | | on on off on | | on | on | off . | off | off | | Drive 0 is set up for SA1002 Drive 1 is set up for SA800 Drive 1 is set up for SA800 Drive 2 is set up for SA1004 Drive 3 is set up for SA850 #### 10.0 TRACK FORMAT DESCRIPTION #### 10.1 26 SECTOR FORMAT The 26 sector format is an IBM compatible format which employes FM single density encoding on all tracks of the single density format (IBM 3740 compatible) and on track 0, side 0 of the double density format. This format vields 26 sectors of 128 bytes per sector. The remainder of the tracks on the double density formats are encoded with MFM double density which yields 26 sectors of 256 bytes per sector (IBM system 34 compatible). Figure 9 shows the two type of encoding utilized. FIGURE 9. 26 SECTOR FORMAT - SA800/850 # 10.2 32 SECTOR FORMAT The 32 sector format employs MFM encoding on all tracks of the SA1000. This format yields 32 sectors of 256 bytes per sector. Figure 10 shows the 32 sector format. FIGURE 10. 32 SECTOR FORMAT - SA1000 #### 11.0 DRIVE JUMPER SETTINGS ## 11.1 JUMPER SETTINGS FOR SA800/801 FLOPPY The following information is contained in the SA800/801 Diskette Storage Drive OEM Manual, Shugart Associates, 1977. | | Jumper Name | Function (Enabled if Jumper Installed) | | | | | |-----|-------------------------------------------|----------------------------------------------------------------|--|--|--|--| | | Α | Install enable DRSEL to drive selection | | | | | | | В | Install, Head Load on Drive Select | | | | | | | С | Remove, Drive Select loads heads | | | | | | | D | Remove, In Use to LED is disabled | | | | | | | DC | Remove, Disable Disk Change to return to controller | | | | | | | DS | Install enable stepper on Drive Select | | | | | | | DS1-4 | Install one only, DS1 = LUN 0 (Drive Select) | | | | | | | HL | Remove, Head load on Drive Select | | | | | | | L | Jumper for -5V (remove for -15V), controller requires -5V only | | | | | | , - | T1 | Remove, Head Load terminator | | | | | | | T2 | Install, Pullup for Drive Select lines | | | | | | | T3 | Install, Direction terminator | | | | | | | T4 | Install, Step terminator | | | | | | | T5 | Install, Write Data terminator | | | | | | | T6 | Install, Write Gate terminator | | | | | | | X | Install, Head Load Enable | | | | | | | <b>Y</b> | Remove, Disable Hdld from driving LED | | | | | | | Z | Install drive select drives in use LED | | | | | | | 800 | Install, enables 800 index only operation | | | | | | | 801 | Remove, disables 801 mode operation | | | | | | | 11.2 HIMDED SETTINGS FOR SASSOVSE1 ELODDY | | | | | | ## 11.2 JUMPER SETTINGS FOR SA850/851 FLOPPY # Jumper Name Function (Enabled if Jumper Installed) Controller is compatible with the factory jumper configuration. See SA850/851 OEM Manual. Note: Jumpers must be set for SA850, not SA851 # 11.3 JUMPER SETTINGS FOR SA1000 WINCHESTER # Jumper Name Function (Enabled if Jumper Installed) Controller is compatible with the factory jumper configuration. See SA1000 OEM Manual. FIGURE 11. SA1403D DIMENSIONAL DRAWING FIGURE 12. SA1403D FUNCTIONAL BLOCK DIAGRAM Notes # WESTERN DIGITAL C O R P O R A T / O N FD179X-02 # Floppy Disk Formatter/Controller Family #### **FEATURES** - TWO VFO CONTROL SIGNALS RG & VFOE - SOFT SECTOR FORMAT COMPATIBILITY - AUTOMATIC TRACK SEEK WITH VERIFICATION - ACCOMMODATES SINGLE AND DOUBLE DENSITY FORMATS IBM 3740 Single Density (FM) IBM System 34 Double Density (MFM) Non IBM Format for Increased Capacity - READ MODE Single/Multiple Sector Read with Automatic Search or - Entire Track Read Selectable 128, 256, 512 or 1024 Byte Sector Lengths - WRITE MODE Single/Multiple Sector Write with Automatic Sector Search - Entire Track Write for Diskette Formatting - SYSTEM COMPATIBILITY Double Buffering of Data 8 Bit Bi-Directional Bus for Data, Control and Status DMA or Programmed Data Transfers All Inputs and Outputs are TTL Compatible On-Chip Track and Sector Registers/Comprehensive Status Information - PROGRAMMABLE CONTROLS Selectable Track to Track Stepping Time Side Select Compare - INTERFACES TO WD1691 DATA SEPARATOR - WINDOW EXTENSION - INCORPORATES ENCODING/DECODING AND ADDRESS MARK CIRCUITRY - FD1792/4 IS SINGLE DENSITY ONLY - FD1795/7 HAS A SIDE SELECT OUTPUT #### 179X-02 FAMILY CHARACTERISTICS | FEATURES | 1791 | 1792 | 1793 | 1794 | 1795 | 1797 | |-----------------------|------|------|------|------|------|------| | Single Density (FM) | х | X | X | х | X | х | | Double Density (MFM) | Х | | X | | х | X | | True Data Bus | | | X | Х | | X | | Inverted Data Bus | х | Х | | | х | | | Write Precomp | X | X | X | X | х | X | | Side Selection Output | | | | | х | X | #### **APPLICATIONS** 8" FLOPPY AND 51/4" MINI FLOPPY CONTROLLER SINGLE OR DOUBLE DENSITY CONTROLLER/FORMATTER FD179X SYSTEM BLOCK DIAGRAM ## PIN OUTS | PIN<br>NUMBER | PIN NAME | SYMBOL | FUNCTION | |---------------|-----------------------|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 1 | NO CONNECTION | NC | Pin 1 is internally connected to a back bias generator and must be left open by the user. | | 19 | MASTER RESET | MR | A logic low (50 microseconds min.) on this input resets the device and loads HEX 03 into the command register. The Not Ready (Status Bit 7) is reset during MR ACTIVE. When MR is brought to a logic high a RESTORE Command is executed, regardless of the state of the Ready signal from the drive. Also, HEX 01 is loaded into sector register. | | 20 | POWER SUPPLIES | Vss | Ground | | 21 | | V∞ | +5V ±5% | | 40 | | Voo | +12V ±5% | | COMPUTE | R INTERFACE: | | | | 2 | WRITE ENABLE | WE | A logic low on this input gates data on the DAL into the selected register when $\overline{\text{CS}}$ is low. | | 3 | CHIPSELECT | CS . | A logic low on this input selects the chip and enables computer communication with the device. | | 4 | READ ENABLE | RE | A logic low on this input controls the placement of data from a selected register on the DAL when $\overline{\text{CS}}$ is low. | | 5,6 | REGISTER SELECT LINES | A0, A1 | These inputs select the register to receive/transfer data on the DAL lines under $\overline{RE}$ and $\overline{WE}$ control: | | İ | | | CS A1 A0 RE WE | | ! | | | 0 0 0 Status Reg Command Reg<br>0 0 1 Track Reg Track Reg<br>0 1 0 Sector Reg Sector Reg<br>0 1 1 Data Reg Data Reg | | 7-14 | DATA ACCESS LINES | DALO-DAL7 | Eight bit Bidirectional bus used for transfer of data, control, and status. This bus is receiver enabled by WE or transmitter enabled by RE. Each line will drive 1 standard TTL load. | | 24 | CLOCK | CLK | This input requires a free-running 50% duty cycle square wave clock for internal timing reference, 2 MHz $\pm$ 1% for 8" drives, 1 MHz $\pm$ 1% for mini-floppies. | | 38 | DATA REQUEST | DRQ | This open drain output indicates that the DR contains assembled data in Read operations, or the DR is empty in Write operations. This signal is reset when serviced by the computer through reading or loading the DR in Read or Write operations, respectively. Use 10K pull-up resistor to +5. | | 39 | INTERRUPT REQUEST | INTRQ | This open drain output is set at the completion of any command and is reset when the STATUS register is read or the command register is written to. Use 10K pull-up resistor to +5. | | FLOPPY D | DISK INTERFACE: | | | | 15 | STEP | STEP | The step output contains a pulse for each step. | | 16 | DIRECTION | DIRC | Direction Output is active high when stepping in, active low when stepping out. | | 17 | EARLY | EARLY | Indicates that the WRITE DATA pulse occuring while Early is active (high) should be shifted early for write precompensation. | | 18 | LATE | LATE | Indicates that the write data pulse occurring while Late is active (high) should be shifted late for write precompensation. | | PIN<br>NUMBER | PIN NAME | SYMBOL | FUNCTION | |---------------|---------------------------------------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 22 | TEST | TEST | This input is used for testing purposes only and should be tied to +5V or left open by the user unless interfacing to voice coil actuated steppers. | | 23 | HEAD LOAD TIMING | HLT | When a logic high is found on the HLT input the head is<br>assumed to be engaged. It is typically derived from a 1 shot<br>triggered by HLD. | | 25 | READ GATE<br>(1791, 1792, 1793, 1794) | RG | This output is used for synchronization of external data<br>separators. The output goes high after two Bytes of zeros in<br>single density, or 4 Bytes of either zeros or ones in double<br>density operation. | | 25 | SIDE SELECT OUTPUT<br>(1795, 1797) | sso | The logic level of the Side Select Output is directly controlled by the 'S' flag in Type II or III commands. When U = 1, SSO is set to a logic 1. When U = 0, SSO is set to a logic 0. The SSO is compared with the side information in the Sector I.D. Field. If they do not compare Status Bit 4 (RNF) is set. The Side Select Output is only updated at the beginning of a Type II or III command. It is forced to a logic 0 upon a MASTER RESET condition. | | 26 | READ CLOCK | RCLK | A nominal square-wave clock signal derived from the data<br>stream must be provided to this input. Phasing (i.e. RCLK<br>transitions) relative to RAW READ is important but polarity<br>(RCLK high or low) is not. | | 27 | RAW READ | RAW READ | The data input signal directly from the drive. This input shall be a negative pulse for each recorded flux transition. | | 28 | HEAD LOAD | HLD | The HLD output controls the loading of the Read-Write head against the media. | | 29 | TRACK GREATER THAN 43 | TG43 | This output informs the drive that the Read/Write head is positioned between tracks 44-76. This output is valid only during Read and Write Commands. | | - 30 | WRITE GATE | WG | This output is made valid before writing is to be performed on the diskette. | | 31 | WRITE DATA | WD | A 200 ns (MFM) or 500 ns (FM) output pulse per flux transition. WD contains the unique Address marks as well as data and clock in both FM and MFM formats. | | 32 | READY | READY | This input indicates disk readiness and is sampled for a logic high before Read or Write commands are performed. If Ready is low the Read or Write operation is not performed and an interrupt is generated. Type I operations are performed regardless of the state of Ready. The Ready input appears in inverted format as Status Register bit 7. | | 33 | WRITE FAULT<br>VFO ENABLE | WF/VFOE | This is a bi-directional signal used to signify writing faults at the drive, and to enable the external PLO data separator. When WG = 1, Pin 33 functions as a WF input. If WF = 0, any write command will immediately be terminated. When WG = 0, Pin 33 functions as a VFOE output. VFOE will go low during a read operation after the head has loaded and settled (HLT = 1). On the 1795/7, it will remain low until the last bit of the second CRC byte in the ID field. VFOE will then go high until 8 bytes (MFM) or 4 bytes (FM) before the Address Mark. It will then go active until the last bit of the second CRC byte of the Data Field. On the 1791/3, VFOE will remain low until the end of the Data Field. This pin has an internal 100K Ohm pull-up resistor. | | 34 | TRACK 00 | TR00 | This input informs the FD179X that the Read/Write head is positioned over Track 00. | | PIN NUMBER | PIN NAME | SYMBOL | FUNCTION | |------------|----------------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 35 | INDEX PULSE | ĪĒ | This input informs the FD179X when the index hole is encountered on the diskette. | | 36 | WRITE PROTECT | WPRT | This input is sampled whenever a Write Command is received. A logic low terminates the command and sets the Write Protect Status bit. | | 37 | DOUBLE DENSITY | DDEN | This input pin selects either single or double density operation. When $\overline{\text{DDEN}}=0$ , double density is selected. When $\overline{\text{DDEN}}=1$ , single density is selected. This line must be left open on the 1792/4. | #### GENERAL DESCRIPTION The FD179X are N-Channel Silicon Gate MOS LSI devices which perform the functions of a Floppy Disk Formatter/Controller in a single chip implementation. The FD179X, which can be considered the end result of both the FD1771 and FD1781 designs, is IBM 3740 compatible in single density mode (FM) and System 34 compatible in Double Density Mode (MFM). The FD179X contains all the features of its predecessor the FD1771, plus the added features necessary to read/write and format a double density diskette. These include address mark detection, FM and MFM encode and decode logic, window extension, and write precompensation. In order to maintain compatibility, the FD1771, FD1781, and FD179X designs were made as close as possible with the computer interface, instruction set, and I/O registers being identical. Also, head load control is identical. In each case, the actual pin assignments vary by only a few pins from any one to another The processor interface consists of an 8-bit bi-directional bus for data, status, and control word transfers. The FD179X is set up to operate on a multiplexed bus with other bus-oriented devices. The FD179X is TTL compatible on all inputs and outputs. The outputs will drive ONE TTL load or three LS loads. The 1793 is identical to the 1791 except the DAL lines are TRUE for systems that utilize true data busses. The 1795/7 has a side select output for controlling double sided drives, and the 1792 and 1794 are "Single Density Only" versions of the 1791 and 1793 respectively. On these devices, DDEN must be left open. #### ORGANIZATION The Floppy Disk Formatter block diagram is illustrated on page 5. The primary sections include the parallel processor interface and the Floppy Disk interface. Data Shift Register — This 8-bit register assembles serial data from the Read Data input (RAW READ) during Read operations and transfers serial data to the Write Data output during Write operations. Data Register — This 8-bit register is used as a holding register during Disk Read and Write operations. In Disk Read operations the assembled data byte is transferred in parallel to the Data Register from the Data Shift Register. In Disk Write operations information is transferred in parallel from the Data Register to the Data Shift Register. When executing the Seek command the Data Register holds the address of the desired Track position. This register is loaded from the DAL and gated onto the DAL under processor control. Track Register — This 8-bit register holds the track number of the current ReadWrite head position. It is incremented by one every time the head is stepped in (towards track 76) and decremented by one when the head is stepped out (towards track 00). The contents of the register are compared with the recorded track number in the ID field during disk Read, Write, and Verify operations. The Track Register can be loaded from or transferred to the DAL. This Register should not be loaded when the device is busy. Sector Register (SR) — This 8-bit register holds the address of the desired sector position. The contents of the register are compared with the recorded sector number in the ID field during disk Read or Write operations. The Sector Register contents can be loaded from or transferred to the DAL. This register should not be loaded when the device is busy. Command Register (CR) — This 8-bit register holds the command presently being executed. This register should not be loaded when the device is busy unless the new command is a force interrupt. The command register can be loaded from the DAL, but not read onto the DAL. Status Register (STR) — This 8-bit register holds device Status information. The meaning of the Status bits is a function of the type of command previously executed. This register can be read onto the DAL, but not loaded from the DAL **CRC Logic** — This logic is used to check or to generate the 16-bit Cyclic Redundancy Check (CRC). The polynomial is: $G(x) = x^{16} + x^{12} + x^6 + 1$ . The CRC includes all information starting with the address mark and up to the CRC characters. The CRC register is preset to ones prior to data being shifted through the circuit. Arithmetic/Logic Unit (ALU) — The ALU is a serial comparator, incrementer, and decrementer and is used for register modification and comparisons with the disk recorded ID field. Timing and Control — All computer and Floppy Disk Interface controls are generated through this logic. The internal device timing is generated from an external crystal clock. The FD179X has two different modes of operation according to the state of $\overline{DDEN}$ . When $\overline{DDEN} = 0$ double density (MFM) is assumed. When $\overline{DDEN} = 1$ , single FD179X BLOCK DIAGRAM density (FM) is assumed. 1792 & 1794 are single density only. AM Detector — The address mark detector detects ID, data and index address marks during read and write operations. ### PROCESSOR INTERFACE The interface to the processor is accomplished through the eight Data Access Lines $(\overline{\text{DAL}})$ and associated control signals. The $\overline{\text{DAL}}$ are used to transfer Data, Status, and Control words out of, or into the FD179X. The $\overline{\text{DAL}}$ are three state buffers that are enabled as output drivers when Chip Select (CS) and Read Enable ( $\overline{\text{RE}}$ ) are active (low logic state) or act as input receivers when $\overline{\text{CS}}$ and Write Enable ( $\overline{\text{WE}}$ ) are active. When transfer of data with the Floppy Disk Controller is required by the host processor, the device address is decoded and CS is made low. The address bits A1 and A0, combined with the signals RE during a Read operation or WE during a Write operation are interpreted as selecting the following registers: | | A1 | - A0 | READ (RE) | WRITE (WE) | |---|----|------|-----------------|------------------| | Γ | 0 | 0 | Status Register | Command Register | | ļ | 0 | .1 | Track Register | Track Register | | 1 | 1 | 0 | Sector Register | Sector Register | | ١ | 1 | 1 | Data Register | Data Register | During Direct Memory Access (DMA) types of data transfers between the Data Register of the FD179X and the processor, the Data Request (DRQ) output is used in Data Transfer control. This signal also appears as status bit 1 during Read and Write operations. On Disk Read operations the Data Request is activated (set high) when an assembled serial input byte is transferred in parallel to the Data Register. This bit is cleared when the Data Register is read by the processor. If the Data Register is read after one or more characters are lost, by having new data transferred into the register prior to processor readout, the Lost Data bit is set in the Status Register. The Read operation continues until the end of sector is reached. On Disk Write operations the data Request is activated when the Data Register transfers its contents to the Data Shift Register, and requires a new data byte. It is reset when the Data Register is loaded with new data by the processor. If new data is not loaded at the time the next serial byte is required by the Floppy Disk, a byte of zeroes is written on the diskette and the Lost Data bit is set in the Status Register. At the completion of every command an INTRQ is generated. INTRQ is reset by either reading the status register or by loading the command register with a new command. In addition, INTRQ is generated if a Force Interrupt command condition is met. The 179X has two modes of operation according to the state of $\overline{\rm DDEN}$ (in 37). When $\overline{\rm DDEN}=1$ , single density is selected. In either case, the CLK input (Pin 24) is at 2 MHz. However, when interfacing with the mini-floppy, the CLK input is set at 1 MHz for both single density and double density. #### GENERAL DISK READ OPERATIONS Sector lengths of 128, 256, 512 or 1024 are obtainable in either FM or MFM formats. For FM, DDEN should be placed to logical "1." For MFM formats, DDEN should be placed to a logical "0." Sector lengths are determined at format time by the fourth byte in the "ID" field. | Sector Le | ngth Table* | |------------------------------|----------------------------------------| | Sector Length<br>Field (hex) | Number of Bytes<br>in Sector (decimal) | | 00 | 128 | | 01 | 256 | | 02 | 512 | | 03 | 1024 | \*1795/97 may vary — see command summary. The number of sectors per track as far as the FD179X is concerned can be from 1 to 255 sectors. The number of tracks as far as the FD179X is concerned is from 0 to 255 tracks. For IBM 3740 compatibility, sector lengths are 128 bytes with 26 sectors per track. For System 34 compatibility (MFM), sector lengths are 256 bytes/sector with 26 sectors/track; or lengths of 1024 bytes/sector with 8 sectors/track. (See Sector Length Table) For read operations in 8" double density the FD179X requires RAW READ Data (Pin 27) signal which is a 200 ns pulse per flux transition and a Read clock (RCLK) signal to indicate flux transition spacings. The RCLK (Pin 26) signal is provided by some drives but if not it may be derived externally by Phase lock loops, one shots, or counter techniques. In addition, a Read Gate Signal is provided as an output (Pin 25) on 1791/92/93/94 which can be used to inform phase lock loops when to acquire synchronization. When reading from the media in FM, RG is made true when 2 bytes of zeroes are detected. The FD179X must find an address mark within the next 10 bytes; otherwise RG is reset and the search for 2 bytes of zeroes begins all over again. If an address mark is found within 10 bytes, RG remains true as long as the FD179X is deriving any useful information from the data stream, Similarly for MFM, RG is made active when 4 bytes of "00" or "FF" are detected. The FD179X must find an address mark within the next 16 bytes, otherwise RG is reset and search resumes. During read operations (WG = 0), the $\overline{VFOE}$ (Pin 33) is provided for phase lock loop synchronization. $\overline{VFOE}$ will go active low when: - a) Both HLT and HLD are True - b) Settling Time, if programmed, has expired - c) The 179X is inspecting data off the disk If WF/VFOE is not used, leave open or tie to a 10K resistor to +5 #### GENERAL DISK WRITE OPERATION When writing is to take place on the diskette the Write Gate (WG) output is activated, allowing current to flow into the Read/Write head. As a precaution to erroneous writing the first data byte must be loaded into the Data Register in response to a Data Request from the FD179X before the Write Gate sional can be activated. Writing is inhibited when the Write Protect input is a logic low, in which case any Write command is immediately terminated, an interrupt is generated and the Write Protect status bit is set. The Write Fault input, when activated, signifies a writing fault condition detected in disk drive electronics such as failure to detect write current flow when the Write Gate is activated. On detection of this fault the FD178X terminates the current command, and sets the Write Fault bit (bit 5) in the Status Word. The Write Fault input should be made inactive when the Write Gate output becomes inactive. For write operations, the FD179X provides Write Gate (Pin 30) and Write Data (Pin 31) outputs. Write data consists of a series of 500 ns pulses in FM (DDEN = 1) and 200 ns pulses in MFM (DDEN = 0). Write Data provides the unique address marks in both formats. Also during write, two additional signals are provided for write precompensation. These are EARLY (Pin 17) and LATE (Pin 18). EARLY is active true when the WD pulse appearing on (Pin 30) is to be written EARLY. LATE is active true when the WD pulse is to be written LATE. If both EARLY and LATE are low when the WD pulse is present, the WD pulse is to be written at nominal. Since write precompensation values vary from disk manufacturer to disk manufacturer, the actual value is determined by several one shots or delay lines which are located external to the FD179X. The write precompensation signals EARLY and LATE are valid for the duration of WD in both FM and MFM formats. #### READY Whenever a Read or Write command (Type II or III) is received the FD179X samples the Ready input. If this input is logic low the command is not executed and an interrupt is generated. All Type I commands are performed regardless of the state of the Ready input. Also, whenever a Type II or III command is received, the TG43 signal output is updated. #### COMMAND DESCRIPTION The FD179X will ac \$ pt eleven commands. Command words should only be loaded in the Command Register when the Busy status bit is off (Status bit 0). The one exception is the Force Interrupt command. Whenever a command is being executed, the Busy status bit is set. When a command is completed, an interrupt is generated and the Busy status bit is reset. The Status Register indicates whether the completed command encountered an error or was fault free. For ease of discussion, commands are divided into four types. Commands and types are summarized in Table 1. TABLE 1. COMMAND SUMMARY | ommands for Models: 1791, 1792, 1793, 1794 | | | | | | B. Commands for Models: 1795, 1797 | | | | | | | | | | | |--------------------------------------------|---------------------------------------------------------------------------------------------------------|-------------|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------|------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------|-------------------------------------------------------------------------|-------------------------------------------|-----------------------------------------| | | | | | В | its | | | | | Bits | | | | | | | | Command | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | Restore | 0 | 0 | 0 | 0 | h | v | r1 | Ф | 0 | 0 | 0 | 0 | h | v | <b>F1</b> | ro | | Seek | 0 | 0 | 0 | 1 | h | ٧ | r <sub>1</sub> | Ю | 0 | 0 | 0 | 1 | h | ٧ | ŕş. | ro | | Step | 0 | 0 | 1 | Т | h | ٧ | <b>F</b> 1 | ю | 0 | 0 | 1 | Т | h | ٧ | rı | ro | | Step-in | 0 | 1 | 0 | Т | h | ٧ | <b>r</b> 1 | ro | 0 | 1 | 0 | Т | h | ٧ | r <sub>1</sub> | ro | | Step-out | 0 | 1 | 1 | т | h | V | r <sub>1</sub> | ro | 0 | 1 | 1 | Т | h | v | r1 | ro | | Read Sector | 1 | 0 | 0 | m | s | Ε | С | 0 | 1 | 0 | 0 | m | L | Ε | U | 0 | | Write Sector | 1 | 0 | 1 | m | S | E | С | a0 | 1 | 0 | 1 | m | L | Ε | U | a | | Read Address | 1 | 1 | 0 | 0 | 0 | Ε | 0 | 0 | 1 | 1 | 0 | 0 | 0 | E | U | 0 | | Read Track | 1 | 1 | 1 | 0 | 0 | Ε | 0 | 0 | 1 | 1 | 1 | 0 | 0 | Ε | U | 0 | | Write Track | 1 | 1 | 1 | 1 | 0 | Ε | 0 | 0 | 1 | 1 | 1 | 1 | 0 | Ε | U | 0 | | Force Interrupt | 1 | 1 | 0 | 1 | lз | 12 | 11 | Ю | 1 | 1 | 0 | 1 | lз | 12 | 11 | ю | | | Command Restore Seek Step Step-in Step-out Read Sector Write Sector Read Address Read Track Write Track | Command 7 | Command | Command 7 6 5 Restore 0 0 0 Seek 0 0 0 Step 0 0 1 Step-out 0 1 0 Step-out 1 0 0 Write Sector 1 0 0 Write Sector 1 0 1 Read Address 1 1 0 Read Track 1 1 1 Write Track 1 1 1 | Command 7 6 5 4 | Bits Command 7 6 5 4 3 | Command 7 6 5 4 3 2 Restore 0 0 0 0 0 h V Seek 0 0 0 1 h V Step 0 0 1 T h V Step-out 0 1 0 T h V Read Sector 1 0 0 m S E Read Address 1 1 0 0 E Read Track 1 1 1 0 0 E Write Fack 1 1 1 0 0 E | Command 7 6 5 4 3 2 1 Restore 0 0 0 0 0 h V f1 Seek 0 0 0 1 h V f1 Step 0 0 1 T h V f1 Step-out 0 1 0 T h V f1 Step-out 0 1 1 T h V f1 Read Sector 1 0 0 m S E C Write Sector 1 0 1 m S E C Read Address 1 1 0 0 0 E 0 Read Track 1 1 1 0 0 E 0 Write Track 1 1 1 0 E 0 | Command 7 6 5 4 3 2 1 0 | Command 7 6 5 4 3 2 1 0 7 Restore 0 0 0 0 h V r1 r0 0 Seek 0 0 0 1 h V r1 r0 0 Step 0 0 1 T h V r1 r0 0 Step-out 0 1 0 T h V r1 r0 0 Step-out 0 1 1 T h V r1 r0 0 Step-out 0 1 1 T h V r1 r0 0 Read Sector 1 0 0 m S E C 0 1 Write Sector 1 0 1 m S E C 20 1 Read Address 1 1 0 0 0 E 0 0 1 Read Track 1 1 1 0 0 E 0 0 1 Write Track 1 1 1 0 0 E 0 0 1 | Command 7 6 5 4 3 2 1 0 7 6 Restore 0 0 0 0 0 h V f1 70 0 0 Seek 0 0 0 1 h V f1 70 0 0 Step 0 0 1 T h V f1 70 0 0 Step 0 0 1 T h V f1 70 0 0 Step-out 0 1 0 T h V f1 70 0 0 Read Sector 1 0 0 m S E C 0 1 0 Read Address 1 1 0 0 0 E 0 0 1 1 Read Track 1 1 1 0 0 E 0 0 1 1 Write Track 1 1 1 0 E 0 0 1 1 Write Track 1 1 1 0 E 0 0 1 1 | Command 7 6 5 4 3 2 1 0 7 6 5 Restore 0 0 0 0 h V F1 F0 0 0 0 Seek 0 0 0 1 h V F1 F0 0 0 0 Step 0 0 1 T h V F1 F0 0 0 1 Step-out 0 1 0 T h V F1 F0 0 0 1 Read Sector 1 0 0 m S E C 0 1 0 1 Read Address 1 1 0 0 0 E 0 0 1 1 0 Write Sector 1 1 0 0 0 E 0 0 1 1 0 Read Track 1 1 1 0 E 0 0 1 1 1 Write Track 1 1 1 0 E 0 0 1 1 1 | Command 7 6 5 4 3 2 1 0 7 6 5 4 Restore 0 0 0 0 h V r1 r0 0 0 0 0 0 | Command 7 6 5 4 3 2 1 0 7 6 5 4 3 3 8 8 8 8 8 9 9 9 9 9 9 9 9 9 9 9 9 9 | Command 7 6 5 4 3 2 1 0 7 6 5 4 3 2 1 | Command 7 6 5 4 3 2 1 0 7 6 5 4 3 2 1 | ### FLAG SUMMARY ### TABLE 2. FLAG SUMMARY | Command<br>Type | Bit<br>No(s) | | Description | | | |-----------------|--------------|-------------------------------------------------------------|----------------------------------------------------------------------|------|------| | I | 0, 1 | r1 r0 = Stepping Motor Rate<br>See Table 3 for Rate Summary | Description. | | 1.0 | | . 1 | 2 | V = Track Number Verify Flag | V = 0, No verify<br>V = 1, Verify on destination track | | | | 1 | 3 | h = Head Load Flag | h = 1, Load head at beginning<br>h = 0, Unload head at beginning | | | | ı | 4 | T = Track Update Flag | T = 0, No update T = 1, Update track register | | | | H | 0 | <sup>a</sup> 0 = Data Address Mark | a <sub>0</sub> = 0, FB (DAM)<br>a <sub>0</sub> = 1, F8 (deleted DAM) | | | | 11 | 1 | C = Side Compare Flag | C = 0, Disable side compare<br>C = 1, Enable side compare | | | | 11 & 111 | 1 | U = Update SSO | U = 0, Update SSO to 0<br>U = 1, Update SSO to 1 | | | | 11 & 111 | 2 | E = 15 MS Delay | E = 0, No 15 MS delay<br>E = 1, 15 MS delay | | | | н | 3 | S = Side Compare Flag | S = 0, Compare for side 0<br>S = 1, Compare for side 1 | | | | н | 3 | L = Sector Length Flag | LSB's Sector Len | | | | | | | 00 01<br>L = 0 256 512 | 1024 | 128 | | | | | L = 1 128 256 | 512 | 1024 | | 11 | - 4 | m = Multiple Record Flag | m = 0, Single record<br>m = 1, Multiple records | | | | IV | 0-3 | x | | | | <sup>\*</sup>NOTE: See Type IV Command Description for further information. #### TYPE I COMMANDS The Type I Commands include the Restore, Seek, Step, StepIn, and Step-Out commands. Each of the Type I Commands contains a rate field (10 11), which determines the stepping motor rate as defined in Table 3. A 2 µs (MFM) or 4 µs (FM) pulse is provided as an output to the drive. For every step pulse issued, the drive moves one track location in a direction determined by the direction output. The chip will step the drive in the same direction it last stepped unless the command changes the direction. The Direction signal is active high when stepping in and low when stepping out. The Direction signal is valid 12 $\mu$ s before the first stepping pulse is generated. The rates (shown in Table 3) can be applied to a Step-Direction Motor through the device interface. TABLE 3. STEPPING RATES | CI | LK | 2 MHz | 2 MHz | 1 MHz | 1 MHz | 2 MHz | 1 MHz | |----|----|--------|--------|--------|--------|--------|--------| | DD | EN | 0 | 1 1 | . 0 | 1 | × | x | | R1 | R0 | TEST=1 | TEST=1 | TEST=1 | TEST=1 | TEST=0 | TEST=0 | | 0 | 0 | 3 ms | 3 ms | 6 ms | 6 ms | 184µs | 368µs | | 0 | 1 | 6 ms | 6 ms | 12 ms | 12 ms | 190µs | 380µs | | 1 | 0 | 10 ms | 10 ms | 20 ms | 20 ms | 198μs | 396µs | | 1 | 1 | 15 ms | 15 ms | 30 ms | 30 ms | 208μs | 416µs | | | | | | | | | | After the last directional step an additional 15 milliseconds of head settling time takes place if the Verify flag is set in Type I commands. Note that this time doubles to 30 ms for a 1 MHz clock. If TEST = 0, there is zero settling time. There is also a 15 ms head settling time if the E flag is set in any Type II or III command. When a Seek, Step or Restore command is executed an optional verification of Read-Write head position can be performed by settling bit 2 (V=1) in the command word to a logic 1. The verification operation begins at the end of the 15 millisecond $\Phi$ ettling time after the head is loaded against the media. The track number from the first encountered ID Field is compared against the contents of the Track Register. If the track number compare and the ID Field Cyclic Redundancy Check (CRC) is correct, the verify operation is complete and an INTRQ is generated with no errors. If there is a match but not a valid CRC, the CRC error status bit is set (Status bit 3), and the next encountered ID field is read from the disk for the verification operation. The FD179X must find an ID field with correct track number and correct CRC within 5 revolutions of the media; otherwise the seek error is set and an INTRQ is generated. If V=0, no verification is performed. The Head Load (HLD) output controls the movement of the beginning of a Type I command if the h flag is set (h = 1), at the end of the Type I command if the verify flag (V = 1), or upon receipt of any Type II or III command. Once HLD is active it remains active until either a Type I command ide state (non-busy) and 15 index pulses have occurred. Head Load timing (HLT) is an input to the FD179X which is used for the head engage time. When HLT = 1, the FD179X assumes the head is completely engaged. The head engage time is typically 30 to 100 ms depending on drive. The low to high transition on HLD is typically used to fire a one shot. The output of the one shot is then used for HLT and supplied as an input to the FD179X. #### HEAD LOAD TIMING When both HLD and HLT are true, the FD179X will then read from or write to the media. The "and" of HLD and HLT appears as status Bit 5 in Type I status. In summary for the Type I commands: if h=0 and V=0, HLD is reset. If h=1 and V=0, HLD is set at the beginning of the command and HLT is not sampled nor is there an internal 15 ms delay. If h=0 and V=1, HLD is set near the end of the command, an internal 15 ms occurs, and the FD179X waits for HLT to be true. If h=1 and V=1, HLD is set at the beginning of the command. Near the end of the command, after all the steps have been issued, an internal 15 ms delay occurs and the FD179X then waits for HLT to occur For Type II and III commands with E flag off, HLD is made active and HLT is sampled until true. With E flag on, HLD is made active, an internal 15 ms delay occurs and then HLT is sampled until true. #### RESTORE (SEEK TRACK 0) Upon receipt of this command the Track 00 (TR00) input is sampled. If TR00 is active low indicating the Read-Write head is positioned over track 0, the Track Register is loaded with zeroes and an interrupt is generated. If TR00 is not active low, stepping pulses (pins 15 to 16) at a rate specified by the 11 0 field are issued until the TR00 input is activated. At this time the Track Register is loaded with zeroes and an interrupt is generated. If the TR00 input does not go active low after 255 stepping pulses, the FD179X terminates operation, interrupts, and sets the Seek error status bit, providing the V flag is set. A verification operation also takes place if the V flag is set. The h bit allows the head to be loaded at the start of command. Note that the Restore command is executed when MR goes from an active to an inactive state and that the DRQ pin stays low. #### SEEK This command assumes that the Track Register contains the track number of the current position of the Read-Write head and the Data Register contains the desired track number. The FD179X will update the Track register and issue stepping pulses in the appropriate direction until the contents of the Track register are equal to the contents of the Data Register (the desired track location). A verification operation takes place if the V flag is on. The h bit allows the head to be loaded at the start of the command. An interrupt is generated at the completion of the command. Note: When using multiple drives, the track register must be updated for the drive selected before seeks are issued. #### STEP Upon receipt of this command, the FD179X issues one stepping pulse to the disk drive. The stepping motor direction is the same as in the previous step command. After a delay determined by the '110 field, a verification takes place if the V flag is on. If the U flag is on, the Track Register is updated. The h bit allows the head to be loaded at the start of the command. An interrupt is generated at the completion of the command. #### STEP-IN Upon receipt of this command, the FD179X issues one stepping pulse in the direction towards track 76. If the U TYPE I COMMAND FLOW flag is on, the Track Register is incremented by one. After a delay determined by the f1f0 field, a verification takes place if the V flag is on. The h bit allows the head to be loaded at the start of the command. An interrupt is generated at the completion of the command. #### STEP-OUT Upon receipt of this command, the FD179X issues one stepping pulse in the direction towards track 0. If the U flar is on, the Track Register is decremented by one. After a delay determined by the '1'0 field, a verification takes place if the V flag is on. The h bit allows the head to be loaded at the start of the command. An interrupt is generated at the completion of the command. #### **EXCEPTIONS** On the 1795/7 devices, the SSO output is not affected during Type 1 commands, and an internal side compare does not take place when the (V) Verify Flag is on. TYPE I COMMAND FLOW #### TYPE II COMMANDS The Type II Commands are the Read Sector and Write Sector commands. Prior to loading the Type II Command into the Command Register, the computer must load the Sector Register with the desired sector number. Upon receipt of the Type II command, the busy status Bit is set. If the E flag = 1 (this is the normal case) HLD is made active and HLT is sampled after a 15 msec delay. If the E flag is 0, the head is loaded and HLT sampled with no 15 msec delay. The ID field and Data Field format are shown on page When an ID field is located on the disk, the FD179X compares the Track Number on the ID field with the Track Register. If there is not a match, the next encountered ID field is read and a comparison is again made. If there was a match, the Sector Number of the ID field is compared with the Sector Register. If there is not a Sector match, the next encountered ID field is read off the disk and comparison again made. If the ID field CRC is correct, the data field is then located and will be either written into, or read from depending upon the command. The FD179X must find an ID field with a Track number, Sector number, side number, and CRC within four revolutions of the disk; otherwise, the Record not found status bit is set (Status bit 3) and the command is terminated with an interrupt. TYPE II COMMAND Each of the Type II Commands contains an (m) flag which determines if multiple records (sectors) are to be read or written, depending upon the command. If m=0, a single sector is read or written and an interrupt is generated at the completion of the command. If m=1, multiple records are read or written with the sector register internally updated so that an address verification can occur on the next record. The FD179X will continue to read or write multiple records and update the sector register in numerical ascending sequence until the sector register exceeds the number of sectors on the track or until the Force Interrupt command is loaded into the Command Register, which terminates the command and generates an interrupt. For example: If the FD179X is instructed to read sector 27 and there are only 26 on the track, the sector register exceeds the number available. The FD179X will search for 5 disk revolutions, interrupt out, reset busy, and set the record not found status bit. The Type II commands for 1791-94 also contain side select compare flags. When C=0 (Bit 1) no side comparison made. When C=1, the LSB of the side number is read off the ID Field of the disk and compared with the contents of the (S) flag (Bit 3). If the S flag compares with the side number recorded in the ID field, the FD179X continues with the ID search. If a comparison is not made within 5 index pulses, the interrupt line is made active and the Record-Not-Found status bit is set. NO TOSE OF THE STORY STO TYPE II COMMAND The Type II and III commands for the 1795-97 contain a side select flag (Bit 1). When U = 0, SSO is updated to Similarly, U = 1 updates SSO to 1. The chip compares the SSO to the ID field. If they do not compare within 5 revolutions the interrupt line is made active and the RNF status bit is set. The 1795/7 READ SECTOR and WRITE SECTOR commands include a 'L' flag. The 'L' flag, in conjunction with the sector length byte of the ID Field, allows different byte lengths to be implemented in each sector. For IBM compatability, the 'L' flag should be set to a one. #### READ SECTOR Upon receipt of the Read Sector command, the head is loaded, the Busy status bit set, and when an ID field is encountered that has the correct track number, correct sector number, correct side number, and correct CRC, the data field is presented to the computer. The Data Address TYPE II COMMAND TYPE II COMMAND Mark of the data field must be found within 30 bytes in single density and 43 bytes in double density of the last ID field CRC byte; if not, the ID field is searched for and verified again followed by the Data Address Mark search. If after 5 revolutions the DAM cannot be found, the Record Not Found status bit is set and the operation is terminated. When the first character or byte of the data field has been shifted through the DSR, it is transferred to the DR, and DRQ is generated. When the next byte is accumulated in the DSR, it is transferred to the DR and another DRQ is generated. If the Computer has not read the previous contents of the DR before a new character is transferred that character is lost and the Lost Data Status bit is set. This sequence continues until the complete data field has been inputted to the computer. If there is a CRC error at the end of the data field, the CRC error status bit is set, and the command is terminated (even if it is a multiple record At the end of the Read operation, the type of Data Address Mark encountered in the data field is recorded in the Status Register (Bit 5) as shown: #### STATUS BIT 5 Deleted Data Mark #### 0 Data Mark #### WRITE SECTOR Upon receipt of the Write Sector command, the head is oaded (HLD active) and the Busy status bit is set. When an ID field is encountered that has the correct track number, correct sector number, correct side number, and correct CRC, a DRG is generated. The FD179X counts of 11 bytes in single density and 22 bytes in double density from the CRC field and the Write Gate (WG) output is made active if the DRQ is serviced (i.e., the DR has been loaded by the computer). If DRQ has not been serviced, the command and the Lost Data status bit is set. If the DRQ has been serviced, the WG is made active and six bytes of zeroes in single density and 12 bytes in double density are then written on the disk. At this time the Data Address Mark is then written on the disk as determined by the <sup>20</sup> field of the command as shown below. | <b>a</b> 0 | Data Address Mark (Bit 0) | | |------------|---------------------------|---| | 1 | Deleted Data Mark | - | | 0 | Data Mark | | The FD178X then writes the data field and generates DRQ's to the computer. If the DRQ is not serviced in time for continuous writing the Lost Data Status Bit is set and a byte of zeroes is written on the disk. The command is not terminated. After the last data byte has been written on the disk, the two-byte CRC is computed internally and written on the disk followed by one byte of logic ones in FM or IMFM. The WG output is then deactivated. For a 2 MHz clock the INTRQ will set 8 to 12 usec after the last CRC byte is written. For partial sector writing, the proper method is to write the data and fill the balance with zeroes. By letting the chip fill the zeroes, errors may be masked by the lost data status and improper CRC Bytes. ### TYPE III COMMANDS ### READ ADDRESS Upon receipt of the Read Address command, the head is loaded and the Busy Status Bit is set. The next encountered ID field is then read in from the disk, and the six data bytes of the ID field are assembled and transferred to the DR, and a DRQ is generated for each byte. The six bytes of the ID field are shown below: | | TRACK | SIDE | SECTOR | SECTOR | CRC | CRC | |---|-------|--------|---------|--------|-----|-----| | | ADDR | NUMBER | ADDRESS | LENGTH | 1 | 2 | | ĺ | 1 | 2 | 3 | 4 | 5 | 6 | Although the CRC characters are transferred to the computer, the FD179X checks for validity and the CRC error status bit is set if there is a CRC error. The Track Address of the ID field is written into the sector register so that a comparison can be made by the user. At the end of the operation an interrupt is generated and the Busy Status is reset. #### READ TRACK Upon receipt of the READ track command, the head is loaded, and the Busy Status bit is set. Reading starts with the leading edge of the first encountered index pulse and continues until the next index pulse. All Gap, Header, and data bytes are assembled and transferred to the data register and DRO's are generated for each byte. The accumulation of bytes is synchronized to each address mark encountered. An interrupt is generated at the completion of the command. This command has several characteristics which make it suitable for diagnostic purposes. They are: the Read Gate is not activated during the command; no CRC checking is performed; gap information is included in the data stream; the internal side compare is not performed; and the address mark detector is on for the duration of the command. Because the A.M. detector is always on, write splices or noise may cause the chip to look for an A.M. If an address mark does not appear on schedule the Lost Data status flag is set. The ID A.M., ID field, ID CRC bytes, DAM, Data, and Data CRC Bytes for each sector will be correct. The Gap Bytes may be read incorrectly during write-splice time because of synchronization. TYPE III COMMAND WRITE TRACK TYPE III COMMAND WRITE TRACK #### CONTROL BYTES FOR INITIALIZATION | DATA PATTERN | FD179X INTERPRETATION | FD1791/3 INTERPRETATION | |--------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | IN DR (HEX) | IN FM (DDEN = 1) | IN MFM (DDEN = 0) | | 00 thru F4 F5 F6 F7 F8 thru FB FC FD FE FF | Write 00 thru F4 with CLK = FF Not Allowed Not Allowed Generate 2 CRC bytes Write F6 thru FB, Clk = C7, Preset CRC Write F6 with Clk = D7 Write FD with Clk = FF Write FE, Clk = C7, Preset CRC Write FF with Clk = FF | Write 00 thru F4, in MFM Write A1* in MFM, Preset CRC Write C2** in MFM Generate 2 CRC bytes Write F8 thru FB, in MFM Write FC in MFM Write FD in MFM Write FE in MFM Write FF in MFM | <sup>\*</sup>Missing clock transition between bits 4 and 5 #### WRITE TRACK FORMATTING THE DISK (Refer to section on Type III commands for flow diagrams.) Formatting the disk is a relatively simple task when operating programmed I/O or when operating under DMA with a large amount of memory. Data and gap information must be provided at the computer interface. Formatting the disk is accomplished by positioning the R/W head over the desired track number and issuing the Write Track command. Upon receipt of the Write Track command, the head is loaded and the Busy Status bit is set. Writing starts with the leading edge of the first encountered index pulse and continues until the next index pulse, at which time the interrupt is activated. The Data Request is activated imediately upon receiving the command, but writing will not start until after the first byte has been loaded into the Data Register. If the DR has not been loaded by the time the index pulse is encountered the operation is terminated making the device Not Busy, the Lost Data Status Bit is set, and the Interrupt is activated. If a byte is not present in the DR when needed, a byte of zeroes is substituted. This sequence continues from one index mark to the next index mark. Normally, whatever data pattern appears in the data register is written on the disk with a normal clock pattern. However, if the FD179X detects a data pattern of F5 thu FE in the data register, this is interpreted as data address marks with missing clocks or CPC generation. The CRC generator is initialized when any data byte from F8 to FE is about to be transferred from the DR to the DSR in FM or by receipt of F5 in MFM. An F7 pattern will generate two CRC characters in FM or MFM. As a consequence, the patterns F5 thru FE must not appear in the gaps, data fields, or ID fields. Also, CRC's must be generated by an F7 pattern. Disks may be formatted in IBM 3740 or System 34 formats with sector lengths of 128, 256, 512, or 1024 bytes. #### TYPE IV COMMANDS The Forced Interrupt command is generally used to terminate a multiple sector read or write command or to in- sure Type I status in the status register. This command can be loaded into the command register at any time. If there is a current command under execution (busy status bit set) the command will be terminated and the busy status bit reset The lower four bits of the command determine the conditional interrupt as follows: 0 = Not-Ready to Ready Transition 11 = Ready to Not-Ready Transition 12 = Every Index Pulse 3 = Immediate Interrupt The conditional interrupt is enabled when the corresponding bit positions of the command (13 · 10) are set to a 1. Then, when the condition for interrupt is met, the IN-TRO line will go high signifying that the condition specified has occurred. If 13 · 10 are all set to zero (HEX D0), no interrupt will occur but any command presently under execution will be immediately terminated. When using the immediate interrupt condition (13 = 1) an interrupt will be immediately generated and the current command terminated. Reading the status or writing to the command register will not automatically clear the interrupt. The HEX D0 is the only command that will enable the immediate interrupt (HEX D8) to clear on a subsequent load command register or read status register operation. Follow a HEX D8 with D0 command. Wait 8 micro sec (double density) or 16 micro sec (single density before issuing a new command after issuing a forced interrupt (times double when clock = 1 MHz). Loading a new command sooner than this will nullify the forced interrupt. Forced interrupt stops any command at the end of an internal micro-instruction and generates INTRQ when the specified condition is met. Forced interrupt will wait until ALU operations in progress are complete (CRC calculations, compares, etc.). More than one condition may be set at a time. If for example, the READY TO NOT-READY condition ( $^{1}1=1$ ) and the Every Index Pulse ( $^{1}2=1$ ) are both set, the resultant command would be HEX "DA". The "OR" function is performed so that either a READY TO NOT- READ or the next Index Pulse will cause an interrupt condition. <sup>\*\*</sup>Missing clock transition between bits 3 & 4 #### STATUS REGISTER Upon receipt of any command, except the Force Interrupt command, the Busy Status bit is set and the rest of the status bits are updated or cleared for the new command. If the Force Interrupt Command is received when there is a current command under execution, the Busy status bit is reset, and the rest of the status bits are unchanged. If the Force Interrupt command is received when there is not a current command under execution, the Busy Status bit is reset and the rest of the status bits are updated or cleared. In this case, Status reflects the Type I commands. The user has the option of reading the status register through program control or using the DRQ line with DMA or interrupt methods. When the Data register is read the DRQ bit in the status register and the DRQ line are automatically reset. A write to the Data register also causes both DRQ's to reset The busy bit in the status may be monitored with a user program to determine when a command is complete, in lieu of using the INTRQ line. When using the INTRQ, a busy status check is not recommended because a read of the status register to determine the condition of busy will reset the INTRQ line. The format of the Status Register is shown below: | | | | (BI | TS) | | | | |----|----|----|-----|-----|----|----|----| | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | S7 | S6 | S5 | S4 | S3 | S2 | S1 | S0 | Status varies according to the type of command executed as shown in Table 4. Because of internal sync cycles, certain time delays must be observed when operating under programmed I/O. They are: (times double when clock = 1 MHz) | | | Delay Reg'd. | | | |--------------------------|---------------------------------|--------------|-------|--| | Operation | Next Operation | FM | MFM | | | Write to<br>Command Reg. | Read Busy Bit<br>(Status Bit 0) | 12 µS | 6 µs | | | Write to<br>Command Reg. | Read Status<br>Bits 1-7 | 28 μs | 14 µS | | | Write Any<br>Register | Read From Diff.<br>Register | 0. | 0 | | #### IBM 3740 FORMAT - 128 BYTES/SECTOR Shown below is the IBM single-density format with 128 bytes/sector. In order to format a diskette, the user must issue the Write Track command, and load the data register with the following values. For every byte to be written, there is one Data Request. #### IBM 3740 FORMAT - 128 BYTES/SECTOR Shown below is the IBM single-density format with 128 bytes/sector. In order to format a diskette, the user must issue the Write Track command, and load the data register with the following values. For every byte to be written, there is one Data Request. | NUMBER<br>OF BYTES | HEX VALUE OF<br>BYTE WRITTEN | | | | |--------------------|------------------------------|--|--|--| | 40 | FF (or 00) <sup>1</sup> | | | | | 6 | 00 | | | | | 1 . | FC (Index Mark) | | | | | * 26 | FF (or 00)' | | | | | 6 | 00 | | | | | 1 | FE (ID Address Mark) | | | | | 1 | Track Number | | | | | 1 | Side Number (00 or 01) | | | | | 1 | Sector Number (1 thru 1A) | | | | | 1 | 00 (Sector Length) | | | | | 1 | F7 (2 CRC's written) | | | | | 11 | FF (or 00)1 | | | | | 6 | 00 | | | | | 1 | FB (Data Address Mark) | | | | | 128 | Data (IBM uses E5) | | | | | 1 | F7 (2 CRC's written) | | | | | 27 | FF (or 00)' | | | | | 247** | FF (or 00)1 | | | | <sup>\*</sup>Write bracketed field 26 times #### IBM SYSTEM 34 FORMAT: 256 BYTES/SECTOR Shown below is the IBM dual-density format with 256 bytes/sector. In order to format a diskette the user must issue the Write Track command and load the data register with the following values. For every byte to be written, there is one data request. | NUMBER<br>OF BYTES | HEX VALUE OF<br>BYTE WRITTEN | | | | |--------------------|------------------------------|--|--|--| | 80 | 4E | | | | | 12 | 00 | | | | | 3 | F6 (Writes C2) | | | | | 1 | FC (Index Mark) | | | | | • 50 | 4E | | | | | 12 | 00 | | | | | 3 | F5 (Writes A1) | | | | | 1 | FE (ID Address Mark) | | | | | 1 | Track Number (0 thru 4C) | | | | | 1 | Side Number (0 or 1) | | | | | 1 | Sector Number (1 thru 1A) | | | | | 1 | 01 (Sector Length) | | | | | 1 | F7 (2 CRCs written) | | | | | 22 | 4E | | | | | 12 | 00 | | | | | 3 | F5 (Writes A1) | | | | | 1 | FB (Data Address Mark) | | | | | 256 | DATA | | | | | 1 | F7 (2 CRCs written) | | | | | 54 | 4E | | | | | 598** | 4E | | | | <sup>\*</sup>Write bracketed field 26 times <sup>\*\*</sup>Continue writing until FD179X interrupts out. Approx. 598 bytes. **IBM TRACK FORMAT** <sup>\*\*</sup>Continue writing until FD179X interrupts out. Approx. 247 bytes. <sup>1-</sup>Optional '00' on 1795/7 only. #### 1. NON-IBM FORMATS Variations in the IBM formats are possible to a limited extent if the following requirements are met: - 1) Sector size must be 128, 256, 512 or 1024 bytes. - 2) Gap 2 cannot be varied from the IBM format. - 3) 3 bytes of A1 must be used in MFM. In addition, the Index Address Mark is not required for operation by the FD179X. Gap 1, 3, and 4 lengths can be as short as 2 bytes for FD179X operation, however PLL lock up time, motor speed variation, write-splice area, etc. will add more bytes to each gap to achieve proper operation. It is recommended that the IBM format be used for highest system reliability. | | FM | MFM | |-----------|---------------------------|-----------------------------------------| | Gap I | 16 bytes FF | 32 bytes 4E | | Gap II | 11 bytes FF | 22 bytes 4E | | • | 6 bytes 00 | 12 bytes 00<br>3 bytes A1 | | Gap III** | 10 bytes FF<br>4 bytes 00 | 24 bytes 4E<br>8 bytes 00<br>3 bytes A1 | | Gap IV | 16 bytes FF | 16 bytes 4E | <sup>\*</sup>Byte counts must be exact. <sup>\*\*</sup>Byte counts are minimum, except exactly 3 bytes of A1 must be written. READ ENABLE TIMING #### TIMING CHARACTERISTICS $T_A = 0^{\circ}C$ to $70^{\circ}C$ , $V_{DD} = + 12V \pm .6V$ , $V_{SS} = 0V$ , $V_{CC} = +5V \pm .25V$ ### READ ENABLE TIMING (See Note 6, Page 21) | SYMBOL | CHARACTERISTIC | MIN. | TYP. | MAX. | UNITS | CONDITIONS | |--------|------------------------|------|------|------|-------|------------------------| | TSET | Setup ADDR & CS to RE | 50 | | | nsec | | | THLD | Hold ADDR & CS from RE | 10 | | | nsec | | | TRE | RE Pulse Width | 400 | 1 | | nsec | $C_L = 50 \text{ pf}$ | | TDRR | DRQ Reset from RE | | 400 | 500 | nsec | · | | TIRR | INTRO Reset from RE | | 500 | 3000 | nsec | See Note 5 | | TDACC | Data Access from RE | | | 350 | nsec | $C_L = 50 \text{ pf}$ | | TDOH | Data Hold From RE | 50 | | 150 | nsec | C <sub>L</sub> = 50 pf | ### WRITE ENABLE TIMING (See Note 6, Page 21) | SYMBOL | CHARACTERISTIC | MIN. | TYP. | MAX. | UNITS | CONDITIONS | |-----------------------------|--------------------------------------------------------------------------------------------------------------------|-----------------|------------|-------------|----------------------------------------------|------------| | TSET THLD TWE TDRR TIRR TDS | Setup ADDR & CS to WE Hold ADDR & CS from WE WE Pulse Width DRQ Reset from WE INTRQ Reset from WE Data Setup to WE | 50<br>10<br>350 | 400<br>500 | 500<br>3000 | nsec<br>nsec<br>nsec<br>nsec<br>nsec<br>nsec | See Note 5 | INPUT DATA TIMING ### WRITE ENABLE TIMING | MPUI DAIA II | TOT DATA TIMING. | | | | | | |-----------------|-----------------------|------|------|------|-------|----------------| | SYMBOL | CHARACTERISTIC | MIN. | TYP. | MAX. | UNITS | CONDITIONS | | Tpw | Raw Read Pulse Width | 100 | 200 | | nsec | See Note 1 | | tbc | Raw Read Cycle Time | 1500 | 2000 | | nsec | 1800 ns @ 70°C | | Tc | RCLK Cycle Time | 1500 | 2000 | | nsec | 1800 ns @ 70°C | | Tx <sub>1</sub> | RCLK hold to Raw Read | 40 | | | nsec | See Note 1 | | Tx2 | Raw Read hold to RCLK | 40 | | | nsec | See Note 1 | | | | | | | | | ## WRITE DATA TIMING: (ALL TIMES DOUBLE WHEN CLK = 1 MHz) (See Note 6, Page 21) | SYMBOL | CHARACTERISTICS | MIN. | TYP. | MAX. | UNITS | CONDITIONS | |----------|-------------------------------------------------|------------|----------------|------|--------------|------------------------| | Twp | Write Data Pulse Width | | 500 | 650 | nsec | FM | | Twg | Write Gate to Write Data | | 200 | 350 | nsec<br>µsec | MFM<br>FM | | Tbc | Write data cycle Time | | 1<br>2,3, or 4 | | μsec<br>μsec | MFM<br>± CLK Error | | Ts<br>Th | Early (Late) to Write Data<br>Early (Late) From | 125<br>125 | | | nsec<br>nsec | MFM<br>MFM | | | Write Data | 123 | | | lisec | | | Twf | Write Gate off from WD | | 2 | | μsec<br>μsec | FM<br>MFM | | Twdl | WD Valid to Clk | 100 | | | nsec | CLK=1 MHZ | | Twd2 | WD Valid after CLK | 50<br>100 | | | nsec | CLK=2 MHZ<br>CLK=1 MHZ | | | | 30 | | | nsec | CLK=2 MHZ | WRITE DATA TIMING ### MISCELLANEOUS TIMING: (Times Double When Clock = 1 MHz) (See Note 6, Page 21) | SYMBOL | CHARACTERISTIC | MIN. | TYP. | MAX. | UNITS | CONDITIONS | |------------------|--------------------------|--------|------|-------|-------|-------------| | TCD1 | Clock Duty (low) | 230 | 250 | 20000 | nsec | | | TCD <sub>2</sub> | Clock Duty (high) | 200 | 250 | 20000 | nsec | ļ | | TSTP | Step Pulse Output | 2 or 4 | | | μsec | See Note 5 | | TDIR | Dir Setup to Step | | 12 | l | μsec | ± CLK ERROR | | TMR | Master Reset Pulse Width | 50 | 1 | l . | μsec | I CLN ENNOR | | TIP Ì | Index Pulse Width | 10 | | | μsec | See Note 5 | | TWF | Write Fault Pulse Width | 10 | | | μsec | See Note 5 | ### **MISCELLANEOUS TIMING** \*FROM STEP RATE TABLE #### NOTES: - 1. Pulse width on RAW READ (Pin 27) is normally 100-300 ns. However, pulse may be any width if pulse is entirely within window. If pulse occurs in both windows, then pulse width must be less than 300 ns for MFM at CLK = 2 MHz and 600 ns for FM at 2 MHz. Times double for 1 MHz. - 2. A PPL Data Separator is recommended for 8" MFM. - 3. tbc should be 2 $\mu$ s, nominal in MFM and 4 $\mu$ s nominal in FM. Times double when CLK = 1 MHz. - 4. RCLK may be high or low during RAW READ (Polarity is unimportant). - 5. Times double when clock = 1 MHz. - 6. Output timing readings are at $V_{OL} = 0.8v$ and $V_{OH} =$ **Table 4. STATUS REGISTER SUMMARY** | віт | ALL TYPE I<br>COMMANDS | READ<br>ADDRESS | READ<br>SECTOR | READ<br>TRACK | WRITE<br>SECTOR | WRITE<br>TRACK | |-----|------------------------|-----------------|----------------|---------------|------------------|------------------| | S7 | NOT READY | NOT READY | NOT READY | NOT READY | NOT READY | NOT READY | | S6 | WRITE<br>PROTECT | 0 | 0 | 0 | WRITE<br>PROTECT | WRITE<br>PROTECT | | S5 | HEAD LOADED | 0 | RECORD TYPE | 0 | WRITE FAULT | WRITE FAULT | | S4 | SEEK ERROR | RNF | RNF | 0 | RNF | 0 | | S3 | CRC ERROR | CRC ERROR | CRC ERROR | 0 | CRC ERROR | 0 | | S2 | TRACK 0 | LOST DATA | LOST DATA | LOST DATA | LOST DATA | LOST DATA | | S1 | INDEX PULSE | DRQ | DRQ | DRQ | DRQ | DRQ | | S0 | BUSY | BUSY | BUSY | BUSY | BUSY | BUSY | ### STATUS FOR TYPE I COMMANDS | BIT NAME | MEANING | |----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | S7 NOT READY | This bit when set indicates the drive is not ready. When reset it indicates that the drive is ready. This bit is an inverted copy of the Ready input and logically 'ored' with MR. | | S6 PROTECTED | When set, indicates Write Protect is activated. This bit is an inverted copy of WRPT input. | | S5 HEAD LOADED | When set, it indicates the head is loaded and engaged. This bit is a logical "and" of HLD and HLT signals. | | S4 SEEK ERROR | When set, the desired track was not verified. This bit is reset to 0 when updated. | | S3 CRC ERROR | CRC encountered in ID field. | | S2 TRACK 00 | When set, indicates Read/Write head is positioned to Track 0. This bit is an inverted copy of the TROO input. | | S1 INDEX | When set, indicates index mark detected from drive. This bit is an inverted copy of the $\overline{\text{IP}}$ input. | | S0 BUSY | When set command is in progress. When reset no command is in progress. | #### STATUS FOR TYPE II AND III COMMANDS | BIT NAME | MEANING | |--------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | S7 NOT READY | This bit when set indicates the drive is not ready. When reset, it indicates that the drive is ready. This bit is an inverted copy of the Ready input and 'ored' with MR. The Type II and III Commands will not execute unless the drive is ready. | | S6 WRITE PROTECT | On Read Record: Not Used. On Read Track: Not Used. On any Write: It indicates a Write Protect. This bit is reset when updated. | | S5 RECORD TYPE/<br>WRITE FAULT | On Read Record: It indicates the record-type code from data field address mark. 1 = Deleted Data Mark. 0 = Data Mark. On any Write: It indicates a Write Fault. This bit is reset when updated. | | S4 RECORD NOT<br>FOUND (RNF) | When set, it indicates that the desired track, sector, or side were not found. This bit is reset when updated. | | S3 CRC ERROR | If S4 is set, an error is found in one or more ID fields; otherwise it indicates error in data field. This bit is reset when updated. | | S2 LOST DATA | When set, it indicates the computer did not respond to DRQ in one byte time. This bit is reset to zero when updated. | | S1 DATA REQUEST | This bit is a copy of the DRQ output. When set, it indicates the DR is full on a Read Operation or the DR is empty on a Write operation. This bit is reset to zero when updated. | | S0 BUSY | When set, command is under execution. When reset, no command is under execution. | #### **ELECTRICAL CHARACTERISTICS** Absolute Maximum Ratings V<sub>DD</sub> with repect to V<sub>SS</sub> (ground): +15 to -0.3V Voltage to any input with respect to V<sub>SS</sub> = +15 to -0.3V lcc = 60 MA (35 MA nominal) loo = 15 MA (10 MA nominal) C<sub>IN</sub> & Cout = 15 pF max with all pins grounded except one under test. Operating temperature = 0°C to 70°C Storage temperature = -55°C to + 125°C #### **OPERATING CHARACTERISTICS (DC)** TA = 0°C to 70°C, $V_{DO}$ = + 12V ± .6V, $V_{SS}$ = 0V, $V_{CC}$ = + 5V ± .25V | SYMBOL | CHARACTERISTIC | MIN. | MAX. | UNITS | CONDITIONS | |-----------------|---------------------|------|------|-------|--------------------------| | l <sub>IL</sub> | Input Leakage | | 10 | μΑ | VIN = VDD.** | | lou | Output Leakage | 1 | 10 | μΑ | Vout = Voo | | ViH | Input High Voltage | 2.6 | 1 | V | | | VIL | Input Low Voltage | 1 | 0.8 | v | | | V <sub>OH</sub> | Output High Voltage | 2.8 | 1 | 1 v 1 | $I_0 = -100 \mu\text{A}$ | | Vol | Output Low Voltage | 1 | 0.45 | v | lo = 1.6 mA* | | P₀ | Power Dissipation | | 0.6 | w | | <sup>\*1792</sup> and 1794 0 = 1.0 mA <sup>\*\*</sup>Leakage conditions are for input pins without internal pull-up resistors. Pins 22, 23, 33, 36, and 37 have pull-up resistors. See Tech Memo #115 for testing procedures. 40 LEAD CERAMIC "A" or "AL" 40 LEAD RELPACK "B" or "BL" 40 LEAD CERDIP "CL" 40 LEAD PLASTIC "P" or "PL" Notes #### APPENDIX A ### CP/M-80 2.2 BIOS Programming Considerations BIOS provides the operations necessary to access the disk drives and to interface with peripherals. The user interface with the BIOS is through a series of Entry Points. These entry points are "Jump Vectors". Each jump address corresponds to a particular subroutine which performs a specific function. The Base (+B for the jump vectors) depends on the size of RAM memory. ### **BIOS Entry Vector Table** **BIOS Cold Boot** Entry Point: Function(s): (Bbase + 00) - Bios This entry is called only by the Boot Loader to initialize CP/M. Argument(s): Value(s) Returned: None None Registers Saved: None **BIOS Warm Boot** **Entry Point:** (Bbase + 03) - Bwboot Function(s): Perform a Warm Start by reloading the CCP and BDOS from the disk in the A: drive, returning control to the CCP. Argument(s): Value(s) Returned: None None Registers Saved: Errors Returned: None in registers; however, message 'Boot Err' is displayed. **BIOS Console Status** **Entry Point:** (Bbase + 06) - Bconst **BIOS Console Input** **Entry Point:** (Bbase + 09) - Bconin **BIOS Console Output** Entry point: (Bbase + 0C) - Bconot **BIOS List Output** **Entry Point:** (Bbase + OF) - Bprint **BIOS Punch Output** **Entry Point:** (Bbase + 12) - Bpunch **BIOS Reader Input** **Entry Point:** (Bbase + 15) - Breadr **BIOS Home Disk** **Entry Point:** Function(s): (Bbase + 18) - Bhome Sets track number to zero in preparation for disk access. None Arguments: Value(s) Returned: None **Registers Saved:** None **Errors Returned:** None **BIOS Select Disk** Entry Point: (Bbase + 1B) - Bseld Function(s): Select the requested logical disk. The drive that will be logged on in further operations is the default drive (or drive A if the default drive cannot be selected). Arguments: (C) = drive to select (00 - 0F) even if media identification required (E) odd if media identification (E) = previously issued and no disks removed/replaced Value(s) Returned: (HL) = address of CP/M-compatible Disk Parameter Header if select successful 0 otherwise Registers Saved: Frrors Returned: (HL) =None None **BIOS Set Track** **Entry Point:** (Bbase + 1E) - Bsett Function(s): Stores desired track number in preparation for a disk read or write record call. (BC) = track number Araument(s): None Value(s) Returned: Registers Saved: None Errors Returned: None **BIOS Set Sector** **Entry Point** (Bbase + 21) - Bsets Function(s): Stores desired sector number in preparation for a read or write record call. Argument(s): (BC) =sector number None Value(s) Returned: None Registers Saved: Errors Returned: None ### **BIOS Set DMA Address** **Entry Point:** (Bbase + 24) - Bsetd Function(s): Stores desired transfer address in preparation for a read or write a record call. Argument(s): transfer address (BC) = Value(s) Returned: Registers Saved: Errors Returned: None **BIOS Read Sector** Entry Point: (Bbase + 27) - Bread Function(s) Transfer one 128 (decimal) byte record from the selected disk to the current DMA transfer address. None None Argument(s): Bseld, Bsett, Bsctrn, Bsets, Bsetd previously called. Value(s) Returned: Registers Saved: None none Errors Returned: (A) =00 if no error (A) = FF if error **BIOS Write Sector** **Entry Point:** (Bbase + 2A) - Bwritt Function(s): Transfer one 128 (decimal) byte record from the current DMA transfer address to the selected disk. Argument(s): Bseld, Bsett, Bsctrn, Bsets, Bsetd previously called. Value(s) Returned: Registers Saved: None None **Errors Returned:** (A) =00 if no error (A) =FF if error **BIOS List Status** **Entry Point:** (Bbase + 2D) - Bprnts **BIOS Sector Translate** Entry Point: (Bbase + 30) - Bsctrn Function(s): Translate a logical sector number into a physical sector number in preparation for a call to Bsets, the BIOS set sector call. Argument(s): (BC) = Sector number (0 < = (BC) < sectors per track (DE) = Skew table address obtained from the CP/M Disk Parameter Header Value(s) Returned: (HL) = (BC) if(DE) = 0 (L) = [(DE) + (BC)] if (DE) = 0 (H) = (B) should be 0 Registers Saved: None Errors Returned: None Notes # **APPENDIX B** # **Monitor Entry Vector Table** | F000H | Cold start monitor | |-------|--------------------------------------| | F003H | Warm start monitor | | F006H | Keyboard status | | F009H | Keyboard input | | F00CH | CRT output | | F00FH | Fast CRT output from C | | F012H | SIO channel B input status | | F015H | SIO channel B input | | F018H | SIO channel B output | | F01BH | Drive select | | F01EH | Home r/w head | | F021H | Seek to track | | F024H | Read sector | | F027H | Write sector | | F02AH | Execute physical driver request | | F02DH | Set direct CRT cursor | | F030H | Direct CRT display | | F033H | CRT memory block move | | F036H | Return address of disk mapping table | | F039H | Return address of day variable | | F03CH | Return configuration status | | F03FH | SIO channel B output ready status | | F042H | Set configuration | | F045H | Start screen print | | F048H | Accessible 1-second interrupt | | F04BH | Console status through iobyte | | F04EH | Console input through iobyte | | F051H | Console output through iobyte | | F054H | Printer output through iobyte | | F057H | Printer status through iobyte | | F05AH | Communications input ready status | | F05DH | Communications input data | | F060H | Communications output data | | F063H | Communications output ready status | | F066H | Idle while i/o is pending | | F069H | Record soft error | | | | Notes ## **APPENDIX C** # **Documented System Storage and Structures** # **Z80-A Mode 2 Interrupt Vectors** | FF00 | SIOVO: | DFFS2 | ; Z80-A SIO port B xmit buffer empty | |-------|---------|--------|-------------------------------------------| | | | | • | | FF02 | SIOV1: | DEFS2 | ;Z80-A SIO port B external/status change | | FF04 | SIOV2: | DEFS2 | ;Z80-A SIO port B receive data available | | FF06 | SIOV3: | DEFS2 | ;Z80-A SIO port B special receive | | | | | condition | | FF08 | SIOV4: | DEFS2 | ;Z80-A SIO port A xmit buffer empty | | FF0A | SIOV5: | DEFS2 | ; Z80-A SIO port A external/status change | | FF0C | SIOV6: | DEFS2 | ;Z80-A SIO port A receive data available | | FF0E | SIOV7: | DEFS2 | ;Z80-A SIO port A special receive | | | 3.017. | D2.32 | condition | | | | | Condition | | FF10 | CTCVO: | DEFS2 | ;Z80-A CTC channel 0 interrupt | | FF12* | CTCV1: | DEFS2 | ;Z80-A CTC channel 1 interrupt | | | | | • | | FF14 | CTCV2: | DEFS2 | ;Z80-A CTC channel 2 interrupt | | FF16* | CTCV3: | DEFS2 | ;Z80-A CTC channel 3 interrupt | | | | | | | FF18 | SYSVA: | DEFS2 | ;System Z80-A PIO port A interrupt | | FF1A* | SYSVB: | DEFS2 | ;System Z80-A PIO port B interrupt | | | | | | | FF1C | GENVA: | DEFS2 | ;General purpose Z80-A PIO port A | | | | | interrupt | | FF1E | GENVB: | DEFS2 | ;General purpose Z80-A PIO port B | | 1116 | CLIAVD. | UL1 32 | | | | | | interrupt | <sup>\*</sup>Vectors used by the Monitor ROM # **Keyboard Data Input FIFO Variables** | | FF31 | fifin: | defs 1 | ;FIFO input pointer<br>;FIFO output pointer | |--|------|--------|--------|---------------------------------------------| |--|------|--------|--------|---------------------------------------------| ### More Interrupt Vectors FF34 expvec: defs 8 ;Space for 4 vectors for expansion slot ### **Available Memory Pointers** availb: FF3C FF3E availt: defs 2 defs 2 ;Bottom of available memory ;Top of available memory ### **End of documented storage locations** ### **Logical to Physical Drive Mapping Tables** Seltab contains two bytes per logical CP/M drive A-P. The first byte is an index into the physical driver address table (see next table). The second byte is a unit number that is passed to the driver by the XQDVR dispatcher. ### Seltab: Δ٠ defb R٠ defb 1.0 1,1 :Floppy unit 0 :Floppy unit 1 C: defb D· defb ;Floppy unit 2 1,2 1,3 :Floppy unit 3 E: defb 1.4 :Rigid partition 0 :Rigid partition 1 F: defb 1.5 defb G: 1,6 defb Н٠ ; Rigid partition 2 : Rigid partition 3 1,7 1. defb 0.0 1: defb 0.0 :Error driver :Error driver :Error driver defb K: 0.0 L: defb 0.0 M: defb 0.0 0.0 :Error driver :Error driver :Error driver N: defb 0: defb :Error driver 0,0 P: defb 0.0 : Error driver # **Physical Driver Address Table** Drvtab contains the addresses of several independent physical disk drivers. By convention, driver number 0 always returns a select error. Unused entries in Seltab should point to this trivial driver. | Drvtab: | defw<br>defw<br>defw | Selerr<br>Dskdvr<br>0 | ;Select error physical driver<br>;Disk driver (WD or SA)<br>;Empty physical driver<br>;Expansion slots | |---------|----------------------|-----------------------|--------------------------------------------------------------------------------------------------------| | | defw | 0 | | | | defw | 0 | | | | defw | 0 | | | | defw | 0 | | | | defw | 0-1 | ;Mark last entry | | | | | | # **Physical Driver Request Block** | db | command | ;FF = Select | |----|---------|---------------------------------------| | | | ;00 = Write | | | | ;01 = Read | | ds | 1 | ;For system use | | db | Ldrive | ;Logical drive for request (00 - 0F) | | dw | Track | ;Track number for request | | dw | Sector | ;Sector number for request | | dw | Address | ;Address of sector buffer for request | # **Time-of-Day and Timer Variables** | Milsec: | ds | 2 | ;Location incremented by CTC1<br>;Interrupt | |----------|----|----|---------------------------------------------| | | ds | 2 | ;(unused) | | Ticker: | ds | 2 | ;Increments once per second | | Steprt: | ds | 1 | ;WD1797 step rate | | Motor: | ds | 1 | ; Disk motor/select timeout (1 Hz) | | HL→ Day: | ds | 1 | ;01-31 | | Month: | ds | 1 | ;01-12 | | Year: | ds | 1 | ;80-99 | | Hour: | ds | 1 | ;00-23 | | Minute: | ds | 1 | ;00-59 | | Second: | ds | 1 | ;00-59 | | Linbuf: | ds | 80 | ;Line buffer | ## How To Make Monitor Calls from Basic Several of the monitor function calls return the value in the HL register if the H register equals 0, or return the value at the address pointed to by the HL register if the H register is not zero. This convention allows Microsoft Basic Users to access these functions directly. The examples listed in this section demonstrate this feature of the ROSR ROM. ``` 100 110 'Make 820-II Monitor call to get address of day variable, then 120 ' Print Day, Month etc. 130 140 DATA Day, Month, Year, Hour, Minute, Second 150 160 DEFINT I 170 GETTOD = &HF039:CALL GETTOD(I) 'Return Add. of Day 180 FOR X = 0 TO 5 190 READ X$ 200 PRINT USING "\ \ ##:X$.PEEK(I + X) 210 NEXT X 220 END 100 110 'Do configuration status call & print value returned 120 130 DEFINT I 140 GETCON = &HF03C:CALL GETCON(I) 'Get config status 150 PRINT CHR$(26); 'Clear Screen PRINT "The configuration status word is - "; 160 170 PRINT HEX$(I); 180 PRINT " (Hex)". 190 END ``` ``` 100 'Example Using Line Delete To scroll screen up. 110 'Make 820-II Monitor Call to get address of day variable 120 'then calculate address of line input buffer variable. 130 140 'Clear screen, fill screen with characters, position 150 'Cursor back on top line, send line delete code to CRT, 160 'This moves the line deleted from the top of the screen 170 'To the input buffer. 180 190 'Recall deleted line from line input buffer & display 200 on line 23 of the screen. 210 220 230 WIDTH 255 240 PRINT CHR$(5); " "; 'Remove cursor 250 DEFINT 260 GETTOD = &HF039:CALL GETTOD(I) 'Get address of Day Variable 270 1 = 1 + 6 'Line input buffer is at Day + 6 280 PRINT CHR$(26): 'Clear screen 290 FOR X = 1 TO 23 300 PRINT STRING$(80,CHR$(X + 64)); 'Fill Screen' 310 NEXT X 320 330 FOR M = 1 TO 100 'Do 100 lines 340 PRINT CHR$(30): 'Put Cursor back on top line 350 PRINT CHR$(27); "R"; 'Do line delete, move deleted 360 'Line to buffer. 370 PRINT CHR(27); " = "; CHR(32 + 22); CHR(32) 380 FOR X = 0 TO 79 'Now print characters back from 390 PRINT CHR$(PEEK(I + X); 'Input buffer 400 NEXT X 410 NEXT M 420 PRINT CHR$(26); CHR$(5); CHR$(2); 'Clear screen and 430 Restore Cursor. ``` END ``` 100 'Example Using Line Insert To scroll screen down. 110 'Make 820-II Monitor Call to get address of day variable 120 'then calculate address of line input buffer variable. 130 140 'Clear screen, fill screen with characters, position 150 'Cursor back on top line, send line insert code to CRT. 160 'This moves the line deleted from the bottom of the screen 'To the input buffer. 170 180 190 'Recall deleted line from line input buffer & display 200 on the first line of the screen. 210 220 230 WIDTH 255 240 PRINT CHR$(5); " "; 'Remove cursor 250 DEFINT I 260 GETTOD = &HF039:CALL GETTOD(!) 'Get address of Day Variable 270 1=1+6 'Line input buffer is at Day + 6 280 PRINT CHR$(26): 'Clear screen 290 FOR X = 1 TO 23 300 PRINT STRING$(80,CHR$(X + 64)); 'Fill Screen 310 NEXT X 320 330 FOR M = 1 TO 100: 'Do 100 lines 340 PRINT CHR$(30); 'Put Cursor back on top line 350 PRINT CHR$(27): "E": ' Do line insert, move deleted 'Line to buffer. 360 370 PRINT CHR(27); " = "; CHR(32 + 22); CHR(32) 'Now print characters back from 380 FOR X = 0 TO 79 390 PRINT CHR$(PEEK(I + X); 'Input buffer 400 NEXT X 410 NEXT M 420 PRINT CHR$(26); CHR$(5); CHR$(2); 'Clear screen and 430 Restore Cursor. 440 END ``` ## **Bank Switching** • The Bank control switch is bit 7 of port 1C. Bit 7 = 0 = Bank 1 (RAM) Bit 7 = 1 = Bank 0 (ROM) - Change bit 7 only: Bits 0 through 6 should be maintained. - Bank 0 and 1 are mutually exclusive; data movement to or from one bank will not affect the other. - When bank switching, the driver code must be executed at C000h or above; the upper 16K (C000h-FFFFh) is common memory to both banks. ## For example, DI IN A,(1Ch) SET 7.a ;read port :set bit ΕI OUT (1Ch),a ;output DI IN A,(1Ch) RES 7,a reset bit ΕI OUT (1Ch) ``` 26 27 Absolute Memory Addresses. :: 28 29 0000 rom 01000h and debug; non resident code base 30 1800 romsiz equ 01000h+((not debug) and 0800h) 31 1800 Rx1984 equ 01800h :prescription for the future 32 0800 Lx 1984 equ 00800h ; length of future 33 0003 iobyte equ 00003h :i/o byte 34 0080 00080h bootld equ ;boot loader address 35 ED80 bootbf equ 0ed80h :boot loader buffer 36 FEOO OffOOh ram eau :system ram page address 37 F000 0f000h monitr egu resident monitor address 38 3000 crtmem equ 03000h :crt memory address 39 3000 crtmax equ crtmem+24*128 crt maximum address 40 0030 crtbas equ high crtmem starting page of display ram 41 0030 crttop equ high crtmax ending page of display ram 42 43 I/O Port Addresses. ;; 44 . 45 0000 00h bauda eau :channel a baud rate generator 46 0004 siodoa equ 04h ;sio data port A (communications) 47 0005 siodpb equ 05h :sio data port B (printer) 48 0006 06h siocpa equ ;sio control/status port A 49 0007 siocpb equ 07h :sio control/status port B 50 0008 08h gpioda equ general purpose parallel i/o A data 51 0009 gpioca equ 09h :general purpose parallel i/o A control 52 000A apiodb equ 0ah general purpose parallel i/o B data 53 0008 apiocb egu Obb general purpose parallel 1/o B control 54 0000 baudb equ 0ch :channel b baud rate generator 0010 wd1797 10h eau ;western digital disk controller base 56 0014 scroll equ 14h crt bottom line scroll register 57 0018 ctc equ 18h :quad counter/timer circuit 58 0018 18h ctc0 eou ;ctc channel 0 (user) 59 0019 ctc1 equ 19h :ctc channel 1 (msec, screen print) 60 001A ctc2 eau lah :ctc channel 2 (one second prescaler) 61 001B ctc3 equ 1bb :ctc channel 3 (one second) 62 0010 syspio equ 1ch :system pio data 63 0010 1dh sysctl equ ;system pio control 001F kbddat equ 1eh :keyboard data 001F 1fh kbdctl eau :kevboard control 28h 0028 bellof equ turn bell off 67 0029 bellon equ 29h turn bell on 68 30h 0030 sisden egu ;select single density 69 0031 sidden equ 31h select double density 70 0034 chrom1 equ 34h :select ROM 1 character generator 71 0035 35h ;select ROM 2 character generator chrom2 eau lowlite equ 72 0036 36h :select low intensity attribute 73 0068 68h :set internal clocks for asynchronous sio A async equ ``` sync eau 69h ;set external clocks for synchronous sio A Appendix 74 Symbol Definitions Balcones Operating System for the XEROX 820-II MACRO-80 3.44 ``` 76 Configuration Status Byte Bit Definitions. :: 77 78 0007 c.keym eau :Keyboard upper bit is passed 79 0006 c.sasi eau :Shugart SA-1403D Disk Controller 80 0004 c.five equ ; Five inch micro floppies 81 82 :: Ascii. 83 84 0004 eot equ 04h :ascii end of text 85 000A 1 f eau Oah ascii line feed 86 0000 сr equ 0dh :ascii carriage return 0011 11h xon eau :ascii Xon 88 0013 xoff eau 13h :ascii Xoff 89 001B esc equ 1bh :ascii escape 90 001A clrs eau 1ah :clear screen 91 92 Special Key Constants. 93 94 001E Helpkey equ 01eh 95 009E Scrprt equ 09eh ;Screen Print key CTRL <HELP> 96 009B Abort equ 09bh :Automatic Abort CTRL <ESC> 97 98 :: Bell Constants. 99 100 0035 bltim 35h :bell loop time eau 101 0061 blonc 61h eau ;bell on time 102 0061 blofc equ 61h :bell off time 103 104 Assembly Options. :: 105 106 8000 o.resv equ 10000000000000000 :reserved 107 4000 01000000000000000b o.auto equ ; auto boot A: 108 2000 o.help equ 00100000000000000 ;help command 109 1000 o.prot equ 00010000000000000b :printer protocol 110 0800 o.ddvr equ 00001000000000000b :disk drivers 111 0400 o.baud equ 0000010000000000b :baud rate set command 112 0200 olinpo equ 0000001000000000b :in command 113 0100 o.outc equ 0000000100000000 ;out command 114 0080 o.verf equ 0000000010000000ь :verify memory block 115 0040 0000000001000000ь o.ramt equ ;simple ram test 116 0020 o.disk equ 0000000000100000ь :console disk read/write commands 117 0010 o.esct equ 0000000000010000b :escape command table 118 0008 o.type equ 0000000000001000ь typewriter mode 119 0004 o.fill equ 0000000000000100b :fill memory 120 0002 0000000000000010b o, move equ ;move memory 121 0001 o.term equ 0000000000000001ь :terminal scroll driver 122 123 0000 options defl debug and not o.ddvr and not o.esct 0000 124 options defl options and not oldisk and not olresv 125 0000 options defl options and not o.verf and not o.fill 126 0000 options defl options and not o.ramt 127 128 BFFF options defl (not debug or o.esct) and not o.auto 129 130 configuration sector offsets. :: 131 : ``` | | | | | | to to the to the town the town to | |-----|------|--------|---------|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 138 | EE79 | z.siov | equ | z.siom+2 | ;data carrier detect low/high/ignore | | 139 | EE7B | z.xonp | equ | z.siov+2 | ;Xon/Xoff protocal | | 140 | EE7D | z baua | eau | z.xonp+2 | :comm channel baud rate | | 141 | EE7E | z.baub | equ | z.baua+1 | printer baud rate | | 142 | EE7F | z.iobt | eau | z.baub+1 | :initial i/o byte | | 143 | | | | | *************************************** | | 144 | | :: | paralle | printer status | bits. | | 145 | | | | | | | 146 | 0007 | p.ackn | equ | 7 | :acknowledge | | 147 | 0006 | p.onln | equ | 6 | on line | | 148 | 0005 | p.rdyi | equ | 5 | ready to input | | 149 | 0004 | p.rdyo | equ | 4 | ;ready to output | | 150 | 0002 | p.strb | eau | 2 | :data stobe | | 151 | 0000 | p.auto | equ | 0 | auto LF enable | | 152 | | • | | | · | | 153 | | | subttl | Code Generation | Control Macros Definitions | | 154 | | | page | | | ``` 155 156 Rom code placement macros. : ; 157 : 158 The Common Segment holds the non-resident (banked) portion :: 159 of the monitor. This segment is not copied to ram. 160 161 . . . The Data Segment holds the resident portion of the monitor. 162 It is moved to ram at location MONITR during initialization. 163 164 . . The Code Segment holds the various Transient Commands. Each 165 command is loaded from the ROM to the TPA when it is executed. 166 167 The following macros keep it all straight. ;; 168 169 below - Generate code for rom below. :: 170 171 below macro 172 segment b ;;enable common segment 173 endm 174 175 :: above - Generate code for ram above. 176 177 above macro 178 seament d ::enable data segment 179 endm 180 181 :: Overlay - Generate code for transients. 182 183 overlav macro addr 184 def l tloc+$-cloc tloc 185 addr eau tloc+bloc+cloc-Monitr 186 segment c ;;enable code segment 187 endm 188 189 bseq - activate common segment. ;; 190 191 bseq macro 192 common /COMROM/ 193 defs comres 194 defl $ sega 195 endm 196 197 segment - Activate Segment. :: 198 199 segment macro s 200 update ::update active phase counter 201 s&space def1 ;;set enabled segment active 202 s&seg ::activate segment code placement 203 .phase s&loc ::set absolute segment location counter 204 endm 205 206 update - Update Phase Counters. ;; 207 208 update macro 209 if bspace ``` Balcones Operating System for the XEROX 820-II MACRO-80 3.44 09-Dec-81 Code Generation Control Macros Definitions | 215 | * | | if | tpal lt (\$-clo | c) | |-----|------|---------|----------|-----------------|------------------------------------| | 216 | | tpal | defl | \$-cloc | | | 217 | | | endif | | | | 218 | | | else | | | | 219 | | x&loc | defl | \$ | ;;save segment address | | 220 | | | endif | | ,, | | 221 | | x&space | def1 | 0 | ::clear segment active | | 222 | | • | .dephase | | ;;revert to relocatable | | 223 | | | endif | | ,, | | 224 | | | endm | | | | 225 | | | endm | | | | 226 | | | | | | | 227 | 0000 | bloc | defl | rom | establish non-resident code base: | | 228 | F000 | dloc | defl | monitr | establish resident code base | | 229 | 0000 | tloc | defl | 0 | establise Transient code base | | 230 | 0000 | tpal | | 0 | establish maximum transient length | | 231 | 0000 | bspace | | 0 | preset common segment inactive | | 232 | 0000 | cspace | | 0 | preset code segment inactive | | 233 | 0000 | dspace | defl | 0 | preset data segment inactive | | 234 | 0000 | comres | defl | 0 | preset common base address | | 235 | | | | | | | 236 | | | subttl | Ram Loader for | Testing Only | | 237 | | | page | | | | | | | | | | Appendix E • ``` 267 00FD comres defl 100h-3 268 269 below :generate non-resident code 270 00001 defs comres 271 272 prs - preset storage. :: 273 : 274 Entry: Power up or Reset button. 275 ; 276 0000 F3 prs: di :lock up system 277 0001 ΑF XOF 278 0002 3D prs1: dec ; the pause that refershes 20 FD 279 0003 jΓ nz,prs1 280 0005 ED 73 FFEO Ìα (rstsp).sp :save partial reset state 281 0009 22 FFE2 ١d (rsthl).hl ; in case the luser go boom 282 000C E 1 hl :pick possible return off stack DOD 283 000D 22 FFE4 1d (rstoc).hl 284 0010 0.9 exx give primary registers half a break 285 0011 1 C inc 286 0012 31 3839 1d sp,3839h ; load strange values in SP 31 4142 287 0015 1 d sp.4142h 288 0018 4C ١d c,h ;insure 43 289 0019 ١d b.e :registers 290 001A ١d c,a ;can 291 001B 4E ١d c.(h1) :forget 292 0010 45 1 d b.1 ; insure 53 293 001D ١d d,e :registers 294 001E 1 d В.е ;can 295 001F 4F ١d C.a : CODY 296 0020 4D ١d C.1 297 0021 50 1 d d,b 298 0022 1d d.1 299 0023 54 1 d d.h 300 0024 45 ١d b, 1 52 301 0025 1 d d.d 302 0026 08 af.af eх 303 0027 3E 17 ١d a,24-1 ; line up bottom of screen 304 0029 D3 14 out (scroll).a init scroll port 305 002B 21 3000 1 d hl.crtmem. :clear display memory 36 20 ١d (h1),'' 306 002E 307 0030 .11: 3001 ١d de.crtmem+1 308 0033 01 OBFF 1 d bc.crtmax-crtmem-1 309 0036 ED BO ldir :pray the video hardware works 0038 31 F000 insure monitor ram ok 310 ١d sp,monitr 311 003B 21 AA55 1 d h1.0aa55h ; walk checker board through ram prs2: 312 003E C1 DOD bc :read ram 313 003F E5 h١ :write ram fast push 314 0040 D1 de :read ram fast DOD C5 315 0041 push bc : put ram back ``` System Initialization | | 316 | 0042 | F١ | | | pop | af | ;and verify it | |---|-----|-------|------------|-----|--------|-------|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | 317 | 0043 | 90 | | | sub | b | · · · · · · · · | | | 318 | 0044 | 20 76 | | | ir | nz,err1 | :if ram failure | | | 319 | 0046 | ED 52 | | | sbc | hl,de | , rum rumare | | | 320 | 0048 | 20 72 | | | jr | nz.err1 | ; if ram or register failure | | | 321 | 004A | 38 | | | dec | sp | ;advance test address | | | 322 | 004B | 3F | | | ccf | ap | , advance test address | | | 323 | 004C | ED 7A | | | | | | | | 324 | | 20 EB | | | adc | hl,sp | The second secon | | | | 004E | | | | jr | nz,prs2 | ; if top of memory not reached | | | 325 | 0050 | 31 0000 | | | ١d | sp,stack | ;set monitor stack | | | 326 | 0053 | 21 0000 | | | ۱d | hl,prs | ;set rom address | | | 327 | 0056 | 01 1800 | | | ld . | bc,romsiz | | | | 328 | 0059 | CD OOAF | * . | | call | ccs | ;compute check sum | | | 329 | 005C | 20 63 | | | jr | nz,err2 | ; if bad rom | | | 330 | 005E | 21 00E6 | | | ld | hl, intab | point to default variable table | | | 331 | 0061 | 06 00 | | prs3: | 1 d | b.0 | | | | 332 | 0063 | 4E | | | 1 d | c,(hl) | ;set data block length | | | 333 | 0064 | 23 | | | inc | h1 | | | | 334 | 0065 | 5 E | | | 1 d | e.(h1) | ;set variable address in ram | | | 335 | 0066 | 23 | | | inc | hì | , set variable address in ram | | | 336 | 0067 | 56 | | | 1 d | d,(h1) | | | | 337 | 0068 | 23 | | | inc | | | | | 338 | 0069 | ED BO | | | ldir | hl | point to initial values | | | 339 | | | | | | | copy data from rom to variables in ram | | | | 006B | CB 7E | | | bit | 7,(hl) | | | | 340 | 006D | 28 F2 | | | jr | z,prs3 | ;if more data to preset | | | 341 | 006F | 23 | | | inc | h1 | ;point to i/o init data table | | | 342 | 0070 | 46 | | prs4: | ١d | b,(h1) | ;set number of bytes to preset | | | 343 | 0071 | 23 | | | inc . | hl | | | | 344 | 0072 | 4E | | | ld . | c,(hl) | ;set i/o port address | | | 345 | 0073 | 23 | | | inc | hl | · | | | 346 | 0074 | ED B3 | | | otir | | shoot preset data to i/o device | | | 347 | 0076 | CB 7E | | | bit | 7,(h1) | | | | 348 | 0078 | 28 F6 | | | ir | z.prs4 | ; if more devices require initialization | | | 349 | 007A | DB 1E | | | in | a,(kbddat) | assert PARDY | | | 350 | 007C | ED SE | | | im | 2 | ;select interrupt mode 2 | | | 351 | 007E | 3E FF | | | 1 d | a,high vectab | set interrupt vector page | | | 352 | 0080 | ED 47 | | | 1 d | i.a | , set interrupt vector page | | | 353 | 0082 | 21 041B | | | 1d | hl.rbase | ;set resident base address | | | 354 | 0085 | 11 F000 | | | l d | | | | | 355 | 0088 | 01 0F00 | | | 10 | de, monitr | set monitor address | | | 356 | 0088 | ED BO | | | | bc,ram-monitr | set max resident length | | | | | | | | ldir | | plant monitor upstairs | | | 357 | 008D | 21 1800 | | | 1 d | h1,Rx1984 | ;prognosticate | | | 358 | 0090 | 01 0800 | | | 1 d | bc,Lx1984 | | | | 359 | 0093 | CD OOAF | | | call | ccs | | | | 360 | 0096 | 20 14 | | | jr | nż,prs5 | | | | 361 | 0098 | 2A 1FFD | | | 1 d | hl,(Rx1984+Lx19 | 984-3) | | | 362 | 009B | 11 55AA | | | l d | de,55aah | | | | 363 | 009E | ED 52 | | | sbc | hl,de | | | | 364 | 00A0 | 21 FADB | | | 1 d | hl,cmdtab | | | | 365 | 00A3 | 11 F360 | | | ld | de, seltab | | | | 366 | 00A6 | 01 FC55 | | | ld | bc.cloc | | | | 367 | 00A9 | CC 1800 | | | call | z,Rx1984 | ;FutureShock | | | 368 | OOAC | C3 FC55 | | prs5: | jp | signon | ;Signon Resident Monitor | | | 369 | 00.00 | 30. 1. 000 | | p. 33: | 16 | o.gnon | To salvon was insur mount of | | | 370 | OOAF | 1E 00 | | ccs: | 1 d | e.0 | .orgent chackeum | | | 371 | 0081 | 7E | | | | | ;preset ckecksum | | 1 | 3/1 | 0001 | / E . | | ccs1: | 10 | a,(hl) | | | Appendix E | 427 | OOFF | 02 | | defb | 02 | use non-blinking box cursor | |-------------|------------|--------------|----------------------------|---------------|--------------|----------------------------|--------------------------------------| | en o | 425<br>426 | 00FB<br>00FD | FFAC<br>3000 | | defw | cursor<br>crtmem | :base address is 3000h | | ∕ <b>હે</b> | 423<br>424 | OOFA | 08 | • | defb | 8 | • | | ≥ | 421<br>422 | | | ; | initia | lize the crt dis | splay | | | 420 | 00F9 | 00 | | defb | 0 | ;fifo out | | | 418<br>419 | 00F7<br>00F8 | 00 | | defb<br>defb | 0 | ;fifo count<br>;fifo in | | | 416<br>417 | 00F4<br>00F5 | 03<br>FF30 | | defb<br>defw | 3<br>fifont | | | | 414<br>415 | | | ; | | eyboard fifo | | | | 413 | | | : | | | , and decide time. Intellight vector | | | 411<br>412 | 00F0<br>00F2 | 0000<br>F192 | | defw<br>defw | 0<br>timer | one second timer interrupt vector | | | 409<br>410 | OOEC | FF12<br>F1FD | | defw<br>defw | ctcvec+2<br>milli | ;one millisecond interrupt timer | | | 408 | 00E8 | 06 | | defb | 6 | | | | 406<br>407 | 00E9 | F140 | | defw | keysrv | parallel keyboard interrupt vector | | * | 404<br>405 | 00E6<br>00E7 | 02<br>FF1A | intab: | defb<br>defw | 2<br>sysvec+2 | | | | 403 | | | ; | | | ppr vector table | | | 401<br>402 | | | | • | ilize the interru | unt westen toble | | | 399<br>400 | 00E5<br>0009 | 72 | errm1 | equ | (\$-errm1)/2 | | | | 397<br>398 | 00DD<br>00E1 | 52 6F 6D 20<br>45 72 72 6F | errm2: | db | 'Rom Error' | | | | 396 | OODC | 72 | | | 455 | | | | 394<br>395 | 00D4<br>00D8 | 52 61 6D 20<br>45 72 72 6F | errm1: | db | 'Ram Error' | | | | 392<br>393 | 00D1 | C3 0000 | | jp | prs | try restart again; | | | 391 | OOCF | 20 FB | | or<br>jr | c<br>nz,err3 | | | | 389<br>390 | OOCE | 78<br>81 | | 1d | a,b | | | | 387<br>388 | OOCA<br>OOCC | ED B0<br>0B | err3: | ldir<br>dec | bc | ;pause a while | | | 386 | 00C7 | 01 0009 | | 1 d | bc,errm1 | (3,1,111,12) | | | 384<br>385 | 00C1<br>00C4 | 21 00DD<br>11 3024 | err2:<br>err: | ld<br>ld | hl,errm2<br>de,crtmem+40-( | (eccm) /2) | | | 383 | OOBF | 18 03 | | jr | err | ;set ram error message | | | 381<br>382 | 00BC | 21 00D4 | err1: | ۱a | hl,errm1 | | | | 379<br>380 | OOBA<br>OOBB | B3<br>C9 | | or<br>ret | e | | | | 378 | 0088 | 20 F7 | | jr | nz,ccs1 | | | 489 | 013A | C7 | · · | iefb | 11000111b | ;put ctc3 in counter mode with interrupt | |------------|--------------|----------|-----|--------------|------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 490 | 013B | 7D | d | lefb | 125 | ;ctc3 period = 125*8 msec = 1 second | | 491 | | | ; | | | | | 492 | | | | | | o for asynchronous serial | | 493 | | | ; i | nterfa | ce to printer or | terminal | | 494 | | | ; | | 12 | | | 495 | 013C | OA 07. | | lefb | 10,siocpb | | | 496 | 013E | 01 | | lefb | 1 | ;select register #1 | | 497<br>498 | 013F<br>0140 | 00 | | iefb<br>iefb | 000000006 | ;disable interrupts | | 498 | 0140 | 00 . | | iefb | low siovec | select register #2 | | 500 | 0141 | 03 | | iefb | 3 | :base sio interrupt vector<br>:select register #3 | | 501 | 0142 | 41 | | iefb | 01000001b | ; select register #3 :7 bits/rx characters | | 502 | 0144 | 0.4 | | lefb | 4 | ; bits// Characters | | 503 | 0145 | 47 | | iefb | 010001116 | ; l6x clock, 1 stop bit, even parity enabled | | 504 | 0146 | 05 | | iefb | 5 | select register #5 | | 505 | 0147 | AA | | lefb | 101010106 | :DTR. 7 bits/tx character. Tx enb. RTS | | 506 | 0.47 | | - | | 70.0.0.00 | tem, to the the distance of th | | 507 | 0148 | 01 OC | d | iefb | 1.baudb | | | 508 | 014A | 07 | | lefb | 0111b | :default clock is 1200 bps | | 509 | | | | | | | | 510 | | | : | | | | | 511 | | | ; 1 | nitial | ize communicatio | ns port for async modem interface | | 512 | | | ; | | | | | 513 | 014B | 08 06 | | iefb | 8,siocpa | | | 514 | 014D | 01 - | | iefb | 1 | ;select register #1 | | 515 | 014E | 00 | | iefb | 00000000ь | ;disable interrupts | | 516 | 014F | 03 | | lefb | 3 | ;select register #3 | | 517 | 0150 | 41 | | lefb | 01000001ь | ;7 bits/rx characters | | 518 | 0151 | 04<br>47 | | efb | 4<br>01000111b | ;select register #4 | | 519<br>520 | 0152<br>0153 | 05 | | lefb<br>lefb | 5 | ;16x clock, 1 stop bit, even parity enabled | | 520 | 0153 | AA | | iefb | 10101010b | ;select register #5<br>;DTR, 7 bits/tx character, Tx enb, RTS | | 522 | 0154 | ** | | ero | 101010100 | ; DIR, 7 DIES/EX CHARACTER, IX CHD, RIS | | 523 | 0155 | 01 00 | | iefb | 1.bauda | | | 524 | 0157 | 05 | | efb | 0101b | :default clock is 300 bps | | 525 | 0.07 | | _ | | | | | 526 | 0158 | 01 68 | d | lefb | 1.asvnc | :set internal Rx+Tx clocks | | 527 | 015A | 00 | d | iefb | 0 | | | 528 | | | : | | | | | 529 | | | ; i | nitial | ize PIO for Cent | ronics style printer | | 530 | | | ; | | | | | 531 | 015B | 03 09 | | iefb | 3,gpioca | | | 532 | 015D | CF | | iefb | 110011116 | ;mode 3 | | 533 | 015E | 00 | | iefb | 00000000ь | ;all output | | 534 | 015F | 07 | C | iefb | 000001116 | ;no interrupts | | 535 | | | | | | | | 536 | 0160 | 03 OB | | iefb | 3,gpiocb | | | 537 | 0162 | CF | | lefb | 11001111b | ;mode 3 | | 538 | 0163 | F0 | | tefb | 11110000b<br>00000111b | supper nibble in, lower out | | 539 | 0164 | 07 | C | iefb | 000001116 | ;no interrupts | | | | | | | | | | ģ | | | | | | |-----|-----|------|-------|--------|----------------------------------| | Φ. | 540 | | | | | | ž | 541 | 0165 | 01 OA | defb | 1,gpiodb | | dix | 542 | 0167 | 05 | defb | (1 shl p.strb) or (1 shl p.auto) | | | 543 | | | | | | ш | 544 | 0168 | FF | defb | -1 ;end of i/o init table | | | 545 | | | | | | | 546 | | | subttl | Resident Monitor Entry Points | | | 547 | | | page | | 603 552 553 ``` 554 variables is not allowed. Future releases of the Resident 555 Monitor will always provide compatability with these entry 556 vectors. 557 558 This restriction also applies to the Resident Monitor Ram 559 Page at the top of memory. Access to Ram Variables must 560 be obtained through the appropriate entry vector. 561 562 ahove 563 0266 d&seq C3 F07C 564 F000 cold: iр restart :monitor restart 565 F003 C3 FA62 warm: in prompt :monitor entry point 566 F006 C3 FOCD const: jp kbdst console status to A 567 FO09 C3 F008 conin: kbdin :console input to A ip 568 FOOC C3 F2F1 conout: jp crtout :console output from A C3 F2FE 569 FOOF jp fastort :fast crt output from C 570 F012 C3 F0E5 ip siost :sio channel b status to A 571 F015 C3 FOFO jp sioin ;sio channel b input to A 572 F018 C3 F0F8 jp sicout :sio channel b output from A 573 FO1B C3 FA17 ip select :select drive in C 574 FO1E C3 FA3C jp home ·home r/w head 575 F021 C3 FA3E ip seek seek to track in C 576 F024 C3 FA48 jρ read :read sector C -> buffer @ HL 577 F027 C3 FA44 ip write :write sector C <- buffer @ HL 578 FO2A C3 F344 jp xadvr :execute physical driver request @ HL 579 FD2D C3 F284 ip setcur set direct crt cursor from HL 580 F030 C3 F288 jp outcur direct crt display C3 F2A3 581 E033 ip crtldir :crt memory block move ala' LDIR 582 F036 C3 F097 jp getsel return address of disk mapping table to HL C3 F086 583 F039 dayti: ip daytim :return address of Time-of-Day 584 F03C C3 F08B jp config return configuration status 585 C3 F105 F03F ip siordy :sio channel b output ready status 586 F042 C3 FOA4 iρ setcon :set configuration 587 E045 C3 FOBF jp ssp start screen print 588 F048 C3 F13F usrsec: ip nulint :user accessible 1 second interrupt 589 F04B C3 F7A3 iocons console status through inbyte jp C3 F7AF 590 FO4F jp inconi ;console input through iobyte 591 F051 C3 F796 iocono :console output through inbyte jр 592 F054 C3 F7BB iolist jp ;printer output through iobyte 593 E057 C3 F7CC ip inlsts :printer status through jobyte 594 F05A C3 F770 io comins :communications input ready status 595 F05D C3 F775 ip cominp :communications input data to A C3 F77F communications output data from C 596 F060 jp comout 597 F063 C3 F788 ip comots :communications output ready status 598 :idle while i/o is pending F066 C3 F13F idle: iο nulint 599 F069 C3 F0D2 softv: jp soft :record soft error 600 F06C defs 16.-1 :space for option rom linkage 601 ``` to services provided by the Resident Monitor. Any access to code in the Monitor or its Ram page past the keyboard subttl Monitor Function Processors ``` 604 605 Monitor Restart. :: 606 607 F07C F3 restart:di :lock system 608 F07D DB 1C in a.(syspio) 609 F07F F6 80 1 shl 7 or ;enable banked rom 610 D3 1C F081 out (syspio).a 611 F083 C3 0000 jр ors ; reload monitor from rom or ram 612 613 Daytim - Return Address of Time-of-Day. ;; 614 615 F086 11 FF56 daytim: 1d de,day :point to day of month 616 F089 18 OF jr retval 617 618 ;; Config - Return Configuration Status Byte, 619 620 3A FOE3 F08B config: 1d a, (mask) turn keyboard mask into c.keym 621 F08E E6 80 and 080h 622 F090 F6 00 oг 623 F091 confg equ S-1 ;*****=>;This word stored by Preset 624 F092 5F 1d 625 F093 16 01 ١d d,rev-400 return revision level 626 F095 18 03 jr retval 627 628 :: getsel - Get address of Select table. 629 630 F097 11 F360 getsel: Id de.Seltab ;set select table address 631 632 :: Retval - Return Value to Caller. 633 634 F09A 24 retval: inc ;see if high level language call 635 F09B 25 dec h 636 F09C 28 03 jr z,retv1 ; if assembly level call 637 F09E 73 ١d (h1).e ;store answer in variable 638 F09F 23 inc h1 639 FOAG 72 ١d (h1).d 640 FOA 1 EB retv1: ex de,hl ; leave result in HL as well 641 FOA2 FB eiret: ei C9 642 FOA3 ret 643 644 :: setcon - set configuration. 645 646 FOA4 7 E setcon: 1d a.(hl) :get configuration table index 647 FOA5 CB BF res 7,a 648 FOA7 FE 06 СР numcon 649 FOA9 0.0 ret nc :if index out of range 650 FOAA 5F e,a 7E 651 FOAB 1 d a.(h1) :get read/write flag 652 FOAC 23 inc 653 FOAD 46 ١d b.(h1) :get configuration data 654 FOAE 16 00 1 d d.0 655 FOB0 21 FFBF ١d hl,contbl ;set address of configuration table addresses 656 F0B3 19 add hl.de 657 FOB4 19 add hl,de 658 FOB5 5E 1d e,(h1) ;get configurable byte address ``` | 665 | FOBC C8<br>FOBD 70<br>FOBE C9 | | ret<br>1d<br>ret | z<br>(h1),b | ;if asking current configuration<br>;store new configuration | | | |-------------------|--------------------------------------------------------------|----------|-------------------------------|-------------------------------------|--------------------------------------------------------------|--|--| | 668 | | | ;; ssp | - start screen pr | int. | | | | 671 | FOBF 3E 67<br>FOC1 32 F2 | 7<br>20E | ssp: ld | a,3+((24+1) s<br>(spact),a | shl 2) ;start with cr/lf | | | | 673<br>674<br>675 | FOC4 AF<br>FOC5 32 F2<br>FOC8 3E 81<br>FOCA D3 19<br>FOCC C9 | 1 | xor<br>1d<br>1d<br>out<br>ret | a<br>(spcnt),a<br>a,81h<br>(ctc1),a | start millisecond timer; | | | | 678<br>679 | | | subt<br>page | | inter Drivers | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | console / Printer brivers ``` 681 above :run this code upstairs 682 00CD" d&seq 683 684 kbdst - keyboard status. 685 686 Returns A = 0 if no char 687 A = -1 if char available 688 3A FF30 689 FOCD kbdst: 1 d a. (fifcnt) get input fife bytecount 690 FODO B7 or 691 FOD 1 C8 ret ; if keyboard queue is empty 692 693 :: soft - record soft error. 694 695 FOD2 F6 FF soft: or :set ready / error status 696 FOD4 C9 ret 697 698 kbdin - Keyboard Input. :: 699 700 Returns A = character 701 702 FOD5 CD F066 kbdin1: call idle :idle cou 703 FOD8 CD FOCD kbdin: call kbdst 704 FODB 28 F8 ir z.kbdin1 :loop until keyboard input ready 705 FODD E5 push hì CD F130 706 FODE call remove :get keyboard entry 707 FOF 1 E1 DOD h1 708 E6 7F F0E2 07fh kbmask: and 709 F0E3 equ :****=>:this byte modified by ESC 0/1 710 FOE4 C9 ret 711 712 siost - sio channel b input ready status. 11. 713 714 F0E5 DB 07 siost: in a.(siocob) :det sio status register 715 FOE7 F6 01 and 00000001b 716 FOE9 CB ret :if no data available 717 FOEA 3E FF 1 d a.-1 718 FOEC C9 ret 719 720 sioin - Sio channel b input character. ;; 721 FOED 722 CD F066 sigin1: call idle ;idle cpu 723 FOFO CD FOES sigin: call siost :test console status 724 F0F3 28 F8 ir z.sigin1 ;loop until data is 725 F0F5 DB 05 in a.(siodpb) :ready at sic data port 726 FOF7 C9 ret 727 728 ;; sicout - Sic channel B output character. 729 730 FOFB F5 af sicout: push 731 FOF9 CD F105 siox1: call siordy 732 FOFC CC F066 call z,idle ; idle cpu if transmitter not ready 733 FOFF 28 F8 jr z,siox1 734 F1 F101 DOD ``` ``` 740 F105 3E 10 siordy: 1d a.10h :reset status latch 741 F107 D3 07 (stocpb).a out 742 F109 DB 07 in a. (sincob) 743 F108 E6 04 00000100ь and :test the status bit 744 FIOC :*****=>:modified at run time siomsk equ G-1 745 F100 EE 04 000001006 xor 746 FIDE sioval equ 5-1 :*****=>:modified at run time 747 FIOF 28 02 ir z.siord1 if hardware is ready 748 F111 AF XOF 749 F112 C9 ret 750 F113 F6 FF siord1: or :set ready status 751 F115 00 ;*****=>;put RET here to disable Xon/Xoff xonenb: nop 752 CD FOE5 F116 call siost 753 F119 28 11 jr z,siord3 :if input not available 754 F11B CD FOFO ca11 sioin 755 FILE E6 7F 7fh and 756 F120 06 13 Xoff sub 757 F122 28 05 jr z,siord2 :if printer said Stop 758 F124 06 FF Xon-Xoff sub 759 F126 20 04 jr nz,siord3 ; if not Resume 760 F128 2F col set printer ready 761 F129 32 F12D siord2: ld (xofflg).a 762 F12C 3E FF siord3: 1d a.-1 763 xoffla eau F12D 5-1 :*****=>;set ^S pending flag 764 F12E 87 or а 765 F12F C9 ret 766 767 :: Remove - remove key from fifo. 768 :decrement fifo count 769 F130 21 FF30 remove: ld hl.fifcnt 770 F133 35 dec (h1) 771 F134 21 FF32 ١d hl.fifout ;point hl to fifo output offset 772 F137 (h1) advance fifo pointer 34 index: inc 773 F138 CB A6 res 4.(h1) :modulo 16 774 F13A 3E 20 ١d a, low fifo 775 F13C 86 add a.(h1) :index into fifo by offset 776 F13D 6F 1 d l,a 777 7E F13E ١d a.(h1) :fetch character in fifo 778 F13F C9 nulint: ret 779 780 Interrupt Service Routines subttl 781 page ``` | | 841 | F196 | 31 FF5 | 0 + | | 1 d | sp.intstk | | |------------|-----|------|------------|-----|---------|------|-------------|----------------------------------| | | 842 | F199 | E5 | | | push | h) | | | | 843 | F19A | F5 | + | | push | af | | | | 844 | F19B | 2A FF5 | 2 | | 1 d | hl,(tikcnt) | advance binary seconds counter | | | 845 | F19E | 23 | | | inc | hl | , | | | 846 | F19F | 22 FF5 | 2 | | 1 d | (tikent),hl | | | | 847 | F1A2 | CD F04 | 8 | | call | usrsec | ;invoke user's interrupt routine | | | 848 | F1A5 | 21 FF5 | 5 | | 1 d | hl,timout | :decrement disk turn-off timer | | | 849 | F1A8 | 35 | | • | dec | (hi) | | | | 850 | F1A9 | 20 06 | | | jr | nz,timer1 | exit if not timed out yet | | | 851 | FIAB | DB 1C | | | in | a,(syspio) | | | | 852 | FIAD | E6 F8 | | | and | 11111000ь | disable all drive selects which | | | 853 | FIAF | D3 1C | | | out | (syspio),a | turns off spindle motors | | | 854 | FIBI | C5 | | timer1: | push | bc | · | | | 855 | F182 | 06 02 | | | 1d | b,2 | | | | 856 | F1B4 | 3E 3B | | | 1 d | a,59 | | | | 857 | F1B6 | 21 FF5 | В | | ld | hl,secs | :point at wall clock | | | 858 | F1B9 | 34 | | timer2: | inc | (h1) | increment seconds | | | 859 | F1BA | BE | | | ср | (h1) | | | | 860 | F1BB | 30 2B | | | jr | nc,timer3 | ; if not one minute or hour | | | 861 | F1BD | 36 00 | | | 1 d | (h1),0 | | | | 862 | FIBF | 2B | | | dec | h1 | | | | 863 | F1C0 | 10 F7 | | | djnz | timer2 | | | | 864 | F1C2 | 3E 17 | | | 1 d | a,23 | | | | 865 | F1C4 | 34 | | | inc | (h1) | ;increment hours | | | 866 | F1C5 | BE | | | ср | (h1) | | | | 867 | F1C6 | 30 20 | | | jr | nc,timer3 | ;if not one day | | | 868 | F1C8 | 36 00 | | | 1 d | (h1),0 | | | | 869 | FICA | D5 | | | push | de . | | | | 870 | FICB | 2 <b>B</b> | | | dec | h1 | | | | 871 | F1CC | 2 <b>B</b> | | | dec | h1 | | | | 872 | FICD | 4E | | | 1d | c,(h1) | ;get month | | | 873 | FICE | 2B | _ | | dec | h1 | point to day | | | 874 | FICF | 11 F1F | 0 | | 1 d | de, dpm-1 | point to day/month table; | | | 875 | F1D2 | EB | | | e× | de,hl | | | | 876 | F1D3 | 09 | | | add | hl,bc | | | | 877 | F1D4 | 7E | | | 1d | a,(h1) | get number of days; | | | 878 | F1D5 | EB | | | ex | de,hl | | | | 879 | F1D6 | D1 | | | pop | de | | | | 880 | F1D7 | 34 | | | inc | (h1) | ;increment day | | | 881 | F1D8 | BE | | | ср | (h1) | | | | 882 | F1D9 | 30 OD | | | jr | nc,timer3 | ; if not end of month | | | 883 | FIDB | 36 01 | | | 1d | (h1),1 | reset day in month | | | 884 | FIDD | 23 | | | inc | h1 | | | | 885 | FIDE | 34 | | | inc | (h1) | ;increment month | | ▶ | 886 | FIDF | 3E 0B | | | 1 d | a,11 | | | Ó | 887 | FIEI | BE | | | сp | (h1) | | | • | 888 | F1E2 | 30 04 | | | jr | nc,timer3 | ;if not new years eve | | | 889 | F1E4 | 36 01 | | | 1 d | (h1),1 | wrap december to january; | | 3 | 890 | F1E6 | 23 | | | inc | h1 | | | <u>u.</u> | 891 | F1E7 | 34 | | | inc | (h1) | signal Guy Lombardo; | | Appendix E | 892 | F1E8 | C 1 | | timer3: | pop | bc | | | ш | | | | | | | | | | | | | | | | | | | ``` 894 rfi - return From Interrupt. :: 895 896 F1E9 F 1 rfi: af non 897 FIFA F1 pop h1 FIEB 31 0000 898 ìď sp.0 :restore stack 899 FIEC saystk equ $-2 :****=>:this word modified at runtime 900 FIEE :re-enable interrupts and return ED 4D 901 FIEF retins: reti 902 903 Table of days per month. ;; 904 905 F1F1 1 F dom: db 31 :january 906 F1F2 1 C db 28 :febuary 907 F1F3 16 db 31 :march 908 F1F4 1 E db 30 :april 909 F1F5 15 31 db ; may 910 F1F6 1.5 db 30 : june F1F7 911 1 F db 31 ijuly 912 FIFR 16 31 db :august FIF9 913 1 F db 30 :september 914 FIFA 1 F db 31 ;october 915 FIFB 3 F 30 db :november 1 F 916 FIFC db 31 :december 917 918 :: milli - Millisecond timer interrupt service. 919 920 FIFD milli: service 921 F1FD ED 73 F1EC 1 d (savstk).so 922 F201 31 FE50 1 d sp.intstk 923 F204 E5 push h) 924 F205 F5 push af 24 FE50 925 F206 ìd hl.(Milsec) 926 F209 23 inc :increment millisecond counter 927 F20A 22 FF50 1 d (Milsec).hl 928 F20D 3E 00 1.d a O :set screen print flag 929 F20E spact eau S-1 :****=>:this byte modified at runtime 930 F20F 67 1.d h,a 931 F210 E6 03 and 3 932 F212 28 6D ic z.mi116 ; if not printing screen 933 F214 6F ١d 1.a 934 F215 CD F105 cal' siordy get printer status 935 F218 28 67 z.mi116 ; if printer not ready ir 936 F21A 20 dec 937 F21B 20 48 ir nz.mil12 :if not character print state 938 F21D DB 1C in a, (syspio) :qet pio state 939 F21F F5 push 940 F220 CD F29C crton cal 941 F223 3E 00 ١d a.0 :get character count 942 F224 spcnt equ S-1 :*****=>:byte modified at runtime 943 F225 ЗD dec a 944 F226 FA F236 m, mi10 jp. ; if end of line 945 F229 32 F224 1 d (spcnt).a 946 F22C 21 0000 1 d h1.0 ;set next character address 947 F22D spaddr S-2 :****=>:word modified at runtime eau 948 F22F 7E 1d a, (h1) ``` ``` 952 F234 18 22 ; if not end of line 953 F236 3E 61 mi10: ١d a.1+(24 shl 2) ;set address of next print line 954 F238 94 sub 955 F239 1 F rra 956 F23A CB 2F sra 957 F23C CD F31E call cca :compute cursor address 958 F23F E5 hl push ;save next line address 959 C5 F240 push bc 960 F241 06 50 ١d b.80 ;delete trailing blanks 961 F243 7D ١d a,l 962 F244 80 add a.b 963 F245 6F 1 d 1.a 964 F246 2D mil01: dec 965 F247 7 E ١d a.(h1) :get next character 966 F248 E6 7F 7fh and 967 F24A FE 20 CD 968 nz,mi102 F24C 20 02 ir ; if not trailing blank 969 F24E 10 F6 djnz mi101 970 F250 78 mi102: 1 d a,b 971 F251 32 F224 ١d (spcnt).a set number of characters to print 972 F254 C1 DOD bc 973 F255 E1 pop h1 974 F256 3E 03 ١d a.3 ;set CR next state 975 F258 22 F22D mill1: 1 d (spaddr),hl set next display address 976 F25B 21 F20E ìd hl.spact :set state variable 977 F25E В6 or (h1) ; advance state 978 F25F 77 (h1),a ١d E1 979 F260 af :get pio back pop 980 F261 D3 1C (syspio),a out 981 F263 18 1C ir mil16 982 F265 2D mill2: dec :check next state 983 F266 21 F20E ١d hl,spact ;set state address 984 F269 20 11 ir nz.mill4 if not 1f state 985 F26B 7E ١d a.(h1) D6 04 986 F26C sub 1 shl 2 :advance line counter 987 F26E 77 ١d (hl).a 988 F26F FE FE Ср 2-(1 shl 2) 989 F271 20 05 ir nz.mi113 990 F273 3E 01 ١d a.1 :disable ctc interrupt 991 F275 D3 19 out (ctc1).a 992 F277 77 1 d (h1),a 3E 0A 993 F278 mil13: 1 d a.lf ;set line feed 994 F27A 18 02 mi115 995 F27C 3E 0D mil14: 1d a,cr ;set carriage return 996 F27E D3 05 mill5: out (siodpb).a ;move paper or carriage 997 F280 35 (h1) 998 F281 C3 F1E9 mil16: jp rfi :return from interrupt 999 1000 subttl Crt Driver 1001 page ``` 1004 1006 1007 1009 1011 1012 1013 1014 1015 1017 1019 1020 1021 1022 1023 1024 1026 1028 1029 1030 1031 1033 1035 1036 1037 1038 1039 1040 1042 1043 1044 1045 1046 1047 1048 1049 1050 1051 1052 1053 1054 1055 1056 ``` F284 22 FFAF setcur: 1d (dircur).hl ;set up cursor address F287 C9 ret :: outcur - store character directly to crt memory. F288 CD F29C outcur: call crton turn on crt bank F28B 2A FFAF ١d hl. (dircur) :fetch direct cursor F28F 71 1 d (h1).c :store character F28F 23 inc F290 22 FFAF 1 d (dircur).hl crtoff - turn crt ram off. . . F293 F3 crtoff: di :lock pio access F294 DB 1C in a, (syspio) F296 CB BF crtof1: res 7.a :reset crt bank enable F298 FB еi ;unlock pio access F299 D3 1C crton1: out (syspio),a F29B C9 ret ;; crton - turn crt ram on. F29C F3 crton: di ;lock time-out interrupt F29D DB 1C in a, (syspio) get pio status F29F CB FF set 7.a enable bank F2A1 18 F6 ir crton1 ;; block move from/to crt memory. Entry: HL = Source address DE = Destination address BC = Number of bytes to move A = 0 - Move crt ram to crt ram A < 0 - Move sys ram to crt ram A > 0 - Move crt ram to sys ram F2A3 ED 73 F31B crtldir:ld (usrstk),sp :do not use callers stack F2A7 31 FFE0 1 11 sp.crtstk :since it may disappear F2AA Α7 and а ;set entry conditions F2AB CD F29C cal crton F2AE 28 37 ir z.crtmv :block move within crt ram F2B0 F2 F2B5 iρ p,ldir2 ; if move from crt ram to system ram F2B3 EE 80 ldirl: xor 80h F285 D3 1C ldir2: out (syspio).a :enable source bank F2B7 E5 push h1 :save move source address F2B8 21 FFB0 ١d h1.-80 :count down one transfer buffer F2BB ED 4A adc hl.bc F2BD E3 (sp),h1 eх :save overflow, retrieve source address F2BE FA F2C4 jp m,ldir3 :if less than one buffer F2C1 01 0050 ١d bc.80 :transfer one buffer F2C4 C5 ldir3: push bc :save byte count F2C5 05 push de ; save destination address ``` :: setcur - set direct display cursor position. | - | 1060 | FZCC | CI | | | pop | DC | | |---|------|-------|-----|---------|------------|----------|--------------|---------| | | 1061 | F2CD | DB | 1C | | in | a,(syspio) | ; enat | | | 1062 | F2CF | EE | 80 | | xor | 80h | | | | 1063 | F2D1 | D3 | 1C | | out | (syspio).a | | | | 1064 | F2D3 | E5 | | | push | h1 | ;save | | | 1065 | F2D4 | 21 | | | 1 d | hl.linbuf | set | | | 1066 | F2D7 | ED | 80 | | ldir | | : move | | | 1067 | F2D9 | E١ | . 77 | | pop | h1 | • | | | 1068 | F2DA | C 1 | | | pop | bc · | ;retr | | | 1069 | F2DB | 78 | | | id | a,b | , | | | 1070 | F2DC | A.7 | | | and | a . | | | | 1071 | F200 | | F2E9 | | jp | m,crtmvo | ;no n | | | 1072 | F2E0 | B 1 | | | or<br>or | C | , | | | 1073 | F2E1 | | 06 | | jr. | z,crtmvo | ;if r | | | 1074 | F2E3 | | 1C | | in | a,(syspio) | | | | 1075 | F2E5 | | cc | | ir | ldir1 | :cont | | | 1076 | 1 243 | , , | | | J. | 14111 | , | | | 1077 | F2E7 | ΕÒ | В0 | crtmv: | ldir | | | | | 1078 | F2E9 | | | crtmvo: | | crtoff | ; turr | | | 1079 | F2EC | | 7B F31B | CI CIIIVO: | ld . | sp,(usrstk) | ; (0) | | | 1080 | F2F0 | C9 | | | ret | sp, (usistk) | | | | 1081 | F2F0 | Ca | | | ret | | | | | | | | | | | | | | | 1082 | | | | | subttl | Resident Crt | briver. | | | 1083 | | | | | page | | | | | | | | | | | | | Appendix E enable destination bank :move data from buffer to destination ino more move, turn crt ram off and return ; continue transfer one buffer at a crack retrieve bytes left to transfer ;save source address set upper buffer ; if no more turn crt ram off Resident Crt Driver. ``` 1085 crtout - Crt Output Driver. :: 1086 1087 Entry: Character in register A 1088 16 bytes of stack space available 1089 Exit: Char displayed, all registers saved 1090 1091 F2F1 E5 h1 crtout: push ;maintain users registers on his stack 1092 F2F2 05 push de 1093 F2F3 C5 push bс 1094 F2F4 F5 af push 1095 F2F5 4F 1 d c.a ;set character to process CD F2FE 1096 F2F6 call fastcrt process character quickly 1097 F2F9 F١ af gog restore callers registers 1098 F2FA Ci pop bc 1099 F2FB D 1 000 de 1100 F2FC E 1 pop hì 1101 F2FD C9 ret 1102 1103 :: fastcrt - fast crt driver. 1104 1105 Entry: Character in C 1106 Exit: The only register preserved is SP 1107 Peeking in register A reveals valuable characters. 1108 1109 F2FE ED 73 F31B fastcrt:1d (usrstk).sp ;do not use callers stack 1110 F302 31 FFE0 ld sp,crtstk :since it may disappear 1111 F305 DD E5 push ix 1112 F307 DB 1C in a, (syspio) read system pio 1113 F309 В7 or set bank enable status 1114 F30A E5 push af ; save status for exit code 1115 F30B CD F29C call crton turn on crt memory 1116 F30E FB еi enable interrupts 1117 F30F CD 0169 call crtdvr :execute crt driver rom 1118 F312 F1 pop af :get previous bank enable status 1119 F313 F4 F293 call p,crtoff idisable bank now if it was disabled on entry 1120 F316 DD E1 pop 1 x 1121 F318 3E 00 ١d a,0 ; sneak balcones golden characters to FAST users 1122 F319 gold equ 5-1 1123 31 F31B F31A ١d sp.usrstk ; restore callers stack 1124 F31B usrstk equ ;*****=>; this operand word is modified at runtime 1125 F31D С9 ret 1126 1127 cca - compute cursor address. : : 1128 : 1129 : Entry: A = Row 1130 1131 F31E 67 cca: ١d h,a 1132 F31F 3A FFB1 ١d a. (base) 1133 F322 84 add a.h 1134 F323 30 ccal: inc entry with base absolute 1135 F324 D6 18 cca2: sub 24 ditto 1136 F326 30 FC ir nc,cca2 1137 F328 C6 78 add a.24+2*crtbas 1138 F32A 67 1 d h,a ``` | 1143<br>1144 | | | | rstatt | - Restore Pre | vious Attrib | ite | | | |--------------|--------------|------------|-------------------|------------|----------------------|----------------|----------|-----------|---------| | 1145 | | | : . | . 5.4 | Medicare inc | * 1000 Att. 10 | | | | | 1146 | F332<br>F333 | 01.0000 | rstatt:<br>Istatt | l d<br>equ | bc,0<br><b>\$-</b> 2 | ;execute | previous | attribute | routine | | 1148 | F335 | C5 | istatt | push | bc | | | | | | 1149 | F336 | C9 | | ret | | | | | | | 1151 | F337 | E5 | setprv: | push | h1 | | | | | | 1152 | | 21 01CF | | 1d | hl.setlow | | | | | | 1153 | F339 | | prvatt | equ | <b>S</b> -2 | | | | | | 1154 | F33B | 22 F333 | | 1d | (lstatt),hl | | | | | | 1155 | F33E | ED 43 F339 | | 1d | (prvatt).bc | | | | | | 1156 | | E1 | | рор | hì | | | | | | 1157 | F343 | C9 | | ret | | | | | | | 1158 | | | | | | | | | | | 1159 | | | | subttl | Rom-resident | Crt Driver | | | | | 1160 | | | | page | | | | | | setmsk: rrca ;get low order bit as upper bit mask Appendix 1271 01F7 0F | 12 | 72 | 01F8 | F6 | 7 F | | or | 7fh | | |----|------------|------|----------|------|----------|------------------|------------------|--------------------------------------| | | 73 | 01FA | 4F | | | 1 d | c,a | | | | 74 | | - 1.1 | F0E3 | | ld | de, mask | | | | 75 | OIFE | 1 A | | | 1 d | a,(de) | | | | 76 | 01FF | | F319 | | 1 d | (gold),a | stash balcones gold; | | | 77 | 0202 | 79 | | | 1 d | a,c | | | | 78 | 0203 | 12 | | | 1 d | (de),a | store keyboard mask; | | | 179 | 0204 | С9 | | | ret | | | | | 80 | | | | | | | | | | 81 | | | | :: | Process | cursor position | sequence. | | | 82 | | | | ; | | | | | | 83 | 0205 | 3 E | 02 | setxy: | 1 d | a,2 | | | | 84 | 0207 | 12 | | | 1 d | (de),a | ;make leadin=2 next time | | | 85 | 0208 | C9 | | | ret | | | | | 86 | | | | | | | | | | 87 | 0209 | 3D | | setxy1: | | a | | | | 88 | 020A | 20 | 10 | | jr | nz,m3tst | ; if not in state 2 | | | 89 | 020C | 6F | | | 1 d | l,a | ;clear low cursor pos | | | 90 | 020D | 3 E | 03 | | ld | a,3 | | | | 91 | 020F | 12 | | | 1 d | (de),a | ;set state 3 for next time | | | 92 | 0210 | 79 | | setrow: | | a,c | | | | 93 | 0211 | E6 | | | and | 07fh | strip parity bit; | | | 94 | 0213 | D6 | 20 | | sub | | | | | 95 | 0215 | D8 | | | ret | c | ;if illegal character | | | 96 | 0216 | FΕ | 18 | | ср | 24 | | | | 97 | 0218 | DO | | | ret | nc | | | | 98 | 0219 | C3 | F31E | | jp | cca | compute cursor address | | | 99 | | | | | | | | | | 100 | 021C | 3D | | m3tst: | dec | a | | | | 101 | 021D | 20 | OC | | jr | nz,m4tst | ;if not ready for column | | | 02 | 021F | 79 | | setcol: | | a,c | | | | 103 | 0220 | E6 | | | and | 07fh | strip parity bit; | | | 104 | 0222 | D6 | 20 | | sub | , , | ; of esc,'=',row,col sequence | | | 105 | 0224 | D8 | | | ret | С | | | | 06 | 0225 | FE | 50 | | cp | 80 | | | | 107 | 0227 | DO | | | ret | nc | | | | 08 | 0228 | B5 | | | or | 1 | merge in col# with l | | | 09 | 0229 | 6F | | | 1 d | 1,a | | | | 10 | 022A | С9 | | | ret | | | | | 111 | | | | | | | | | | 112 | 022B | 3D | | m4tst: | dec | a | | | | 13 | 022C | 20<br>D1 | 04 | | jr | nz,m5tst | ; if not escape state 4 | | | 114 | 022E | | 0.00 | | pop | de | ;pitch address of crtd3 | | | 115 | 022F | C3 | 0182 | | jр | crtd1 | ;display character in C | | | 116 | 0232 | | FFAE | m5tst: | 1 d | - ( | | | | | 0232 | | | motst: | 1 d | a,(csrchr) | | | | 18 | 0235 | 79 | F319 | | 10 | (gold),a | ;stash balcones gold | | | 119<br>120 | 0238 | | FFAE | | 10 | a,c | | | | | | 09 | FFAC | | ret | (csrchr),a | store new cursor character; | | | 21 | 023C | CA | | | ı <del>e</del> t | | | | | 22 | | | | | | | 1 -1 | | | 23 | | | | ;; | contri | - process contro | character. | | | 24 | 0000 | | | <u>.</u> | | | | | | 25 | 023D | | FFB2 | contrl: | | de,leadin | point at leadin state | | | 26 | 0240 | | 01B4 | | jp | nc.multi | ; if multi code sequence in progress | | 13 | 127 | 0243 | FE | 05 | | ср | 'E'-64 | | | 1332 | 024C | 09 | | add | hl,bc | ;index through control character table | |------|------|------|---------|--------|-----------------|--------------------------------------------------------| | 1333 | 024D | 09 | | add | h1.bc | , time-gir control character table | | 1334 | 024E | 4E | | 1 d | c,(h1) | | | 1335 | 024F | 23 | | inc | hi | | | 1336 | 0250 | 46 | | 1 d | b.(h1) | :get address of control subroutine | | 1337 | 0251 | E1 | | pop | h1 | | | 1338 | 0252 | C5 | | push | bc | | | 1339 | 0253 | C9 | | ret | | :execute control code driver | | 1340 | | | | | | , | | 1341 | | | | if | (options a | and o.esct) ne O | | 1342 | 0254 | 0205 | ctltab: | | defcur | :Ctrl-e is define new cursor character | | 1343 | 0256 | F332 | | defw | rstatt | :Ctrl-f is restore previous attribute mode | | 1344 | 0258 | 032F | | defw | bell | ;Ctrl-g is the bell | | 1345 | 025A | 02CE | | defw | bakspc | ;Ctrl-h is cursor left | | 1346 | 025C | 031F | | defw | tab | :Ctrl-i is tab | | 1347 | 025E | 02F7 | | defw | lfeed | ;Ctrl-j is cursor down | | 1348 | 0260 | 02DC | | defw | upcsr | ;Ctrl-k is cursor up | | 1349 | 0262 | 02D4 | | defw | forspc | :Ctrl-1 is cursor right | | 1350 | 0264 | 02F2 | | defw | return | ;Ctrl-m is carriage return | | 1351 | 0266 | 0200 | | defw | nono | Ctrl-m is carriage return; | | 1352 | 0268 | 0200 | | defw | nono | | | 1353 | 026A | 0200 | | defw | nono | ;Ctrl-o is not acceptable | | 1354 | 0260 | 0361 | | defw | cireos | ;Ctrl-p is not acceptable | | 1355 | 026E | 0200 | | defw | nono | Ctrl-q is clear to end-of-screen | | 1356 | 0270 | 0200 | | defw | nono | | | 1357 | 0273 | 0200 | | defw | nono | ;Ctrl-s is not acceptable<br>;Ctrl-t is not acceptable | | 1358 | 0274 | 0200 | | defw | nono | ;Ctrl-u is not acceptable | | 1359 | 0274 | 0200 | | defw | nono | | | 1360 | 0278 | 0200 | | defw | nono | ;Ctrl-v is not acceptable<br>;Ctrl-w is not acceptable | | 1361 | 027A | 0344 | | defw | clreol | | | 1362 | 027A | 0200 | | | | ;Ctrl-x is clear to end-of-line | | 1363 | 027E | 0357 | | defw | nono | ;Ctrl-y is not acceptable | | | | | | defw | clrscn | :Ctrl-z is clear screen | | 1364 | 0280 | 02BD | | defw | escape | ;Ctrl-[ is escape | | 1365 | 0282 | 02C0 | | defw | nono | ;Ctrl-\ is not acceptable | | 1366 | 0284 | 02C0 | | defw | nono | (Ctrl-) is not acceptable | | 1367 | 0286 | 02C9 | | defw | homeup | :Ctrl-^ is home up | | 1368 | 0288 | 02C1 | | defw | stuff | ;Ctrl is display control chars | | 1369 | | | | | | | | 1370 | 0036 | | ctlsiz | equ | \$-ctltab | | | 1371 | | | | | | | | 1372 | | | ; ; | Escape | sequence ta | ible. | | 1373 | | | ; | | | | | 1374 | | | ; | | | nal compatibility with terminals supporting | | 1375 | | | ; | ADM-3a | style super | sets. | | 1376 | | | ; | | | | | 1377 | 028A | 28 | esctab: | db | ′(′ | disable attribute; | | 1378 | 028B | 29 | | db | ')' | ;enable atribute | | 1379 | 028C | 2A | | db | 1 * 1 | ;clear screen | | 1380 | 028D | 30 | | db | .0. | strip keyboard upper bit | | 1381 | 028E | . 31 | | db | 111 | pass keyboard upper bit | | 1382 | 028F | 34 | | db | '4' | char font and blinking | | 1383 | 0290 | 35 | | db | 15 <sup>1</sup> | char font and graphics | | | | | | | | · · · · · · · · · · · · · · · · · · · | Appendix E Appendix | 1522 | 032A | E6 | F8 | | and | 11111000b | advance cursor to next tab stop | |------|------|-----|------|---------|--------|-----------------|------------------------------------------| | 1523 | 032C | 6F | | | 1 d | 1,a | , | | 1524 | 032D | 19 | | | add | hì.de | | | 1525 | 032E | C9 | | | ret | , | | | 1526 | | | | | | | | | 1527 | | | | | bell - | Move speaker ba | ck and forth | | 1528 | | | | ; ' | | more opeaner ba | en and rorein | | 1529 | 032F | 3.5 | 35 | bell: | 1 d | a,bltim | :Bell time constant | | 1530 | 0331 | D3 | | bell1: | out | (bellon),a | ;push speaker out | | 1531 | 0333 | 06 | | Deiii: | 1d | b,blonc | ;set Bell on time constant | | 1532 | 0335 | 10 | | | | \$ | | | 1533 | 0333 | D3 | | | djnz | | pause B*2 micro seconds | | | | | | | out | (bellof),a | ;yank speaker in | | 1534 | 0339 | 06 | | | 1 d | b,blofc | set Bell off time constant | | 1535 | 033B | | FE | | djnz | \$ | | | 1536 | 033D | 3 D | | | dec | a | | | 1537 | 033E | 20 | F1 | | jr | nz,bell! | ; if more noise to make | | 1538 | 0340 | C9 | | | ret | | | | 1539 | | | | | | | | | 1540 | | | | ;; | cirlin | - Clear line. | | | 1541 | | | | | | | | | 1542 | 0341 | CD | 02F2 | cirlin: | call | return | return cursor and fall through cireol | | 543 | | | | | | | protein carson and rarr timeagn circus. | | 1544 | | | | | cirent | - Clear to end | of line | | 1545 | | | | : ' | CITEOI | Crear to end | or rine. | | 1546 | 0344 | 7 D | | cireoi: | 1 4 | a.1 | | | 1547 | 0345 | E6 | 70 | Cireor: | | 011111116 | | | 1548 | 0345 | FE | | | and | | get column component of cursor posistion | | | | | 50 | | ср | 80 | | | 1549 | 0349 | 00 | | | ret | nc | ; if someone busted curpos | | 1550 | 034A | ED | | | neg | | | | 1551 | 034C | C6 | 50 | | add | a,80 | calculate number of characters to clear | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 1000 | | | | | 0,1116 | · · · · | , end or rine not crear | |------|------|-----|---------|---------|--------|-----------------|----------------------------------------------| | 1557 | 0355 | 6F | | | 1 d | 1,a | ;restore cursor column | | 1558 | 0356 | C9 | | | ret | | | | 1559 | | | | | | | | | 1560 | | | | :: | clrscn | - clear visible | screen memory. | | 1561 | | | | ; | | | | | 1562 | 0357 | 21 | 3000 | clrscn: | 1.d | hl,crtmem | :home cursor | | 1563 | 035A | | 17 | | 1 d | a,23 | | | 1564 | 035C | | FFB1 | | 10 | (base).a | ;put line 23 at bottom of screen | | 1565 | 035F | | 14 | | out | | :note scroll register gets A8-A12, not d0-d7 | | 1566 | 0331 | 03 | 17 | | out | (301011),2 | inde scioti register gets Ad-A12, not do-d/ | | | | | | | | | | | 1567 | | | | :: | cireos | - clear to end | of screen. | | 1568 | | | | ; | | | | | 1569 | 0361 | | 0344 | clreos: | | clreol | clear remainder of current row; | | 1570 | 0364 | E5 | | | push | hl | ;save cursor location | | 1571 | 0365 | ED | 4B FFB1 | clrs1: | 1 d | bc.(base) | ;set bottom screen row to c | | 1572 | 0369 | 7 D | | | 1 d | a.l | | | 1573 | 036A | 17 | | | rla | | | | 1574 | 036B | 7 C | | | 1d | a.h | | | 1575 | 036C | 17 | | | rla | -• | get row# component of hl into a | | 1576 | 036D | | 1 F | | and | 00011111b | , get i our component of in into a | | 1577 | 036F | 89 | 11 | | | c | | | | | | 08 | | cp | | | | 1578 | 0370 | | | | jr | z,clrs2 | ; if hl is on bottom row of screen | | 1579 | 0372 | | 02E7 | | call | dnesr | ;point hl to next row | | 1580 | 0375 | | 0341 | | call | clrlin | and fill that line with spaces | | 1581 | 0378 | | EB · | | jr | clrs1 | | | 1582 | 037A | E 1 | | clrs2: | pop | hl | restore original cursor pointer; | | 1583 | 037B | C9 | | | ret | | | | 1584 | | | | | | | | | 1585 | | | | :: | lindel | - Line delete. | | | 1586 | | | | ; ' | | | | | 1587 | 037C | E5 | | lindel: | nush | h1 | :save cursor address | | 1588 | 037D | | 040F | | call | bbg | :bury balcones gold | | 1589 | 0370 | 29 | 0401 | | add | hì,hì | ; our y barcones gord | | | | 7 C | | | | | | | 1590 | 0381 | | | | ld . | a,h | | | 1591 | 0382 | | 1F | | and | 00011111b | ;extract row | | 1592 | 0384 | | 4B FFB0 | | 1 d | bc,(base-1) | get base screen row in b | | 1593 | 0388 | | 03D1 | lind1: | call | smp | ;set move parameters | | 1594 | 038B | 88 | | | СР | ь | | | 1595 | 038C | 28 | 10 | | jr | z.lind2 | ;if last line | | 1596 | 038E | C5 | | | push | bc | ;b=last line, c=row | | 1597 | 038F | 01 | 0050 | | ld | bc.80 | | | 1598 | 0392 | ED | В0 | | ldir | | | | 1599 | 0394 | C 1 | | | рор | bc | | | 1600 | 0395 | 79 | | | 1d | a,c | | | 1601 | 0396 | 3 C | | | inc | a | | | 1602 | 0397 | | 18 | | | 24 | | | | | | | | сp | | | | 1603 | 0399 | | ED | | jr | c,lind1 | | | 1604 | 0398 | AF | | | xor | a | ;wrap | | 1605 | 039C | | EA | | jr | lind1 | ;move next line | | 1606 | 039E | EB | | lind2: | ex | de,hl | | | 1607 | 039F | CD | 0341 | lind3: | call | cirlin | | | | | | | | | | | | | | | | | | | | 1649 1650 :: chrins - Character insert. 1651 1652 03DC E5 chrins: push h1 1653 03DD 7D ١d a, 1 :set cursor column 1654 03DE E6 7F and 011111111 ;set move length = 79-column 1655 03E0 ED 44 neg 1656 03E2 C6 4F add a,79 1657 03E4 47 1d b,a :number of chars to move 1658 03E5 7E ١d a.(h1) ;get char under cursor 1659 03E6 36 20 ١d (h1),'' :clear char under cursor 1660 03E8 28 06 ir z.chrin2 :if cursor in last column 1661 03EA 2C chrin1: inc 1662 03EB 4E ١d c,(h1) 1663 03EC 77 1 d (h1),a ``` 1668 03F4 · C9 ret 1670 :: chrdel - Character delete. 1671 1672 03E5 chrdel: push h1 1673 03F6 7D 1d a.1 1674 03F7 E6 7F and 01111111b :isolate cursor column 1675 03F9 ED 44 neg 03FB a.79 1676 C6 4F add 1677 03FD 4F 1d c.a :number of chars to move = 79-column 1678 03FE 06 00 1.0 b,0 1679 0400 54 ١d d.h 1680 0401 5D 1 d e, 1 1681 0402 1.4 1 d a.(de) 1682 0403 32 F319 1 d (gold),a :mine balcones gold 1683 0406 23 inc 1684 0407 C4 0418 call nz.ldirx 1685 040A EB eх de.hl 1686 040B 36 20 1 d (h1).' ' :blank last char on line 1687 040D E1 pop :restore cursor 1688 C9 040E ret 1689 1690 bbg - bury balcones gold. ;; 1691 1692 040F CD 02F2 bba: call return 1693 0412 . 11 FF5C 1 d de,linbuf 1694 0415 01 0050 bc.80 1 d 1695 0418 ED BO ldirx: ldir 1696 0414 C9 ret 1697 1698 subttl Logical to Physical Driver Executioner ``` page | • | 1700 | | | | | | | | | |---|--------------|-------|----------|------|---|--------|---------|-------------------|-----------------------------------| | | 1701 | | | | | | above | | ;code goes in ram | | • | 1702 | 0518! | | | + | | d&seg | | | | | 1703 | | | | | | | | | | • | 1704 | | | | | ;; | Xddvr - | · Execute Physica | 1 Driver, | | | 1705 | | | | | ; | | | | | | 1706 | | | | | ; | Entry: | HL = Pointer to | Physical Drive Request Block | | | 1707 | | | | | ; | | | | | | 1708 | | | | | | | | | | | 1709 | F344 | 23 | | | xqdvr: | inc | h! | point at physical unit | | | 1710 | F345 | E5 | | | | push | h! | | | | 1711<br>1712 | F346 | 23<br>5E | | | | inc | h1 | | | | 1713 | F347 | | F360 | | | 1 d | e,(h1) | set logical drive | | | | F348 | | | | | 1 d | hl,Seltab | ;Set driver mapping table addres: | | | 1714<br>1715 | F34B | | 00 | | | 1 d | d.0 | | | | | F34D | 19 | | | | add | hl,de | ;index into driver select table | | | 1716<br>1717 | F34E | 19 | | | | add | hl,de | | | | | F34F | 5E | | | | 1 d | e,(h1) | set physical driver index; | | | 1718 | F350 | 23 | | | | inc | hl | | | | 1719 | F351 | 7 E | | | | 1 d | a,(h1) | set physical unit | | | 1720<br>1721 | F352 | | F380 | | | ۱d | hl,Drvtab | set Driver table address; | | | | F355 | 19 | | | | add | hl,de | | | | 1722 | F356 | 19 | | | | add | hl,de | | | | 1723 | F357 | 5E | | | | ld | e,(hl) | set physical driver address; | | | 1724 | F358 | 23 | | | | inc | hl | | | | 1725 | F359 | 56 | | | | ١d | d,(h1) | | | | 1726 | F35A | E 1 | | | | pop | h1 | recover request block address | | | 1727 | F35B | 77 | | | | ld | (h1),a | store physical unit; | | | 1728 | F35C | 28 | | | | dec | h1 | | | | 1729 | F35D | D5 | | | | push | de | execute physical driver; | | | 1730 | F35E | C9 | | | | ret | | | | | 1731 | | | | | | | | | | | 1732 | | | | | | subtti | Physical Disk D | river Area | | | 1733 | | | | | | page | | | ``` 1738 035F" d&seq 1739 Waste space to get drivers on page boundry. :: 1740 1741 F35F Wasted: 1742 000F bndry 0fh eau 1743 if ($ and bndry) ne 0 1744 E35E bndry+1-($ and bndry),-1 defs 1745 endif 1746 1747 :: Logical to Physical Drive Mapping Tables. 1748 1749 : Seltab contains two bytes per logical CP/M drive A-P. 1750 The first byte is an index into the physical driver 1751 address table below. The second byte is a unit number 1752 that is passed to the driver by the standard deblocker. 1753 1754 F360 Seltab: 1755 F360 1756 01 00 . A : defb 1.0 :Floppy Unit 0 1757 F362 01 01 .B: defb 1.1 :Floppy Unit 1 1758 F364 01 02 :Floppy Unit 2 . C : defb 1.2 1759 F366 01 03 . D : defb 1.3 ;Floppy Unit 3 1760 1761 F368 01 04 . E : defb 1.4 :Rigid Partition 0 1762 F36A 01 05 .F: defb 1.5 Rigid Partition 1 1763 F36C 01 06 . G: defb 1.6 :Rigid Partition 2 1764 F36F 01 07 .H: defb 1.7 :Rigid Partition 3 1765 1766 F370 00 00 . I : defb 0,0 :Error Driver 1767 F372 00 00 .J: defb 0.0 :Error Driver 1768 F374 00 00 defb 0.0 :Error Driver . K: 0.0 :Error Driver 1769 F376 00 00 . L : defb 1770 1771 F378 00 00 . M: defb 0.0 :Error Driver 00 00 0,0 :Error Driver 1772 F37A . N : defb 1773 F37C 00 00 .0: defb 0.0 :Error Driver 0.0 :Error Driver 1774 F37F 00 00 . P : defb 1775 1776 Physical Driver Address Table. . . 1777 : 1778 Dyrtab contains the addresses of several independent physical disk drivers. By convention, driver # 0 always 1779 1780 . returns a select error. 1781 F380 F42A Drvtab: defw Selerr 1782 ;select error physical driver 1783 F382 F4B0 defw Dskdvr :Disk driver (WD or SA) 1784 F384 0000 defw 0 :Empty physical driver expansion slots ppendix E 1785 F386 0000 defw 0 0000 defw 0 1786 F388 1787 F38A 0000 defw ō 1788 F38C 0000 defw n ``` | Physical | DISK DE | nver Area | | | | | |--------------|---------|-----------|--------|--------|-----------|-------------------------------------------| | 1789<br>1790 | F38E | FFFF | | defw | 0-1 | mark last empty expansion slot | | | | | | | | | | 1791 | | | | overia | d Monitor | Ram Address Definitions. | | 1792 | | | 1 | | | | | 1793 | FC80 | | dirbuf | equ | 0fc80h | director buffer; | | 1794 | FD00 | | chk00 | equ | 0fd00h | Directory Check Vector for Floppy Drive O | | 1795 | FD20 | | chk01 | equ | 0fd20h | Directory Check Vector for Floppy Drive 1 | | 1796 | FD40 | | chk02 | equ | 0fd40h | Directory Check Vector for Floppy Drive 2 | | 1797 | FD60 | | chk03 | equ | 0fd60h | Directory Check Vector for Floppy Drive 3 | | 1798 | 0000 | | chk04 | equ | 0 | ;No Check Vector for Rigid Partition O | | 1799 | 0000 | | chk05 | equ : | 0 | :No Check Vector for Rigid Partition 1 | | 1800 | 0000 | | chk06 | equ | 0 | :No Check Vector for Rigid Partition 2 | | 1801 | 0000 | | chk07 | equ | Ó | :No Check Vector for Rigid Partition 3 | | 1802 | | | | • | | • • • • • • • • • • • • • • • • • • • • | | 1803 | FD80 | | a1100 | equ | 0fd80h | ;Floppy Drive O Allocation Vector | | 1804 | FDAO | | a1101 | equ | 0fda0h | :Floppy Drive 1 Allocation Vector | | 1805 | FDCO | | a1102 | equ | ofdc0n | ;Floppy Drive 2 Allocation Vector | | 1806 | FDEO | | a1103 | equ | 0fde0h | ;Floppy Drive 3 Allocation Vector | | 1807 | FE00 | | a1104 | equ | 0fe00h | Rigid Partition Allocation vectors | | 1808 | FE80 | | a1105 | equ | 0fe80h | , Kigia raitition Allocation vectors | | 1809 | FECO | | a1106 | equ | 0fec0h | | | 1810 | FEEO | | a1107 | equ | 0fee0h | | | 1811 | | | 21107 | equ | 0.66011 | | | 1812 | | | | subttl | 04-1-0 | ameter Headers | | 1813 | | | | | DISK Par | ameter neaders | | 1013 | | | | page | | | | 1852<br>1853<br>1854<br>1855<br>1856<br>1857 | F3E8<br>F3EC<br>F3F0<br>F3F4<br>F3F8<br>F3FC<br>F400<br>F404<br>F408<br>F40C | FC80 F<br>0000 0<br>0000 0<br>FC80 F<br>0000 0<br>0000 0<br>FC80 F | 000<br>000<br>490<br>ECO | dw dw dw dw dw dw dw subttl | chk05,a1105<br>0,0,0,0<br>dirbuf,Dpbrg6<br>chk06,a1106 | :Rigid Partition 2 :Rigid Partition 3 Tables | |----------------------------------------------|------------------------------------------------------------------------------|--------------------------------------------------------------------|---------------------------------|-----------------------------|---------------------------------------------------------------------------------------------------|----------------------------------------------| | 1853<br>1854<br>1855<br>1856<br>1857 | F3EC<br>F3F0<br>F3F4<br>F3F8<br>F3FC<br>F400<br>F404<br>F408 | 0000 F<br>0000 0<br>0000 0<br>FC80 F<br>0000 F<br>0000 0<br>FC80 F | 000<br>000<br>490<br>ECO | dw dw dw dw dw dw dw dw dw | chk05,a1105<br>0,0,0,0<br>dirbuf,Dpbrg6<br>chk06,a1106<br>0,0,0,0<br>dirbuf,Dpbrg7<br>chk07,a1107 | :Rigid Partition 3 | | 1853<br>1854<br>1855 | F3EC<br>F3F0<br>F3F4<br>F3F8<br>F3FC<br>F400<br>F404<br>F408 | 0000 F<br>0000 0<br>0000 0<br>FC80 F<br>0000 F<br>0000 0<br>FC80 F | 000<br>000<br>490<br>ECO | dw<br>dw<br>dw<br>dw<br>dw | chk05,a1105<br>0,0,0,0<br>dirbuf,Dpbrg6<br>chk06,a1106<br>0,0,0,0<br>dirbuf,Dpbrg7 | | | 1853<br>1854 | F3EC<br>F3F0<br>F3F4<br>F3F8<br>F3FC<br>F400<br>F404<br>F408 | 0000 F<br>0000 0<br>0000 0<br>FC80 F<br>0000 F<br>0000 0<br>FC80 F | 000<br>000<br>490<br>ECO | dw<br>dw<br>dw<br>dw<br>dw | chk05,a1105<br>0,0,0,0<br>dirbuf,Dpbrg6<br>chk06,a1106<br>0,0,0,0<br>dirbuf,Dpbrg7 | | | 1853 | F3EC<br>F3F0<br>F3F4<br>F3F8<br>F3FC<br>F400<br>F404 | 0000 F<br>0000 0<br>0000 0<br>FCB0 F<br>0000 F | 000<br>000<br>490<br>ECO | dw<br>dw<br>dw<br>dw | chk05,a1105<br>0,0,0,0<br>dirbuf,Dpbrg6<br>chk06,a1106<br>0,0,0,0 | | | | F3EC<br>F3F0<br>F3F4<br>F3F8<br>F3FC | 0000 F<br>0000 0<br>0000 0<br>FCB0 F<br>0000 F | E80<br>000<br>000<br>490<br>EC0 | dw<br>dw<br>dw | chk05,a1105<br>0,0,0,0<br>dirbuf,Dpbrg6<br>chk06,a1106 | | | | F3EC<br>F3F0<br>F3F4<br>F3F8<br>F3FC | 0000 F<br>0000 0<br>0000 0<br>FC80 F<br>0000 F | E80<br>000<br>000<br>490<br>EC0 | dw<br>dw<br>dw | chk05,a1105<br>0,0,0,0<br>dirbuf,Dpbrg6<br>chk06,a1106 | | | 1852 | F3EC<br>F3F0<br>F3F4<br>F3F8 | 0000 F<br>0000 0<br>0000 0<br>FC80 F | E80<br>000<br>000<br>490 | dw<br>dw | chk05,a1105<br>0,0,0,0<br>dirbuf,Dpbrg6 | :Rigid Partition 2 | | 1851 | F3EC<br>F3F0<br>F3F4<br>F3F8 | 0000 F<br>0000 0<br>0000 0<br>FC80 F | E80<br>000<br>000<br>490 | dw<br>dw | chk05,a1105<br>0,0,0,0<br>dirbuf,Dpbrg6 | :Rigid Partition 2 | | 1850 | F3EC<br>F3F0<br>F3F4 | 0000 F | 000<br>000 | dw | 0,0,0,0 | :Rigid Partition 2 | | 1848 | F3EC<br>F3F0 | 0000 F | 000 | dw | chk05,a1105 | :Rigid Partition 2 | | 1847<br>1848 | F3EC | 0000 F | E80 | dw | chk05,a1105 | D/-/- D/-/ D | | 1846 | | | | | | | | 1845 | | | | | | | | 1844 | | | AHO | d₩ | dirbuf,Dpbrg5 | | | 1843 | F3E4 | 0000 0 | | | | | | 1842 | F3E0 | 0000 0 | | dw | 0,0,0,0 | Rigid Partition 1 | | 1841 | | | | | | * | | 1840 | F3DC | 0000 F | E00 | dw | chk04,a1104 | | | 1839 | F3D8 | FCBO F | | dw | dirbuf,Dpbrg4 | | | 1838 | F3D4 | 0000 0 | | | | | | 1837 | F3D0 | 0000 0 | | dw - | 0,0,0,0 | Rigid Partition 0 | | 1836 | | | | | | | | 1835 | F3CC | FD60 F | | dw | chk03,a1103 | | | 1834 | F3CB | FC80 0 | | dw | dirbuf.0 | | | 1833 | F3C4 | 0000 0 | | | | | | 1832 | F3C0 | 0000 0 | 000 | dw | 0.0.0.0 | ;Floppy Drive 3 | | 1831 | . 556 | . 540 1 | | | | | | 1830 | F3BC | FD40 F | | dw | chk02.a1102 | | | 1829 | F388 | FC80 0 | | dw | dirbuf,0 | | | 1828 | F3B4 | 0000 0 | | u# | 0,0,0,0 | 11 TOPPY DI TVE Z | | 1825 | F3B0 | 0000 0 | 000 | dw | 0.0.0.0 | :Floppy Drive 2 | | 1825 | FJAC | FD20 F | DAU | dw | Chkui, aiiui | | | 1824<br>1825 | F3A8<br>F3AC | FC80 0<br>FD20 F | | dw | dirbuf,0<br>chk01.all01 | | | | | | | | | | | 1822 | F3A0<br>F3A4 | 0000 0 | | d₩ | 0,0,0,0 | :Floppy Drive 1 | | 1,821 | | | | | | | | 1820 | F39C | FD00 F | D80 | dw | chk00,a1100 | | | 1819 | F398 | FC80 0 | | dw | dirbuf,0 | | | 1818 | F394 | 0000 0 | | | | | page Appendix | 1885 | F430 | UUTA | | aw | 26 | ; spt | |------|-------|-----------|--------|--------|--------------------|------------------------------------------------| | 1886 | F432 | 03 07 00 | | db | 3,7,0 | ;blkshf, blkmsk, nullmsk | | 1887 | F435 | 00F2 003F | | dw | | dsw,dirm,alloc01,chksiz,trk off | | 1888 | F439 | 00C0 0010 | | | | | | 1889 | F43D | 0002 | | | | | | 1890 | F43F | 00 | | db | 0 | :128 byte sectors | | 1891 | | | | | | , | | 1892 | | | : | Single | Density, Double | Side | | 1893 | | | • | | | | | 1894 | F440 | 001A | | dw | 26 | ;spt | | 1895 | F442 | 04 OF 01 | | db | 4,15,1 | ;blkshf, blkmsk, nullmsk | | 1896 | F445 | 00F6 007F | | dw | | 2;dsw.dirm.alloc01,chksiz.trk off | | 1897 | F449 | 0000 0010 | | | ,,,,,,,,,,, | -,,, | | 1898 | F44D | 0002 | | | | | | 1899 | F44F | 00 | | db | 0 | :128 byte sectors | | 1900 | | | | | - | , | | 1901 | F450 | | dpb8d: | | | | | 1902 | | | | Double | Density, Single | Side | | 1903 | | | , | | | | | 1904 | F450 | 0034 | | dw | 2*26 | :spt | | 1905 | F452 | 04 OF 01 | | db | 4,15,1 | ;blkshf, blkmsk, nullmsk | | 1906 | F455 | 00F2 007F | | dw | | 2:dsw.dirm.alloc01.chksiz.trk off | | 1907 | F459 | 0000 0020 | | | | -, -, -, -, -, -, -, -, -, -, -, -, -, - | | 1908 | F45D | 0002 | | | | | | 1909 | F45F | 81 | | db | 81n | ;256 byte sectors, track zero single density | | 1910 | | | | | • | , 200 by to bootors, truck zero single density | | 1911 | | | : | Double | Density, Double | Side | | 1912 | | | • | | | | | 1913 | F460 | 0034 | | dw | 2*26 | :spt | | 1914 | F462 | 05 1F 03 | | db | 5.31.3 | ;blkshf, blkmsk, nullmsk | | 1915 | F465 | 00F6 007F | | dw | | 2:dsw.dirm.alloc01.chksiz.trk off | | 1916 | F469 | 00C0 0020 | | | 240, 127, 152, 02, | 2,43#,411 m,4110001,011M312,01K 011 | | 1917 | F46D | 0002 | | | | | | 1918 | F46F | 81 | | db | 81h | ;256 byte sectors, track zero single density | | 1919 | 1 401 | 01 | | uu. | 0 | ,130 byte sectors, track zero single density | | 1920 | | | | subttl | Micco Florov Di | sk Parameter Blocks | | 1921 | | | | page | с. с . торру Бт | on randimeter brocks | | 1321 | | | | Page | | | | | | | | | | | | | | | | | | | | 1922 | | | | | | | |--------------|--------------|-----------------------|--------|--------|-------------------|----------------------------------------------| | 1923 | F470 | | dpb5s: | | | | | 1924 | | | | | | | | 1925 | | | : | Single | Density, Single : | Side | | 1926 | | | | - | | | | 1927 | F470 | 0012 | | dw | 18 | ;spt | | 1928 | F472 | 03 07 00 | | db | 3,7,0 | ;blkshf, blkmsk, nulmsk | | 1929 | F475 | 0052 001F | | dw | 82,31,128,8,3 | dsw,dirm,alloc01,chksiz,trk off | | 1930 | F479 | 0080 0008 | | | | | | 1931 | F47D | 0003 | | | | | | 1932 | F47F | 00 | | db | 0 | ;128 byte sectors | | 1933 | | | | | | | | 1934 | | | ; | Single | Density, Double | Side | | 1935 | | | | | | | | 1936 | F480 | 0012 | | dw | 18 | ;spt | | 1937 | F482 | 03 07 00 | | db | 3,7,0 | ;blkshf, blkmsk, nulmsk | | 1938 | F485 | 00AC 001F | | dw | 172,31,128,8,3 | dsw,dirm,alloc01,chksiz,trk off; | | 1939 | F489 | 0080 0008 | | | | | | 1940 | F48D | 0003 | | | | | | 1941 | F48F | 00 | | db | 0 | ;128 byte sectors | | 1942 | | | | | | | | 1943 | F490 | | dpb5d: | | | | | 1944 | | | | _ | | | | 1945 | | | : | Double | Density, Single: | Side | | 1946<br>1947 | 5400 | 0000 | | | | | | 1947 | F490<br>F492 | 0022 | | dw | 17*2 | ;spt | | 1948 | F495 | 03 07 00<br>009C 003F | | db | 3,7,0 | ;blkshf, blkmsk, nulmsk | | 1950 | F495 | 0000 0010 | | dw | 156,63,192,16,3 | dsw,dirm,alloc01,chksiz,trk off | | 1951 | F49D | 0003 | | | | | | 1951 | F49F | 81 | | db | 81h | ;256 byte sectors, track zero single density | | 1953 | F49F | 01 | | ab | e in | ;256 byte sectors, track zero single density | | 1954 | | | | Double | Density, Double | Sido | | 1955 | | | ; | Doddie | Density, Double | 510e | | 1956 | F4A0 | 0022 | | dw | 17*2 | :spt | | 1957 | F4A2 | 04 OF 01 | | db | 4.15.1 | ;blkshf, blkmsk, nulmsk | | 1958 | F4A5 | 00A2 003F | | dw | | :dsw.dirm.alloc01.chksiz.trk off | | 1959 | F4A9 | 0000 0010 | | U# | 102,00,192,10,3 | , usa, unim, a nucun, chastz, trk off | | 1960 | FAAD | 0003 | | | | | | 1961 | FAAF | 81 | | db | 81h | :256 byte sectors, track zero single density | | 1962 | | <b>.</b> | | 55 | · | ,200 byte sectors, track zero single density | | 1963 | | | | subttl | Western Dinital | WD-1797-02 Floppy Disk Driver | | 1964 | | | | page | meatern Digital | HO 1707 OZ 1 TOPPY DISK DITTORI | | 1971 | | | | | | |------|---|-------|-----------|-----------|---------------------------------------------| | 1972 | | HL-> | db | command | ;1 = read, 0 = write, -1 = select dph | | 1973 | ; | | db | phunit | ;physical unit for request (0-3) | | 1974 | : | 1 | db | cpunit | ;CP/M logical drive for request (0-15) | | 1975 | • | : | dw | track | ;CP/M track number (offset already applied) | | 1976 | | | dw | sector | ;Phys sector number (after deblocking) | | 1977 | : | 1 | dw | address | ;CP/M dma transfer address | | 1978 | : | : | | | | | 1979 | | subtt | 1 Assembl | y Constar | nts | | 1980 | | page | | | | | | | | | | | | | | | | | | | | Operating<br>Constants | System | for | the | XEROX | 820-11 | MACRO-80 | 3.44 | 09-Dec-8 | 1 | |------------------------------|------------------------|--------|-----|-----|-------|------------------|----------------|-------------|----------|------------------------------------------------------------| | 1981<br>1982<br>1983<br>1984 | 0066 | | | | | NMI | equ | 00066h | | ;address of non maskable interrupt | | 1985<br>1986 | | | | | | ;; | WD 1797 | I/O port | address | es. | | 1987<br>1988 | 0010 | | | | | wdsr<br>wdcr | equ<br>equ | 10h<br>10h | | ;status<br>;command | | 1989<br>1990 | 0011 | | | | | wdtr<br>wdsn | equ<br>equ | 11h<br>12h | | ;track<br>;sector | | 1991<br>1992 | 0013<br>001C | | | | | wddt<br>wds1 | equ<br>equ | 13h<br>1ch | | ;data<br>;drive select port | | 1993<br>1994 | 0030<br>0031 | | | | | wdsd<br>wddd | equ | 30h<br>31h | | select single density; select double density; | | 1995<br>1996 | | | | | | :: | External | Disk Pa | rameter | Tables. | | 1997<br>1998<br>1999 | 0007 | | | | | ;<br>fm.un | | _ | | | | 2000 | 0007<br>0004<br>0005 | | | | | fm.ds<br>fm.dd | equ<br>equ | 7<br>4<br>5 | | | | 2002 | 0006<br>00A0 | | | | | fm.fv<br>fm.ddss | equ | 6 | m dd) oc | (1 shl fm,un) | | 2004 | 0040 | | | | | ntrk8 | equ | 77 | m.uu, oi | (1 siii iiii.dii) | | 2006<br>2007 | 0028 | | | | | ntrk5 | equ | 40 | | | | 2008<br>2009 | 0004<br>0005 | | | | | c.8in<br>c.two | equ<br>equ | 4<br>5 | | | | 2010<br>2011<br>2012 | 0006<br>000A | | | | | timou<br>dpbofs | equ<br>equ | 10 | | ;motor / select time out<br>;offset in dph for dpb address | | 2013<br>2014 | | | | | | | subtt1<br>page | Floppy D | isk Driv | er Proper | | | 1010 | 1404 | - | _ | | | 1110 | | , point to anit | |----------|------|------|-----|------|---|--------|------|--------------|--------------------------------------------| | | 2021 | F4B5 | | F4E7 | | | 1 d | (rdop),a | | | | 2022 | F4B8 | 3 C | | | | inc | а | | | | 2023 | F4B9 | | 55 | | | jr | z,selec | ; if select command | | | 2024 | F4BB | | OA | | | ١d | b,10 | ;set retry count | | | 2025 | F4BD | C5 | | | flop1: | push | bc | ;save count | | | 2026 | F4BE | E5 | | | | push | h1 | ;save command | | | 2027 | F4BF | 7 E | | | | ١d | a,(hì) | ;set unit select | | | 2028 | F4C0 | | F544 | | | call | selunt | | | | 2029 | F4C3 | | F506 | | | jp | m,flop5 | ; if unit not ready | | | 2030 | F4C6 | 23 | | | | inc | h1 | | | | 2031 | F4C7 | 23 | | | | inc | hl | | | | 2032 | F4C8 | 4 E | | | | ١d | c,(h1) | ;set track low | | | 2033 | F4C9 | | F5A3 | | | call | seekx | ;position disk | | | 2034 | F4CC | 4 E | | | | ١d | c,(h1) | retrieve track low | | | 2035 | F4CD | 20 | 37 | | | jr | nz,flop5 | ; if unrecoverable error | | | 2036 | F4CF | 23 | | | | inc | h1 | track high; | | | 2037 | F4D0 | 23 | | | | inc | h l | | | | 2038 | F4D1 | 13 | | | | inc | de | ;point to second byte of track table entry | | | 2039 | F4D2 | 1 A | | | | ١d | a,(de) | :get diskette type | | | 2040 | F4D3 | E6 | 18 | | | and | 18h | | | | 2041 | F4D5 | 7 E | | | | 1 d | a.(hl) | ;sector low | | | 2042 | F4D6 | | 06 | | | ir | nz.flop2 | ; if single density, cp/m skews | | | 2043 | F4D8 | 79 | | | | 1 d | a,c | ;get current logical track | | | 2044 | F4D9 | B7 | | | | or | a | 1300 | | | 2045 | F4DA | 7 E | | | | 1d | a,(h1) | :set sector | | | 2046 | F4DB | | 01 | | | ir | z,flop2 | ; if single density track zero | | | 2047 | F4DD | 30 | • . | | | inc | a | translate for double density | | | 2048 | F4DE | | 12 | | flop2; | out | (wdsn),a | ;set sector to read in 1791 | | | 2049 | F4E0 | 23 | | - | | inc | hl | ;skip sector high | | | 2050 | F4E1 | 23 | | | | inc | h1 | ;dma1 | | | 2051 | F4E2 | 5E | | | | 1 d | e.(hl) | ;set transfer address to HL | | | 2052 | F4E3 | 23 | | | | inc | h1 | :dmah | | | 2053 | F4E4 | 56 | | | | 1 d | d.(hl) | , dillari | | | 2054 | F4E5 | EB | | | | ex | de.hl | | | | 2055 | F4E6 | | 00 | | | 1 d | a.0 | :set read/write switch | | | 2056 | F4E7 | 32 | 00 | | rdop | equ | \$-1 | ,sec read/hirte switch | | | 2057 | F4E8 | 87 | | | Таор | or | a | | | | 2058 | F4E9 | | A8 | | | 1d | c.0a8h | :preset write command | | | 2059 | F4EB | | A3 | | | ld | a,0a3h | ;set second part of OUTI | | | 2060 | F4ED | | 03 | | | ir | z,flop3 | ;if write | | | 2061 | F4EF | | 88 | | | ]r | c.088h | | | | | | | 00 | | | dec | | turn write command into read command | | | 2062 | F4F1 | 3D | | | 610 | | a<br>( | ;turn OUTI into INI | | | 2063 | F4F2 | | F4FE | | flop3: | 1d | (rdwra),a | ;set up i/o direction | | Þ | 2064 | F4F5 | 3E | 00 | | | 1 d | a,0 | | | Appendix | 2065 | F4F6 | 1. | | | rdwrs | equ | <b>\$</b> -1 | ;set side compare flag | | ŏ | 2066 | F4F7 | 81 | | | | add | a,c | | | - Ō | 2067 | F4F8 | 4F | | | | 1d | c,a | | | | 2068 | F4F9 | | F61D | | | call | stc | ;start transfer | | ο. | 2069 | F4FC | 76 | | | flop4: | halt | | ;wait for DRQ or INT | | × ′ | | | | | | | | | | | m | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 2132 | F558 | 32 | F559 | | 1 d | (mtradr),a | Process and the second second | |----------|------|--------------|-----|---------|-----------|--------|------------------|--------------------------------------------| | | 2133 | F559 | | | mtradr | equ | \$-2 | ;address filled in by once only routine | | | 2134 | F55B | FB | | | ei | • - | ;insure clock enabled | | | 2135 | F55C | СВ | RQ | | res | 1,c | :map C->A, D->B | | | 2136 | F55E | DB | | | in | a,(wdsl) | read current select | | | 2137 | F560 | 47 | | | 1d | b.a | , read current serect | | | 2138 | F561 | E6 | FA | | and | not 7 | | | | 2139 | F563 | 81 | | | or | c . | :insert new select | | | 2140 | F564 | 3 C | | | inc | a | :0-1, 1-2 | | | 2141 | F565 | 03 | 1.0 | | out | (wds1),a | ;select drive | | | 2142 | F567 | AB | , , | | xor | b | , serect arre | | | 2143 | F568 | E6 | 0.3 | | and | 3 | | | | 2144 | F56A | 28 | | | jr | z,sel3 | ; if drive select identical | | | 2145 | F56C | 3E | | | 10 | a,-1 | force track position recovery | | | 2146 | F56E | 12 | | | 10 | (de),a | , torce track position recovery | | | 2147 | F56F | CB. | 60 | | bit | c.8in.b | :test 8/5 status | | | 2148 | F571 | 20 | | | ir | nz.sel3 | :if 8" | | | 2149 | F573 | | F647 | | call | rdc | set type I status | | | 2150 | F576 | 06 | | | 1d | b, 2*4 | ;watch for four holes (8 transitions) | | | 2151 | F578 | E5 | 00 | sellw: | push | h) | (water for roof notes to crais (tions) | | | 2152 | F579 | | F559 | Sellw: | ld | hl.(mtradr) | get address of motor select timer | | | 2153 | F57C | 7E | F 5 5 8 | | 10 | a,(hl) | get address or motor select timer | | | 2154 | F57D | É1 | | | pop | hl | | | | 2155 | F57E | D6 | | | sub | timou-2 | :look for 1-2 seconds | | | 2156 | F580 | D8 | 04 | | ret | C TIMOU-2 | ;if drive not spinning | | | 2157 | F581 | DB | 10 | | in | a,(wdsr) | ; if drive not spinning | | | 2158 | F583 | E6 | | | and | a,(wosi) | | | | 2158 | F585 | 28 | | se12: | jr | z,sellw | ; if index not under light | | | 2160 | F587 | | F585 | Seiz: | ld | a.(sel2) | ; switch index polarity | | | 2161 | F58A | EE | | | xor | 8 | (jr z) xor (jr nz) | | | 2162 | F58C | | F585 | | 1d | (sel2),a | (()1 2) XOI ()1 112) | | | 2163 | F58F | 10 | | | dinz | sellw | ;wait for at least three revolutions | | | 2164 | F591 | DB | | se13: | in | a,(wdsr) | set ready status | | | 2165 | F593 | E6 | | Sel3: | and | 80h | ;set ready status | | | 2166 | F595 | C9 | 80 | | ret | 8011 | | | | 2167 | Loso | Ca | | | 161 | | | | | 2168 | F596 | 3E | | seldns: | 1 - | a.18h | :set track zero single density | | | 2169 | F598 | | F632 | selden: | | (dsw),a | store switch for read/write routines | | | | | E6 | | se ideii: | | 18h | ; store switch for read/write routines | | | 2170 | F59B<br>F59D | D3 | | | and | (wddd).a | :pre-select dual density | | | 2171 | | | 3.1 | | | | | | | 2172 | F59F | C8 | 20 | | ret | z<br>(wdsd).a | ;if dual density<br>;select single density | | | 2173 | F5A0 | C9 | 30 | | out | (woso),a | ; select single density | | | 2174 | F5A2 | Ca | | | ret | | | | D | 2175 | | | | | | | | | Ó | 2176 | | | | | seek . | - position disk. | | | Ü | 2177 | | | | : | | | | | ₾ . | 2178 | F5A3 | 79 | | seekx: | | a,c | ;set new track | | ਣ | 2179 | F5A4 | B7 | | | or | а | | | Appendix | 2180 | F5A5 | | F596 | | call | z,seldns | ;force single density track 0 | | × | 2181 | F5AB | 13 | | | inc | de | | | m | | | | | | | | | FIGURE DISK Driver Proper ``` 2182 F5A9 1 A ١d a, (de) 2183 F5AA 18 dec de 2184 F5AB F6 01 and 2185 F5AD 28 15 ir z.sek1 : if one sided diskette 2186 FEAF DB 1C in a. (wds1) 2187 F581 CB 67 bit c.8in.a 2188 F5B3 06 40 14 b.ntrk8 :set number of eight inch tracks 2189 F5B5 20 02 ir nz.sek0 :if 8" drives 2190 F5B7 06 28 id b.ntrk5 F589 2191 79 sek0: ١d a.c :set seek track 2192 F5BA 88 CD 2193 F588 3F 00 1 d a.0 :preset side 0 2194 F5BD 38 05 ir c.sek1 if side 0 2195 F5BF 79 1 d a.c 2196 F5C0 90 sub ;wrap to side 1 2197 F5C1 4F 1 d c.a F5C2 3E 02 2198 1 d a,2 ;set side 1 2199 F5C4 32 F4F6 sek1: 1 1 (rdwrs).a :store F1 (update SSO) 2200 F5C7 87 add a.a ;move into select port position 2201 F5C8 47 1d b.a 2202 F5C9 F3 di 2203 F5CA DB 1C a. (wds1) in 2204 F5CC CB 97 res 2.a 2205 F5CE в0 or 2206 F5CF FB e i 2207 F5D0 D3 1C out (wds1).a :send out REAL SSO 2208 F5D2 1A a. (de) :check current position ١d 2209 F503 D3 11 out (wdtr),a :inform 1797 of current track 2210 F5D5 В9 CD 2211 F5D6 28 17 ir z.seek3 ; if position ok, load head 2212 F5D8 ЗC inc :check for forced recovery 2213 F5D9 CC F5F8 call z.rse :recover seek errors 2214 E5DC 28 OD z.seek1 :if error not recoverable 2215 F5DE 79 seek0: 1 d a,c ;set new track 2216 F5DF 03 13 out (wddt).a in data register 2217 F5E1 3E 1C ١d a.1ch ;set seek with verify command 2218 F5E3 CD F643 call isc :issue step command 2219 F5E6 E6 98 and 98h 2220 F5E8 79 1 d a.c :update current track 2221 F5E9 28 02 ic z,seek2 ; if no errors 2222 F5EB F6 FF seek1: or - 1 :force recovery next time 2223 F5ED 12 seek2: 1d (de).a 2224 FSEE C9 ret 2225 F5EF CD F647 seek3: call rdc ;set type I status 2226 F5F2 E6 20 and 20h :test head load 2227 F5F4 28 E8 jΓ z,seek0 ; if head is not loaded 2228 F5F6 ΑF retzr: xor :sav seek complete C9 2229 F5F7 ret 2230 2231 :: rse - recover seek error. 2232 2233 F5F8 C5 rse: push bc 2234 F5F9 CD F605 call rdid ; read id mark 2235 F5FC 20 05 jr ; if track position identified nz.rsel 2236 FSFE CD F641 call recal. :recalibrate 2237 F601 E6 04 and :verify track zero flag set ``` | Ρ | | | | | XEROX 820-11 | MACRO-8 | 30 3.44 0 | 9-Dec-81 | |---------|----------|------------|-----------|---|--------------|---------|------------|-----------| | ppendix | Floppy [ | Disk Drive | er Proper | | | | | | | ğ | 2294 | F647 | 3E D0 | | rdc: | ۱d | a,0d0h | ; t | | ⊼ | 2295 | | | | | | | | | == | 2296 | | | | | icc - | issue cont | roller co | | | 2297 | | | | : | | | | | ш | 2298 | F649 | D3 10 | | icc: | out | (wdcr),a | : 1 | | | 2299 | | | | | | | | | | 2300 | | | | ;; | woc - | wait opera | tion comp | | | 2301 | | | | | | | | | | 2302 | F64B | 3E 14 | | woc: | 1d | a.20 | ; 5 | | | 2303 | F64D | 3D | | woc1: | dec | a | ,- | | | 2304 | F64E | 20 FD | | | ir | nz.woc1 | | | | 2305 | F650 | CD F066 | | woc2: | call | idle | ; 1 | | | 2306 | F653 | DB 10 | , | WOCZ: | in | a.(wdsr) | | | | | | | | | | | ; 5 | | | 2307 | F655 | CB 47 | | | bit | 0,a | | | | 2308 | F657 | 20 F7 | | | jr | nz,woc2 | ; 1 | | | 2309 | F659 | C9 | | | ret | | | | | 2310 | | | | | | | | | | 2311 | | | | | subttl | Media For | mat Selec | | | 2312 | | | | | page | | | | | | | | | | | | | | rdc: | 1 d | a,0d0h | ;terminate and set type I status | |-------|----------------|-------------------|----------------------------------| | ;; | icc - | issue controller | command. | | icc: | out | (wdcr),a | ;issue 1797 command | | ;; | woc - | wait operation co | omplete. | | woc: | 1 d | a,20 | ;set 60 usec delay | | woc1: | dec<br>jr | a<br>nz,woc1 | | | woc2: | call | idle | ;idle cpu | | | in<br>bit | a,(wdsr)<br>O,a | ;set 1797 status | | | jr<br>ret | nz,woc2 | ;if busy, wait | | | subtt1<br>page | Media Format Se | lector | res fm.un.(h1) clear retry 2367 F6B7 CB BE | | 70 | 3 | | | | | | | | | |---|--------|---|------|-------|-------------|---|---------|----------|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | pendix | 5 | 2368 | F6B9 | 20 BA | | | ir | nz.smf0a | ;if retry | | | 7 | • | 2369 | F6BB | C9 . | | | ret | nz,smrua | | | | | - | 2370 | F6BC | CB AE | | smf1b: | res | fm.dd.(hl) | return select error;<br>back up to single density dpbs | | | | | 2371 | F6BE | CB BE | | smf2: | res | fm.un,(h1) | clear retry | | | п | n | 2372 | F6C0 | DB 1C | | 3mi 2. | in | a,(wds1) | ; clear retry | | | | | 2373 | F6C2 | CB D7 | | | set | 2,a | :select side 2 | | | | | 2374 | F6C4 | D3 1C | | | out | (wdsl),a | ; serect side 2 | | | | | 2375 | F6C6 | CD F605 | | | call | rdid | read id mark | | | | | 2376 | F6C9 | 28 09 | | | ir | z,smf4 | ; if no id found, must be one side | | | | | 2377 | F6CB | 00 | | | dec | c . | , ii no la loune, most de one side | | | | | 2378 | F6CC | 20 06 | | | ir | nz.smf4 | ;if side 1 ID not read | | | | | 2379 | F6CE | CB E6 | | | set | fm.ds.(h1) | ;bump up to two sided dpbs | | | | | 2380 | F600 | 21 F6D1 | | | ld | hl.smfa | ;set double sided status in track table | | | | | 2381 | F6D1 | 2 | | smfa | equ | \$-2 | , set dooble sided states in track table | | | | | 2382 | F6D3 | 34 | | J u | inc | (h1) | | | | | | 2383 | F6D4 | 21 0000 | | smf4: | 1d | h1,0 | ;set diskette type | | | | | 2384 | F6D5 | 21 0000 | | dtype | equ | <b>\$</b> -2 | ; set diskette type | | | | | 2385 | F6D7 | 7D | | drype | ld | a.1 | ;save type | | | | | 2386 | F6D8 | 4C | | | 10 | c.h | ;preset no translate | | | | | 2387 | F6D9 | 44 | | | 1d | b,h | ;preset no translate | | | | | 2388 | F6DA | 11 F430 | | | 10 | de,dpb8s | ;set base of disk parameter blocks | | | | | 2389 | F6DD | 19 | | | add | hl.de | ;set base or disk parameter blocks | | | | | 2390 | F6DE | EB | | | ex | de,hl | return DPB address in DE | | | | | 2391 | F6DF | CB 6F | | | bit | fm.dd.a | ; return DPB address in DE | | | | | 2392 | F6E1 | CO | | | ret | nz | ; if diskette is double density | | | | | 2393 | F6E2 | 01 F6ED | | | ld | bc,trn5 | ;preset 5.25" skew table | | | | | 2394 | F6E5 | CB 77 | | | bit | fm.fv,a | , preset 5.25 skew table | | | | | 2395 | F6E7 | CO | | | ret | nz | ;if diskette is small | | | | | 2396 | F6E8 | 01 F410 | | | 10 | bc.trn6 | set 8" translate | | | | | 2397 | F6EB | 3C | | | inc | a | force NZ | | | | | 2398 | F6EC | C9 | | | ret | - | , , , , , , , , , , , , , , , , , , , , | | | | | 2399 | | - | | | | | | | | | | 2400 | | | | :: | Skew hv | 5 translate tab | le . | | | | | 2401 | | | | | | | | | | | | 2402 | F6ED | 01 06 0B 10 | | trn5: | db | 01,06,11,16 | | | | | | 2403 | F6F1 | 03 08 0D 12 | | | db | 03,08,13,18 | | | | | | 2404 | F6F5 | 05 OA OF 02 | | | db | 05,10,15,02 | | | | | | 2405 | F6F9 | 07 OC 11 O4 | | | db | 07,12,17,04 | | | | | | 2406 | F6FD | 09 OE | | | db | 09,14 | | | | | | 2407 | | | | | | • | | | - | | | 2408 | F6FF | 7F 00 C0 00 | | trktbl: | db | 7fh,0,0c0h,0,20 | h.0.2.0.81h | | | | | 2409 | F703 | 20 00 02 00 | | | | | | | | | | 2410 | F707 | 81 | | | | | | | | | | 2411 | | | | | | | | | | | | 2412 | F708 | | | rigdpb | equ | 0f708h | | | | | | 2413 | F770 | | | iobloc | equ | 0f770h | | | | | | 2414 | | | | | - | | | | | | | 2415 | | | | A. | above | | | | | | | 2416 | 0708" | | + | | d&seg | | | | | | | 2417 | | | | | | | | | | | | 2418 | | | | | .dephase | | | | | | | 2419 | | | | | .phase | | i contraction of the | | | | | 2420 | F470 | | | sasstr | equ | \$ | | | | | | 2421 | | | | | | | | | | m | | 2422 | | | | | | Rigid Partition | Disk Parameter Blocks. | | | 55 | i | 2423 | | | | | page | | | | | · ω | ) | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Rtk&6 :track offset 2478 F49D ppendix E | 2497 | EE00 | <br> | rgdbuf | equ | 0ee00h | rigid parameter load buffer | |------|------|------|--------|---------|--------------------|-------------------------------------------| | 2498 | | | | | | | | 2499 | | | | Sasi P | io Port Addresses | | | 2500 | | | 1 | | | | | 2501 | 0011 | | picAs | egu | 11h | :Pio A Status | | 2502 | 0010 | | pioAd | equ | pioAs xor 01b | | | 2503 | 0013 | | pioBs | eau | pioAs xor 10b | | | 2504 | 0012 | | pioBd | equ | pioAs xor 11b | | | 2505 | 00.1 | | p.000 | | promo nor rio | | | 2506 | 0010 | | Sasid | equ | pioAd | :bus data | | 2507 | 0012 | | Sasic | equ | pioBd | bus control | | 2508 | 0012 | | Sasis | equ | pioBd | bus status | | 2509 | 0012 | | 34313 | equ | p.1000 | , bus status | | 2510 | 001C | | syspio | equ | 1ch | :system configuration port | | 2511 | 0010 | | Syspiu | equ | 1011 | ayarem com iguration port | | 2512 | | | | Sasi co | ontroller status i | it definitions | | 2513 | | | : ' | 3031 0 | merorier status | | | 2514 | 0000 | | b.bsy | equ | 00 | :(in) controller busy status | | 2515 | 0000 | | b.msg | equ | 01 | (in) status byte completion status | | | 0007 | | | | 02 | ;(in) control byte or data byte transfer | | 2516 | | | b.cd | equ | 03 | | | 2517 | 0003 | | b.req | equ | | ;(in) controller request for data/command | | 2518 | 0004 | | b.10 | equ | 04 | ;(in) data transfer direction | | 2519 | 0005 | | b.sel | equ | 05 | ;(out) controller select | | 2520 | 0006 | | b.par | equ | 06 | ;(in) buss parity error | | 2521 | 0007 | | b.rst | equ | 07 | ;(out) controller reset | | 2522 | | | | | | | | 2523 | | | :: | Logica | Unit Assignment: | | | 2524 | | | | | | | | 2525 | 0000 | | falun | equ | 0 | ;A: Lun | | 2526 | 0001 | | fblun | equ | 1 | ;B; Lun | | 2527 | 0000 | | fclun | equ | 0 | ;C: Lun | | 2528 | 0002 | | fdlun | equ | 2 | ;D: Lun | | 2529 | 0003 | | rglun | equ | 3 | ;E: Lun | | 2530 | | | | | | | | 2531 | | | | subttl | Sasi Class Code | Definitions | | 2532 | | | | page | | | | | | | | | | | 2535 2536 2537 2538 2539 2540 2541 2542 2543 2544 2545 2546 2547 2548 2549 2550 2551 2552 2553 2554 2555 2556 2557 2558 2559 2560 2561 2562 2563 2564 2565 2566 2567 2568 2569 2570 2571 2572 2573 2574 2575 2576 2577 2578 2579 2580 2581 2582 2583 2584 2585 2586 2587 0000 0001 0002 0003 0004 0005 0006 0007 0008 0009 000A 0008 000C 00C0 0000 0001 0002 0003 0000 0001 0006 0007 0080 00E0 ``` . DTC Reference Manual Dated February 4, 1981. class 0 commands. . . 00h c.trdy equ :test ready status c.recal equ 01h :recalibrate drive c.rsvn equ 02h :request syndrome 03h c.rosn egu :request sense after error c.fmat equ 04h :format drive c.vtrk 05h verify track format eau 06h c.ftrk eau :format single track c.flaw equ 07h :format track with flaw c.read equ 08h :read data C.WFDF eau 09h :write protect sector c.writ equ 0ah :write data c.seek equ 0bh initiate seek c.init equ 0ch :inititialize drive Class 6 commands. c.flpv equ 0c0h :define floppy disk format :: Floppy Format Codes. fmds equ Ω :double side bit fmdd eau :double density bit fm.sz equ 2 sector size bit fm.wr equ 3 : log2(fm.ddds+1) 00h fm.sdss equ :Single Density, Single Sided fm.sdds eau 01h :Single Density, Double Sided fmddss egu 06h ;Double Density, Single Sided 07h fm.ddds egu :Double Density, Double Sided fm.hard equ 80h :Rigid Class 7 commands. c.tram equ 0e0h ;test ram buffer Message Macros. :: pmsg macro n.msq if1 .printx +MSG N+ endif endm phex macro n,m ,radix 16 %(n), <m> pmsg .radix 10 endm ``` Class Command Codes for Prom Set AS31\* : : 843 Balcone Sasi CI 2588 2589 2590 Balcones Operating System for the XEROX 820-II MACRO-80 3,44 $\,$ 09-Dec-81 Physical Driver Select 2646 2647 E60 ``` Select - Physical Driver Select. :: 2650 2651 F500 7 F sselec: ld a.(hl) :set physical unit 2652 F501 FF OR verify in range CD 2653 F502 numunt egu S-1 2654 F503 3F ccf 2655 F504 D4 F50E call :set media format nc.smfs 2656 F507 DΩ if media identified ret nc 2657 2658 select - Select Error Driver. . . 2659 2660 F508 21 0000 xselerr: ld h1.0 :Select Error Driver 2661 F50B F6 FF select: or - 1 2662 F500 C9 ret 2663 2664 :: smfs - Set Media Format. 2665 2666 entry: A = Driver unit index 2667 HL = DPH address, if no carry 2668 2669 F50F CD F6F6 call first :execute first time only routine 2670 F511 CD F5AF call mlu :map to logical unit 2671 E514 FB eх de.hl get doh index to hi 2672 F515 7 D 1.d a.1 and A 2673 F516 29 add hi.hl :index *16 2674 F517 29 hl.hl add 2675 F518 29 add hl.hl 2676 F519 29 add hl.hl 2677 F51A 11 F390 set base of Disk Parameter Headers 1 d de Dobase 2678 F510 19 add hl.de 2679 F51F FF 04 CD 2680 F520 DO ret nc :if rigid unit 2681 F521 F5 h1 :save doh address push 2682 F522 3E 80 1 d a.80h :disable error recovery 2683 F524 32 F6F5 1 d (dctrl).a 2684 32 F5F1 F527 ١d (lastfm+1).a 2685 F52A ΩA 1 d a (bc) :always try double side first 2686 F52B F6 01 or 1 shl fmds 2687 F52D 02 1 d (bc).a 2688 F52F 3E 07 ١d a.8-1 try each type two times 2689 F530 32 F53D smfs1: 1 d (smfsa),a :set retry count 2690 F533 C5 bc ; save define format table address push 2691 F534 CD F57A call cdd :check drive density 2692 F537 C 1 gog bc 2693 F538 60 1 d h.b ;set format table address 2694 F539 69 1d 1.c 2695 F53A 28 14 ir z.smfs2 ; if diskette type identified 2696 F53C 3E 00 ١d a.0 2697 F53D smfsa S-1 eau ; diskette type retry counter 2698 F53E D6 01 sub 2699 F540 38 31 ic c.smfs4 : if media not identified 2700 F542 35 dec (h1) ;advance disk type code 2701 F543 F2 F548 p.smfs1a if no wrap ai 2702 F546 36 07 (h)), fm, ddds 1 d ``` ``` 2707 F550 57 smfs2: ìа d,a preset no translate 2708 F551 54 1.0 e.d CB 4E 2709 F552 bit fmdd.(hl) 2710 F554 20 03 ir nz.smfs3 ; if diskette is double density F556 11 F410 2711 ١d de.trn6 set single density translate 2712 F559 F1 smfs3: pop b1 eget dob address 2713 E55A E5 h1 push 2714 F558 73 ìd (h1).e store translate address 2715 F550 23 inc h1 2716 F55D 72 (h1).d 1 d 2717 F55E 11 0009 1 d de.10-1 2718 F561 19 add bl.de :point to dpb address in dph 2719 F562 ÓΔ ١d a.(bc) :get selected format 2720 F563 ·E6 03 and 2721 F565 FB eх de.hl 2722 F566 6F ١d 1.a 2723 F567 29 add hl.hl :index by 16 2724 F568 29 add h1.h1 2725 F569 29 61.61 add 2726 F56A 29 add hl.hl 2727 F56B 01 F430 ١d bc.dob8s ;set dpb base 2728 F56E 09 ;set dpb address (clears carry) add hl.bc 2729 F56F EB eх de.hl recover dpb pointer address in dph 2730 E570 7.3 (h1),e 1 d 2731 F571 23 inc h1 2732 F572 72 (h1),d 1 d 2733 F573 E 1 smfs4: gog h1 :get dob address 2734 F574 3E 00 1 d a,0 :enable error recovery 2735 F576 32 F6F5 ١d (dctrl).a 2736 F579 0.9 ret 2737 2738 :: check drive density. 2739 2740 F57A 0A cdd: 1 d a,(bc) ;get attempted side 2741 F57B F6 01 and :try side 1 on ds. 0 on ss 2742 F57D 11 0201 ١d de.2*256+1 2743 F580 28 02 jг z,cdd0 ; if single side 2744 F582 16 4F 10 d.77+2 :use back side 2745 F584 CD F5C2 cdd0: call mpa ;map physical address 2746 F587 21 F6F0 1d hi,opcode 2747 F58A 36 08 1 d (h1),c,read 2748 F58C CD F643 call iccs :issue controller command 2749 F58F CD F6CE call sim :set input mode 2750 F592 CD F687 cdd1: call wfr :wait for req 2751 F595 20 04 ir nz,cdd2 :if timeout or status, not data requested 2752 F597 ED 78 in a,(c) eat sector 2753 F599 18 F7 ir cdd1 2754 F59B CD F669 cdd2: call ;wait command complete WCC 2755 F59E С9 ret 2756 2757 p21 - Physical to Logical Mapping Table. ;; 2758 ; ``` | <br>2819 | F5DF | 7 C | | | 1 d | a,h | map first 77 tracks to side zero | |----------|------|--------|---|--------|--------|------------------|----------------------------------------| | 2820 | FSEO | FE 4D | | | cp | 77 | | | 2821 | F5E2 | 38 02 | | | ir | c,mpa21 | ; if side zero tracks | | 2822 | F5E4 | D6 4D | | | sub | 77 | offset to back side | | 2823 | F5E6 | 3F | | mpa21: | ccf | | | | 2824 | F5E7 | 8 F | | | adc | a,a | | | 2825 | F5E8 | 67 | | | 1 d | h,a | | | 2826 | F5E9 | E5 | | mpa22: | push | hl | ;save track/sector | | 2827 | F5EA | OA | | | 1 d | a,(bc) | get floppy format | | 2828 | F5EB | 2A F6E | В | | 1 d | hl,(deflun) | get new unit | | 2829 | F5EE | 67 | | | 1d | h,a | | | 2830 | F5EF | 11 FFF | F | | 1 d | de,-1 | get previously used format/lun | | 2831 | F5F0 | | | lastfm | equ | <b>\$</b> -2 | | | 2832 | F5F2 | 22 F5F | 0 | | 1d | (lastfm),hl | ;save this format/unit for next time | | 2833 | F5F5 | B7 | | | or | a - | | | 2834 | F5F6 | ED 52 | | | sbc | hl,de | | | 2835 | F5F8 | 28 OC | | | jr | z,mpa3 | ; if unit and format same as last time | | 2836 | F5FA | 32 F6E | | | ld | (flpfrm),a | | | 2837 | F5FD | 21 F6E | | | 1 d | hl,deflpy | ;issue define floppy command | | 2838 | F600 | CD F64 | | | call | iccs | | | 2839 | F603 | CD F66 | 9 | | call | WCC | | | 2840 | F606 | E1 | | mpa3: | pop | h1 | ;recover track / sector | | 2841 | F607 | 44 | | | 1 d | b,h | ;set track | | 2842 | F608 | 11 001 | A | | ld | de,26 | ;compute sector-26-1+(Track+1)*26 | | 2843 | F60B | 62 | | | ld | h,d | ;clear upper track | | 2844 | F60C | 37 | | | scf | | | | 2845 | F60D | ED 52 | | | sbc | hl,de | ;adjust sector | | 2846 | F60F | 04 | | | inc | b | ;force one pass | | 2847 | F610 | 19 | | mpa4: | add | hì,de | multiply track by sectors/track | | 2848 | F611 | 10 FD | | | djnz | mpa4 | ;if multiply incomplete | | 2849 | F613 | 7C | | mpa5: | 1 d | a,h | ;swap H & L | | 2850 | F614 | 65 | | | 1 d | h,1 | | | 2851 | F615 | 6F | _ | | 1 d | 1,a | | | 2852 | F616 | 22 F6F | 2 | | 1 d | (addrh),hl | ;Store address in command block | | 2853 | F619 | C9 | | | ret | | | | 2854 | | | | | | | | | 2855 | | | | | subttl | Sasi Bus Control | interrace | | 2856 | | | | | page | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | last time ``` 2858 :: gca - get controller attention 2859 2860 F614 CD F64D qca: :reset controller if required call reset 2861 F610 7E 1 d a,(h1) get command 2862 F61E FE 01 cn c.recal 2863 F620 3F 0A 1d a.9+1 :set 9+ second time-out 2864 F622 28 02 ir z.gca0 :if recalibrate, use long time-out 2865 F624 3E 03 a.2+1 :use short time-out 2866 F626 32 F627 qca0: 1 d (ocaa).a 2867 F627 ;****=>;monitor one second timer address goes here ocaa equ $-2 2868 F629 CD F6D2 call som :set output mode 2869 F620 3E 01 1 d a. 1 :Set sasi controller address 2870 F62E D3 10 Out (Sasid).a 2871 F630 3F 20 ١d a.1 shl b.sel :assert Select Line 2872 F632 D3 12 Out (Sasic).a 2873 F634 DR 12 qca1: in a. (Sasis) :get sasi status 2874 F636 OF rrca :get busy bit in C 2875 F637 38 06 ir c.gca2 ; if controller is ready 2876 F639 CD F645 call cft :check for time-out 2877 E630 F2 F634 iρ p.gcal : if not timed out 2878 F63F AF qca2: xor 2879 F640 D3 12 out (Sasic).a :drop Select 2880 F642 C9 ret 2881 2882 - issue Controller Command. :: 2883 2884 HL => Sasi command block 2885 2886 F643 7E iccs: ١d a,(h1) :peek at opcode 2887 F644 FE 04 c.fmat 2888 F646 C8 ret , :do not allow format entire disk 2889 F647 CD F61A call ;get controller attention 2890 F64A 01 0610 1 d bc.Sasid+6*256 :set port / command block length 2891 F640 CD F687 iccs1: call :wait for REO wfr 2892 F650 C8 ret :if data requested 2893 F651 ED A3 outi send next byte 2894 F653 20 F8 ir nz.iccs1 2895 F655 ret 2896 2897 transmit data out :: 2898 2899 F656 CD F687 call tdo: wfr :wait for req 2900 F659 20 OE ir nz.wcc if not data requested 2901 F658 ED B3 otir :pitch sector out 2902 F65D 18 OA jr WCC 2903 2904 :: tdi - transmit data in. 2905 F65F 2906 CD F6CE tdi: call sim :set input mode 2907 F662 CD F687 call wfr :wait for req 2908 F665 20 02 ic nz,wcc ; if status, not data requested 2909 F667 ED B2 inir :read sector 2910 2911 wcc - wait command complete. :: ``` Appendix Sasi Bus Control Interface ``` 2968 running. When, and if the controller times-out, this 2969 routine is re-enabled. Thus, the controller will be 2970 reset again before the next command is issued. ; 2971 2972 F6AD 00 reset: nop :*****:>:Note RET gets put here after reset 2973 NOP gets put there if time-out 2974 F6AE 3E CF a.11001111b ١d ;initialize pio in mode 3 2975 F6B0 (pioBs),a D3 13 out 2976 F6B2 3E 5F 1 d a.01011111b ;d7, d5 are outputs 2977 F684 D3 13 out (pioBs),a 2978 F6B6 3E 80 ١d a.1 shl b.rst :assert reset to controller 2979 F6B8 D3 12 out (Sasic).a 2980 F6BA AF xor 2981 F6BB D3 12 (Sasic),a out ;de-assert reset 2982 F6BD 3E C9 1 d a,0c9h 2983 F6BF 32 F6AD ١d (reset).a ;disable reset until time-out 2984 F6C2 E5 push h1 2985 F6C3 21 F6E8 1 d hl,rgrecal 2986 F6C6 CD F643 call iccs ; issue recursive rigid recalibrate 2987 F6C9 CD F669 call WCC 2988 F6CC E1 pop h١ 2989 F6CD C9 ret 2990 2991 Sim - Set Input Mode. :: 2992 2993 F6CE 3E 4F a,01001111b sim: ١d set pio A input mode 2994 F6D0 18 02 jr som1 2995 2996 Som - Set Output Mode. . . 2997 2998 F6D2 3E 0F som: ١d a,00001111b :set pio A output mode 2999 F6D4 D3 11 som1: out (pioAs),a 3000 F6D6 C9 ret 3001 3002 ;; check write protect. 3003 3004 F6D7 0A CWD: 1 d a.(bc) get drive type 3005 F6D8 E6 80 and fm.hard 3006 ÇВ F6DA ret z : if not rigid disk access 3007 F6D8 3E 00 1 d a,0 :get dirty parameter flag 3008 F6DC rdonly equ $-1 3009 F6DD В7 oг 3010 F6DE C8 ret z :if not write protected 7 A 3011 F6DF ١d a.d 3012 F6E0 В7 οг 3013 С8 F6E1 ret :if track zero request 3014 F6E2 3A F6F0 ١d a, (opcode) 3015 F6E5 D6 08 sub c.read ;allow reads, but no writes to file system 3016 F6E7 C9 ret 3017 3018 subtt! Sasi Command Blocks 3019 page ``` | 3023 | 1000 | 01 | rgrecar | uu | C.recar | | |------|------|----------|---------|--------|---------------|---------------------------------------| | 3026 | F6E9 | 60 | reclun: | db | 3 sh1 5 | | | 3027 | | | | | | | | 3028 | F6EA | CO | | | - 61 | define from from | | | | | deflpy: | | c.flpy | define floppy format; | | 3029 | F6EB | 00 | deflun: | db | 0 | | | 3030 | F6EC | 00 00 00 | | db | 0,0,0 | | | 3031 | F6EF | 00 | flpfrm: | db | 0 | | | 3032 | | | | | | | | 3033 | F6F0 | 00 | opcode: | db | 0 | :Class code / Operation | | 3034 | F6F1 | 00 | lun: | db | 0 | :Logical Unit & Logical Address 20-16 | | 3035 | F6F2 | 00 | addrh: | db | 0 | : Logical Address 15-8 | | 3036 | F6F3 | 00 | addrl: | db | 0 | Logical Address 7-0 | | 3037 | F6F4 | 01 | nblk: | db | -1 | Number of Blocks | | 3038 | F6F5 | 00 | dctrl: | db | 0 | :Error Retry Disable Control word | | 3039 | | | | | | , | | 3040 | | | | subttl | Overlayable I | nitialization Code | | 3041 | | | | page | • | | | | | | | | | | Overlayable Initialization Code ``` 3042 3043 :: First - First time only. 3044 3045 F6F6 first: push 3046 $-dskdvr, <SASI Resident Length is> phex 3047 0010 .radix 16 3048 000A .radix 10 F6F7 3049 3E C9 ١d a,0c9h ;nuke self first time 3050 F6F9 32 F6F6 ١d (first).a 3051 F6FC 26 00 ١d h.0 :indicate return register value 3052 F6FE CD F039 call dayti get address of monitor timer 3053 F701 2B dec 3054 F702 22 F6A9 (cfta).hl ;store address of timer for check routine ١d 3055 F705 22 F627 1 d (gcaa),hl ; and for command startup 3056 3057 F708 21 F767 first1; ld hl,cnfdpb :point to physical driver read command 3058 F70B CD F4B0 call sa1403 ; read partition parameters 3059 F70E В7 3060 F70F CC F723 call z.cob ; if no errors then check parameter blocks 3061 F712 28 OD jr z,first2 ; if parameters are loaded 3062 F714 21 F76C 1 d hl.cnfdpb+5 ;try backup heads 3063 F717 7 E 1 d a,(h1) get logical sector 3064 F718 C6 20 add a,32 advance to next head 3065 F71A 77 1 d (h1).a 3066 F718 20 EB ir nz,first1 ; if 4 heads and 2 cylinders not attempted 3067 F71D 2F Cpl :set tracks > 0 read only 3068 F71E 32 F6DC 1 d (rdonly),a 3069 F721 F 1 first2: pop 3070 F722 0.9 ret 3071 3072 :: check parameter blocks. 3073 3074 F723 21 EE00 cpb: 1 d hl,rgdbuf ;point to dpb buffer 3075 F726 34 F760 1 d a.(cnfdpb+5) :get sector this dob set came from 3076 F729 FE 20 CD 3077 20 04 F72B ir nz.cpb1 : if not primary set 3078 F72D 7 E ١d a.(h1) 3079 FE E5 F72E Cp 0e5h 3080 F730 C8 ret z :use default dobs if none configured 3081 F731 11 000F cpb1: 1 d de, 16-1 :set offset from high spt to deblock control 3082 F734 06 04 1 d verify 4 dobs b.4 3083 F736 7 E cpb2: ١d a,(h1) :set low sectors / track 3084 F737 87 or 3085 F738 CO ret ; if bummer sectors / track 3086 F739 19 add hl,de :advance to deblock control 3087 F73A 7 E a.(h1) 1 d 3088 F73B E6 87 and 87h 3089 CB 2F F73D sra a 3090 F73F CB 2F sra а 3091 F741 CO :if bad deblocking constant ret 3092 F742 23 inc 3093 F743 10 F1 dinz cpb2 3094 F745 2B dec 3095 F746 11 F4AF ١d de.Dpbrq4+16*4-1 3096 F749 01 0040 bc.16*4 ) d ``` balcones operating system for the AEROA 820-11 MACRO-80 3.44 U9-Dec-81 page 3138 820 Style Disk Driver Emulator ``` 3139 3140 820 Style Disk Driver Emulator. :: 3141 3142 above :generate code in ram 3143 DADE" d&seq 3144 3145 FACE phycmd: defb :physical Driver Command 3146 FAOF FF phyunt: defb - 1 :physical unit 3147 FA10 00 phydry: defb 00 ·logical unit 3148 FA11 0000 phytrk: defw track 3149 FA13 0001 physec: defw 0.1 sector 3150 FA15 ED80 phydma: defw bootbf :dma address 3151 3152 Select - Select Unit for I/O. :: 3153 3154 Entry: C = Unit : 3155 Exit: A = 0 if no errors 3156 A = -1 if errors 3157 3158 FA17 79 select: 1d a,c :set drive selected 3159 FA18 FE 08 CD 3160 FAIA 30 1D ir nc.sell 3161 FA1C 32 FA10 (phydry).a 1d :save logical CP/M drive 3162 FAIF 21 FA5A 1d hl.seltbl ;set select table address 3163 FA22 06 00 ١d b.0 3164 FA24 09 add hl.bc :index into select table 3165 FA25 7 F 1 d a, (h1) 3166 FA26 87 3167 FA27 EB eх de.hl 3168 FA28 67 ld h,a ; in case previous select worked, say no doh 3169 FA29 1 d 1.a to internal routines 3170 FA2A CB ret z · ; if drive has already been selected D5 3171 FA2B push de :save table address 3172 FA2C 06 FF 14 b -1 :set Select operation 3173 FA2E CD FAS1 call xaphys ;execute physical driver 3174 FA31 70 1 d a, 1 get returned dph address 3175 FA32 84 or h 3176 Di FA33 pop retrieve select table address 3177 FA34 28 03 ir z.sell :if select unsuccessful 3178 F436 ΔF xor :return no errors 3179 FA37 12 ١d (de).a prevent more density re-selects 3180 FA3B Ca ret 3181 FA39 F6 FF sell: or - 1 :return error 3182 FA3B C9 ret 3183 3184 Position to track zero. ;; Home 3185 3186 FA3C 0E 00 home: ١d c.0 ;force track zero 3187 3188 :: Seek - Seek Track. 3189 3190 Entry: C = Track to read/write from next : 3191 3192 FA3E seek: ١d a.c 3193 FA3F 32 FA11 ١d (phytrk),a ``` 3285 FAB7 DD E1 pop iх :line buffer and test if error 3286 FAB9 2A FFB5 1 d hi, (parami) 3287 FABC ED 58 FF87 ١d de.(param2) 3288 FACO ED 4B FFB9 1 d bc, (param3) 3289 FAC4 CD FAD6 call :call subroutine @ ix ipix 3290 FAC7 30 99 ir nc,prompt ;go back to prompt if no errors ``` FAU 3297 FAD4 18 BC jr prompt 3298 3299 FAD6 DD E9 (ix) :call subroutine @ ix ioix: jр 3300 3301 FAD8 177B cmdtab: defw help :@ - Help user 3302 FADA 1188 defw boot ;a - boot cp/m 3303 FADC 1353 defw baud :b - bit rate 3304 FADE 1436 defw black ;c - memory block move 3305 FAEO 12F2 defw memdmp ;d - dump memory in hex/ascii 3306 FAE2 1315 defw view ;e - enter memory 3307 FAE4 1428 defw fill :f - fill memory 3308 FAE6 12DB defw aoto g - goto program 3309 FAE8 14E2 defw term ;h - host terminal 3310 FAEA 13CA defw incmd :i - read from input port 3311 FAEC FAC9 defw what ;j - not used 3312 FAEE FAC9 defw what :k - not used 3313 FAFO 1188 defw boot :1 - load system 3314 FAF2 1315 defw view :m - memory examine/change 3315 FAF4 FAC9 defw what :n - not used 3316 FAF6 13F1 defw outcmd ;o - write to output port 3317 FAF8 1459 defw proto :p - printer protocol 3318 FAFA FAC9 defw what ;q - not used 3319 FAFC 1367 defw dskcmd :r - display disk sector data 3320 FAFE FAC9 defw what :s - not used 3321 FB00 1477 defw type :t - typewriter mode 3322 FB02 FAC9 defw what :u - not used 3323 FB04 1443 defw vercmd :v - memory block compare 3324 FB06 1367 defw dskcmd :w - disc sector write command 3325 FB08 13FB defw test :x - ram diagnostic 3326 FB0A FAC9 defw what ;y - not used 3327 FBOC FAC9 defw what z - not used 3328 0036 cmdsiz equ $-cmdtab 3329 BE 3330 FB0E check: cp (h1) 3331 FBOF C8 :return if (h1)=a ret z 3332 FB10 F5 push af 3333 FB11 CD FB22 call mdata :print what was actually read 3334 FB14 CD FC3D call pnext 3335 FB17 73 68 6F 75 defm 'should=' 3336 6C 64 3D FB1B 3337 FB1E 04 defb eot 3338 FB1F F1 af 000 3339 FB20 18 07 ir put2j 3340 3341 FB22 CD FC36 mdata: call crlf 3342 FB25 CD FC16 call put4hs 3343 F828 7 E 1d a.(h1) C3 FC1B 3344 FB29 put2j: jp put 2hs 3345 ``` subttl Console support routines 3346 Appendix m page Appendix E | | 3353 | FB31 | 3E OD | | ١d | a,cr | | |---|------|------|------------|----------|------|--------------|------------------------------------------| | | 3354 | FB33 | 32 FF5D | | 1 d | (linbuf+1),a | | | | 3355 | FB36 | C9 | | ret | | | | | 3356 | FB37 | 41 | getlin: | | b.c | ;save max line length parameter in b | | | 3357 | FB38 | CD FC27 | | call | echo | get a character from the console | | | 3358 | FB3B | FE 1E | g | ср | Helpkey | 1,301 0 0 | | | 3359 | FB3D | 28 ED | | ir | z,gethlp | ; if user needs help | | | 3360 | FB3F | 77 | | 1d | (h1),a | , | | | 3361 | FB40 | FE OD | | СР | cr | ;check for carriage return | | | 3362 | FB42 | CB | | ret | z | if end of line | | | 3363 | FB43 | FE 08 | | ср | 'H'-64 | ;check for ctl-h backspace | | | 3364 | FB45 | 28 09 | | jr | z,glin4 | tonoon to ott ii baanspaac | | | 3365 | FB47 | FE 20 | | ср | 7.7 | | | | 3366 | FB49 | D8 | | ret | c " | other control characters are illegal | | | 3367 | FB4A | 23 | | inc | n1 | store character in buffer | | | 3368 | FB4B | 9D | | dec | c | , , , , , , , , , , , , , , , , , , , , | | | 3369 | FB4C | 20 EA | | jr | nz,glin1 | get another if there's more room | | | 3370 | FB4E | 37 | | scf | | | | | 3371 | FB4F | C9 | | ret | | return with carry=1 if too | | | 3372 | | 03 | | | | many characters are entered | | | 3373 | FB50 | 2B | glin4: | dec | h l | :delete last character from buffer | | | 3374 | FB51 | CD FC3D | <b>3</b> | call | pnext | , | | | 3375 | FB54 | 20 08 | | defb | ','H'-64 | :delete character from screen | | | 3376 | FB56 | 04 | | defb | eot | , | | | 3377 | FB57 | oc | | inc | c | | | | 3378 | FB58 | 78 | | 1 d | a.b | set max line length | | | 3379 | FB59 | 91 | | sub | c . | | | | 3380 | FB5A | 30 DC | | ir | nc,glin1 | ; if backspace not past the start of the | | | 3381 | FB5C | C9 | | ret | | | | | 3382 | | | | | | | | | 3383 | FB5D | FD 23 | para0: | inc | iy | ;advance character scan | | | 3384 | FB5F | 01 00FF | params: | 1 d | bc,low -1 | ;set parameter index | | | 3385 | FB62 | FD 7E 00 | | 1 d | a,(iy+0) | ;fetch character | | | 3386 | FB65 | D6 0D | | sub | cr | | | | 3387 | FB67 | C8 | | ret | z | ;if no parameters | | | 3388 | FB68 | D6 13 | | sub | ′ '-cr | | | | 3389 | FB6A | 28 F1 | | jr | z,para0 | ;if leading blanks | | | 3390 | FB6C | OC | para1: | inc | c | ;advance parameter index | | | 3391 | FB6D | CB 51 | | bit | 2,c | | | | 3392 | FB6F | 37 | | scf | | | | | 3393 | FB70 | CD | | ret | nz | error if > 4 numbers entered; | | | 3394 | FB71 | C5 | para2: | push | bc | ;save parameter count | | | 3395 | FB72 | CD FBDA | | call | gethex | read a number from line buffer | | | 3396 | FB75 | C1 | | pop | bc | | | | 3397 | FB76 | DD 21 FFB5 | para4: | 1 d | ix,param1 | point to parameter storage area | | | 3398 | FB7A | DD 09 | | add | ix,bc | ;add parameter count in bc | | ś | 3399 | FB7C | DD 09 | | add | ix,bc | | | 5 | 3400 | FB7E | DD 75 00 | | 1 d | (ix+0),l | | | 3 | 3401 | FB81 | DD 74 01 | | ١d | (ix+1),h | store data returned from 'GETHEX' | | 2 | 3402 | FB84 | FE 20 | | СР | | | | | | | | | | | | the line Appendix E 1 d e.1 3458 FBDE 5D | | 3463<br>3464 | FBE3<br>FBE4 | 19<br>FD 7E 00 | | add<br>1d | hl,de<br>a,(iy+0) | append next digit;get next character from line buffer; | | |----------|--------------|--------------|----------------|---------------------------------------|-----------|-------------------|--------------------------------------------------------|--| | | 3465 | FBE7 | 4F | | ld | c,a | · · | | | | 3466 | FBE8 | FD 23 | | inc | iy | ; advance buffer address | | | | 3467 | FBEA | CD FBF3 | | call | hexbin | convert one ascii hex to binary; | | | | 3468 | FBED | 5F | | ld | e,a | | | | | 3469 | FBEE | 30 EF | | jr | nc,gnum1 | | | | | 3470 | FBFO | 79 | | 1 d | a,c | return first non hex digit; | | | | 3471 | FBF1 | B7 | | or | a | | | | | 3472 | FBF2 | C9 | | ret | | | | | | 3473 | | | | | | A. B.C. | | | | 3474<br>3475 | | | · · · · · · · · · · · · · · · · · · · | nexoin | - convert ne | x to binary. | | | | 3476 | FBF3 | D6 30 | ;<br>hexbin: | ab | .0. | | | | | 3477 | FBF5 | D8 30 | | ret | c | | | | | 3478 | FBF6 | FE OA | | ср | 10 | | | | | 3479 | FBF8 | 3F | | ccf | | | | | | 3480 | FBF9 | DO . | | ret | nc | | | | | 3481 | FBFA | D6 07 | | sub | 7 | | | | | 3482 | FBFC | FE OA | | ср | 10 | | | | | 3483 | FBFE | D8 | | ret | С | | | | | 3484 | FBFF | FE 10 | | ср | 16 | | | | | 3485 | FC01 | 3F | | ccf | | | | | | 3486 | FC02 | C9 | | ret | | | | | | 3487 | | | | | | | | | | 3488 | FC03 | F5 | put2hx: | push | af | | | | | 3489 | FC04 | 1 F | | rra | | | | | | 3490 | FC05 | 1 F | | rra | | | | | | 3491 | FC06 | 1 F. | | rra | | | | | | 3492 | FC07 | 1F | | rra | | | | | | 3493 | FC08 | CD FCOC | | call | putnib | | | | | 3494 | FCOB | F1 | | pop | af | | | | | 3495 | FCOC | E6 OF | putnib: | | 000011116 | | | | | 3496 | FCOE | C6 90 | | add | a,90h | | | | | 3497 | FC10 | 27 | | daa | | | | | | 3498 | FC11 | CE 40 | | adc | a,40h | | | | | 3499 | FC13 | 27 | | daa | | | | | | 3500 | FC14 | 18 OA | | jr | output | | | | | 3501<br>3502 | FC16 | 7.0 | put4hs: | 1 | a.h | | | | | 3502 | FC17 | 7C<br>CD FCO3 | | call | put2hx | | | | | 3504 | FC1A | 70 | | ld | a,1 | | | | | 3505 | FC1B | CD FC03 | put2hs: | | put2hx | | | | | 3506 | FCID | CD 1 CG3 | putziis. | Call | putznix | | | | | 3507 | | | ;; | space - | output space | 0 | | | _ | 3508 | | | | орисс | острот оры | , | | | ð | 3509 | FC1E | 3E 20 | space: | 1 d | a,'' | ;fall through to output space | | | Appendix | 3510<br>3511 | FC20 | C3 F00C | output: | jp | conout | display character; | | | 0 | 3512<br>3513 | | | | dmpfmt | - Dump Comma | nd Output Formatter. | | | | | | | ; | | | | | | п | 1 . | | | | | | | | ret page Transient Command Area E79 3565 3566 3567 3568 FC54 C9 ``` Appendix E 3622 FCB4 20 3623 FCB5 34 2E 30 31 defb rev/100+'0'.'.'.(rev mod 100)/10+'0'.(rev mod 10)+'0' ``` | Balcones<br>Transien | | | 9-Dec-81 | |----------------------|------|----------------------------|--------------------| | 3624 | FCB9 | 0 1F 1C 20 defm ' ',31,28 | ' 1982 Xerox Corp' | | 3625 | FCBD | 1 39 38 32 | | | 3626 | FCC1 | 0 58 65 72 | | | 3627 | FCC5 | F 78 20 43 | | | 3628 | FCC9 | F 72 70 | | | 3629 | FCCC | D OA defb cr.1f | | | 3630 | FCCE | A defb lf | | | 3631 | FCCF | C 20 2D 20 defm 'L - Load | System' | | 3632 | FCD3 | C 6F 61 64 | • | | 3633 | FCD7 | 0 53 79 73 | | | 3634 | FCDB | 4 65 6D | | | 3635 | FCDE | D OA defb cr,1f | | | 3636 | | | | | 3637 | | if options ar | nd o.term | | 3638 | FCEO | 8 20 2D 20 defm 'H - Host | Terminal' | | 3639 | FCE4 | 8 6F 73 74 | | | 3640 | FCE8 | 0 54 65 72 | | | 3641 | FCEC | D 69 6E 61 | | | 3642 | FCFO | C | | | 3643 | FCF1 | D OA defb cr.lf | | | 3644 | | endif | | | 3645 | | if options ar | nd o.type | | 3646 | FCF3 | 4 20 2D 20 defm 'T - Types | vriter' | | 3647 | FCF7 | 4 79 70 65 | | | 3648 | FCFB | 7 72 69 74 | | | 3649 | FCFF | 5 72 | | | 3650 | FD01 | D OA defb cr.lf | | | 3651 | | endif | | | 3652 | FD03 | 7 04 defb 7,eot | | | 3653 | | | | | 3654 | FD05 | D F006 eatkey: call const | | | 3655 | FD08 | A F003 jp z,warm | go enter monitor; | | 3656 | FD0B | D F009 call conin | | | 3657 | FD0E | 8 F5 jr eatkey | | | 3658 | | | | | 3659 | | subttl I/O byte ( | Drivers | | 3660 | | page | | Palcones Operation System for the MEDON ROOTT MACRO-RO 3 44 DR-Doc-R1 ``` 3666 .dephase .phase iobloc 3667 3668 comins - Communications input status. ;; 3669 F770 DB 06 3670 comins: in a.(siocpa) 3671 F772 0F rrca 3672 F773 9F sbc a,a 3673 F774 C9 ret 3674 3675 coming - Communications input data. . . 3676 3677 F775 DB 06 cominp: in a.(siocpa) OF 3678 F777 rrca 3679 F778 30 FB jr nc,cominp 3680 F77A DB 04 in a, (siodpa) 3681 F77C C3 F0E2 jр kbmask 3682 3683 :: comout - Communications output. 3684 3685 F77F CD F788 comout: call comots 3686 F782 28 FB jr z, comout 3687 F784 79 ١d a.c 3688 F785 D3 04 (siodpa),a out 3689 F787 С9 ret 3690 3691 :: comots - Communications output status. 3692 3693 F788 DB 06 a, (siocpa) comots: in 3694 F78A E6 04 and 3695 F78C CB ret z 3696 F78D F6 FF -1 or C9 3697 F78F ret 3698 3699 conjob - get console i/o byte. :: 3700 3701 F790 3A 0003 coniob: ld a. (iobyte) 3702 F793 E.6 03 000000116 and 3703 F795 C9 ret 3704 3705 :: iocono - Console output through iobyte. 3706 3707 F796 CD F790 iocono: call coniob 3708 F799 28 E4 jr z.comout 3709 F798 ЗD dec CA F2FE z.fastcrt 3710 F79C jр Appendix 3711 F79F ١d a.c 3712 C3 FOF8 F7A0 jр sicout 3713 3714 :: iocons - Console status through iobyte. 3715 ``` | _ | .,, | D. 11010 | | | | | | | |---|--------------|--------------|------------------|---------|------------|------------------------|------------------|-------| | | 3716 | F7A3 | CD F790 | iocons: | | coniob | | | | | 3717<br>3718 | F7A6 | 28 C8 | | jr | z,comins | | | | | 3718 | F7A8<br>F7A9 | 3D<br>CA FOCD | | dec | a | | | | | 3719 | F7AG | C3 FOE5 | | jp<br>jp | z,kbdst<br>siost | | | | | 3721 | . / // . | 55 , 525 | | | | | | | | 3722<br>3723 | | | :: | ioconi | - Console input | through iobyte. | | | | 3724 | F7AF | CD F790 | ioconi: | | contob | | | | | 3725<br>3726 | F7B2<br>F7B4 | 28 C1<br>3D | | jr | z,cominp | | | | | 3726 | F785 | CA FOD8 | | dec<br>jp | a<br>z.kbdin | | | | | 3728 | F7B8 | C3 FOFO | | jp | z,kodin<br>sidin | | | | | 3729 | 50 | 22 . 01 0 | | | | | | | | 3730<br>3731 | | | ;; | | - List output th | hrough iobyte. | | | | 3732 | F7BB | 3A 0003 | iolist: | | a,(iobyte) | | | | | 3733 | F7BE | E6 CO | | and | 11000000ь | | | | | 3734 | F7C0 | 28 BD | | jr | z,comout | | | | | 3735 | F7C2 | EA F7DC | | jp . | pe,pioout | | | | | 3736<br>3737 | F7C5<br>F7C6 | 79<br>FA FOF8 | | ld: | a,c | | | | | 3738 | F7C9 | C3 F2FE | | jp<br>.ip | m,sicout<br>fastort | | | | | 3739 | 1,709 | C3 12FE | | | | | | | | 3740<br>3741 | | | ;; | List o | utput through io | byte | | | | 3742 | F7CC | 3A 0003 | iolsts: | 1 d | a,(iobyte) | | | | | 3743 | F7CF | E6 C0 | | and | 11000000ь | | | | | 3744 | F7D1 | 28 B5 | | jr | z,comots | | | | | 3745 | F7D3 | EA F7F4 | | jp | pe,piosto | | | | | 3746<br>3747 | F7D6<br>F7D9 | FA F105<br>F6 FF | | jp | m,siordy | | | | | 3747 | F7DB | F6 FF | | or<br>ret | -1 | | | | | 3749 | F 7 DB | Co | | | | | | | | 3750<br>3751 | | | ; ; | Parall | el Output Driver | • | | | | 3752 | F7DC | CD F7F4 | pioout: | call | piosto | | | | | 3753 | F7DF | 28 FB | | jr | z.pioout | ; if printer not | ready | | | 3754 | F7E1 | 79 | | ١d | a,c | | | | | 3755 | F7E2 | D3 08 | | out | (gpioda),a | ;load character | data | | | 3756 | F7E4 | DB OA | | in | a,(gpiodb) | | | | | 3757<br>3758 | F7E6<br>F7E8 | CB 97<br>D3 OA | | res<br>out | p.strb,a<br>(gpiodb),a | ;assert strobe | | | | 3759 | F7EA | CB D7 | | set | p.strb.a | :release stobe | | | | 3760 | F7EC | D3 0A | | out | (gpiodb).a | ease stone | | | | 3761 | F7EE | 3E OA | | 1d | a,10 | delay for ACK | | | | 3762 | F7F0 | 3D | pio1: | dec | a | , | | | | 3763 | F7F1 | 20 FD | | jr | nz,pio1 | | | | | 3764<br>3765 | F7F3 | C9 | | ret | | | | | | 3766 | | | :: | Parall | el Output Status | | | | | 3767 | E754 | DB OA | : | | - (:) | | | | | 3768<br>3769 | F7F4<br>F7F6 | 2F | piosto: | cpl | a,(gpiodb) | ;read status | | | | 3770 | F7F7 | E6 10 | | and | i shi p.rdyo | | | | | | | | | | | | | | | 3782 | | | | | | | | | |---|--------------|--------------|------------|----|-------|-----------|----------------|---------|---------------------------------------| | _ | 3783 | | | | | if | options and | | | | • | 3784 | | | ; | | disk | boot loader | command | | | | 3785 | | | : | | | | | | | • | 3786 | | | | | overlay | boot | | | | | 3787 | 01487 | | + | | c&seg | | | | | | 3788 | | | | | | | | | | | 3789 | FC55 | 21 FF5D | | | 1 d | hl,linbuf+1 | | | | | 3790 | FC58 | 7 E | bo | ot1: | 1 d | a,(h1) | ;sca | in command line | | | 3791 | FC59 | 2C | | | inc | 1 | | | | | 3792 | FC5A | D6 0D | | | sub | cr | | | | | 3793 | FC5C | 28 OB | | | jr | z,boot2 | ; if | no parameter, boot from A: | | | 3794 | FC5E | FE 13 | į. | | ср | , ,-cr | | | | | 3795 | FC60 | 28 F6 | | | jr | z,boot1 | ;ski | p leading blanks | | | 3796 | FC62 | D6 34 | | | sub | 'A'-Cr | | | | | 3797 | FC64 | D8 | | | ret | c | ;if | invalid drive | | | 3798 | FC65 | FE 10 | | | ср | 16 | | | | | 3799 | FC67 | 3F | | | ccf | | | | | | 3800 | FC68 | D8 | | | ret | С | | bad drive | | | 3801 | FC69 | 4F | bd | ot2: | 1 d | c,a | ;set | boot drive selected | | | 3802 | FC6A | C6 41 | | | add | a, 'A' | | | | | 3803 | FC6C | 32 FCDD | | | ld | (bootd),a | | up error message | | | 3804 | FC6F | 2E 00 | | | ld | 1,0 | ;set | : A: | | | 3805 | FC71 | C5 | | | push | bc | | | | | 3806 | FC72 | E5 | | | push | h1 | | | | | 3807 | FC73 | CD FCEE | | | call | swap | | tch boot drive with A: | | | 3808 | FC76 | 21 FCD9 | | | 1 d | hl,booter | ;set | boot error return | | | 3809 | FC79 | E5 | | | push | h1_ | | | | | 3810 | FC7A | 0E 00 | | | 1 d | c,0 | ;the | n boot from A: | | | 3811 | FC7C | CD FA17 | | | call | select | | | | | 3812 | FC7F | CO | | | ret | nz | ; if | drive not configured or density error | | | 3813 | FC80 | 3E FF | | | 1 d | a,-1 | | | | | 3814 | FC82 | 12 | | | 1 d | (de),a | | | | | 3815 | FC83 | 11 000A | | | 1 d | de,10 | ;set | dpb address offset within dph | | | 3816<br>3817 | FC86<br>FC87 | 19<br>5E | | | add | hl,de | | | | | 3818 | FC88 | 23 | | | l d | e,(hl) | ;set | dpb address | | | 3819 | FC89 | 56 | | | inc<br>Id | h1 | | | | | 3820 | FCBA | CD FA3C | | | call | d,(h1)<br>home | | | | | 3821 | FCBD | DE DI | | | ld | | | | | | 3822 | FC8F | 1A | | | ld | c,1<br>a,(de) | | sector 1 | | | 3823 | FC90 | 32 FCD4 | | | 10 | (boots).a | | low sectors per track | | | 3824 | FC93 | B7 | | | or | a | ; 1117 | orm boot loader | | | 3825 | FC94 | 20 OD | | | jr | nz,boot3 | | | | | 3826 | FC96 | 21 000D | | | ld | h1,13 | | not rigid | | | 3827 | FC99 | 19 | | | add | hl,de | ; set | reserved track offset within dpb | | | 3828 | FC9A | 4E | | | 1 d | c,(h1) | | | | | 3829 | FC9B | 23 | | | inc | h] | ; get | reserved tracks | | | 3830 | FC9C | 46 | | | 1d | b, (h1) | | | | | 3831 | FC9D | 0B | | | dec | bc (n) | | | | | 3832 | FC9E | ED 43 FA11 | | | 1d | (phytrk),bc | | nt behind directory | | | 3833 | FCA2 | 4F | | | 1d | (phytrk),bc | | implied seek<br>sector zero for rigid | | | 3834 | FCA3 | 21 ED80 | ho | ot3: | 1d . | hl.bootbf | | nt to boot load buffer | | | 3835 | FCA6 | CD FA48 | DC | ,013; | call | read | | nt to boot load buffer | | _ | 3836 | FCA9 | 00 | | | ret | nz | | read error | | п | 0000 | | 0.0 | | | | 114 | ; 11 | read error | djnz swap1 :if swap not complete Appendix I 3892 FD02 10 F7 | endix | 3893<br>3894 | FD04 | C9 | | ret | | | |------------------|--------------|--------------|---------------------|------|----------|----------------------|------------------------------------------------| | . <del>∑</del> . | 3895<br>3896 | | | :: | 1 cp | - load configuration | on parameters. | | ш | 3897 | FD05 | 3E 81 | ice | ): ld | a,10000001b | ;default i/o byte to CRT: and LPT: | | | 3898 | FD07 | 32 0003 | | ld | (iobyte),a | ,, | | | 3899 | FDOA | 3A FCD4 | | 1 d | a,(boots) | get boot diskette type | | | 3900 | FDOD | B7 | | or | a | | | | 3901 | FDOE | 0E 20 | | ١d | c,32 | | | | 3902 | FD10 | 21 ED80 | | 1 d | hl,bootbf | use boot loader buffer; | | | 3903 | FD13 | 28 08 | | jr | z,lcp1 | ; if rigid, use system track, sector 32 | | | 3904 | FD15 | FE 18 | | ср | 26+1 | | | | 3905 | FD17 | D8 | | ret | С | ;no parameters from single density boots | | | 3906 | FD18 | 0E 03 | | 1 d | c,3 | dd configuration comes from track 0, sector 3; | | | 3907 | FD1A | 21 EE00 | _ | 1 d | hl,bootbf+128 | use second half of boot loader buffer; | | | 3908 | FD1D | CD FA48 | 1 cp | | read | | | | 3909 | FD20 | CO | | ret | nz | ;if can't read configuration | | | 3910 | FD21 | 3A EE00 | | 1 d | a,(bootbf+128) | | | | 3911<br>3912 | FD24<br>FD26 | D6 E5<br>C8 | | sub | 0e5h | | | | 3912 | FD27 | 3A EE7B | | ret | z | | | | 3914 | FD27 | B7 | | ld | a,(z.xonp) | ;configure Xon-Xoff | | | 3915 | FD2B | 28 03 | | or<br>jr | z.lcp2 | | | | 3916 | FD2D | FE C9 | | CD. | 0c9h | | | | 3917 | FD2F | co | | ret | nz | | | | 3918 | FD30 | 32 F115 | 100 | | (Xonenb),a | | | | 3919 | FD33 | 3A EE60 | | 10 | a.(z.stpr) | ;configure step rate | | | 3920 | FD36 | 32 FF54 | | 10 | (steprt),a | , com igure step rate | | | 3921 | FD39 | 3A EESF | | 10 | a,(z.scra) | ;configure screen attribute | | | 3922 | FD3C | 32 FD49 | | 1 d | (Icpa),a | tour ignic screen act ibute | | | 3923 | FD3F | 3A EE62 | | 1 d | a,(z.keym) | ;configure keyboard mask | | | 3924 | FD42 | 32 FD4B | | ld | (Icpb),a | toom igure keyboard mask | | | 3925 | FD45 | CD FC3D | | call | pnext | | | | 3926 | FD48 | 18 | | defb | esc | | | | 3927 | FD49 | 00 | 1 cp | a: defb | 0 | | | | 3928 | FD4A | 1B | | defb | esc | | | | 3929 | FD4B | 00 | 100 | b: defb | 0 | | | | 3930 | FD4C | 04 | | defb | eot | | | | 3931 | FD4D | 21 EE63 | | 1 d | hl,z.sioA | configure Sio channels; | | | 3932 | FD50 | 3E 02 | | 1 d | a,2 | | | | 3933 | FD52 | 46 | l cp | | b,(hl) | get number of bytes | | | 3934 | FD53 | 23 | | inc | h1 | | | | 3935 | FD54 | 4 E | | ١d | c,(h1) | get port address | | | 3936 | FD55 | 23 | | inc | hl | | | | 3937 | FD56 | ED B3 | | otir | | | | | 3938 | FD58 | 3D | | dec | a | | | | 3939 | FD59 | 20 F7 | | jr | nz,1cp3 | | | | 3940 | FD5B | 3A EE7D | | 1d | a,(z.baua) | configure channel A bit rate | | | 3941 | FD5E | 03 00 | | out | (bauda),a | | | | 3942 | FD60 | 3A EE7E | | 1 d | a,(z.baub) | configure channel B bit rate | | | 3943 | FD63 | D3 OC | | out | (baudb),a | | | | 3944 | FD65 | 3A EE77 | | 1 d | a,(z.siom) | configure printer ready mask | | | 3945 | FD68 | 32 F10C | | ld | (siomsk),a | | | | 3946<br>3947 | FD6B<br>FD6E | 3A EE79<br>32 F10E | | 1d | a,(z.siov) | configure printer ready value; | | m | 3947 | FD71 | 32 F 10E<br>3A EE7F | | l d | (sioval),a | | | E87 | 3548 | -0/1 | JM EE/F | | ۱d | a,(z.iobt) | configure I/O byte | ``` 3953 endif 3954 3955 -- goto to memory location command -- ;; 3956 3957 overlay goto 3958 026B' + c&seg 3959 3960 FC55 В7 or 3961 FC56 37 scf 3962 FC57 C8 ret z :if no parameters 3963 FC58 E5 push h1 set goto address 3964 FC59 DD E1 iх pop ; 1d ix,hl 3965 FC5B EΒ ex de.hl set second arg to HL 3966 FC5C 7 D ١d a.1 : and A 3967 FC5D 50 ١d d,b set third arg to DE 3968 FC5E 5D ١d e.1 3969 FC5F ED 4B FFBB ١d bc, (param4) ; set fourth arg to BC 3970 FC63 CD FAD6 call jpix 3971 FC66 CD FC1B call put 2hs :print A req 3972 FC69 C3 FC16 put4hs jр 3973 3974 -- memory dump command -- ;; 3975 : 3976 overlay memdmp 3977 0282 + c&seg 3978 3979 FC55 3D dec ; check parameter count 3980 FC56 28 06 ir z,mdmp2 3981 FC58 30 dec 28 08 3982 FC59 jr z,mdmp3 3983 FC5B 2A FFBD mdmp1: 1 d hl.(last) 3984 FC5E 11 0010 mdmp2: 1d de.16 3985 FC61 18 OE jr mdmp3b 3986 3987 FC63 EΒ mdmp3: ex de.hl 3988 FC64 ED 52 hl,de sbc :derive bytecount for dump range 3989 FC66 D8 ret С :if addresses backwards 3990 FC67 06 04 ١d b,4 3991 FC69 CB 3C mdmp3a: srl h :divide bytecount by 16 3992 FC6B CB 1D C.C. 3993 FC6D 10 FA djnz mdmp3a 3994 FC6F 23 inc h1 3995 FC70 EB de.hl eх 3996 FC71 CD FB8F mdmp3b; call dump ;dump de*16 bytes strting at h1 3997 FC74 22 FFBD ١d (last).hl 3998 FC77 С9 ret 3999 4000 -- memory examine command -- 4001 4002 overlay view 4003 02A5 c&seg 4004 ``` Appendix m ``` 4066 options and o.disk 4067 :: -- disk sector read/write command -- 4068 4069 * R <unit> <track> <sector> <address> 4070 * W <unit> <track> <sector> <address> : 4071 4072 overlay dskcmd 4073 02F7' c&seg 4074 4075 FC55 47 ١d b.a 4076 FC56 3A FESC 1 d a,(linbuf) D6 57 4077 FC59 sub ·w· FC5B 4078 20 1E ir nz.dsk1 4079 FC5D BO or 4080 FC5E 20 16 ir nz.dsk0 4081 FC60 4F ١d c.a 4082 FC61 CD F2FE call Fastcrt 4083 FC64 23 inc 4084 FC65 11.0011 1d de.17 4085 FC68 01 0015 ١d bc,21 4086 FC6B EB ex de.hl AF 4087 FC6C xor 4088 FC6D 32 FC54 ($-25),a 1 d 4089 FC70 CD F2A3 call crtldir 4090 EC73 C3 FC36 crlf jp 4091 4092 FC76 3A FC54 dsk0: ١d a.($-34) 4093 FC79 В7 or 4094 FC7A CO ret nz 4095 FC7B 78 dsk1: 1 d a.b 4096 FC7C FE 04 CD :check parameter count 4097 FC7E 37 scf 4098 FC7F CO ret 4099 FC80 21 FFB5 1d hl,parami :move parameters to disk command 4100 FC83 11 FA10 1 d de.phydry 4101 FC86 01 0007 1 d bc,3*2+1 4102 FC89 ED AO ldi 4103 FC8B 23 inc h1 ;skip upper unit 4104 FC8C ldir ED BO 4105 FC8E 05 dec ;set select operation 4106 FC8F CD FA51 call xqphys ; execute physical select 4107 FC92 7D a, 1 ١d 4108 FC93 В4 or 4109 FC94 28 16 jr ; if select error z,dskerr 4110 FC96 06 00 ١d :preset write command b.0 4111 FC98 3A FF5C ١d a,(linbuf) :get command 4112 FC9B FE 57 СĐ 4113 FC9D 28 01 jr z,dsk3 : if write 4114 FC9F 04 inc 4115 FCAD CD FA51 call dsk3: xaphys :execute driver 4116 FCA3 2A FFBB ١d hl, (param4) ``` ср 2 require two parameters 4172 FC55 FE 02 | | 4177 | FCSB | ED 29 | | | out | (c),e | joutput to do-d7 and address to ad-al7 | | |----------|------|-------|---------|---|--------|-------------------------------------------------------------------------------------------|------------------------------------------------------------|----------------------------------------|--| | | 4178 | FC5D | 87 | | | or | a | | | | | 4179 | FCSE | C9 | | | ret | | | | | | 4180 | | | | | else | | | | | | 4181 | | | | outcmd | equ | what | | | | | 4182 | | | | | endif | | | | | | 4183 | | | | | | | | | | | 4184 | | | | | if | options and | o camt | | | | 4185 | | | | ;; | | | diagnostic command | | | | 4186 | | | | • • | mem | ory read/wille | dragnostic command | | | | | | | | • | * V -E | | | | | | 4187 | | | | ; | * X <t< td=""><td>irst addr&gt; <la< td=""><td>ist addr&gt;</td><td></td></la<></td></t<> | irst addr> <la< td=""><td>ist addr&gt;</td><td></td></la<> | ist addr> | | | | 4188 | | | | | | | | | | | 4189 | | | | | overla | y test | | | | | 4190 | 0388' | | + | | c&seg | | | | | | 4191 | | | | | | | | | | | 4192 | FC55 | FE 02 | | | ср | 2 | ;check parameter count | | | | 4193 | FC57 | 37 | | | scf | | | | | | 4194 | FC58 | CO | | | ret | nz | | | | | 4195 | FC59 | 13 | | | inc | de | | | | | 4196 | FC5A | 5A | | | 1 d | e.d | get ending page address into e | | | | 4197 | FC5B | 54 | | | 10 | d,h | get starting page address into d | | | | 4198 | FCSC | 06 00 | | | 1 d | b.0 | ;initialize pass counter | | | | 4199 | FCSE | 62 | | test1: | | h,d | point hi to start of block | | | | | FCSF | 2E 00 | | testi: | ld | 1.0 | ;point in to start or brock | | | | 4200 | | | | | | | | | | | 4201 | FC61 | 7D | | test2: | | a,1 | | | | | 4202 | FC62 | AC | | | xor | h | generate test byte; | | | | 4203 | FC63 | AB | | | XOL | b | | | | | 4204 | FC64 | 77 | | | ١d | (h1),a | store byte in ram; | | | | 4205 | FC65 | 23 | | | inc | hl | | | | | 4206 | FC66 | 7 C | | | ١d | a,h | | | | | 4207 | FC67 | 88 | | | СР | e | ;check for end of test block | | | | 4208 | FC68 | 20 F7 | | | jr | nz,test2 | | | | | 4209 | FC6A | 62 | | | 1d | h.d | now read back each byte & compare | | | | 4210 | FC6B | 2E 00 | | | 1 d | 1.0 | point hi back to start | | | | 4211 | FC6D | 7D | | test3: | 1 d | a.1 | ., | | | | 4212 | FC6E | AC | | | xor | h | re-generate test byte data | | | | 4213 | FC6F | AB | | | xor | b | , | | | | 4214 | FC70 | CD FBOE | | | call | check | ;verify memory data still good | | | | 4215 | FC73 | CO | | | ret | nz | ;exit if escape request is indicated | | | | 4216 | FC74 | 23 | | | inc | hl | ; else go on to next byte | | | | 4216 | FC75 | 7 C | | | 1 d | a,h | ; else go on to next byte | | | | 4218 | | 88 | | | | | | | | | | FC76 | | | | сp | e | ;check for end of block | | | | 4219 | FC77 | 20 F4 | | | jr | nz,test3 | | | | | 4220 | FC79 | 04 | | | inc | ь | ;bump pass count | | | | 4221 | FC7A | 3E 2B | | | 1d | a,'+' | | | | Þ | 4222 | FC7C | CD FC20 | | | call | output | | | | - | 4223 | FC7F | 28 DD | | | jr | z,test1 | ;do another pass if user not unhappy | | | ŏ | 4224 | FC81 | C9 | | | ret | | | | | ĕ | 4225 | | | | | else | | | | | Appendix | 4226 | | | | test | equ | what | | | | ۵ | 4227 | | | | | endif | | | | | Δ. | 4228 | | | | | | | | | | m | 7420 | | | | | | | | | | | | | | | | | | | | h١ inc 4284 FC63 23 defb else esc.'1' :set 8 bit keyboard mode Appendix E 4339 4340 FC62 1B 31 page subttl Terminal / Screen Manager 4381 4382 4383 ``` 4389 000F 15 pass8 4390 0016 inslin equ 22 4391 0017 23 dellin equ 4392 001A clrchr eau 26 4393 001E homser eau 30 4394 001F force eau 31 4395 4396 0081 kuplin equ 81h :Move top line off screen to buffer 4397 0082 kdnlin equ 82h :Move bottom line off screen to buffer 4398 00B1 Rmttog equ 80h+'1' :Toggle Remote Echo 4399 00B2 Rmtalf equ 80h+'2' :Toggle Remote Auto LF after CR 4400 008A Localf equ 80h+1f :Toggle Local Auto LF after CR 4401 OOFF Typtog equ 80h+7fh :Toggle Local Echo 4402 DOAE 80b+'.' Brkkey equ :Hardware BREAK function 4403 4404 0007 s.lecho equ ;local echo 4405 0006 s.recho equ 6 :remote echo 4406 0005 s.autol equ 5 ;local auto if after cr 4407 0004 s.autor equ 4 remote auto If after cr 4408 4409 01'00 Trmbuf equ 4410 EEBO Trmbuf+760*80 Bufton equ 4411 EF00 Siobuf equ Monitr-100h 4412 EF00 Trmstk equ Sigbuf 4413 4414 FC55 FE 02 2 :check number of arguments 4415 FC57 3F ccf 4416 FC58 D8 ret : if more than 1 С 4417 87 FC59 or а 4418 FC5A 20 02 ir nz.term1 :if port specifed 4419 FC5C 2E 00 1.0 ١d 4420 FC5E 01 0406 term1: 1d bc.siocpa+siodpa*256 :preset A channel ports 4421 FC61 CB 45 bit 0.1 4422 FC63 28 03 jr z.term2 :if 0/1 or A/B 4423 FC65 01 0507 ìd bc.siocob+siodob*256 :set B channel ports 4424 FC68 ED 43 FE78 term2: 1 d (ports),bc 4425 FC6C 31 EF00 1 ત sp.trmstk 4426 FC6F CD FC3D call pnext 4427 FC72 1 A db clrs 4428 if options and o.esct 4429 FC73 18 31 db esc,'1' 4430 6156 4431 db pass8 4432 endif 4433 FC75 54 65 72 6D 'Terminal mode. Touch CTRL+ESC to exit.' 69 6E 61 6C 4434 FC79 4435 FC7D 20 6D 6F 64 4436 65 2E 20 20 FC81 ``` Appendix 4437 4438 FC85 FC89 54 6F 75 63 68 20 43 54 ``` 4500 FD08 20 04 j٢ nz,pki7 4501 FDOA 3E 20 1 d a.1 shl s.autol 4502 FDOC 18 06 nk 18 4503 FDOE FE B2 pki7: Rmtalf 4504 FD10 20 09 nz,pki9 ir 4505 FD12 3E 10 ١d a, 1 sh1 s.autor 4506 FD14 FD AE 00 pki8: (iv) XOF 4507 FD17 FD 77 00 1 d (iy),a 4508 FD1A C9 ret 4509 FD1B FE AE pki9: Brkkev CD 4510 FD1D CO ret 3A FCB2 4511 FD1E ١d a.(brkflg) 4512 FD21 EE FF clrbrk: xor -1 4513 FD23 32 FCB2 ١d (brkflg).a 4514 FD26 16 10 ١d d,10h ;set line SPACING 4515 FD28 20 02 jr nz, setbrk 4516 FD2A 16 00 ١d d.O :set line MARKING 4517 FD2C ED 4B FE78 setbrk: ld bc, (ports) 4518 FD30 3E 05 1 d a.5 :set up WR5 4519 FD32 F3 di 4520 ED 79 (c).a FD33 out 4521 FD35 3E AA ١d а.10101010ь ;assert DTR, 7 bpc, RTS, Tx Enb 4522 FD37 B2 or 4523 FD38 ED 79 out (c).a 4524 FD3A FB еí 3E FF a,Offh 4525 FD3B 1 d 4526 FD3D C3 FE90 sicot :send RUBOUT to allow MARKING 4527 4528 prc - Process Remote Character. :: 4529 4530 FD40 CD FED6 prc: call sioinc :read remote character 4531 FD43 FD CB 00 76 bit s.recho,(iy) 4532 FD47 C4 FD5F call nz,sndrmt :echo it back 4533 FD4A 18 26 ir doc display it locally 4534 4535 sndloc - send character to screen. :: 4536 4537 FD4C CD FD72 sndloc: call doc 4538 FD4F FE OD ср CF 4539 FD51 CO ret nz FD CB 00 6E 4540 FD52 bit s.autol.(iv) 4541 FD56 C8 ret 4542 FD57 3E OA ١d a.lf 4543 FD59 CD FD72 call doc 4544 FD5C 3E 0D ١d a.cr 4545 FD5E C9 ret 4546 4547 ;; sndrmt - send character to remote. 4548 4549 FD5F CD FE90 sndrmt: call sioot 4550 FD62 FE OD Сr ср ``` Appendix 01 0050 ١d bc,80 4606 | | 4612 | FDC5 | 3E 20 | | ١d | a,′′ | | | |-------------|--------------|------------------------------|-----------------------------------|-----------------|-------------------------------|-------------------------------------------|-----------------------------------------|--| | | 4613 | FDC7 | ED A9 | dln1: | cpd | ٠, | | | | | 4614 | FDC9 | 20 03 | J | jr | nz.dln2 | ; if not trailing blank | | | | 4615 | FDCB | EA FDC7 | | jр | pe.dini | , it not training brank | | | | 4616 | FDCE | EI | dln2: | pop | h1 | | | | | 4617 | FDCF | EO | G | ret | po | ; if entire line blank | | | | 4618 | FDD0 | 41 | | 1d | b,c | , it shows the blank | | | | 4619 | FDD1 | 04 | | inc | b | | | | | 4620 | FDD2 | C5 | dln3: | push | bc | | | | | 4621 | FDD3 | 7E | | ld | a,(hl) | | | | | 4622 | FDD4 | 4F | | 1 d | c,a | | | | | 4623 | FDD5 | FE 20 | | cp | 717 | | | | | 4624 | FDD7 | 30 08 | | ir | nc,dln4 | | | | | 4625 | FDD9 | E5 | | push | h1 | | | | | 4626 | FDDA | OE 1F | | 1d | c.force | ;force next character out | | | | 4627 | FDDC | CD FE9B | | call | outert | *************************************** | | | | 4628 | FDDF | E 1 | | pop | h l | | | | | 4629 | FDEO | 4E | | 1 d | c.(hl) | | | | | 4630 | FDE1 | 23 | dln4: | inc | h1 | ; advance address | | | | 4631 | FDE2 | E5 | | push | h1 | | | | | 4632 | FDE3 | CD FE9B | | call | outert | ;display character | | | | 4633 | FDE6 | E1 | | рор | h1 | | | | | 4634 | FDE7 | C1 | | pop | bc | | | | | 4635 | FDE8 | 10 E8 | | djnz | d1n3 | ; if not entire line | | | | 4636 | FDEA | C9 | | ret | | | | | | 4637 | | | | | | | | | | 4638 | | | ;; | dbl - | Display bottom li | ne. | | | | 4639 | | | ; | | | | | | | 4640 | FDEB | CD FC3D | db1: | call | pnext | ;plant cursor on bottom line | | | | : 4641 | FDEE | 1B 3D 37 20 | | db | esc,'=',' '+23, | ′ ',eot | | | | 4642 | FDF2 | 04 | | | | | | | | 4643 | FDF3 | 2A FEE6 | | ١d | hl,(botptr) | | | | | 4644 | FDF6 | E5 | | push | h1 | | | | | 4645 | FDF7 | 01 004F | | 1 d | bc,80-1 | | | | | 4646 | FDFA | CD FDC2 | | call | dln | display bottom line; | | | | 4647 | FDFD | E1 | | pop | h1 | | | | | 4648 | FDFE | 01 0050 | | ld | bc,80 | | | | | 4649 | FE01 | 09 | | add | h1.bc | | | | | 4650 | FE02 | EB | | e× | de,hl | | | | | 4651 | FE03 | CD FE34 | | call | wup | | | | | 4652 | FE06 | ED 53 FEE6 | | 1d | (botptr),de | | | | | 4653 | FEOA | C9 | | ret | | | | | | | | | | | | | | | | 4654 | | | | | 11-1-1-1-1-1 | | | | | 4654<br>4655 | | | ;; | 161 - | link bottom line. | | | | <b>&gt;</b> | 4654<br>4655 | 5500 | 01 0050 | : | | | | | | Ą | 4654<br>4655 | FEOB | 01 0050 | ;;<br>;<br>!b1: | ۱d | bc,80 | | | | App | 4654<br>4655 | FEOE | 2A FEE6 | : | 1 d<br>1 d | bc,80<br>hl,(botptr) | | | | Apper | 4654<br>4655 | FEOE<br>FE11 | 2A FEE6<br>B7 | : | ld<br>ld<br>or | bc,80<br>h1,(botptr)<br>a | | | | Append | 4654<br>4655 | FEOE<br>FE11<br>FE12 | 2A FEE6<br>B7<br>ED 42 | : | ld<br>ld<br>or<br>sbc | bc,80<br>hi,(botptr)<br>a<br>hi,bc | | | | Appendi | 4654<br>4655 | FE0E<br>FE11<br>FE12<br>FE14 | 2A FEE6<br>B7<br>ED 42<br>CD FE41 | : | ld<br>ld<br>or<br>sbc<br>call | bc,80<br>h!,(botptr)<br>a<br>h!,bc<br>wlp | | | | Appendix E | 4654<br>4655 | FEOE<br>FE11<br>FE12 | 2A FEE6<br>B7<br>ED 42 | : | ld<br>ld<br>or<br>sbc | bc,80<br>hi,(botptr)<br>a<br>hi,bc | | | Appendix E ``` FEBC 3A FEEC siopl1: ld a, (opoint) FEBF 95 sub FECO 28 03 jr z,siop12 ; if buffer full FEC2 22 FEEA 1 d (ipoint),hl FEC5 E 1 siop12: pop FEC6 C 1 siop13: pop bc FEC7 C9 ret :: Sioist - Sio Input Status. FEC8 CD FEA7 Sioist: call Siopl ;poll for input FECB 2A FEEC 1 d hl, (opoint) ;set out pointer FECE 3A FEEA ١d a. (ipoint) FED1 95 sub FED2 C8 ret z ; if data not ready FED3 F6 FF or -1 FED5 С9 ret Sigin - Sig Input Character. :: FED6 CD FEC8 Sioinc: call Sioist :set input ready status FED9 28 FB z,Sioinc ir FEDB 7 E a,(h1) ١d FEDC 2C inc :advance out FEDD 20 02 jг nz,Sioi1 FEDF 2E 00 1d 1.low siobuf FEET 22 FEEC Sioil: 1d (opoint),hl FEE4 C9 ret FEE5 00 0. status: db FEE6 0100 botptr: dw Trmbuf FEE8 0100 topptr: dw Trmbuf FEEA EF00 ipoint: dw siobuf FEEC EF00 opoint: dw siobuf else 4812 what term equ 4813 endif 4814 4815 i f options and o.help 4816 4817 Help Key Command. ;; 4818 . 4819 overlay help 4820 070B c&seg 4821 4822 FC55 CD FC3D call pnext 4823 FC58 42 61 75 64 defb 'Baud <rate> [B/A]',cr,lf 4824 FC5C 09 09 3C 72 4825 FC60 61 74 65 3E 4826 FC64 20 5B 42 2F 4827 FC68 41 5D 0D 0A 4828 FC6C 44 75 6D 70 [start] [end]'.cr.lf defb 'Dump E103 4829 FC70 09 09 5B 73 4830 FC74 74 61 72 74 ``` | 4836 | FC89 | 64 64 72 3E | | | | | |------|--------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------| | 4837 | FC8D | OD OA | | | | | | 4838 | FC8F | 4D 6F 64 69 | | defb | 'Modify | <addr>',cr,lf</addr> | | 4839 | FC93 | 66 79 09 09 | | | • | | | 4840 | FC97 | 3C 61 64 64 | | | | | | 4841 | FC9B | 72 3E OD OA | | | | | | 4842 | FC9F | 50 72 6F 74 | | defb | 'Protocol | <pre><xon> [msk val]',cr,lf</xon></pre> | | 4843 | FCA3 | 6F 63 6F 6C | | | | | | 4844 | FCA7 | 09 3C 78 6F | | | | | | 4845 | FCAB | 6E 3E 20 5B | | | | | | 4846 | FCAF | 6D 73 6B 20 | | | | | | 4847 | FCB3 | 76 61 6C 5D | | | | | | 4848 | FCB7 | OD OA | | | | | | 4849 | FCB9 | 04 | | defb | eot | | | 4850 | FCBA | C9 | | ret | | | | 4851 | | | | else | | | | 4852 | | | help | equ | what | | | 4853 | | | • | endif | | | | 4854 | | | | | | | | 4855 | | | | subttl | Segment Size | e Information | | 4856 | | | | page | | | | | | | | | | | | | | | | | | | | | 4837<br>4838<br>4840<br>4841<br>4842<br>4843<br>4844<br>4845<br>4846<br>4846<br>4847<br>4848<br>4849<br>4851<br>4853<br>4853<br>4855 | 4837 FCBD<br>4838 FCBF<br>4840 FC97<br>4841 FC98<br>4842 FC9F<br>4843 FCA7<br>4844 FCA7<br>4844 FCA7<br>4846 FCA9<br>4840 FCB9<br>4850 FCB9<br>4853<br>4854<br>4853<br>4854 | 4837 FC8D OD OA 4838 FC8F 40 6F 64 69 4839 FC93 66 79 09 09 4840 FC97 36 61 64 64 4841 FC98 72 3E 0D OA 4842 FC9F 50 72 6F 74 4843 FCA3 6F 63 6F 6C 4844 FCA7 09 3C 78 6F 4845 FCA7 09 3C 78 6F 4846 FCA8 6E 3E 2D 58 4846 FCA8 6E 3E 2D 58 4846 FCA8 6C 4848 FCA8 6C 3E 2D 58 4854 4855 | 4837 FC8D 0D 0A 4838 FC8F 4D 6F 64 69 4839 FC93 66 79 09 09 4840 FC93 3C 61 64 64 4841 FC9B 72 3E 0D 0A 4842 FC9F 50 72 6F 74 4843 FCA3 6F 63 6F 6C 4844 FCA7 09 3C 78 6F 4844 FCAF 60 73 68 20 4846 FCAF 60 73 68 20 4847 FCAF 60 73 68 20 4848 FCAF 6C 74 67 74 4849 FCAF 6C 74 66 6C 74 4849 FCAF 6C 75 66 6C 75 4848 6C 75 4848 FCAF 6C 75 6C 75 4848 FCAF | 4837 FC8D OD OA 4838 FC8F 40 6F 64 69 defb 4839 FC93 66 79 09 09 48440 FC97 3C 61 64 64 4841 FC98 72 3E 0D OA 4842 FC87 O72 6F 74 defb 4843 FCA3 6F 63 6F 6C 48444 FCA7 09 3C 78 6F 4845 FCA7 09 3C 78 6F 4846 FCA7 09 16 6E 3E 20 5B 4846 FCA7 09 16 6E 3E 20 5B 4846 FCA7 09 16 6E 3E 20 8B 4846 FCB7 01 01 01 01 01 01 01 01 01 01 01 01 01 | 4837 FC8D | ``` Balcones Operating System for the XEROX 820-II MACRO-80 3.44 09-Dec-81 Segment Size Information 4857 4858 Top of Overlay Area. :: 4859 4860 overlay stop 4861 0771 + c&seg 4862 0299 tpamax eau toal :set length of transient move 4863 4864 Top of Resident Monitor. :: 4865 4866 below 4867 0000! defs comres 4868 041B rbase eau 4869 4870 Top of Non Resident Monitor. :: 4871 4872 above 4873 0518! d&seq 4874 FC55 restop equ resident ton 4875 0055 resien equ $-monitr :length of resident monitor 4876 4877 update clear active segment 4878 4879 Top of Burned Rom Set. ;; 4880 4881 17E1 romtop eau bloc+dloc+tloc-monitr 4882 4883 Fill Out Unused Rom Space. :: 4884 4885 0055" cseq 4886 4887 if (rom+romsiz-romtop) gt 0 4888 07711 defs (rom+romsiz-romtop).-1 4889 endif 4890 4891 subttl Resident Monitor System Ram 4892 page ``` .deohase subttl Console Messages page 4985 4986 end entry | ń | | | | | | | | | |-----------|---------|---------|-------|-------|--------|---------|----------|------------| | ppendix F | Macros: | | | | | | | | | ō | ABOVE | | BELOW | | BSEG | MESSAGE | | 01/501 41/ | | Š | PHEX | | PMSG | | PRINTX | SEGMENT | | OVERLAY | | ٥. | UPDATE | | FMSG | | PRINIX | SEGMENT | | SERVICE | | Σ. | OPDATE | | | | | | | | | т | Symbols | | | | | | | | | | 0080 | • | | F360 | . A | F362 | . В | | | | F364 | . ċ | | F366 | .D | F368 | . E | | | | F36A | . F | | F36C | . G | F36E | .н | | | | F370 | ï | | F372 | .u | F374 | .п<br>.к | | | | F376 | :ĉ | | F378 | . M | F37A | . N | | | | F37C | .0 | | F37E | .P | 009B | ABORT | | | | F6F2 | ADDRH | | F6F3 | ADDRL | FD80 | ALLOO | | | | FDAO | ALLO1 | | FDCO | ALLO2 | FDEO | ALLO3 | | | | FE00 | ALL04 | | FE80 | ALLO5 | FECO | ALLOS | | | | FEEO | ALLO7 | | 0068 | ASYNC | FFB3 | ATTRIB | | | | FA78 | AUTOBT | | FF3C | AVAILB | FF3E | AVAILT | | | | 0000 | B.BSY | | 0002 | B.CD | 0004 | B. 10 | | | | 0001 | B.MSG | | 0006 | B.PAR | 0003 | B.REQ | | | | 0007 | B.RST | | 0005 | B. SEL | 02CE | BAKSPC | | | | FFB1 | BASE | | 1353 | BAUD | FC5D | BAUD1 | | | | FC65 | BAUD2 | | 0000 | BAUDA | 000C | BAUDB | | | | 0018! | BBASE | | 040F | BBG | 032F | BELL | | | | 0331 | BELL1 | | 0028 | BELLOF | 0029 | BELLON | | | | 041B | BLOC | | FC49 | BLOCAD | 1436 | BLOCK | | | | 0061 | BLOFC | | 0061 | BLONC | 0035 | BLTIM | | | | 000F | BNDRY | | 1188 | BOOT | FC58 | BOOT 1 | | | | FC69 | BOOT2 | | FCA3 | BOOT3 | ED80 | BOOTBF | | | | FCDD | BOOTD | | FCD9 | BOOTER | 0080 | BOOTLD | | | | FCD4 | BOOTS | | FEE6 | BOTPTR | FCB2 | BRKFLG | | | | OOAE | BRKKEY | | 0000 | BSPACE | EE80 | BUFTOP | | | | 0004 | C.8IN | | 0004 | C.FIVE | 0007 | C.FLAW | | | | 0000 | C.FLPY | | 0004 | C.FMAT | 0006 | C.FTRK | | | | 000C | C.INIT | | 0007 | C.KEYM | 8000 | C.READ | | | | 0001 | C.RECAL | | 0003 | C.RQSN | 0002 | C.RSYN | | | | 0006 | C.SASI | | 000B | C.SEEK | 00E0 | C.TRAM | | | | 0000 | C.TRDY | | 0005 | C.TWO | 0005 | C.VTRK | | | | 000A | C.WRIT | | 0009 | C.WRPR | F31E | CCA | | | | F323 | CCA1 | | F324 | CCA2 | OOAF | ccs | | | | 00B1 | CCS1 | | F57A | CDD | F584 | CDDO | | | | F592 | CDD1 | | F59B | CDD2 | 0108 | CFINIT | | | | F6A5 | CFT | | F6A9I | CFTA | FBOE | CHECK | | | | FD00 | CHKOO | | FD20 | CHK01 | FD40 | CHK02 | | | | FD60 | СНКОЗ | | 0000 | CHK04 | 0000 | CHK05 | | | | 0000 | CHK06 | | 0000 | CHK07 | 03F5 | CHRDEL | | | | 03EA | CHRINI | | 03F0 | CHRIN2 | 03DC | CHRINS | | | | 0034 | CHROM1 | | 0035 | CHROM2 | FFB4 | CHRSAV | | | | FC55 | CLOC | | 0350 | CLR1 | FD21 | CLRBRK | | | | 001A | CLRCHR | | 0344 | CLREOL | 0361 | CLREOS | | | | 0341 | CLRLIN | | 001A | CLRS | 0365 | CLRS1 | | | | 037A | CLRS2 | | 0357 | CLRSCN | 0036 | CMDSIZ | | | | FAD8 | CMDTAB | | F767 | CNFDPB | F000 | COLD | | | | F775 | COMINP | | F770 | COMINS | F788 | COMOTS | | | | F77F | COMOUT | | 0518 | COMRES | 0518C | COMROM | | | | F091 | CONFG | | F08B | CONFIG | F009 | CONIN | | | _ | F790 | CONIOB | | F00C | CONOUT | F006 | CONST | | | Appendix F | | | | | | | |----------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------|-------------------------------------------------------------|--------------------------------------------|--------------------------------------------------------------|------------------------------------------------------------------------------------|----------------------------------------| | F4F2<br>F6EF<br>00A0<br>0080<br>0002<br>0001<br>001F<br>F626<br>F627<br>FF1C<br>FB37<br>FB50<br>F319 | FF34<br>F2FE<br>0002<br>FF20<br>FC59<br>F721 | FBD1<br>FC27<br>O1EF<br>O0C4<br>O0CC<br>O009<br>O2BD | FCAC<br>OOEF<br>F632<br>FB8F | FDCE<br>FC55<br>FD72<br>F450<br>000A<br>F490<br>F380 | FFE0<br>FFAE<br>0019<br>FF10<br>FFAC<br>F039<br>F6F5<br>F6EA<br>FC80<br>01F2 | 01B2<br>3C00<br>F2E9<br>F29C | | FLOP3<br>FLPFRM<br>FM.DDSS<br>FM.HARD<br>FM.SZ<br>FMDD<br>FORCE<br>GCA0<br>GCAA<br>GENVEC<br>GETLIN<br>GLIN4<br>GOLD | EXPVEC<br>FASTCRT<br>FDLUN<br>FIFO<br>FILL1<br>FIRST2 | DUMP4 ECHO ENATR ERR ERR3 ERRML ESCAPE | DSK3<br>DSKERR<br>DSM6<br>DSW<br>DUMP | DLN2 DLN2 DLOC DOC DPBBD DPBOFS DPBRG6 DRVTAB | CRTSTK CSRCHR CTC1 CTCVEC CURSOR DAYTI DCTRL DEFLPY DIRBUF DISATR | CRTD4<br>CRTMAX<br>CRTMVO<br>CRTON | | F4FC<br>0005<br>0004<br>0001<br>0007<br>0006<br>02D4<br>F634<br>FE50<br>FBDA<br>F097<br>FBDF<br>12DB | 0000<br>0001<br>FF30<br>FF32<br>F6F6<br>F4BD | FA08<br>F69B<br>0000!<br>00BC<br>00D4<br>001B<br>028A | 1367<br>03EF<br>00EF<br>FDB1<br>FB98 | FDD2<br>FC23<br>F490<br>F430<br>F470<br>F4A0<br>FC76 | 003C<br>0018<br>001A<br>0036<br>F6D7<br>F086<br>0000<br>F6EB<br>FFAF<br>FDC2 | 0169<br>3000<br>F296<br>F299 | | FLOP4<br>FM.DD<br>FM.OS<br>FM.SDDS<br>FM.UN<br>FMDDSS<br>FORSPC<br>GCA1<br>GCP<br>GETHEX<br>GETSEL<br>GNUM1<br>GOTO | FALSE<br>FBLUN<br>FIFCNT<br>FIFOUT<br>FIRST<br>FLOP1 | DVRLMT<br>ECR<br>ENTRY<br>ERR1<br>ERRM1<br>ESC<br>ESCTAB | DSKCMD<br>DSM4<br>DSM7<br>DTL<br>DUMP2 | DLN3<br>DMPFMT<br>DPB5D<br>DPB8S<br>DPBRG4<br>DPBRG7<br>DSK0 | CRTTOP CTC CTC2 CTLSIZ CWP DAYTIM DEBUG DEFLUN DIRCUR | CRTDVR<br>CRTMEM<br>CRTOF 1<br>CRTON 1 | | F506<br>0007<br>0006<br>0000<br>0003<br>0000<br>F61A<br>F63F<br>FE61<br>FB2C<br>FB3B<br>FBE4 | 0000<br>0000<br>FF31<br>1428<br>F708<br>F4DE | FD05<br>F0A2<br>0004<br>00C1<br>00DD<br>029B<br>0011 | F4B0<br>01EF<br>0000<br>F6D5<br>FBB4 | FDE1<br>02E7<br>F470<br>F390<br>F480<br>F1F1<br>FC7B | 0000<br>0018<br>0018<br>0254<br>FF56<br>FDEB<br>02C5<br>0017<br>01F3<br>FDC7 | F2A3<br>F2E7<br>F293<br>F2F1 | | FLOPS<br>FM.DDDS<br>FM.FV<br>FM.SDSS<br>FM.WR<br>FMDS<br>GCA<br>GCA2<br>GCP1<br>GETHLP<br>GLIN1<br>GNUM3<br>GPIOCA | FALUN<br>FCLUN<br>FIFIN<br>FILL<br>FIRST1<br>FLOP2 | EATKEY<br>EIRET<br>EOT<br>ERR2<br>ERRM2<br>ESCADR<br>ESCTBL | DSKDVR<br>DSM5<br>DSPACE<br>DTVPE<br>DUMP3 | DLN4 DNCSR DPB5S DPBASE DPBRG5 DPM DSK1 | CSPACE<br>CTCO<br>CTC3<br>CTLTAB<br>DAY<br>DBL<br>DEFCUR<br>DELLIN<br>DIS1<br>DLN1 | CRTLDIR<br>CRTMV<br>CRTOFF<br>CRTOUT | | ppendix F | The*End | d | | | | | |-----------|--------------|------------|--------------|--------------|--------------|--------------| | Ď | 000B | GPIOCB | 8000 | GPIODA | 000A | GPIODB | | ₹ | 177B | HELP | 001E | HELPKEY | FBF3 | HEXBIN | | = | FA3C | HOME | 0209 | HOMEUP | 001E | HOMSCR | | × | FF59 | HRS | F649 | ICC | F643 | ICCS | | 71 | F64D | ICCS1 | F066 | IDLE | FC5A | IN1 | | | FC61 | IN2 | FC77 | IN3 | FC79 | IN4 | | | 13CA | INCMD | F137 | INDEX | 0016 | INSLIN | | | 00E6 | INTAB | FF50 | INTSTK | 112B | IOBDVR | | | 0080 | IOBDVS | F770 | IOBLOC | 0003 | IOBYTE | | | F7AF | IOCONI | F796 | IOCONO | F7A3 | IOCONS | | | F7BB | IOLIST | F7CC | IOLSTS | FEEA | IPOINT | | | F643 | ISC | FAD6 | JPIX | 001F | KBDCTL | | | 001E | KBDDAT | FODB | KBDIN | FOD5 | KBDINI | | | FOCD | KBDST | F0E2 | KBMASK | 0082 | KDNLIN | | | F162 | KEY1 | F167 | KEY2 | F17F | KEY3 | | | F184 | KEY4 | F18F | KEY5 | F140 | KEYSRV | | | 0081 | KUPLIN | FFBD | LAST | F5F0 | LASTFM | | | FEOB | LBL | FE2E | LBL1 | FD05 | LCP | | | FD1D | LCP1 | FD30 | LCP2 | FD52 | LCP3 | | | FD49 | LCPA | FD4B | LCPB | F2B3 | LDIRI | | | F2B5 | LDIR2 | F2C4 | LDIR3 | 0418 | LDIRX | | | FFB2 | LEADIN | 000A | LF | 02F7 | LFEED | | | FF5C | LINBUF | 0388 | LIND1 | 039E | LIND2 | | | 039F | LIND3 | 037C | LINDEL | 03B7 | LINI 1 | | | 03C0 | LINI2 | 03CD | LINI3 | 03A4 | LININS | | | A800 | LOCALF | 0036 | LOWLITE | F333 | LSTATT | | | FD89 | LTL . | F6F1 | LUN | 0800 | LX1984 | | | 021C | M3TST | 022B | M4TST | 0232 | MSTST | | | F0E3 | MASK | FB22 | MDATA | FC5B | MDMP 1 | | | FC5E | MDMP2 | FC63 | MDMP3 | FC69 | MDMP3A | | | FC71 | MDMP3B | 12F2 | MEMDMP | F236 | MILO | | | F246 | MILOI | F250 | MILO2 | F258 | MILLI | | | F265 | MILL2 | F278 | MILL3 | F27C | MILL4 | | | F27E | MILL5 | F281 | MILL6 | F1FD | MILLI | | | FF50 | MILSEC | FF5A | MINS | F5AF | MLU | | | 01DF | MODE | 01E1 | MODE 1 | F000 | MONITR | | | FF57 | MONTH | 00E5 | MOVLN | F5C2 | MPA | | | F5D7 | MPA1 | F5DA | MPA2 | F5E6 | MPA21 | | | F5E9 | MPA22 | F606 | MPA3 | F610 | MPA4 | | | F613 | MPA5 | F559 | MTRADR | 0184 | MULTI | | | F6F4<br>0040 | NBLK | 0066 | NMI | 0200 | NONO | | | 0010 | NT4<br>NT7 | 0020<br>0028 | NT5<br>NTRK5 | 0010<br>004D | NT6<br>NTRK8 | | | F13F | NULINT | 0028 | NUMCON | F502 | NUMUNT | | | 4000 | O.AUTO | 0400 | O.BAUD | 0800 | O.DDVR | | | 0020 | O.DISK | 0010 | O.ESCT | 0004 | O.FILL | | | 2000 | O.HELP | 0200 | O. INPC | 0004 | O.MOVE | | | 0100 | O.OUTC | 1000 | O.PROT | 0040 | O.RAMT | | | 8000 | O.RESV | 0001 | O.TERM | 0008 | O.TYPE | | | 0080 | O.VERF | F6F0 | OPCODE | FEEC | OPOINT | | | BFFF | OPTIONS | 13F1 | OUTCMD | FE9B | OUTCRT | | | F288 | OUTCUR | FC20 | OUTPUT | 0007 | P. ACKN | | | 0000 | P.AUTO | 0006 | P.ONLN | 0007 | P.RDVI | | | 0004 | P.RDYO | 0002 | P.STRB | F59F | P2L | | | FB5D | PARAO | FB6C | PARAI | FB71 | PARA2 | | _ | FB76 | PARA4 | FFB5 | PARAM1 | FFB7 | PARAM2 | | 3 | . 570 | | . 1 55 | | | · ANAME | | | | | | | | | | | F7DC | PIOOUT | F7F4 | PIOSTO | FCB1 | PKI | |----------|-------|---------|-------|---------|------|---------| | | FCC9 | PKI1 | FCDF | PKI2 | FCF3 | PK13 | | | FCF6 | PKI4 | FCFE | PKI5 | FD06 | PKI6 | | | FDOE | PKI7 | FD14 | PKI8 | FD1B | PKI9 | | | FC3D | PNEXT | FE78 | PORTS | FD40 | PRC | | | FAAC | PRMT1 | FA62 | PROMPT | FC68 | PROT 1 | | | FC6F | PROT2 | 1459 | PROTO | 0000 | PRS | | | 0002 | PRS1 | 003B | PRS2 | 0061 | PRS3 | | | 0070 | PRS4 | OOAC | PRS5 | F339 | PRVATI | | | FC1B | PUT2HS | FC03 | PUT2HX | FB29 | PUT2J | | | FC16 | PUT4HS | FCOC | PUTNIB | FF00 | RAM | | | 041B | RBASE | FE6E | RCP | FE73 | RCPA | | | F647 | RDC | F605 | RDID | F61B | RDID1 | | | F6DC | RDONLY | F4E7 | RDOP | FA4A | RDWR | | | F4FE | RDWRA | F4F6 | RDWRS | FA48 | READ | | | F641 | RECAL | F6E9 | RECLUN | F130 | REMOVE | | | F6AD | RESET | 0C55 | RESLEN | F07C | RESTAR | | | FC55 | RESTOP | FIEF | RETINS | 02F2 | RETURN | | | FOA1 | RETV1 | F09A | RETVAL | F5F6 | RETZR | | | 0191 | REV | F1E9 | RFI | EE00 | RGDBUR | | | 0003 | RGLUN | F6E8 | RGRECAL | F708 | RIGDPE | | | 00B2 | RMTALF | 00B1 | RMTTOG | 0000 | ROM | | | 1800 | ROMSIZ | 17E1 | ROMTOP | FA08 | ROTOP | | | F5F8 | RSE | F603 | RSE1 | F332 | RSTATI | | | FFE2 | RSTHL | FFE4 | RSTPC | FFE0 | RSTSP | | | 0001 | RTK4 | 0041 | RTK5 | 0061 | RTK6 | | | 0071 | RTK7 | 1800 | RX1984 | 0005 | S.AUTO | | | 0004 | S.AUTOR | 0007 | S.LECHO | 0006 | S.RECH | | | F480 | SA1403 | F4C0 | SASO | F4B2 | SASOA | | | F4F3 | SAS1 | F4F6 | SAS2 | 0012 | SASIC | | | 0010 | SASID | 0300 | SASIDL | 0012 | SASIS | | | F470 | SASSTR | F1EC | SAVSTK | 0014 | SCROL | | | 009E | SCRPRT | 01C3 | SEARCH | F4E6 | SECLE | | | FF5B | SECS | FA3E | SEEK | F5DE | SEEKO | | | F5EB | SEEK1 | F5ED | SEEK2 | F5EF | SEEK3 | | | F5A3 | SEEKX | 0518! | SEGA | F5B9 | SEKO | | | F5C4 | SEK1 | FA39 | SEL1 | F578 | SEL 1W | | | F585 | SEL2 | F591 | SEL3 | F598 | SELDEN | | | F596 | SELDNS | F510 | SELEC | FA17 | SELECT | | | F50B | SELER1 | F42A | SELERR | F360 | SELTAE | | | FA5A | SELTBL | F544 | SELUNT | 0104 | SETBL | | | FD2C | SETBRK | 021F | SETCOL | FOA4 | SETCO | | | F284 | SETCUR | 01DD | SETGRA | 0109 | SETIN | | | OICF | SETLOW | 01F7 | SETMSK | F337 | SETPRY | | | 0210 | SETROW | 0205 | SETXY | 0209 | SETXY | | 2 | FC73 | SIGNI | FC81 | SIGN2 | FC88 | SIGNS | | × | FC9E | SIGN3A | FCA6 | SIGN4 | FC55 | SIGNO | | × | F6CE | SIM | EFOO | SIOBUF | 0006 | SIOCPA | | 3 | 0007 | SIOCPB | 0004 | SIODPA | 0005 | SIODPE | | ٥ | FEE1 | SIOI1 | FOFO | SIOIN | FOED | SIOIN | | Appendix | FED6 | SIOINC | FE7F | SIOINP | FE77 | SIOINS | | _ | . 250 | 0.01 | | | | 3.0114. | SIOINS | , G | 1763# | | | | | | | | | | |--------|-------|---------|-------|------|------|------|------|------|-------|------| | .н | 1764# | | | | | | | | | | | ï | 1766# | | | | | | | | | | | ij | 1767# | | | | | | | | | | | .ĸ | 1768# | | | | | | | | | | | Ξ. | 1769# | | | | | | | | | | | . M | 1771# | | | | | | | | | | | . N | 1772# | | | | | | | | | | | .0 | 1773# | | | | | | | | | | | .P | 1774# | | | | | | | | | | | ABORT | 96# | 815 | | | | | | | | | | ABOVE | 177# | 562 | 681 | 1701 | 1737 | 2415 | 3126 | 3142 | 3237 | 4872 | | ADDRH | 2852 | 3035# | | | | 24.0 | 0.20 | 0.42 | 020, | 40,2 | | ADDRL | 3036# | . 0000# | | | | | | | | | | ALLOO | 1803# | 1820 | | | | | | | | | | ALL01 | 1804# | 1825 | | | | | | | | | | ALL02 | 1805# | 1830 | | | | | | | | | | ALL03 | 1806# | 1835 | | | | | | | | | | ALLO4 | 1807# | 1840 | | | | | | | | | | ALL05 | 1808# | 1845 | | | | | | | | | | ALL06 | 1809# | 1850 | | | | | | | | | | ALLO7 | 1810# | 1855 | | | | | | | | | | ASYNC | 73# | 526 | | | | | | | | | | ATTRIB | 1179 | 1266 | 4952# | | | | | | | | | AUTOBT | 3251# | | | | | | | | | | | AVAILB | 446 | 4919# | | | | | | | | | | AVAILT | 4920# | | | | | | | | | | | B.BSY | 2514# | | | | | | | | | | | B.CD | 2516# | 2943 | | | | | | | | | | B.10 | 2518# | | | | | | | | | | | B.MSG | 2515# | 2922 | | | | | | | | | | B.PAR | 2520# | 2940 | | | | | | | | | | B.REQ | 2517# | 2938 | | | | | | | | | | B.RST | 2521# | 2978 | | | | | | | | | | B.SEL | 2519# | 2871 | | | | | | | | | | BAKSPC | 1345 | 1445# | | | | | | | | | | BASE | 1132 | 1496 | 1508 | 1564 | 1571 | 1592 | 1623 | 4702 | 4950# | | | BAUD | 3303 | 4047# | | | | | | | | | | BAUD1 | 4053 | 4055# | | | | | | | | | | BAUD2 | 4057 | 4059# | | | | | | | | | | | | | | | | | | | | | | 88 | ASE | 243 | 263# | 266 | | | | | | | | | | |----|-------|-------|-------|-------|-------|-------|-------|-------|------|-------|------|------|-------| | BB | | 1503 | 1588 | 1616 | 1692# | | | | | | | | | | BE | | 1344 | 1529# | | 1002# | | | | | | | | | | | LL1 | 1530# | 1537 | | | | | | | | | | | | | LLOF | 66# | 1533 | | | | | | | | | | | | | LLON | 67# | 1530 | | | | | | | | | | | | | LOW | 171# | 269 | 1162 | 4866 | | | | | | | | | | BL | | 227# | 271 | 563# | 1164 | 1702# | 3572 | 3663 | 3787 | 2050 | 2077 | 4000 | 4047 | | | | 4073 | 4135 | 4170 | 4190 | 4233 | 4254 | 4273 | 4299 | 3958 | 3977 | 4003 | 4047 | | | | 4868 | | 4881 | 4190 | 4233 | 4254 | 42/3 | 4299 | 4327 | 4387 | 4820 | 4861 | | | 0040 | | 4873# | | | | | | | | | | | | | OCAD | 3554# | 4259 | 4278 | | | | | | | | | | | | ock | 3304 | 4254# | | | | | | | | | | | | | OFC | 102# | 1534 | | | | | | | | | | | | | ONC ' | 101# | 1531 | | | | | | | | | | | | | TIM | 100# | 1529 | | | | | | | | | | | | | DRY | 1742# | 1743 | 1744 | 1744 | | | | | | | | | | во | | 3302 | 3313 | 3787# | | | | | | | | | | | BO | OT1 | 3790# | 3795 | | | | | | | | | | | | BO | OT2 | 3793 | 3801# | | | | | | | | | | | | BO | 0T3 | 3825 | 3834# | | | | | | | | | | | | BO | OTBF | 35# | 132 | 3150 | 3834 | 3838 | 3902 | 3907 | 3910 | | | | | | BO | OTD | 3803 | 3863# | | | | | | | | | | | | BO | OTER | 3808 | 3861# | | | | | | | | | | | | BO | OTLD | 34# | 3837 | 3853 | | | | | | | | | | | | OTS | 3823 | 3855# | 3899 | | | | | | | | | | | 80 | TPTR | 4586 | 4595 | 4643 | 4652 | 4658 | 4662 | 4806# | | | | | | | | KFLG | 4457# | 4511 | 4513 | | | | | | | | | | | | KKEY | 4402# | 4509 | 10.0 | | | | | | | | | | | BS | | 191# | 239 | 270 | 1163 | 4867 | | | | | | | | | | PACE | 231# | 270 | 270 | 270# | 563 | 563 | 563# | 682 | 682 | 1163 | 1163 | 1163# | | - | | 1702 | 1702 | 1702# | 1738 | 1738 | 2416 | 2416 | 3127 | 3127 | 3143 | 3143 | 3238 | | | | 3238 | 3572 | 3572 | 3663 | 3663 | 3787 | 3787 | 3958 | 3958 | 3977 | 3977 | 4003 | | | | 4003 | 4047 | 4047 | 4073 | 4073 | 4135 | 4135 | 4170 | 4170 | 4190 | 4190 | 4233 | | | | 4233 | 4254 | 4254 | 4273 | 4273 | 4299 | 4299 | 4327 | 4327 | 4387 | 4387 | 4820 | | | | 4820 | 4861 | 4861 | 4867 | 4867 | 4867# | 4873 | 4873 | | | | 4020 | | | FTOP | 4410# | 4679 | 4697 | 4807 | 4007 | 400/# | 46/3 | 48/3 | 4873# | 4878 | 4878 | | | | BIN | 2008# | 2147 | 2187 | 2327 | | | | | | | | | | | FIVE | 80# | | | 2321 | | | | | | | | | | | | | 3593 | 3596 | | | | | | | | | | | | FLAW | 2547# | | | | | | | | | | | | | | FLPY | 2556# | 3028 | | | | | | | | | | | | | FMAT | 2544# | 2887 | | | | | | | | | | | | | FTRK | 2546# | | | | | | | | | | | | | | INIT | 2552# | | | | | | | | | | | | | | KEYM | 78# | | | | | | | | | | | | | | READ | 2548# | 2605 | 2747 | 3015 | | | | | | | | | | | RECAL | 2541# | 2862 | 3025 | | | | | | | | | | | С. | RQSN | 2543# | | | | | | | | | | | | | | | | | | | | | | | | | | | pendix F | C.WRIT | 2550# | 2603 | 2633 | | | | | | | | | | |-----------|-------|-------|-------|------|------|------|------|------|------|------|------|------| | C.WRPR | 2549# | | | | | | | | | | | | | CCA | 957 | 1131# | 1298 | 1615 | | | | | | | | | | CCA1 | 1134# | 1646 | | | | | | | | | | | | CCA2 | 1135# | 1136 | 1643 | | | | | | | | | | | CCS | 328 | 359 | 370# | | | | | | | | | | | CCS1 | 371# | 378 | | | | | | | | | | | | CDD | 2691 | 2740# | | | | | | | | | | | | CDDO | 2743 | 2745# | | | | | | | | | | | | CDD1 | 2750# | 2753 | | | | | | | | | | | | CDD2 | 2751 | 2754# | | | | | | | | | | | | CFINIT | 437# | 443 | | | | | | | | | | | | CFT | 2876 | 2935 | 2957# | | | | | | | | | | | CFTA | 2959# | 2960 | 3054 | | | | | | | | | | | CHECK | 3330# | 4035 | 4214 | 4282 | | | | | | | | | | CHKOO | 1794# | 1820 | | | | | | | | | | | | CHK01 | 1795# | 1825 | | | | | | | | | | | | CHK02 | 1796# | 1830 | | | | | | | | | | | | CHKO3 | 1797# | 1835 | | | | | | | | | | | | CHK04 | 1798# | 1840 | | | | | | | | | | | | CHK05 | 1799# | 1845 | | | | | | | | | | | | CHK06 | 1800# | 1850 | | | | | | | | | | | | CHK07 | 1801# | 1855 | | | | | | | | | | | | CHRDEL | 1398 | 1672# | | | | | | | | | | | | CHR I N 1 | 1661# | 1665 | | | | | | | | | | | | CHRIN2 | 1660 | 1666# | | | | | | | | | | | | CHRINS | 1400 | 1652# | | | | | | | | | | | | CHROM 1 | 70# | 1249 | | | | | | | | | | | | CHROM2 | 71# | 1242 | 1246 | | | | | | | | | | | CHRSAV | 1168 | 1194 | 4953# | | | | | | | | | | | CLOC | 366 | 3268 | 3570# | 3572 | 3572 | 3573 | 3663 | 3663 | 3663 | 3663 | 3664 | 3778 | | | 3787 | 3787 | 3787 | 3788 | 3958 | 3958 | 3958 | 3958 | 3959 | 3977 | 3977 | 3977 | | | 3978 | 4003 | 4003 | 4003 | 4004 | 4047 | 4047 | 4047 | 4048 | 4073 | 4073 | 4073 | | | 4074 | 4135 | 4135 | 4135 | 4136 | 4170 | 4170 | 4170 | 4171 | 4190 | 4190 | 4190 | | | 4191 | 4233 | 4233 | 4233 | 4234 | 4254 | 4254 | 4254 | 4255 | 4273 | 4273 | 4273 | | | 4274 | 4299 | 4299 | 4299 | 4300 | 4327 | 4327 | 4327 | 4328 | 4387 | 4387 | 4387 | | | 4388 | 4820 | 4820 | 4820 | 4820 | 4821 | 4861 | 4861 | 4861 | 4862 | 4867 | 5007 | | CLR1 | 1554# | 1556 | | | | | | | | | | | | CLRBRK | 4459 | 4512# | | | | | | | | | | | | CLRCHR | 4392# | | | | | | | | | | | | | CLREOL | 1361 | 1397 | 1546# | 1569 | | | | | | | | | | CLREOS | 1354 | 1396 | 1569# | | | | | | | | | | | 02200 | | | | | | | | | | | | | | CLKS | 30# | 3010 | 4007 | 4421 | | | | | | | | | |------------------|--------------|---------------|-------|-------|------|------|-------|------|-------|--------------|------|------| | CLRS1<br>CLRS2 | 1571# | 1581<br>1582# | | | | | | | | | | | | | 1578<br>1363 | | 1500# | | | | | | | | | | | CLRSCN<br>CMDSIZ | 3328# | 1410 | 1562# | | | | | | | | | | | CMDTAB | 364 | 3260 | 3301# | 3328 | | | | | | | | | | CNFDPB | 3057 | 3062 | 3075 | 3116# | | | | | | | | | | COLD | 564# | 3062 | 30/5 | 3110# | | | | | | | | | | COMIND | 595 | 3677# | 3679 | 3725 | | | | | | | | | | COMIND | 595<br>594 | 3670# | 3679 | 3/25 | | | | | | | | | | COMOTS | 594<br>597 | 3685 | 3693# | 3744 | | | | | | | | | | COMOUT | 596 | 3685# | 3686 | 3708 | 3734 | | | | | | | | | COMRES | 234# | 240 | 267# | 270 | 563# | 1162 | 1702# | 4867 | 4070# | | | | | COMROM | 240# | 270# | 1163# | 4867# | 563# | 1163 | 1702# | 4867 | 4873# | | | | | CONFG | 623# | 3580 | 1163# | 486/# | | | | | | | | | | CONFIG | 584 | 620# | | | | | | | | | | | | CONFIG | 567# | 3437 | 3440 | 3525 | 3656 | 4013 | 4147 | 4366 | **** | | | | | CONTOB | 3701# | 3707 | 3716 | 3724 | 3050 | 4013 | 4147 | 4366 | 4460 | | | | | CONDUT | 568# | 3430 | 3433 | 3511 | 3528 | 3548 | 4014 | 4360 | 4363 | 4368 | 4373 | | | CONST | 566# | 3435 | 3654 | 4364 | 4448 | 3546 | 4014 | 4360 | 4363 | 4368 | 43/3 | | | CONTBL | 436 | 655 | 4965# | 4304 | 4440 | | | | | | | | | CONTRL | 1191 | 1325# | 4905# | | | | | | | | | | | CPB | 3060 | 3074# | | | | | | | | | | | | CPB1 | 3077 | 3081# | | | | | | | | | | | | CPB2 | 3083# | 3093 | | | | | | | | | | | | CPB3 | 3102# | 3113 | | | | | | | | | | | | CR | 86# | 995 | 3244 | 3252 | 3353 | 3361 | 3386 | 3388 | 3438 | 2441 | 0507 | 0000 | | CH | 3635 | 3643 | 3650 | 3792 | 3794 | 3796 | 4007 | 4026 | 4028 | 3441<br>4150 | 3537 | 3629 | | | 4369 | 4443 | 4538 | 4544 | 4550 | 4556 | 4827 | 4832 | 4028 | 4841 | 4354 | 4361 | | CRLF | 3282 | 3341 | 3443 | 3536# | 4090 | 4142 | 4827 | 4832 | 4836 | 4841 | 4847 | | | CRTBAS | 40# | 1137 | 1465 | 1477 | 4708 | 4142 | | | | | | | | CRTD1 | 1179# | 1315 | 1465 | 14// | 4708 | | | | | | | | | CRTD2 | 1173 | 1178 | 1191# | | | | | | | | | | | CRTD3 | 1186 | 1190 | 1192# | | | | | | | | | | | CRTD4 | 1203 | 1206# | 1152# | | | | | | | | | | | CRTDVR | 1117 | 1167# | | | | | | | | | | | | CRTLDIR | 581 | 1041# | 3852 | 4089 | | | | | | | | | | CRTMAX | 39# | 41 | 308 | 4005 | | | | | | | | | | CRTMEM | 38# | 39 | 40 | 305 | 307 | 308 | 385 | 426 | 428 | 1562 | | | | CRTMV | 1045 | 1077# | 40 | 505 | 007 | 000 | 505 | 420 | 420 | 1502 | | | | CRTMVO | 1071 | 1073 | 1078# | | | | | | | | | | | CRTOF1 | 1020# | | 1010# | | | | | | | | | | | CRTOFF | 832 | 1018# | 1078 | 1119 | 3278 | 3576 | | | | | | | | CRTON | 940 | 1010 | 1027# | 1044 | 1115 | 3275 | | | | | | | | CRTONI | 1022# | 1030 | | | | 02/0 | | | | | | | | CRTOUT | 568 | 1091# | | | | | | | | | | | | CRTSTK | 1042 | 1110 | 4975# | | | | | | | | | | | CRTTOP | 41# | 1467 | 1475 | | | | | | | | | | | 3., | | | | | | | | | | | | | pendix F | | 4387<br>4867 | 4387<br>4867 | 4387#<br>4867# | 4387#<br>4873 | 4820<br>4873 | 4820<br>4878 | 4820#<br>4878 | 4820# | 4861 | 4861 | 4861# | 4861# | |--------|--------------|--------------|----------------|---------------|--------------|--------------|---------------|-------|-------|-------|-------|-------| | CSRCHR | 1195 | 1317 | 1320 | 4948# | 4073 | 4070 | 4070 | | | | | | | CTC | 57# | | | | | | | | | | | | | CTCO | 58# | 476 | | | | | | | | | | | | CTC1 | 59# | 480 | 675 | 991 | | | | | | | | | | CTC2 | 60# | 484 | | | | | | | | | | | | CTC3 | 61# | 488 | | | | | | | | | | | | CTCVEC | 409 | 478 | 4900# | | | | | | | | | | | CTLSIZ | 1370# | | | | | | | | | | | | | CTLTAB | 1330 | 1342# | 1370 | | | | | | | | | | | CURSOR | 425 | 1167 | 1192 | 4703 | 4947# | | | | | | | | | CWP | 2617 | 3004# | | | | | | | | | | | | DAY | 615 | 4937# | | | | | | | | | | | | DAYTI | 583# | 2089 | 3052 | | | | | | | | | | | DAYTIM | 583 | 615# | | | | | | | | | | | | DBL | 4477 | 4640# | | | | | | | | | | | | DCTRL | 2683 | 2735 | 3038# | | | | | | | | | | | DEBUG | 25# | 29 | 30 | 123 | 128 | | | | | | | | | DEFCUR | 1342 | 1434# | | | | | | | | | | | | DEFLPY | 2837 | 3028# | | | | | | | | | | | | DEFLUN | 2785 | 2828 | 3029# | | | | | | | | | | | DELLIN | 4391# | | | | | | | | | | | | | DIRBUF | 1793# | 1819 | 1824 | 1829 | 1834 | 1839 | 1844 | 1849 | 1854 | | | | | DIRCUR | 1005 | 1011 | 1014 | 4949# | | | | | | | | | | DISI | 1266# | | | | | | | | | | | | | DISATR | 1265# | 1412 | | | | | | | | | | | | DLN | 4609# | 4646 | | | | | | | | | | | | DLN1 | 4613# | 4615 | | | | | | | | | | | | DLN2 | 4614 | 4616# | | | | | | | | | | | | DLN3 | 4620# | 4635 | | | | | | | | | | | | DLN4 | 4624 | 4630# | | | | | | | | | | | | DLOC | 228# | 564 | 682# | 683 | 1163# | 1703 | 1738# | 1739 | 2416# | 2417 | 3123# | 3123 | | | 3124 | 3127# | 3128 | 3143# | 3144 | 3238# | 3239 | 3572# | 4874 | 4878# | 4881 | | | DMPFMT | 3417 | 3419 | 3421 | 3515# | | | | | | | | | | DNCSR | 1472# | 1495 | 1579 | | | | | | | | | | | DOC | 4533 | 4537 | 4543 | 4561# | | | | | | | | | | DPB5D | 1943# | | | | | | | | | | | | | DPB5S | 1923# | 3603 | | | | | | | | | | | | DPB8D | 1901# | | | | | | | | | | | | | DPB8S | 1882# | 2388 | 2727 | | | | | | | | | | | DPBASE | 1817# | 2100 | 2677 | 3099 | | | | | | | | | | FCLUN | 2527# | | | | | | |----------|-------|-------|-------|------|-------|------| | FDLUN | 2528# | 2765 | | | | | | FIFCNT | 417 | 689 | 769 | 814 | 4907# | | | FIFIN | 823 | 4908# | | | | | | FIFO | 774 | 4906# | | | | | | FIFOUT | 771 | 4909# | | | | | | FILL | 3307 | 4233# | | | | | | FILL1 | 4238# | 4244 | | | | | | FIRST | 2669 | 3045# | 3050 | | | | | FIRST1 | 3057# | 3066 | | | | | | FIRST2 | 3061 | 3069# | | | | | | FLOP1 | 2025# | 2080 | | | | | | FLOP2 | 2042 | 2046 | 2048# | | | | | FLOP3 | 2060 | 2063# | | | | | | FLOP4 | 2069# | 2072 | | | | | | FLOP5 | 2029 | 2035 | 2075# | | | | | FLPFRM | 2836 | 3031# | | | | | | FM.DD | 2001# | 2003 | 2370 | 2391 | | | | FM.DDDS | 2568# | 2702 | 2765 | | | | | FM.DDSS | 2003# | 2325 | | | | | | FM.DS | 2000# | 2379 | | | | | | FM.FV | 2002# | 2329 | 2394 | | | | | FM. HARD | 2569# | 2766 | 2767 | 2768 | 2769 | 2805 | | FM.SDDS | 2566# | 2763 | | | | | | FM. SDSS | 2565# | 2762 | | | | | | FM.SZ | 2562# | 2705 | | | | | | FM.UN | 1999# | 2003 | 2366 | 2367 | 2371 | | | FM.WR | 2563# | | | | | | | FMDD | 2561# | 2703 | 2709 | | | | | FMDDSS | 2567# | 2764 | 2807 | | | | | FMDS | 2560# | 2686 | 2817 | | | | | FORCE | 4394# | 4626 | | | | | | FORSPC | 1349 | 1453# | | | | | | GCA | 2860# | 2889 | | | | | | GCA0 | 2864 | 2866# | | | | | | GCA1 | 2873# | 2877 | | | | | | GCA2 | 2875 | 2878# | | | | | | GCAA | 2866 | 2867# | 3055 | | | | | GCP | 4469 | 4481 | 4702# | | | | | GCP1 | 4711# | 4712 | | | | | | GENVEC | 4902# | | | | | | | GETHEX | 3395 | 3456# | | | | | | ō | GLIN1 | 3357# | 3369 | 3380 | | | | | |----------|------------------|------------|---------------|------|-------|------|-------|------| | | GLIN4 | 3364 | 3373# | | | | | | | Ž | GNUM 1 | 3459# | 3469 | | | | | | | pendix F | GNUM3 | 3464# | | | | | | | | × | GOLD | 1122# | 1170 | 1276 | 1318 | 1498 | 1666 | 1682 | | 71 | GOTO | 3308 | 3958# | | .0.0 | 1450 | 1000 | 1002 | | | GPIOCA | 51# | 531 | | | | | | | | GPIOCE | 53# | 536 | | | | | | | | GPIODA | 50# | 3755 | | | | | | | | GPIODB | 52# | 541 | 3756 | 3758 | 3760 | 3768 | | | | HELP | 3301 | 4820# | 0.00 | 0,00 | 0,00 | 0,00 | | | | HELPKEY | 94# | 3358 | 3526 | | | | | | | HEXBIN | 3467 | 3476# | 4016 | 4029 | | | | | | HOME | 574 | 3186# | 3820 | 4023 | | | | | | HOMEUP | 1367 | 1440# | 0010 | | | | | | | HOMSCR | 4393# | 4472 | 4484 | | | | | | | HRS | 4940# | 4472 | 4404 | | | | | | | ICC | 2293 | 2298# | | | | | | | | ICCS | 2622 | 2748 | 2838 | 2886# | 2986 | | | | | ICCS1 | 2891# | 2894 | 2030 | 2000# | 2500 | | | | | IDLE | 598# | 702 | 722 | 732 | 2305 | 2957 | | | | INI | 4142# | 4159 | 122 | 132 | 2305 | 2957 | | | | IN2 | 4145# | 4149 | | | | | | | | IN3 | 4151 | 4156# | | | | | | | | IN4 | 4153 | 4158# | | | | | | | | INCMD | 3310 | 4135# | | | | | | | | INDEX | 772# | 824 | | | | | | | | INSLIN | 4390# | 824 | | | | | | | | INTAB | 330 | 404# | | | | | | | | INTSTK | 796 | 841 | 922 | 4926# | | | | | | IOBDVR | 3663# | 3848 | 922 | 4920# | | | | | | IOBDVS | 447 | 3775# | 3778 | 2050 | | | | | | | | | | 3850 | 0040 | | | | | IOBLOC<br>IOBYTE | 447<br>33# | 2413# | 3666 | 3775 | 3849 | 20.40 | | | | IOCONI | 590 | 3701<br>3724# | 3732 | 3742 | 3898 | 3949 | | | | | | | | | | | | | | IOCONO | 591 | 3707# | | | | | | | | IOCONS | 589 | 3716# | | | | | | | | IOLIST | 592 | 3732# | | | | | | | | IOLSTS | 593 | 3742# | | | | | | | | IPOINT | 4770 | 4778 | 4787 | 4809# | | | | | | ISC | 2218 | 2291# | 2344 | 2363 | | | | | | JPIX | 3289 | 3299# | 3970 | | | | | | | KBDCTL | 65# | 469 | | | | | | | | KBDDAT | 64# | 349 | 800 | | | | | | | KBDIN | 567 | 703# | 3727 | | | | | | | KBDIN1 | 702# | 704 | | | | | | | | KBDST | 566 | 689# | 703 | 3719 | | | | | | | | | | | | | | | KETSKV | 400 | 134# | | _ | | | | | | | | | 4 | |---------|---------------|---------------|-------|------|------|------|------|------|------|------|------|------|---| | KUPLIN | 4396# | 4467 | | | | | | | | | | | | | LAST | 3983 | 3997 | 4961# | | | | | | | | | | | | LASTFM | 2684 | 2831# | 2832 | 2952 | | | | | | | | | | | LBL | 4488 | 4657# | | | | | | | | | | | | | LBL1 | 4667 | 4672# | | | | | | | | | | | | | LCP | 3847 | 3897# | | | | | | | | | | | | | LCP1 | 3903 | 3908# | | | | | | | | | | | | | LCP2 | 3915 | 3918# | | | | | | | | | | | | | LCP3 | 3933# | 3939 | | | | | | | | | | | | | LCPA | 3922 | 3927# | | | | | | | | | | | | | LCPB | 3924 | 3929# | | | | | | | | | | | | | LDIRI | 1047# | 1075 | | | | | | | | | | | | | LDIR2 | 1046 | 1048# | | | | | | | | | | | | | LDIR3 | 1053 | 1055# | | | | | | | | | | | | | LDIRX | 1684 | 1695# | | | | | | | | | | | | | LEADIN | 1171 | 1325 | 4951# | | | | | | | | | | | | LF | 85# | 993 | 3244 | 3537 | 3629 | 3630 | 3635 | 3643 | 3650 | 4354 | 4362 | 4371 | | | Lr . | 4400 | 4443 | 4542 | 4554 | 4569 | 4575 | 4827 | 4832 | 4837 | 4841 | 4848 | 43/1 | | | LFEED | 1189 | 1347 | 1489# | 4554 | 4569 | 45/5 | 4027 | 4032 | 4637 | 4041 | 4040 | | | | LINBUF | 1057 | 1065 | 1693 | 3247 | 3251 | 3283 | 3352 | 3354 | 3789 | 4076 | 4111 | 4580 | | | LINBUR | 4672 | 4946# | 1693 | 3241 | 3251 | 3263 | 3352 | 3354 | 3/89 | 4076 | 4111 | 4580 | | | LINDI | 1593# | 1603 | 1605 | | | | | | | | | | | | LIND1 | 1593# | 1606# | 1605 | | | | | | | | | | | | | | | | | | | | | | | | | | | LIND3 | 1607#<br>1399 | 1638<br>1587# | | | | | | | | | | | | | LINDEL | | | | | | | | | | | | | | | LINI1 | 1624# | 1635<br>1629# | | | | | | | | | | | | | LINI2 | 1627 | | | | | | | | | | | | | | LINI3 | 1625 | 1636# | | | | | | | | | | | | | LININS | 1401 | 1613# | | | | | | | | | | | | | LOCALF | 4400# | 4499 | | | | | | | | | | | | | LOWLITE | 72# | 1239 | | | | | | | | | | | | | LSTATT | 1147# | 1154 | | | | | | | | | | | | | LTL | 4476 | 4574 | 4580# | | | | | | | | | | | | LUN | 2784 | 3034# | | | | | | | | | | | | | LX1984 | 32# | 358 | 361 | | | | | | | | | | | | MSTST | 1288 | 1300# | | | | | | | | | | | | | M4TST | 1301 | 1312# | | | | | | | | | | | | | M5TST | 13-13 | 1317# | | | | | | | | | | | | | MASK | 620 | 709# | 1174 | 1274 | | | | | | | | | | | MDATA | 3333 | 3341# | 4005 | | | | | | | | | | | | | | | | | | | | | | | | | | | 0 | MDMP3 | 3982 | 3987# | | | | | | | | | | | |--------------|---------|-------|-------|-------|------|------|------|------|------|------|------|------|------| | Ō | MDMP3A | 3991# | 3993 | | | | | | | | | | | | ₾ | MDMP3B | 3985 | 3996# | | | | | | | | | | | | $\mathbf{z}$ | MEMDMP | 3305 | 3977# | | | | | | | | | | | | pendix | MESSAGE | 4991# | 5011 | 5012 | 5013 | 5014 | 5015 | 5016 | 5017 | 5018 | 5019 | 5020 | 5021 | | Ĥ | | 5022 | | | | | | | | | | | | | 711 | MILO | 944 | 953# | | | | | | | | | | | | | MILOI | 964# | 969 | | | | | | | | | | | | | MIL02 | 968 | 970# | | | | | | | | | | | | | MILL1 | 952 | 975# | | | | | | | | | | | | | MILL2 | 937 | 982# | | | | | | | | | | | | | MILL3 | 989 | 993# | | | | | | | | | | | | | MILL4 | 984 | 995# | | | | | | | | | | | | | MILL5 | 994 | 996# | | | | | | | | | | | | | MILL6 | 932 | 935 | 981 | 998# | | | | | | | | | | | MILLI | 410 | 920# | | | | | | | | | | | | | MILSEC | 925 | 927 | 4930# | | | | | | | | | | | | MINS | 4941# | | | | | | | | | | | | | | MLU | 2609 | 2670 | 2778# | | | | | | | | | | | | MODE | 1247 | 1250# | | | | | | | | | | | | | MODE 1 | 1244 | 1251# | | | | | | | | | | | | | MONITR | 37# | 228 | 310 | 354 | 355 | 3572 | 3663 | 3787 | 3845 | 3958 | 3977 | 4003 | | | | 4047 | 4073 | 4135 | 4170 | 4190 | 4233 | 4254 | 4273 | 4299 | 4327 | 4387 | 4411 | | | | 4820 | 4861 | 4875 | 4881 | | | | | | | | | | | MONTH | 4938# | | | | | | | | | | | | | | MOVLN | 243 | 266# | | | | | | | | | | | | | MPA | 2620 | 2745 | 2801# | | | | | | | | | | | | MPA1 | 2808 | 2814# | | | | | | | | | | | | | MPA2 | 2812 | 2816# | | | | | | | | | | | | | MPA21 | 2821 | 2823# | | | | | | | | | | | | | MPA22 | 2818 | 2826# | | | | | | | | | | | | | MPA3 | 2835 | 2840# | | | | | | | | | | | | | MPA4 | 2847# | 2848 | | | | | | | | | | | | | MPA5 | 2806 | 2849# | | | | | | | | | | | | | MTRADR | 2091 | 2132 | 2133# | 2152 | | | | | | | | | | | MULTI | 1211# | 1326 | 2.00. | | | | | | | | | | | | NBLK | 3037# | | | | | | | | | | | | | | NMI | 1983# | 2261 | 2264 | 2280 | | | | | | | | | | | NONO | 1351 | 1352 | 1353 | 1355 | 1356 | 1357 | 1358 | 1359 | 1360 | 1362 | 1365 | 1366 | | | 110110 | 1424# | | .000 | | .000 | .007 | 1000 | .000 | .000 | | .005 | 1000 | | | NT4 | 2428# | 2450 | 2450 | | | | | | | | | | | | NT5 | 2429# | 2460 | 2460 | | | | | | | | | | | | NT6 | 2430# | 2470 | 2470 | | | | | | | | | | | | NT7 | 2431# | 2480 | 2480 | | | | | | | | | | | | NTRK5 | 2006# | 2190 | 2-00 | | | | | | | | | | | | NTRKB | 2005# | 2188 | | | | | | | | | | | | | NULINT | 588 | 598 | 778# | | | | | | | | | | | | NUMCON | 435 | 443# | 648 | 4965 | | | | | | | | | | | HOMEON | -35 | -43# | 040 | 4905 | | | | | | | | | | O.HELP | 108# | 4815 | | | | | | | | | | | |---------|-------|-------|-------|-------|------|-------|------|------|------|------|------|------| | O.INPC | 112# | 4129 | | | | | | | | | | | | O.MOVE | 120# | 3551 | 4250 | | | | | | | | | | | O.OUTC | 113# | 4164 | | | | | | | | | | | | O.PROT | 109# | 4295 | | | | | | | | | | | | O.RAMT | 115# | 126 | 4184 | | | | | | | | | | | O.RESV | 106# | 124 | | | | | | | | | | | | O.TERM | 121# | 3637 | 4379 | | | | | | | | | | | O.TYPE | 118# | 3645 | 4323 | | | | | | | | | | | O.VERF | 114# | 125 | 3551 | 4269 | | | | | | | | | | OPCODE | 2606 | 2621 | 2632 | 2746 | 3014 | 3033# | | | | | | | | OPOINT | 4775 | 4786 | 4801 | 4810# | | | | | | | | | | OPTIONS | 123# | 124# | 124 | 125# | 125 | 126# | 126 | 128# | 1218 | 1341 | 3551 | 3637 | | | 3645 | 3783 | 4041 | 4066 | 4129 | 4164 | 4184 | 4229 | 4250 | 4269 | 4295 | 4323 | | | 4338 | 4379 | 4428 | 4471 | 4483 | 4815 | | | | | | | | OUTCMD | 3316 | 4170# | | | | | | | | | | | | OUTCRT | 4565 | 4627 | 4632 | 4754# | | | | | | | | | | OUTCUR | 580 | 1010# | | | | | | | | | | | | OUTPUT | 3500 | 3511# | 4222 | | | | | | | | | | | OVERLAY | 183# | 3571 | 3662 | 3786 | 3957 | 3976 | 4002 | 4046 | 4072 | 4134 | 4169 | 4189 | | | 4232 | 4253 | 4272 | 4298 | 4326 | 4386 | 4819 | 4860 | | | | | | P.ACKN | 146# | | | | | | | | | | | | | P.AUTO | 151# | 542 | | | | | | | | | | | | P.ONLN | 147# | | | | | | | | | | | | | P.RDYI | 148# | | | | | | | | | | | | | P.RDYO | 149# | 3770 | | | | | | | | | | | | P.STRB | 150# | 542 | 3757 | 3759 | | | | | | | | | | P2L | 2762# | 2778 | | | | | | | | | | | | PARAO | 3383# | 3389 | | | | | | | | | | | | PARA1 | 3390# | 3403 | 3405 | | | | | | | | | | | PARA2 | 3394# | | | | | | | | | | | | | PARA4 | 3397# | | | | | | | | | | | | | PARAM1 | 3286 | 3397 | 4099 | 4957# | | | | | | | | | | PARAM2 | 3287 | 4958# | | | | | | | | | | | | PARAM3 | 3288 | 4959# | | | | | | | | | | | | PARAM4 | 3969 | 4116 | 4960# | | | | | | | | | | | PARAMS | 3284 | 3384# | | | | | | | | | | | | PASS8 | 4389# | | | | | | | | | | | | | PHEX | 2583# | 3046 | | | | | | | | | | | | PHYCMD | 3145# | 3223 | 3856 | | | | | | | | | | | PHYDMA | 3150# | 3215 | 4100 | | | | | | | | | | | PHYDRV | 3147# | 3161 | 4100 | | | | | | | | | | | | O PHYL | N 31 | 46# | | | | | | | | | | | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|------|------------------|--------|-----------|------|-------|------|------|------|------|------|------| | | ◆ PI01 | 37 | 62# 376 | 3 | | | | | | | | | | | | ₹ PIOA | | 02# 250 | | | | | | | | | | | | | endi PIOA | | 01# 250 | | 3 2504 | 2999 | | | | | | | | | | × PIOE | | 04# 250 | | | | | | | | | | | | · · | TI PIOE | | 03# 297 | | | | | | | | | | | | The second secon | PIOC | | | | | | | | | | | | | | | PIOS | | | | | | | | | | | | | | - | PKI | 44 | | | | | | | | | | | | | | PKI 1 | | | | | | | | | | | | | | | PKIZ | | | | | | | | | | | | | | | PKIS | | | | | | | | | | | | | | | PKI4 | | | | | | | | | | | | | | | PKIS | | | | | | | | | | | | | | | PKI | | | | | | | | | | | | | | | PKI7 | | | | | | | | | | | | | | | PKIE | | | | 2 4506# | | | | | | | | | | | PKIS | | | | 2 4500# | | | | | | | | | | | PMSC | | 77# 304 | | | | | | | | | | | | | PNEX | | | | 4 3374 | 3536 | 3542# | 3549 | 2617 | 3861 | 2005 | 4400 | 4000 | | | FILE | 44 | | | | 4721 | 4822 | 3549 | 3617 | 3861 | 3925 | 4120 | 4336 | | | PORT | | | | | 4/21 | 4022 | | | | | | | | | PRC | 3 44 | | | 9 . 4/30# | | | | | | | | | | | PRIN | | 99# | 0# | | | | | | | | | | | 1 | PRMT | | | | | | | | | | | | | | | PRON | | 65 · 324 | | 3 3290 | 3297 | | | | | | | | | - 1 - 1 - 1 - 1 - 1 - 1 - 1 - 1 - 1 - 1 | PROT | | | | 3 3290 | 3297 | | | | | | | | | | PROT | | | | | | | | | | | | | | | PROT | | | | | | | | | | | | | | | PRO | | 76# 32 | | 2 611 | | | | | | | | | | | PRS 1 | | 78# 27 | | 2 611 | | | | | | | | | | | PRS2 | | 11# 32 | | | | | | | | | | | | | PRSS | | 31# 34 | | | | | | | | | | | | · | PRS4 | | 31# 34<br>42# 34 | | | | | | | | | | | | | PRSE | | | 8# | | | | | | | | | | | | PRVA | | 53# 115 | | | | | | | | | | | | | PUT2 | | | | 5# 3971 | 4144 | 4146 | | | | | | | | · | PUT2 | | 88# 350 | | | 4144 | 4146 | | | | | | | | | | | | | 5 | | | | | | | | | | | PUT | | | | 0 0070 | | | | | | | | | | | PUT4 | | | | 2# 3972 | | | | | | | | | | | PUTN | | | | | | | | | | | | | | | RAM | | 36# 35 | | 8 4894 | 4970 | 5007 | | | | | | | | | RBAS | | 53 486 | | | | | | | | | | | | | RCP | + 44 | | | | | | | | | | | | | 2 | RCPA | | | | | | | | | | | | | | | RDC | 20 | 18 214 | | | 2354 | | | | | | | | | | RDIC | 22 | 34 224 | 3# 237 | 5 | | | | | | | | | | RECAL | 2236 | 2286# | 2334 | | | | | | |---------|--------|-------|-------|------|------|------|------|------| | RECLUN | 3026# | | | | | | | | | REMOVE | 706 | 769# | | | | | | | | RESET | 2860 | 2950 | 2972# | 2983 | | | | | | RESLEN | 4875# | | | | | | | | | RESTART | 564 | 607# | | | | | | | | RESTOP | 4874# | | | | | | | | | RETINS | 827 | 901# | | | | | | | | RETURN | 1350 | 1482# | 1542 | 1692 | | | | | | RETV1 | 636 | 640# | | | | | | | | RETVAL | 616 | 626 | 634# | | | | | | | RETZR | 2228# | 2323 | 2337 | | | | | | | REV | 16# | 625 | 3623 | 3623 | 3623 | | | | | RFI | 835 | 896# | 998 | | | | | | | RGDBUF | 2497# | 3074 | 3119 | | | | | | | RGLUN | 2529# | 2766 | 2767 | 2768 | 2769 | | | | | RGRECAL | 2985 | 3025# | | | | | | | | RIGDPB | 2412# | 3602 | | | | | | | | RMTALF | 4399# | 4503 | | | | | | | | RMTTOG | 4398# | 4495 | | | | | | | | ROM | 29# | 227 | 563 | 1702 | 4873 | 4887 | 4888 | 5003 | | ROMSIZ | 30# | 244 | 327 | 4887 | 4888 | 5003 | | | | ROMTOP | 4881# | 4887 | 4888 | 5003 | | | | | | RQTOP | 3131# | | | | | | | | | RSE | 2213 | 2233# | | | | | | | | RSE1 | 2235 | 2238# | | | | | | | | RSTATT | 11.46# | 1343 | | | | | | | | RSTHL - | 28.1 | 4978# | | | | | | | | RSTPC | 283 | 4979# | | | | | | | | RSTSP | 280 | 4977# | | | | | | | | RTK4 | 2450# | 2458 | | | | | | | | RTK5 | 2460# | 2468 | | | | | | | | RTK6 | 2470# | 2478 | | | | | | | | RTK7 | 2480# | 2488 | | | | | | | | RX1984 | 31# | 357 | 361 | 367 | | | | | | S.AUTOL | 4406# | 4501 | 4540 | | | | | | | S.AUTOR | 4407# | 4505 | 4552 | | | | | | | S.LECHO | 4404# | 4464 | 4493 | | | | | | | S.RECHO | 4405# | 4497 | 4531 | | | | | | | SA1403 | 2595# | 3058 | | | | | | | | SASO | 2604 | 2606# | | | | | | | | SASOA | 2596# | 2643 | | | | | | | | | SIGN4 | 3578 | 3600 | 3607 | 3617# | | | |---|--------|-------|-------|-------|-------|------|------| | | SIGNON | 368 | 3575# | | | | | | | SIM | 2749 | 2906 | 2913 | 2993# | | | | | SIOBUF | 4411# | 4412 | 4774 | 4800 | 4809 | 4810 | | | SIOCPA | 48# | 513 | 3670 | 3677 | 3693 | 4420 | | | SIOCPB | 49# | 495 | 714 | 741 | 742 | 4423 | | | SIODPA | 46# | 3680 | 3688 | 4420 | | | | | SIODPB | 47# | 725 | 735 | 949 | 996 | 4423 | | | SIOI1 | 4799 | 4801# | | | | | | | SIOIN | 571 | 723# | 754 | 3728 | 4358 | | | | SIOIN1 | 722# | 724 | | | | | | | SIOINC | 4530 | 4795# | 4796 | | | | | | SIOINP | 4735# | 4736 | | | | | | | SIOINS | 4729# | 4735 | 4742 | 4764 | | | | | SIOIST | 4450 | 4785# | 4795 | | | | | | SIOMSK | 437 | 744# | 3945 | 4308 | | | | | SIOOT | 4526 | 4549 | 4555 | 4746# | | | | | SIOOT1 | 4747# | 4748 | | | | | | | SICOUT | 572 | 730# | 3712 | 3737 | 4367 | 4372 | | | SIOPL | 4754 | 4757 | 4763# | 4785 | | | | | SIOPLI | 4773 | 4775# | | | | | | | SIOPL2 | 4777 | 4779# | | | | | | | SIOPL3 | 4765 | 4780# | | | | | | ٠ | SIORD1 | 747 | 750# | | | | | | | SIORD2 | 757 | 761# | | | | | | | SIORD3 | 753 | 759 | 762# | | | | | | SIORDT | 4742# | 4747 | | | | | | | SIORDY | 585 | 731 | 740# | 934 | 3746 | | | | SIOST | 570 | .714# | 723 | 752 | 3720 | 4356 | | | SIOVAL | 438 | 746# | 3947 | 4311 | | | | | SIOVEC | 499 | 4899# | | | | | | | SIOX1 | 731# | 733 | | | | | | | SLDDEN | 69# | | | | | | | | SLERR | 3133# | | | | | | | | SLSDEN | 68# | | | | | | | | SMF | 2103 | 2322# | | | | | | | SMFO | 2328 | 2330# | | | | | | | SMFOA | 2334# | 2368 | | | | | | | SMF1 | 2348# | 2353 | | | | | | | SMF1A | 2351 | 2356# | | | | | | | SMF1B | 2365 | 2370# | | | | | | | SMF2 | 2360 | 2371# | | | | | | | | | | | | | | 4448# 4424# 4452 | TIMOU | 2010# | 2131<br>4933# | 2155 | | | | | | | | | | |--------|-------|---------------|-------|------|-------|-------|------|-------|-------|------|-------|-------| | TLOC | 229# | 3572# | 3572 | 3572 | 3663# | 3663 | 3663 | 3787# | 3787 | 3787 | 3958# | 3958 | | | 3958 | 3977# | 3977 | 3977 | 4003# | 4003 | 4003 | 4047# | 4047 | 4047 | 4073# | 4073 | | | 4073 | 4135# | 4135 | 4135 | 4170# | 4170 | 4170 | 4190# | 4190 | 4190 | 4233# | 4233 | | | 4233 | 4254# | 4254 | 4254 | 4273# | 4273 | 4273 | 4299# | 4299 | 4299 | 4327# | 4327 | | | 4327 | 4387# | 4387 | 4387 | 4820# | 4820 | 4820 | 4861# | 4861 | 4861 | 4881 | | | TOPPTR | 4581 | 4585 | 4600 | 4604 | 4664 | 4668 | 4671 | 4807# | | | | | | TPAL | 230# | 3663 | 3663# | 3787 | 3958 | 3958# | 3977 | 4003 | 4047 | 4073 | 4135 | 4170 | | | 4190 | 4233 | 4254 | 4273 | 4299 | 4327 | 4387 | 4820 | 4820# | 4861 | 4862 | 4867 | | | 5007 | | | | | | | | .020# | 4001 | | -1007 | | TPAMAX | 3270 | 4862# | | | | | | | | | | | | TRKTBL | 2122 | 2408# | | | | | | | | | | | | TRMBUF | 4409# | 4410 | 4684 | 4691 | 4806 | 4807 | | | | | | | | TRMSTK | 4412# | 4425 | | | | | | | | | | | | TRN5 | 2393 | 2402# | | | | | | | | | | | | TRN6 | 1865# | 2396 | 2711 | | | | | | | | | | | TRUE | 22# | 23 | | | | | | | | | | | | TTC | 2073 | 2249 | 2278# | | | | | | | | | | | TTCA | 2262 | 2279# | | | | | | | | | | | | TYP0 | 4330 | 4336# | | | | | | | | | | | | TYP1 | 4356# | 4365 | 4370 | 4374 | | | | | | | | | | TYP2 | 4357 | 4364# | | | | | | | | | | | | TYPE | 3321 | 4327# | | | | | | | | | | | | TYPTOG | 4401# | 4491 | | | | | | | | | | | | UPCSR | 1348 | 1462# | | | | | | | | | | | | UPDATE | 208# | 270 | 563 | 682 | 1163 | 1702 | 1738 | 2416 | 3127 | 3143 | 3238 | 3572 | | | 3663 | 3787 | 3958 | 3977 | 4003 | 4047 | 4073 | 4135 | 4170 | 4190 | 4233 | 4254 | | | 4273 | 4299 | 4327 | 4387 | 4820 | 4861 | 4867 | 4873 | 4877 | | | | | USRSEC | 588# | 847 | | | | | | | | | | | | USRSTK | 1041 | 1079 | 1109 | 1123 | 1124# | 1501 | | | | | | | | VECTAB | 351 | 4898# | | | | | | | | | | | | VERCMD | 3323 | 4273# | | | | | | | | | | | | VERF1 | 4281# | 4289 | | | | | | | | | | | | VERF2 | 4279 | 4.287# | | | | | | | | | | | | VIEW | 3306 | 3314 | 4003# | | | | | | | | | | | VIEWO | 4005# | 4039 | | | | | | | | | | | | VIEW1 | 4012 | 4016# | | | | | | | | | | | | VIEW2 | 4027 | 4033# | | | | | | | | | | | | VIEW3 | 4015 | 4034# | | | | | | | | | | | | | | | | | | | | | | | | | | Σ | VIEW4 | 4008 | 4036# | | | | | | | | | | |------------|---------|-------|-------|-------|-------|------|-------|-------|------|------|------|------| | Appendix F | VIEW5 | 4010 | 4038# | | | | | | | | | | | ŏ | WARM | 565# | 833 | 3655 | 3846 | | | | | | | | | œ | WASTED | 1741# | 000 | 0000 | 0040 | | | | | | | | | Ž | WCC | 2754 | 2839 | 2900 | 2902 | 2908 | 2913# | 2987 | | | | | | Ω. | WD1797 | 55# | 3590 | 3598 | 2302 | 2500 | 2313# | 2307 | | | | | | × | WDCR | 1988# | 2267 | 2298 | 2346 | | | | | | | | | т | WDDD | 1994# | 2171 | 2338 | 2040 | | | | | | | | | | WDDT | 1991# | 2216 | 2266 | 2342 | | | | | | | | | | WDSD | 1993# | 2173 | 2361 | 2342 | | | | | | | | | | WDSL | 1992# | 2136 | 2141 | 2186 | 2203 | 2207 | 2326 | 2372 | 2374 | | | | | WDSN | 1990# | 2048 | 2141 | 2100 | 2203 | 2207 | 2326 | 2312 | 23/4 | | | | | WDSR | 1987# | 2157 | 2164 | 2306 | 2349 | | | | | | | | | WDTR | 1989# | 2209 | 2253 | 2306 | 2349 | | | | | | | | | WFR | 2750 | 2891 | 2899 | 2907 | 2914 | 2919 | 2935# | 2939 | | | | | | WFR1 | 2936 | 2941 | 2945# | 2907 | 2914 | 2919 | 2935# | 2939 | | | | | | WFRA | 2936 | 2941 | 2945# | | | | | | | | | | | WHAT | 3250 | 3256 | 3292# | 3311 | 3312 | 3315 | 3318 | 3320 | 3322 | 0000 | | | | WLP | 4603 | 4661 | 4670 | 4689# | 3312 | 3315 | 3318 | 3320 | 3322 | 3326 | 3327 | | | WOC | 2282 | 2302# | 4670 | 4009# | | | | | | | | | | WOC1 | 2303# | 2304 | | | | | | | | | | | | WOC2 | 2305# | 2308 | | | | | | | | | | | | WRITE | 577 | 3199# | | | | | | | | | | | | WUP | 4584 | 4594 | 4651 | 4678# | | | | | | | | | | XCKS | 243# | 4554 | 4031 | 4078# | | | | | | | | | | XCKS1 | 246# | 253 | | | | | | | | | | | | XOFF | 88# | 756 | 758 | | | | | | | | | | | XOFFLG | 761 | 763# | , 50 | | | | | | | | | | | XON | 87# | 758 | | | | | | | | | | | | XONENB | 439 | 751# | 3918 | 4317 | | | | | | | | | | XODVR | 578 | 1709# | 3225 | | | | | | | | | | | XQPHYS | 3173 | 3223# | 4106 | 4115 | | | | | | | | | | XSELERR | 2660# | 0220" | | | | | | | | | | | | YEAR | 4939# | | | | | | | | | | | | | Z.BAUA | 140# | 141 | 3940 | | | | | | | | | | | Z.BAUB | 141# | 142 | 3942 | | | | | | | | | | | Z.IOBT | 142# | 3948 | | | | | | | | | | | | Z.KEYM | 134# | 135 | 3923 | | | | | | | | | | | Z.SCRA | 132# | 133 | 3921 | | | | | | | | | | | Z.SIOA | 135# | 136 | 3931 | | | | | | | | | | | Z.SIOB | 136# | 137 | | | | | | | | | | | | Z.SIOM | 137# | 138 | 3944 | | | | | | | | | | | Z.SIOV | 138# | 139 | 3946 | | | | | | | | | | | Z.STPR | 133# | 134 | 3919 | | | | | | | | | | | Z.XONP | 139# | 140 | 3913 | | | | | | | | | | | | / | | | | | | | | | | | Notes Quick, Fast Cold Start Loader MACRO-80 3.44 ``` Title Ouick, Fast Cold Start Loader 2 Ouick, Fast Cold Start Loader. . . . Copyright (C) 1982, Balcones Computer Corporation. .z80 F02A Xadvr equ Of O2ab :Physical Driver Executioner 0004 cdisk eau 00004h :current user/disk 12 00000 cseq 13 0000 bios $ eau corigin of bios above ccn & bdos 14 15 ,phase 80h 16 17 0080 phycmd equ 0081 phyunt $+1 eau 19 0082 phydry equ $+2 0083 20 phytrk equ $+3 21 0085 $+5 physec equ 0087 $+7 phydma equ 23 24 quick, fast loader. 25 26 Entry: A = Sectors per Track 27 DE = Address of Physical Command Block that loaded OFD 28 29 0080 EΒ qfs: eх de,hl :transfer command block 30 0081 01 0005 1.d bc.physec-phycmd 31 0084 ED BO ldir ; woe be unto he who changes ofs 32 0086 21 00D5 ١d hl.ldrtb1-5 :set loader control table address 33 0089 0E 05 ١d c.5 :set table entry size 34 0088 09 qfs1: add hl,bc ;advance table address 35 BE 008C (h1) :match with loader control table entry CD 36 008D 38 FC ir c.afs1 ; if match not found yet 37 008F CO ret nz :if entry not in table 38 0090 23 ьl inc 39 0091 4E 1 d c,(h1) :set track offset+1 * 40 0092 23 inc 41 0093 ED AO ldi ;move starting sector, adjust track offset 42 0095 AF xor 43 0096 12 ' (de).a ١d ;clear upper sector 44 0097 7 E ١d a.(h1) set number of sectors 45 0098 23 inc hi 46 0099 6E ١d 1,(h1) :set (sector size)/4-1 009A 23 inc hì :sector size / 4 009B 29 add hl,hl 009C 29 h1.h1 add 50 009D EΒ ех de,hl :set sector size in DE 51 009E 2A 0083 ١d hl.(phytrk) ;add track offset 52 00A1 09 add hl,bc 53 00A2 22 0083 ١d (phytrk),hl 54 00A5 47 ١d b.a ;set number of sectors 55 00A6 7 A ١d a,d :check sector size 56 0047 21 FF80 1 d ``` hl.bios-80h :set starting address endif ``` Appendix G 107 else $ eq 100h-10 108 109 .printx + Perfect Fit + 110 else 111 00F4 100h-10-$,-1 ds ``` ``` ;Manufacturing serial number here if $ ne 100h Printx * Serial Number Out of Place * endif dephase ** DC****** Serialization. MACRO-80 3.44 09-Dec-81 endif :: Seri : sernum: db end sernml Quick, Fast Cold Start Loader 20 44 43 2A 2A 2A 2A 2A 2A 2A ``` 0080 QFS 008B QFS1 00AD QFS2 00AE QFS3 000A SERNML 00F6 SERNUM F02A XQDVR XQDVR XQDVR XQDVR XQDVR No Fatal error(s) Appendix G | _ | 0100 | 10% | 30 | | | |---------|--------|-----|------|-----|--| | | CDISK | 10# | 70 | | | | 3 | LDRTBL | 32 | 74 | 93# | | | D | PHYCMD | 17# | 30 | 62 | | | ₹. | PHYDMA | 22# | 60 | | | | nnendix | PHYDRV | 19# | | | | | × | PHYSEC | 21# | 30 | 64 | | | ລ | PHYTRK | 20# | 51 | 53 | | | | PHYUNT | 18# | | | | | | QFS | 29# | 62 | | | | | QFS1 | 34# | 36 | | | | | QFS2 | 59# | 69 | | | | | QFS3 | 58 | 60# | | | | | SERNML | 75 | 120# | | | | | SERNUM | 73 | 117# | 120 | | | | XQDVR | 9# | 63 | | | | | | | | | | Notes G6 Dios Jump Table | 1<br>2<br>3 | | | | | subttl<br>title | Bios Jump Tab<br>XEROX 820-II | | |-------------|--------|-----|--------|---------|-----------------|-------------------------------|----------------------------| | 4 | | | | ;; | XEROX 8 | 20+ Rom Reside | ent Bios Jump Table. | | 5<br>6<br>7 | ~ | | | ; | Copyrig | ht 1981, Balco | ones Computer Corporation. | | 8<br>9 | | | | ; | .z80 | | | | 10 | 0000 | СЗ | 00F1' | bios: | jp | cboot | :cold start | | 11 | 0003, | C3 | 0069 | bwboot: | | wboot | ;warm start | | 12<br>13 | 0006 | C3 | F04B | bconst: | in | const | :console status | | 14 | 0009 | | FO4E | bconin | | conin | console character in | | 15 | 0000, | | F051 | bconot: | | conout | console character out | | 16 | 000F | | F054 | bprint: | | list | | | 17 | 0012 | | F060 | | | | :list character on printer | | 18 | 0015 | | F05D | bpunch: | | punch | :punch | | 19 | 0015 | C3 | FUSD | breadr: | JÞ | reader | ;reader | | | 0018 | 0.0 | 0.1007 | | | | | | 20 | | | 01861 | bhome: | qį | home | move head to home position | | . 21 | 001B | | 0154 | bseld: | qį | seldsk | ;select disk | | 22 | 001E1 | | 01891 | bsett: | jp. | settrk | ;set track number | | 23 | 0021 | | 01BE' | bsets: | jp | setsec | ;set sector number | | 24 | 0024 | | 01031 | bsetd: | jp | setdma | ;set dma address | | 25 | 0027 | | 01EB′ | bread: | jp | read | read a record; | | 26 | 002A ' | C3 | 01F3′ | bwrit: | jρ | write | ;write a record | | 27 | | | | | | | | | 28 | 002D ' | СЗ | F057 | bprnts: | jp | listst | printer ready status | | 29 | 0030 | СЗ | 01081 | bsctrn: | jp | sectrn | sector translate | | 30 | | | | | | | | | 31 | 0033 | 81 | | initio: | db | 10000001b | :Initial I/O Byte | | 32 | | - | | | | | | | 33 | | | | | Subttl | Cold and Warr | m Start Module | | 34 | | | | | nage | 22.2.3.10 | | ``` 39 0004 cdisk equ :Current user/disk 40 002C nsects eau (ccplen+bdosln)/128 :number of sectors for ccp + bdos 41 0062 rev 42 43 Wboot - Warm Start CP/M. ;; 44 45 0034 3E C3 wbt5: ١d a.0c3h ;plant jumps 0036 21 F206' ١d hl,bios-bdosln+6 47 0039 ВE (h1) CD 003A 20 1C nz.wbterr ; if no jump to bdos 49 003C 32 0000 14 (0),a 50 003F 32 0005 ١d (5).a 51 0042 22 0006 ١d (6),h1 ;set address of jump to bdos 52 0045 21 0003 1 d hl.bwboot :set warm boot address 53 0048 22 0001 (1).hl 54 004B ED 4B 0004 14 bc.(cdisk) ;set current disk / user 55 004F 21 EA00' ١d hl,bios-bdosln-ccplen ;Enter CCP 0050 $-2 :patch to "03" to disable warm boot command whtcom equ 57 0052 3E 03 ١d a.3 58 0054 32 00501 ١d (wbtcom),a 59 0057 FG (h1) iρ 61 0058 CD 0115' wbterr: call pmsg :display error message 62 005B OD OA 42 6F db 13.10. 'Boot Err'.0 63 005F 6F 74 20 45 64 0063 72 72 00 0066 CD 0009' call bconin ; wait for key 66 0069 31 0100 wboot: 1d sp. 100h :use external stack 67 006C CD 013F1 call dboot :inform deblocker 68 006F ١d c,a :(zero) select A: 69 0070 3E 2C ١d a.nsects :set number of sectors to read 70 0072 32 00D0 ١d (secont).a ;set sector counter 71 21 E980 0075 1 d hl,bios-bdosln-ccplen-128 72 0078 22 013B ١d (dmabas).hl ;set base track dma address 73 007B CD 001B call bseld :select boot drive (A:) 74 007E 7 C ١d a.h 75 007F 85 or 28 D6 76 0080 jr z,wbterr 77 0082 23 inc :point to high translate address 7 F 78 0083 ld a, (h1) 79 0084 32 01221 ١d (xlate).a 0087 E5 push 81 0088 OE 00 ١d c.0 :translate sector zero 008A CD 0121' 82 call mls 0080 79 ١d a.c 32 01331 008E 1 d (transz),a ;set sector zero translate value 0091 E 1 h1 DOD 0092 86 11 0009 1 d de. 10-1 offset to dpb 87 0095 19 add hl.de 0096 4E 1 d c.(h1) get dob address 00971 23 inc hì ``` . Ŧ 145 ``` --- 150 0100 50 2F 4D 20 151 0104 76 65 72 73 0108 20 32 2E 32 152 153 0100 154 0100 20 23 32 2D #2-294' 155 01111 32 39 34 156 01141 00 db 0 157 158 pmsg - print message at return address. ;; 159 0115 ٤1 160 pmsg: pop print message after call 161 0116 7E 1 d a.(h1) 0117 162 inc h1 163 01181 87 а or 164 0119 E5 hl push 165 011A' C8 ret 2 ; if end of message 166 011B 4F ١d c.a 01101 CD 000C' 167 call bconot ;display message at current console 18 F4 168 011F' jr pmsg 169 170 ;; mls - map logical sector. 171 172 01211 3E 00 mls: 1 d a,0 ;set translate address 173 0122 xlate equ S-1 174 0123 В7 or a 79 175 0124 1 d a,c 176 0125 28 OB ir z.mls2 ; if not single density 177 0127 read by half tracks 87 add a.a 178 0128 2A 00DC ١d hl.(spt) get sectors per track 179 012B ВD CD 180 0120 38 02 jr c,mls1 ; if not past end of track 181 012E 95 offset back to beginning of track sub 182 012F 3 C inc 0130 3 C mls1: inc :map sector 0->1 183 а 4F 184 01311 1 d c,a 185 01321 D6 00 mls2: sub :offset by translate of sector zero 186 0133 transz equ $-1 187 0134 1 F rra 67 ١d 188 0135 h,a 189 0136 2E 00 ١d 1,0 0138 CB 1D 1 190 rr de,0 191 013A 11 0000 ١d ;set base dma for this track 192 0138 dmabas equ S-2 193 0130 19 add hl,de ;compute address for this sector 194 013E C9 ret 195 Subttl CHARIO - Character I/O Module 196 197 ``` page reader equ equ page punch monitr+5dh monitr+60h Subttl CP/M Deblocking Driver 207 209 210 211 F05D F060 ``` cseg 217 218 Ascii. ;; 219 220 000A 1 f 10 eau 221 000B up 11 equ 222 0000 13 cr equ 223 001B esc eau 27 224 225 4518 inslin equ ('E' sh1 8) + esc 226 521B dellin ('R' sh1 8) + esc 227 228 Absolute Machine Addresses. . . 229 230 FO2A 0f02ah xqdvr equ :Resident Monitor Driver Executioner 231 0004 cdisk equ 4 :CCP active user/disk 232 233 CP/M Write Types. ;; 234 235 0000 wrall equ 0 :normal write to allocated sector 236 0001 wrdir equ ;write to directory sector 237 0002 2 wrual equ :first write to unallocated block 238 239 :: skip - skip next instruction. 240 241 : Uses HL to perform very short jumps 242 243 skip macro 244 ((n)-$) eq 2 if 245 db 26h ;;;set PC = $+2 (1d h,...) 246 endif 247 if ((n)-$) ea 3 248 db 21h :::set PC = $+3 (1d h1,...) 249 endif 250 endm 251 252 Dboot - Deblocking Bootstrap. ;; 253 ; 254 Entry: Called prior to Warm Start reload. : 255 256 013F1 21 0000" dboot: ١d hl,hstbuf ;initialize host buffer address 257 0142 22 021A" 1 d (hstdma).hl 258 0145 21 0210" ١d hl,dphtab ;clear internal DPH table of addresses 259 0148 01 2000 ١d bc.16*2*256 set table length, zero 260 014B 71 dbt2: ١d (hí),c :clear next byte 261 0140 23 inc hl 262 0140 10 F.C djnz dbt2 : if table not clear 263 264 ;; clract - Clear host buffer active. 265 : 266 014F1 AF clract: xor ``` Appendix H ppendix CP/M Deblocking Driver ``` 267 01501 32 026F1 ١d (hstact).a clear host buffer active 268 01531 C9 ret 269 270 select - select CP/M disk. :: 271 272 Entry: C = CP/M Logical Drive, 0-15. 273 E = 2*n+0 if media identification required 274 E = 2*n+1 if media previously identified 275 276 0154 79 seldsk: ld a,c :remember disk to seek 277 01551 32 0205" 1 d (sekdsk).a 278 0158 06 00 1 d b.0 279 015A1 21 0210" sell: 1 d hl,dphtab :set table of remembered dph's 280 01501 add h1.bc ; index by words 281 015E 09 add hl.bc 282 015F' CB 43 bit 0.e 283 0161 28 OA z.se12 :if drive not previously selected 284 01631 7 E a.(h1) set disk parameter header address in hi 285 0164 23 286 0165 66 1 d h.(h1) 287 0166 ١d 1.a 288 0167 84 or 289 0168 20 19 nz.sel3 :if previous select succesful 290 016A 5F ١d e,a :force media identification 291 016B 18 FD ir sel1 292 016D1 E5 se12: push h1 ; save dph table address 293 016E 21 0202" 1 d hl.selcmd+2 294 01711 71 ١d (h1).c :set CP/M Logical drive 2B 295 01721 dec h1 296 01731 2B dec :point to select command 297 0174 36 FF (h1).-1 1 d :set driver select operation 298 0176 CD 02DF' call xdr :execute driver request 299 0179 FB eх de.hl 300 017A E 1 h1 000 301 0178 7.3 1d (h1).e :remember disk parameter header address 302 017C 23 inc h1 303 01701 72 1 d (h1).d 304 017E EΒ de.hl 305 017F 7 D 1 d a.1 306 0180 84 or 307 0181 28 22 iΓ z.sel4 ; if drive not successfully selected 308 0183 £5 se13: push h1 save dph address 309 0184 01 000A Ìd bc.10 ;set dpb offset in doh 310 0187 add hi.bc 311 0188 5E e,(h1) :set disk parameter block address ١d 0189 312 23 inc hl 313 018A 56 ١d d.(h1) 314 0188 EB eх de,hl 315 01801 22 02411 1 d (dobadr).hl 018F 316 0E 03 ١d с,3 317 01911 09 add h1.bc 318 01921 7 E a.(h1) ١d :set block shift factor 319 01931 3 C ;form 128 byte records per block 320 0194 32 021B 1 d (rpb).a 321 0197 OE OC ٦d c, 15-3 ;point to end of dpb ``` add hl.bc 322 01991 ``` 330 331 ;; cad - Clear Active Disk. 332 ; 333 01451 21 0004 cad: 1.d hl.cdisk :get disk that CCP will log in 334 0148 3A 0205" 1 d a. (sekdsk) get disk that failed 335 O1AB ΑE xor (h1) 336 D1AC' E6 0F not 11110000b ; clear active user and 337 O1AE 20 04 ir nz.cad1 ; if selected disk is not default disk 338 01801 7 F ١d a.(h1) :cause CCP to log in A: 339 01811 E6 F0 not 1111b retain active user area and 340 0183 77 ١d (h1),a 341 01841 6C cad1: ١d 1.h :indicate select failure 0185 342 C9 ret 343 344 Home - Set Track Zero. :: 345 346 01861 01 0000 home: ١d bc,0 ;seek track zero 347 348 Settrk - Set Track. ;; 349 350 Entry: BC = Track number 351 352 01891 ED 43 0206" settrk: 1d (sektrk).bc :set track to seek 353 01BD' C9 ret 354 355 Setsec - Set Sector. ;; 356 : 357 Entry: BC = Sector number ; 358 359 01BE' ED 43 020C" setsec: 1d (seksec).bc :set sector to seek 360 01021 C9 ret 361 362 Setdma - Set Direct Memory Address. 363 Entry: BC = DMA address 364 : 365 366 ED 43.020A" (sekdma),bc 01031 setdma: 1d 367 01071 C9 ret 368 369 ;; Sectran - Sector Translate. 370 Entry: BC = Sector number, 0 <= BC < Sectors per Track 371 372 DE = Single byte skew table address Appendix H 373 374 Exit: HL = BC if DF = 0 375 L = (DE+BC) if DE <> 0 H = B 376 which better be zero 377 378 01081 69 sectrn: 1d 1.c :set untranslated sector ``` :fall into clear active disk O 171 01A5' se14: 329 379 0109' 60 ``` 380 01CA 7 A 1.0 a.d 381 01CB В3 or 382 01001 CB ret :if no translate table 383 01CD eх de.hl 384 01CE ' 09 add hl.bc 385 01CE 6 F 1 d 1.(h1) :single byte translate 386 01001 60 1.d h h 387 01011 0.9 ret 388 389 :: Rdwrs - Read or Write Single Density. 390 391 01023 3A 02AE' rdwrs: 1 d a (readon) :set read/write operation 392 01051 21 0203" 1 d hl.sekcmd :set seek request 393 18 07 01087 ir rdwrhs :enter read/write dispatcher 394 395 Readhs - Read Host Sector. 396 397 01DA ' 3E 01 readhs: 1d a.1 :set read operation 398 $+2 skin :jump over write entry point 399 01DC1 26 db 26h 400 401 :: Wriths - Write Host Sector. 402 : 403 01DD1 ΔF wriths: xor :set write operation 404 01DE / 21 0213" 1 d hl.hstcmd 405 406 Rdwrhs - Read or Write Host Sector. 407 408 Entry: HL = Physical command request address 409 A = 0 to write 410 A = 1 to read 411 412 Exit: A = 0, if no errors 413 A = -1, if errors 414 Z = condition of A req 415 416 01F11 (h1),a rdwrhs: ld :set driver operation 417 01E2' CD 02DF' call xdr :execute driver read or write 418 01651 21 02BE1 ١d hl.erflag ;merge error flag for directory protection 419 01E81 86 oг (h1) 420 01E91 77 ١d (h1),a 421 O1EA' C9 ret 422 423 Read - Read CP/M Sector. :: 424 425 Entry: Seldsk, Settrk, Setsec, Setdma previously called 426 427 Exit: A = 0 if no errors 428 A = -1 if errors 429 430 01EB' AF read: XOF ;clear unalloc processing 431 O1EC' 32 02261 1 d (unacnt),a 432 01EF' 0E 00 1 d c.wrall ; inhibit buffer flush after read 433 01F1' 3C inc :set read operation а 434 $+2 skip ``` 1 d h.b hl.de sbc 490 0243 ED 52 CP/M Deblocking Uriver ``` 491 0245 20 04 nz.writ2 :if not end of track 492 02471 22 0211" (unasec),hl 1 d reset to sector zero 493 0244 24 020F" 1 d hl. (unatrk) :advance unallocated track 494 024D1 23 inc h1 495 024E 22 020F" 1.d (unatrk).hl 496 02511 ΔF writ2. x o r :mark pre-read not required 497 02521 18 05 rwoner 498 0254 ΛE writ3. xor :clear unallocated processing 499 02551 32 02261 1 d (unacnt).a 500 0258 3.0 writ4: inc :mark pre-read required 501 502 :: Rwoper - Read or Write Operation Proper 503 504 0259 32 0288 rwoper: 1d (rsflag).a :set pre-read block flag 505 0250 3A 0298 1 d a.(secmsk) set shift counter 506 025F' 2A 020C" 1 d hl. (seksec) 507 0262 CB 3C rwon1. sr1 :compute host sector = comsec/(2**sekmsk) 508 0264 CR 10 гΓ 509 0266 CB 3F sr1 510 0268 20 FB ir nz.rwop1 :if shift incomplete 511 026A 22 0208" ĺα (sekhst).hl set seek host sector 512 026D F6 00 or :check host active flag 513 026F hstact eau S-1 514 026F' 3E 01 1 d a.1 515 02711 32 026E' 1 d (hstact).a :host buffer always become active 516 0274 28 OE z.rwop2 if host buffer was not active 517 0276 21 0215" 1 d hl, hstdsk set active host buffer identification 518 0279 11 02051 1 d de.sekdsk set seek identification 519 027C' CD 02CC' call :compare seek request with active host sector cmo 520 027F' 28 16 jг z.rwop3 if host buffer contains seek sector 521 02811 CD 02C21 ca11 flush :flush buffer if previously written 522 0284 11 0215 rwop2: 1 d de,hstdsk :set host request block address 523 0287 CD 02D6' call cpb copy seek parameter block to host 524 028A 3E 00 10 a.0 :check pre-read required 525 028B rsflag $-1 eau 526 028C 87 527 0280 C4 0104' call nz.readhs ; read host sector if preread required 528 0290 В7 or 529 0291 C4 014F1 call nz.clract :clear host buffer active if read errors 530 0294 32 02C3 (hstwrt).a ١d :mark buffer not written into 531 0297 3A 020C1 rwop3: 1 d a.(seksec) :set seek sector 532 029A' E6 00 :form host buffer index from sector mask and 533 029B secmsk egu S-1 534 0290 1.5 rra 535 029D 57 l d d,a ;multiply index by 128 bytes/sector 536 029E 3E 00 ) d a.0 537 02A0 1.5 rra 538 02A1' SE 1d e,a 539 0242 2A 021A" 1 d hl.(hstdma) :set host buffer address 540 02A5 19 add :form seek buffer address hl.de 541 0246 ED 58 020A" 1 d de, (sekdma) :set user transfer address 542 02AA 01 0080 1 d bc.128 set CP/M sector length 543 02AD' 3E 00 ١d a.0 :set transfer direction 544 02AE' $-1 readop eau B7 545 O2AF or 546 02801 20 05 jr nz,rwop4 ; if read operation ``` .,. | oendix H | 603 | | | | | | | |----------|------------|--------|--------------------|-------|------|--------------------|-------------------------------------| | ನ | 604 | 02DF ' | 22 02EA' | xdr: | 1 d | (xdra),hl | ;save request for retrys | | == | 605 | 02E2' | 2A 02EA' | xdr1: | 1d | hl.(xdra) | restore request address | | × | 606 | 02E5' | CD FO2A | | call | Xqdvr | ;execute physical driver | | I | 607 | 02E8 | 47 | | 1d | b,a | | | | 608 | 02E9 ' | 3A O2EA | | 1d | | ;save read/write error status | | | 609 | O2EA' | SA UZEA | xdra | | a,(xdra) | get driver operation | | | 610 | O2EC, | 4F | xura | equ | <b>\$-</b> 2 | | | | 611 | 02ED ' | 3C | | ld | c,a | ;set message index | | | | | | | inc | a | | | | 612 | 02EE' | 20 05 | | jr | nz,xdr2 | ; if not select request | | | 613 | 02F0' | B5 | | or | 1 | | | | 614 | 02F1' | B4 | | or | h | | | | 615 | 02F2' | CO | | ret | nz | ; if dph address returned by driver | | | 616 | 02F3' | 18 03 | | jr | xdr3 | | | | 617 | 02F5 ' | 78 | xdr2: | ١d | a,b | ;set read/write error status | | | 618 | 02F6' | B7 | | OF | a | | | | 619 | 02F7' | C8 | | ret | z | ;if no read/write errors | | | 620 | 02F8 ' | 2A 02EA' | xdr3: | 1 d | hl,(xdra) | ; put drive name in message | | | 621 | 02FB ' | 23 | | inc | h1 | | | | 622 | 02FC' | 23 | | inc | h1 | | | | 623 | 02FD ' | 7 E | | ld | a,(h1) | | | | 624 | 02FE ' | C6 41 | | add | a, 'A' | | | | 625 | 0300 ' | 32 0330' | | 1 d | (xdrb),a | | | | 626 | 0303 | OC | | inc | c (x0, 5), a | | | | 627 | 0304 | 20 OC | | ni | nz.xdr4 | ; if not select request | | | 628 | 0306 | CD 0375' | | call | pmsgi | , ii not serect request | | | 629 | 0309, | 53 65 6C 65 | | db | 'Select',0 | | | | 630 | 0300, | 63 74 00 | | UD. | Serect , o | | | | 631 | 0310 | 18 16 | | jr | xdr6 | | | | 632 | 0312 | OD . | xdr4: | dec | c | | | | 633 | 0313 | 20 OB | XU14; | jr | | . 16 | | | 634 | 0315 | CD 0375 | | call | nz,xdr5 | ;if not write request | | | 635 | 0318 | 57 72 69 74 | | db | pmsgi<br>'Write',0 | | | | 636 | 0310 | 65 00 | | ab | write ,u | | | | 637 | 031E | 18 08 | | | 40 | | | | 638 | 0320 | CD 0375' | | jr | xdr6 | | | | | | | xdr5: | call | pmsgi | must be read request; | | | 639<br>640 | 0323 | 52 <b>65 61 64</b> | | db | "Read",0 | | | | | 0327 | | -1-0 | | | | | | 641 | 0328 | CD 0115' | xdr6: | call | pmsg | | | | 642 | 032B | 20 45 72 72 | | db | 'Err' | | | | 643 | 032F′ | 20 | | | | | | | 644 | 0330, | 64 3A 20 | xdrb: | db | 'd: ' | | | | 645 | 0333, | 41 28 63 63 | | dЬ | 'A(ccept), ' | | | | 646 | 0337 | 65 70 74 29 | | | | | | | 647 | 033B ' | 2C 20 | | | | | | | 648 | 033D ' | 49 28 67 6E | | db | 'I(gnore), ' | | | | 649 | 0341′ | 6F 72 65 29 | | | | | | | 650 | 0345 | 2C 20 | | | | | | | 651 | 0347 | 52 28 65 74 | | db | 'R(etry) ' | | | | 652 | 0348 | 72 79 29 20 | | | | | | | 653 | 034F ' | 00 | | db | 0 | | | | 654 | 0350 | CD 0009' | | call | bconin | read character from console | | | 655 | 0353 | F5 | | push | af | | | | 656 | 0354 | CD 0115' | | call | pmsg | | | I | 657 | 0357 | OD | | db | c. | | | H13 | 658 | 0358 | 521B | | dw | dellin | | | ω | | . , | | | | | | | | | | | | | | | | | | | | | | | | : | | | | | | P-P | | | | | |-----|--------|-----|-------|--------|--------|-----------|--------------|----------------------|----------| | 663 | 035F′ | | 5F | | and | 5fh | ;ignore par | ity, case | | | 664 | 0361' | FE | . 03 | | СР | 3 | | | | | 665 | 0363' | 28 | OA | | jr | z,xdr7 | : if warm st | art requested | | | 666 | 0365 | D6 | 49 | | sub | ' İ ' | | · | | | 667 | 0367 | C8 | | | ret | z | if user iqu | nored error, don't t | ell BDOS | | 668 | 0368 | D6 | F8 | | sub | 'A'-'I' | , | | | | 669 | 036A' | C2 | 02E2' | | jp | nz.xdr1 | ;retry requ | est | | | 670 | 036D' | 2F | | | cpl | | | | | | 671 | 036E ' | C9 | | | ret | | | | | | 672 | | | | | | | | | | | 673 | 036F ' | CD | 01A5' | xdr7: | call | cad | clear acti | ve disk | | | 674 | 0372 | C3 | 0003 | | jρ | bwboot | | | | | 675 | | | | | •• | | | | | | 676 | 0375 | CD | 0115 | pmsgi: | call | pmsq | | | | | 677 | 0378 | OD | OA | | db | cr,1f | | | | | 678 | 037A' | 45 | 1B | | dw | inslin | | | | | 679 | 037C' | 0.0 | | | db | 0 | | | | | 680 | 037D | C3 | 0115 | | jp | pmsg | | | | | 681 | | | | | •. | | | | | | 682 | | | | | subttl | Deblocker | Storage Area | | | | 683 | | | | | page | | | | | | | | | | | | | | | | reserve dohtab. ('P'-'A'+1)\*2 cseq end H15 727 728 729 730 731 0000" Appendix H | Ξ. | | 700 | 709 | 709# | 709 | 713 | / 13# | /13 | /14 | /14# | 714 | 715 | 715# | |-------|--------|------|------|------|------|-----|-------|-----|-----|------|-----|-----|------| | 껵 | | 715 | 719 | 719# | 719 | 720 | 720# | 720 | 721 | 721# | 721 | 722 | 722# | | ನ | | 722 | 723 | 723# | 723 | 724 | 724# | 724 | 728 | 728# | 728 | | | | endix | BCONIN | 14# | 65 | 654 | | | | | | | | | | | _ | BCONOT | 15# | 167 | | | | | | | | | | | | I | BCONST | 13# | | | | | | | | | | | | | | BDOSLN | 37# | 40 | 46 | 55 | 71 | | | | | | | | | | BHOME | 20# | | | | | | | | | | | | | | BIOS | 10# | 46 | 55 | 71 | 115 | | | | | | | | | | BPRINT | 16# | | | | | | | | | | | | | | BPRNTS | 28# | | | | | | | | | | | | | | BPUNCH | 17# | | | | | | | | | | | | | | BREAD | 25# | | | | | | | | | | | | | | BREADR | 18# | | | | | | | | | | | | | | BSCTRN | 29# | | | | | | | | | | | | | | BSELD | 21# | 73 | | | | | | | | | | | | | BSETD | 24# | 118 | | | | | | | | | | | | | BSETS | 23# | 113 | | | | | | | | | | | | | BSETT | 22# | 108 | | | | | | | | | | | | | BWBOOT | 11# | 52 | 674 | | | | | | | | | | | | BWRIT | 26# | | | | | | | | | | | | | | CAD | 333# | 673 | | | | | | | | | | | | | CAD1 | 337 | 341# | | | | | | | | | | | | | CBOOT | 10 | 146# | | | | | | | | | | | | | CCPLEN | 38# | 40 | 55 | 71 | | | | | | | | | | | CDISK | 39# | 54 | 231# | 333 | | | | | | | | | | | CLRACT | 266# | 529 | | | | | | | | | | | | | CMP | 483 | 519 | 577# | | | | | | | | | | | | CMP 1 | 578# | 583 | | | | | | | | | | | | | CONIN | 14 | 203# | | | | | | | | | | | | | CONOUT | 15 | 204# | | | | | | | | | | | | | CONST | 13 | 202# | | | | | | | | | | | | | CPB | 474 | 523 | 592# | | | | | | | | | | | | CR | 222# | 657 | 677 | | | | | | | | | | | | DBOOT | 67 | 256# | | | | | | | | | | | | | DBT2 | 260# | 262 | | | | | | | | | | | | | DELLIN | 226# | 658 | | | | | | | | | | | | | DMABAS | 72 | 134 | 138 | 192# | | | | | | | | | | | DPBADR | 315 | 489# | | | | | | | | | | | | | DPHTAB | 258 | 279 | 728# | | | | | | | | | | | | ERFLAG | 418 | 454 | 555# | | | | | | | | | | | | ESC | 223# | 225 | 226 | | | | | | | | | | | | FLUSH | 521 | 562# | | | | | | | | | | | | | HOME | 20 | 346# | | | | | | | | | | | | | HSTACT | 267 | 513# | 515 | | | | | | | | | | | | HSTBUF | 256 | 695# | | | | | | | | | | | | | | | | | | | | | | | | | | | INSLIN 225# 678 LF 220# 677 LIST 16 205# LISTS 180 183# MLS 82 111 172# MLS1 180 183# MLS2 176 185# MONITR 200# 202 203 204 205 206 207 208 MSECTS 40# 69 PMSG 61 146 160# 168 641 656 676 680 PMSG 62 164 638 676# PMSG 62 17 20# RDWR 452# RDWR 452# RDWR 462 RDWR 452# RDWRS 391# 459 455 READOP 391 452 544# RESERVE 685# 694 698 702 703 704 705 706 707 708 712 713 REV 41# 152 RPB 320 471# RSFLAG 504 525# RWOP3 50 51# RWOP3 50 51# RWOP3 50 51# RSFLAG 504 555# RWOP3 50 51# RWOP3 50 51# RSFLAG 504 556# RWOP3 50 51# RSFLAG 504 556# RWOP3 50 51# RWOP3 50 51# RSFLAG 504 556# RWOP3 50 51# RSFLAG 504 556# RWOP3 50 51# RSFLAG 504 556# RWOP3 50 51# RWOP3 50 51# RSFLAG 504 556# RWOP3 50 51# RWOP4 566 550# RWOP3 52 566 573# SECKINT 70 374 SEKOMA 366 541 708# SEKOMA 366 541 708# SEKOMA 362 465 510 707# SEKSETR 352 463 706# SEKOMA 362 455 506 531 709# SEKSTR 352 465 516 506 531 709# SEKSTR 352 465 506 507 706# SEKSTR 352 465 506 501 707# SEKSTR 352 465 506 501 707# SEKSTR 352 465 510 707# SEKSTR 352 465 510 707# SEKSTR 352 465 510 707# SEKSTR 352 465 510 707# SEKSTR 352 465 511 707# SEKSTR 352 465 506 531 709# SEKSTR 352 465 506 531 709# | INSLIN 225# 678 LF 220# 677 LIST 16 205# LISTS 28 206# MLS 82 111 172# MLS 180 183# MLS 180 183# MLS 180 183# MLS 27 185 200 69 MLS 180 186 694 MLS 201 185# | INITIO | 31# | | | | | | | | | | | | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|------|------|------|------|------|------|-----|-----|-----|-----|-----|-----| | LEF 200# 677 LISTS 16 205# LISTST 28 206# MLS 20 176 1850 MLS1 180 183# MLS2 176 1850 MIS2 176 176 176 176 176 176 176 176 176 | LEF | | | 678 | | | | | | | | | | | | LIST 16 205# LISTS 28 206# MLS 82 111 172# MLS1 180 183# MLS2 176 185# MM.S1 200# 202 203 204 205 206 207 208 MSECTS 40# 69 PMSG 61 146 160# 168 641 656 676 680 PMSG1 628 634 638 676# PUNCH 152 208# RDWR 452 RDWR 452 RDWR 452 RDWR 452 RDWR 452 READER 18 207# READER 18 207# READER 393 4 16# READER 391# 459 455 READER 397 452 RESERVE 685# 694 698 702 703 704 705 706 707 708 712 713 REV A1# 152 RPB 320 471# RSFLAG 694 698 702 703 704 705 706 707 708 712 713 REV A1# 152 RPB 320 471# RSFLAG 504 525# RWOP1 507# 510 RWOP2 516 522# RWOP3 520 531# RWOP4 546 550# RWOP6 456 550# RWOP6 392 703 704 705 706 707 708 712 713 SECKIN 29 379# 125 SECKIN 29 379# SECKIN 352 463 708# SEKIN 352 463 708# SEKIN 352 463 708# SEKIN 352 465 511 707# SEKSETR 456 511 707# SEKSETR 352 463 706# SEKIN 352 465 516 506 531 709# SEKIN 352 465 550 55 558 SEKIN 352 465 516 506 550 FSEKIN 704 705 706 506 531 709# SEKIN 352 465 516 586 SEKIN 352 465 506 531 709# SEKIN 352 465 516 586 SEKIN 352 465 506 531 709# SEKIN 352 465 516 586 SEKIN 352 465 506 531 709# SEKIN 352 465 516 586 SEKIN 352 465 506 531 709# SEKIN 352 465 516 586 SEKIN 352 465 506 531 709# | LIST 16 205# LLISTS 28 206# MLS 82 111 172# MLS1 180 183# MLS2 176 185# MLS1 176 185# MMS1 200# 69 PMSG 61 146 160# 168 641 656 676 680 PMSG 61 146 660# 168 676# PMSGI 628 634 638 676# PUNCH 17 208# RUNDH 452 RUNDH 393 466 RUNDH 393 416# RUNDH 393 459 465 READER 18 207# READER 18 207# READER 391 452 READER 391 452 READER 391 452 READER 391 452 RESERVE 685# 694 698 702 703 704 705 706 707 708 712 713 REV A1# 152 RPB 320 471# RSFLAG 504 525# RWOP1 507# 510 RWOP2 516 522# RWOP3 520 531# RWOP3 520 531# RWOP4 546 550# RWOP6R 497 504# SEKUMN 396 541 708# SEKUMN 396 541 708# SEKUMN 396 541 708# SEKUMN 396 541 708# SEKUMN 392 455 506 531 709# SEKUMN 392 455 506 531 709# SEKURN | | | | | | | | | | | | | | | LISTST 28 206# MLS 3 82 111 172# MLS1 180 183# MLS2 176 185# MMS1 200# 202 203 204 205 206 207 208 NSECTS 40# 69 PMSG 61 146 160# 168 641 656 676 680 PMSG 61 146 638 676# PUNCH 17 208# RDWR 452# RDWR 452# RDWR 462 466# RDWRS 391# 459 465 READER 18 207# READER 18 207# READER 18 207# READER 685# 694 698 702 703 704 705 706 707 708 712 713 RESERVE 685# 694 698 702 721 722 723 727 READER 504 694 698 702 703 704 705 706 707 708 712 713 RESERVE 41# 150 502# RPD 41# 150 502# RPD 507# 510 RWOP2 516 522# RWOP3 520 531# RWOP4 546 550# RWOP4 546 550# RWOP5 5216 522# RWOP4 546 550# RWOP5 516 522# RWOP4 546 550# RWOP5 516 522# RWOP4 546 550# RWOP5 516 522# RWOP5 520 531# SECKIT 70 123# 125 SECKIT 70 123# 125 SECKIT 70 123# 125 SECKIT 352 463 708# SEKCIT 392 378# SEKCIT 70 378# SEKCIT 392 378# SEKCIT 70 352 465 511 707# SEKCIT 352 465 511 707# SEKSIT 352 465 511 707# SEKSIT 352 465 511 707# SEKSIT 352 465 511 707# | LISTST 28 206# MLS 82 111 172# MLS1 180 183# MLS2 176 185# MNSTC 200# 202 203 204 205 206 207 208 NSECTS 40# 69 PMSG 61 146 160# 168 676# PMSG 61 146 638 676# PUNCH 17 208# RDWR1 462# RDWR1 462 466# RDWRS 391# 459 465 READER 18 207# READER 18 207# READER 397# 527 READER 391 452 544# RESERVE 685# 694 698 702 703 704 705 706 707 708 712 713 REY 114 718 719 720 721 722 723 727 RPWP 27 14 718 719 720 721 722 723 727 RWP 28 41# 125 RWP 29 510 522# RWP 29 510 522# RWP 29 510 522# RWP 29 510 522# RWP 39 520 531# RWP 29 550 531# RWP 466 550# RWP 566 550 | | | | | | | | | | | | | | | MLS 82 111 172# MLS1 180 183# MLS2 176 185# MNS1 200# 202 203 204 205 206 207 208 NSECTS 40# 69 PMSG 61 146 160# 168 641 656 676 680 PMSG1 628 634 638 676# PUNCH 17 208# RDWR1 393 416# RDWR1 393 416# RDWR1 393 416# READER 18 207# READER 18 207# READER 397 527 READER 397 452 RESERVE 685# 694 698 702 703 704 705 706 707 708 712 713 REV 41# 152 RPB 320 471# RSFLAG 694 698 702 721 722 723 727 READER 397# 527 READER 397# 527 READER 397# 527 READER 397# 527 RESERVE 685# 694 698 702 703 704 705 706 707 708 712 713 REV 41# 152 RPB 320 471# RSFLAG 504 525# RWOP1 507# 510 RWOP2 516 522# RWOP3 520 531# RWOP4 546 550# RWOP2 497 504# 125 SECTRN 29 378# SECTRN 29 378# SECTRN 326 437 708# SEKOMA 366 541 708# SEKOMA 366 541 708# SEKOMA 362 545 506 531 709# SEKOMA 352 463 706# SEKORS 352 463 706# SEKORS 352 465 506 531 709# | MLS 82 111 172# MLS1 180 183# MLS2 176 185# MNNITR 200# 202 203 204 205 206 207 208 NSECTS 40# 69 PMSG 61 146 160# 168 641 656 676 680 PMSG1 628 634 638 676# PUNCH 17 208# RDWR1 393 416# RDWR1 393 416# RDWR1 393 416# RDWR1 393 416# READER 18 207# READER 18 207# READER 391 452 READER 685# 694 698 702 703 704 705 706 707 708 712 713 REV 41# 152 RPB 320 471# REV 41# 152 RPB 320 471# RSFLAG 504 526# RWOP1 507# 510 RWOP2 516 522# RWOP3 520 531# RWOP3 520 531# RWOP3 520 531# RWOP4 546 550# RWOP4 546 550# RWOP5 516 522# RWOP6R 497 504# SECTEN 396 573 574 SECTEN 396 574 SECTEN 396 574 SECTEN 396 574 SECTEN 397 39 | | | | | | | | | | | | | | | MLS1 180 183# MS2 176 185# 1 | MLS1 180 183# MLS2 176 185# MONITR 200# 202 203 204 205 206 207 208 MONITR 200# 202 203 204 205 206 207 208 MONITR 200# 69 | | | | 172# | | | | | | | | | | | MINITER 200# 202 203 204 205 206 207 208 NSECTS 40# 69 PMSG 61 146 160# 168 641 656 676 680 PMSG1 628 634 638 676# PUNCH 17 208# RDWR1 452# RDWR1 393 416# RDWR1 393 416# READOR 29 19 430# READOR 391 459 465 READOR 391 452 544# RESERVE 685# 694 698 702 703 704 705 706 707 708 712 713 REV 41# 152 RPB 320 471# RSFLAG 504 525# RWOP1 507# 510 RWOP2 516 522# RWOP3 520 531# RWOP3 520 531# RWOP4 456 550# RWOP6R 497 103# SECON 703 704 RESERVE 369 456 504 RWOP6R 497 103# SECON 703 704 RWOP6R 497 103# SECON 703 704 RWOP6R 497 103# SECON 703 704 RWOP6R 497 103# SECON 703 704 SECON 703 704 RWOP6R 497 103# SECON 703 704 SECON 703 704 SECON 703 704 SECON 703 704 SECON 703 704 SECON 704 SECON 705 SECON 705 SECON 705 SECON 705 SECON 705 SECON 703 704 SECON 705 SECON 705 SECON 705 SECON 705 SECON 705 SECON 703 704 SECON 705 SECON 705 SECON 703 704 SECON 705 SECON 705 SECON 703 704 SECON 705 SE | MINIS 176 185# MONITR 200# 202 203 204 205 206 207 208 MONITR 200# 202 203 204 205 206 207 208 MONITR 200# 202 203 204 205 206 207 208 MONITR 200# 202 203 204 205 206 207 208 MONITR 200# 202 203 204 205 206 207 208 MONITR 200# 202 203 204 205 206 207 208 MONITR 200# 202 203 204 205 206 207 208 MONITR 200# 202 203 204 205 206 207 208 MONITR 200# 202 203 204 205 206 207 208 MONITR 200# 202 203 204 205 206 207 208 MONITR 200# 202 203 204 205 206 207 208 MONITR 200# 202 203 204 205 206 207 208 MONITR 200# 202 203 204 205 205 205 205 205 205 205 205 205 205 | | | | | | | | | | | | | | | MONITR 200# 202 203 204 205 206 207 208 NSECTS 40# 69 PMSG 61 146 160# 168 641 656 676 680 PMSG 61 146 638 676# PMSG 61 146 638 676# PMSG 61 146 638 676# PMSG 61 146 708# FMSG 61 146 708# FMSG 61 146 708# FMSG 61 146 708# FMSG 61 146 708# FMSG 634 658 708# FMSG 61 146 7 | MONITR 200# 202 203 204 205 206 207 208 NSECTS 40# 69 PMSG 61 146 160# 168 641 656 676 880 PMSG 61 146 638 676# PMSG 17 208# RDWR1 452# RDWR1 462 466# RDWRS 391# 459 465 READ 25 119 430# READER 18 207# READER 18 207# READER 694 698 702 703 704 705 706 707 708 712 713 REV 41# 152 RBSFLAG 694 698 702 721 722 723 727 REV 41# 152 RBSFLAG 504 528# RWPDP 320 471# RWPDP 350 471# RWPDP 516 550# RWPDP 550 531# RWPDP 560 550# RWPDP 497 304 481 518 592 705# SEKDMA 366 541 706# SEKSTR 352 463 706# SEKSTR 352 465 511 707# 516 531 709# SEKSTR 352 465 506 531 709# SEKSTR 352 465 506 531 709# SEKSTR 352 465 706# | | | | | | | | | | | | | | | NSECTS 40# 69 PMSG1 628 634 638 676# PMSG1 628 634 638 676# PUNCH 17 208# RDWR 452# RDWR 452# RDWRHS 393 416# RDWRHS 393 416# READR 25 119 430# READR 25 119 430# READR 397# 627 READR 397# 627 READR 397# 627 READR 685# 685# 698 702 703 704 705 706 707 708 712 713 REV 41# 152 RPB 320 471# RSFLAG 504 526# RWOP1 507# 510 RWOP2 516 522# RWOP3 520 531# RWOP4 546 550# RWOP6R 497 504# SECENT 713 703# SECENT 713 703# SECENT 713 703# SECENT 713 703# SECENT 713 703# SECENT 713 703# SECENT 714 718 719 720 721 722 723 727 RWOP3 520 531# RWOP4 546 550# SECENT 7504 550 SECENT 7504 550 SECENT 7504 550 SECENT 7504 750 7 | NSECTS 40# 69 | | | | 203 | 204 | 205 | 206 | 207 | 208 | | | | | | PMSG 61 146 160# 168 641 656 676 680 PMSG1 628 634 638 676# PUNCH 17 208# RDWR 452# RDWR 462 466# RDWRNS 391# 459 465 READ 25 119 430# READER 18 207# READER 397 455 READOP 391 452 544# RESERVE 685# 694 698 702 703 704 705 706 707 708 712 713 REV 41# 152 RPB 320 471# RSFLAG 504 525# RWOPA 504 550# RWOPA 506 501# RWOPA 467 505 SECKINT 70 123# 125 SECKINT 70 123# 125 SECKINT 29 378# SEKCHS 352 463 708# SEKCHS 352 463 708# SEKSTR 352 463 708# SEKSTR 352 463 708# SEKSTR 352 463 706# | PMSG | | | | | | | | | | | | | | | PMSGI 628 634 638 676# PUNCH 17 208# RDWR 452# RDWR 452# RDWR 452# RDWRHS 393 416# RDWRHS 391 459 465 READ 25 119 430# READER 18 207# READER 397 527 READER 391 47 518 RESERVE 615# 694 698 702 703 704 705 706 707 708 712 713 REV 41# 718 719 720 721 722 723 727 REV 41# 718 719 720 721 722 723 727 REV 41# 718 719 720 721 722 723 727 REV 41# 718 719 720 721 722 723 727 REV 41# 718 719 720 721 722 723 727 REV 41# 718 719 720 721 722 723 727 REV 41# 718 719 720 721 722 723 727 REV 41# 718 719 720 721 722 723 727 REV 41# 718 719 720 721 722 723 727 REV 41# 718 719 720 721 722 723 727 REV 41# 718 719 720 721 722 723 727 REV 41# 718 719 720 721 722 723 727 REV 41# 718 719 720 721 722 723 727 REV 41# 718 719 720 721 722 723 727 REV 41# 718 719 720 721 722 723 727 REV 41# 718 719 720 721 722 723 727 REV 41# 718 719 720 721 722 723 727 REV 41# 718 719 720 721 722 723 727 REV 41# 718 719 720 721 722 723 727 REV 41# 718 719 720 721 722 723 727 REV 41# 718 719 720 721 722 723 727 REV 41# 718 719 720 721 722 723 727 REV 41# 718 719 720 721 722 723 727 REV 41# 718 719 720 721 722 723 727 REV 41# 718 719 720 721 722 723 727 REV 41# 718 719 720 721 722 723 727 REV 41# 718 719 720 721 722 723 727 REV 41# 718 719 720 721 722 723 727 REV 41# 718 719 720 721 722 723 727 REV 41# 718 719 720 721 722 723 727 REV 41# 718 719 720 721 722 723 727 REV 41# 718 719 720 721 722 723 727 REV 41# 718 719 720 721 722 723 727 REV 41# 718 719 720 721 722 723 727 REV 41# 718 719 720 721 722 723 727 REV 41# 718 719 720 721 722 723 727 REV 41# 718 719 720 721 722 723 727 REV 41# 718 719 720 721 722 723 727 REV 41# 718 719 720 721 722 723 727 REV 41# 718 719 720 721 722 723 727 REV 41# 718 719 720 721 722 723 727 REV 41# 718 719 720 721 722 723 727 REV 41# 718 719 720 721 722 723 727 REV 41# 718 720 720 723 727 REV 41# 718 720 723 720 720 720 720 720 720 720 720 720 720 | PMSGI 628 634 638 676# PUNCH 17 208# RDWR 452# RDWR 452# RDWRHS 393 416# RDWRHS 393 416# RDWRHS 393 416# RDWRHS 393 416# READ 25 119 430# READER 18 207# READHS 397# 527 528 READHS 397# 528 READHS 397# 528 READHS 398# 528 READHS 398# 528# 538# READHS 398# 538# READHS 398# READHS 398# READHS 398# 578# READHS 398# READHS 398# RE | | | | 160# | 168 | 641 | 656 | 676 | 680 | | | | | | PUNCH 17 208# RDWR 452# RDWR 462 466# RDWRN 391 466# RDWRNS 391# 459 465 READ 25 119 430# READHS 397# 527 READER 18 207# READHS 397 455 SECTR 29 391 452 READER 685# 694 698 702 703 704 705 706 707 708 712 713 REV 41# 152 RPB 320 471# RSFRAG 504 525# RWOP1 507# 510 RWOP2 510 524# RWOP3 510 524# RWOP4 645 504 SECENT 70 123# 125 SECNT 70 123# 125 SECNT 70 123# 125 SECNT 70 123# 125 SECNT 70 378# SECRIN 396 651 708# SEKOMA 366 541 708# SEKOMA 366 541 708# SEKOMA 365 517 708# SEKOMA 366 541 708# SEKOMA 365 517 707# SEKOMA 365 517 707# SEKOMA 365 511 707# SEKOMA 365 511 707# SEKOMA 365 511 707# SEKOMA 365 511 707# SEKOMA 365 511 707# SEKOMA 365 515 703# SEKOMA 365 511 707# SEKOMA 365 511 707# SEKOMA 365 511 707# SEKOMA 365 515 707# SEKOMA 365 511 707# SEKOMA 365 511 707# SEKOMA 365 550 550 531 709# SEKOMA 365 550 455 506 531 709# SEKOMA 365 352 463 706# | PUNCH 17 208# ROWR 452# ROWR1 462 466# ROWRS 391 416# STORE ROWRS 391 459 465 ROWRS 391 459 465 ROWRS 391 459 465 ROWRS 391 459 465 READ 25 119 430# READER 18 207# READER 18 207# READER 18 207# READER 18 207# READER 18 207# RESERVE 685# 694 698 702 703 704 705 706 707 708 712 713 714 718 719 720 721 722 723 727 727 727 727 727 727 727 727 | | | | | | | | | | | | | | | ROWR 452# ROWRHS 393 416# ROWRHS 393 416# ROWRHS 391# 459 465 READ 25 119 430# READRER 18 207# READRER 397# 527 READRER 68# 694 698 702 703 704 705 706 707 708 712 713 RESERVE 68# 694 698 702 721 722 723 727 REDRER 68# 694 698 702 721 722 723 727 REDRER 68# 694 698 702 721 722 723 727 REDRER 68# 694 698 702 721 722 723 727 REDRER 68# 694 698 702 721 722 723 727 REDRER 68# 694 698 702 721 722 723 727 REDRER 68# 694 698 702 721 722 723 727 REDRER 68# 694 698 702 721 722 723 727 REDRER 694 695 694 698 702 721 722 723 727 REDRER 694 695 694 698 720 721 722 723 727 REDRER 695 695 695 695 695 695 695 695 695 695 | ROWR 452 | | | | | | | | | | | | | | | ROWRIN 393 416# ROWRNS 391# 459 465 READ 25 119 430# READER 18 207# READER 397# 527 READOP 391 452 544# RESERVE 685# 694 698 702 703 704 705 706 707 708 712 713 REV 41# 152 RPD 320 471# RSFLAG 504 525# RWOP1 507# 510 RWOP2 510 524# RWOP3 510 524# RWOP4 655 504 RWOP4 50 504# SECONT 70 123# 125 SECONT 70 123# 125 SECONT 70 123# 125 SECONT 70 123# 125 SECONT 29 378# SECONT 29 378# SECONT 29 378# SECONT 29 378# SECONT 29 378# SECONT 29 378# SECONT 392 703# SECONT 392 703# SECONT 392 703# SECONT 392 703# SECONT 392 703# SECONT 392 378# 372# SECON | ROWRI 462 466# ROWRS 391 416# ROWRS 391 459 465 READ 25 119 430# READER 18 207# READER 18 207# READORS 391 452 544# RESERVE 685# 694 698 702 703 704 705 706 707 708 712 713 REV 41# 152 RPB 320 471# RSFLAG 504 526# RWOPI 507# 510 RWOPI 507# 510 RWOPA 546 550# RWOPA 456 550# RWOPA 457 505 533# SECONT 70 123# 125 SECNS 326 457 708 SECNS 396 541 708# SECRN 29 378# SECRN 29 378# SECRN 29 378# SECRN 392 703# SECNS 277 334 481 518 592 705# 378 | | | | | | | | | | | | | | | ROWRS 393 416# ROWRS 391# 459 465 READ 25 119 430# READER 18 207# AT 12 713 713 714 718 719 720 721 722 723 727 706 707 708 712 713 714 718 719 720 721 722 723 727 727 728 729 729 729 729 729 729 729 729 729 729 | ROWRNS 393 416# ROWRNS 391# 459 465 READ 25 119 430# READER 18 207# 714 718 719 720 721 722 723 727 727 708 712 713 713 714 718 719 720 721 722 723 727 727 727 728 727 728 727 728 727 728 727 728 727 728 727 728 727 728 727 728 727 728 727 728 727 728 727 728 727 728 727 728 727 728 727 728 727 728 727 728 727 728 727 728 727 728 727 728 727 728 727 728 727 728 727 728 727 728 728 | | | 466# | | | | | | | | | | | | ROWRS 391# 459 465 READ 25 119 430# READER 18 207# READER 397# 527 READOP 391 452 544# RESERVE 685# 684 698 702 703 704 705 706 707 708 712 713 REV 1152 RP 320 471# RSFLAG 504 525# RWOP1 507# 510 RWOP2 516 522# RWOP3 520 531# RWOP | ROWRS 391# 459 465 READ 25 119 430# READER 18 207# READONS 397# 527 READONS 391 452 544# RESERVE 685# 694 698 702 703 704 705 706 707 708 712 713 REV A1# 152 RP 320 471# RSFLAG 504 525# RWOP1 507# 510 RWOP2 516 522# RWOP3 540 531# RWOP3 540 531# RWOP3 540 531# RWOP3 540 531# RWOP3 540 531# RWOP3 540 531# RWOP3 540 541 70# RWOP3 550 538# SECCNT 97 54# SECKNT 99 378# SEKMA 366 541 70# SEKMA 366 541 70# SEKMS 277 334 481 518 592 705# SEKMS 277 334 481 518 592 705# SEKNST 456 511 707# SEKSTR 456 511 707# SEKSTR 352 463 706# SEKNTK 352 463 706# | | | | | | | | | | | | | | | READ 25 119 430# READER 18 207# READHS 397# 527 READOP 391 452 544# RESERVE 685# 694 698 702 703 704 705 706 707 708 712 713 REV 41# 152 RPB 320 471# RSFLAG 504 525# RWOP1 507# 510 RWOP2 516 522# RWOP3 520 531# RWOP4 546 550# RWOP4 546 550# SECCNT 70 123# 125 SECMSK 326 457 505 533# SECCNT 70 123# 125 SECKNS 326 457 708 SEKSMA 366 541 708# SEKSMA 366 541 708# SEKSMA 366 541 708# SEKSMA 366 541 708# SEKSMA 366 541 707# SEKSKS 277 334 481 518 592 705# SEKSKS 259 455 506 531 709# SEKSKR 352 463 706# SEKSKR 352 463 706# | READ 25 119 430# READER 18 207# READHS 397# 527 READOPS 391# 452 544# RESERVE 685# 694 698 702 703 704 705 706 707 708 712 713 REV 41# 152 RPB 320 471# 78 719 720 721 722 723 727 REV 41# 152 RPB 320 471# 78 78 78 78 78 78 78 78 78 78 78 78 78 | | | | 465 | | | | | | | | | | | READER 18 207# READOP 397# 527 READOP 391 452 544# RESERVE 685# 694 698 702 703 704 705 706 707 708 712 713 FLY ATTEM TO THE TOTAL | READER 18 207# READOP 391 452 544# RESERVE 685# 694 698 702 703 704 705 706 707 708 712 713 714 718 719 720 721 722 723 727 REV A1# 152 RPB 320 471# RSFLAG 504 525# RWOP1 507# 510 RWOP2 516 522# RWOP3 520 531# RECENT 19 52# RWOP3 520 531# RECENT 29 378# SECND 392 703# 704# | | | | | | | | | | | | | | | READHS 397# 527 READOP 391 452 544# RESERVE 685# 694 698 702 703 704 705 706 707 708 712 713 REV 41# 152 RPB 320 471# RSFLAG 504 525# RWOP1 507# 510 RWOP2 516 522# RWOP3 520 531# RWOP4 546 550# RWOP4 546 550# SECONT 70 123# 125 SECONT 70 123# 125 SECONT 70 123# 125 SECONT 29 378# SECONT 70 703# SECONT 392 703# SEKOMA 366 541 708# SEKOMA 366 541 708# SEKOMA 366 551 707# SEKSCM 277 334 481 518 592 705# SEKSCH 352 463 706# SEKSTR 352 463 706# SEKTR 352 463 706# SEKTR 352 463 706# | READHS 397# 527 READOP 391 452 544# RESERVE 685# 694 698 702 703 704 705 706 707 708 712 713 REV 41# 152 RPB 320 471# 8 RSFLAG 504 525# RWOP1 507* 510 RWOP2 516 522# RWOP3 520 531# RWOP4 546 550# RWOP4 546 550# RWOP3 520 531# RWOP4 546 550# 646 550# RWOP5 510 570# 570# 570# 570# 570# 570# 570# 570 | | 18 | | | | | | | | | | | | | RESERVE 685# 694 698 702 703 704 705 706 707 708 712 713 REV A1# 152 RPB 320 471# RSFLAG 504 525# RWOP1 507# 510 RWOP2 516 522# RWOP3 520 531# RWOP3 520 531# RWOP3 520 531# SECHT 49 150 505 533# SECRT 29 378# SEKDMA 366 541 708# SEKDMA 366 541 708# SEKDMA 366 541 708# SEKNST 456 511 707# SEKSET 359 455 506 531 709# SEKSET 352 463 706# | RESERVE 685# 694 698 702 703 704 705 706 707 708 712 713 RESERVE 685# 694 698 702 703 704 705 706 707 708 712 713 REV A1# 152 RPB 320 471# RSFLAG 504 526# RWOP1 507# 510 RWOP2 516 522# RWOP3 520 531# SECHT 797 505 SECHT 797 505 SECHT 797 505 SECHT 797 703# 704# S | | | | | | | | | | | | | | | RESERVE 685# 694 698 702 703 704 705 706 707 708 712 713 REV 41# 152 RPB 320 471# 718 719 720 721 722 723 727 RSFLAG 504 525# RWOP1 507# 510 RWOP2 516 522# RWOP3 520 531# RWOP4 546 550# RWOP4 546 550# RWOP4 546 550# RWOP5 510 504# 550# 504# 550# 504# 550# 504# 550# 504# 550# 504# 550# 504# 550# 504# 550# 504# 550# 504# 550# 504# 550# 504# 550# 504# 550# 504# 550# 504# 550# 504# 550# 504# 550# 504# 550# 504# 550# 504# 550# 504# 550# 504# 550# 504# 550# 504# 550# 504# 550# 504# 550# 504# 550# 504# 550# 504# 550# 504# 550# 504# 550# 504# 550# 504# 550# 504# 550# 504# 550# 504# 550# 504# 550# 504# 550# 504# 550# 504# 550# 504# 550# 504# 550# 504# 550# 504# 550# 504# 550# 504# 550# 504# 550# 504# 550# 504# 504 | RESERVE 685# 694 698 702 703 704 705 706 707 708 712 713 REV 41# 152 RPB 320 471# 755 750 721 722 723 727 RWOP1 507 510 RWOP2 516 522# RWOP3 520 531# RWOP4 546 550# RWOP1 507 70 708 712 713 RWOP4 546 550# RWOP4 546 550# RWOP4 497 504# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 531# 550 53 | | | | 544# | | | | | | | | | | | 714 718 719 720 721 722 723 727 REV | 714 718 719 720 721 722 723 727 REV 41# 152 RPB 320 471# RSFLAG 504 526# RWOP1 507# 510 RWOP2 516 522# RWOP3 520 531# RWOP3 520 531# RWOP3 520 531# RWOP3 520 531# RWOP4 546 550# RWOP5 509 509 509 509 509 509 509 509 509 50 | RESERVE | 685# | 694 | 698 | 702 | 703 | 704 | 705 | 706 | 707 | 708 | 712 | 713 | | RPB 320 471# RSFLAG 504 525# RWOP1 507# 510 RWOP2 516 522# RWOP3 520 531# RWOP3 520 531# RWOP6R 497 504# SECENT 76 123# 125 SECWS 329 457 505 533# SEKUS 329 457 505 533# SEKUS 366 541 708# SEKOM | RPB 320 471# RSFLAG 504 525# RWOP1 507# 510 RWOP2 516 522# RWOP3 520 531# RWOP3 520 531# RWOP4 546 550# RWOP5 497 504# RWOP6R 497 504# RWOP6R 497 504# SECENT 70 123# 125 SECWS W 322 49 505 533# SEKWS W 324 49 505 534 SEKWS W 326 49 505 534 SEKWS W 326 49 505 534 SEKWS W 326 49 505 534 SEKWS W 326 49 505 534 SEKWS W 327 334 481 518 592 705# SEKWS 277 334 481 518 592 705# SEKWS 256 359 455 506 531 709# SEKSTR 352 463 706# SEKURT 704# | | 714 | 718 | 719 | 720 | 721 | 722 | 723 | 727 | | | | | | RSFLAG 504 525# RWOP1 507# 510 RWOP2 516 522# RWOP3 520 531# RWOP4 546 550# RWOP4 546 550# RWOP5 497 504# SECCNT 70 123# 125 SECMSK 326 457 505 533# SECTRN 29 378# SEKCMD 392 703# SEKCMD 392 703# SEKCMD 392 703# SEKOMA 366 541 708# SEKOMA 366 541 708# SEKOMA 566 551 707# SEKSER 456 511 707# SEKSER 456 359 455 506 531 709# SEKSER 352 463 706# SEKUNT 704# | RSFLAG 504 525# RWOP1 507# 510 RWOP2 516 522# RWOP3 520 531# RWOP4 546 550# RWOP4 546 550# RWOP4 646 550# RWOP4 646 550# SECCNT 70 123# 125 SECMSK 326 457 505 533# SECTRN 29 378# SEKCND 392 703# SEKOMA 366 541 708# SEKOMA 366 541 708# SEKOMA 566 541 707# SEKOST 456 511 707# SEKSTR 456 511 707# SEKSTR 456 511 707# SEKSTR 352 453 706# SEKUNT 704# SEKUNT 704# | REV | 41# | 152 | | | | | | | | | | | | RWOP1 507# 510 RWOP2 516 522# RWOP3 520 531# RWOP4 546 550# RWOPER 497 504# SECENT 70 123# 125 SECWSK 329 457 505 533# SECWSK 329 457 505 533# SECWSK 366 541 708# SEKDMA 366 541 708# SEKDMA 366 541 708# SEKDSK 277 334 481 518 592 705# SEKHST 456 511 707# SEKSER 359 455 506 531 709# SEKSER 352 463 706# SEKURT 704# | RWOP1 507# 510 RWOP2 516 522# RWOP3 520 531# RWOP4 546 550# RWOPER 497 504# SECONT 70 123# 125 SECWSK 326 455# 505 533# SEKMSK 326 455# 505 533# SEKOMA 366 541 708# SEKOMA 366 541 708# SEKOMA 366 541 708# SEKNSK 277 334 481 518 592 705# SEKNSK 277 334 481 518 592 705# SEKNSK 256 359 455 506 531 709# SEKSTR 352 463 706# SEKUST 704# | | | | | | | | | | | | | | | RWOP2 516 522# RWOP4 546 550# RWOP4 546 550# SECCNT 70 123# 125 SECMSK 326 457 505 533# SECTRN 29 378# SEKCMD 392 703# SEKCMD 392 703# SEKCMD 366 541 708# SEKOMA 366 541 708# SEKOMA 566 541 707# SEKNST 456 511 707# SEKSET 456 359 455 506 531 709# SEKTRK 352 463 706# SEKUNT 704# | RWOP2 516 522# RWOP4 546 550# RWOP4 546 550# SECCNT 70 123# 125 SECMSK 326 457 505 533# SECTRN 29 378# SEKCRD 392 703# SEKDMA 366 541 708# SEKDMA 366 541 708# SEKDMA 366 551 707# SEKNST 456 511 707# SEKSET 456 511 707# SEKSET 359 455 506 531 709# SEKTRK 352 463 706# SEKUNT 704# | | | | | | | | | | | | | | | RWOP3 520 531# RWOP4 546 550# RWOPER 497 504# SECNT 70 123# 125 SECMSK 326 457 505 533# SECTRN 29 378# SEKCMD 392 703# SEKCMD 392 703# SEKCMD 366 541 708# SEKOMA 366 541 708# SEKOMS 277 334 481 518 592 705# SEKNST 456 511 707# SEKNST 456 511 707# SEKSEC 359 455 506 531 709# SEKSEC 359 463 706# SEKUNT 704# | RWOP3 520 531# RWOP4 546 550# RWOPER 497 504# SECNTT 70 123# 125 SECMSK 326 457 505 533# SEKCMD 392 703# SEKCMD 392 703# SEKDMA 366 541 708# SEKDMA 366 541 708# SEKDMA 456 511 707# SEKSET 456 511 707# SEKSET 456 511 707# SEKSET 359 455 506 531 709# SEKUNT 704# | | | | | | | | | | | | | | | RWOP4 546 550# RWOPER 497 504# SECCNT 70 123# 125 SECMSK 326 457 505 533# SECTRN 29 378# SEKCMD 392 703# SEKOMA 366 541 708# SEKOMA 277 334 481 518 592 705# SEKHST 456 511 707# SEKSET 359 455 506 531 709# SEKSET 352 463 706# SEKUNT 704# | RWOP4 546 550# RWOPER 497 504# SECCNT 70 123# 125 SECMSK 326 457 505 533# SECTRN 29 378# SEKCMD 392 703# SEKDMA 366 541 708# SEKDMA 366 541 708# SEKDMS 277 334 481 518 592 705# SEKNST 456 511 707# SEKNST 456 511 707# SEKSEC 359 455 506 531 709# SEKURK 352 463 706# SEKUNT 704# | | | | | | | | | | | | | | | RWOPER 497 504# SECCNT 70 123# 125 SECMSK 326 457 505 533# SECTRN 29 376# SEKCMD 392 703# SEKDMA 366 541 708# SEKDMA 27 334 481 518 592 705# SEKNST 456 511 707# SEKNSC 359 455 506 531 709# SEKNST 352 463 706# SEKUNT 704# | RWOPER 497 504# SECCNT 70 123# 125 SECMSK 326 457 505 533# SEKCMS 296 457 505 533# SEKCMD 392 703# SEKDMA 366 541 708# SEKDMA 366 541 708# SEKDSK 277 334 481 518 592 705# SEKHST 456 511 707# SEKSEC 359 455 506 531 709# SEKSEC 359 455 506 531 709# SEKUNT 704# | | | | | | | | | | | | | | | SECORT 70 123# 125 SECMSK 326 457 505 533# SECTRN 29 378# SEKCMD 392 703# SEKDMA 366 541 708# SEKDMA 277 334 481 518 592 705# SEKHST 456 511 707# SEKHST 456 511 707# SEKSEC 359 455 506 531 709# SEKSEC 359 455 506 531 709# SEKURT 704# | SECONT 70 123# 125 SECMSK 326 457 505 533# SECTRN 29 378# SEKCMD 392 703# SEKDMA 366 541 708# SEKDMA 277 334 481 518 592 705# SEKHST 456 511 707# SEKHST 456 511 707# SEKSEC 359 455 506 531 709# SEKNRK 352 463 706# SEKUNT 704# | | | | | | | | | | | | | | | SECMSK 326 457 505 533# SECTRN 29 378# SEKCMD 392 703# SEKDMA 366 541 708# SEKDMA 277 334 481 518 592 705# SEKDSK 277 334 481 518 592 705# SEKDSK 278 359 455 506 531 709# SEKSEC 359 455 506 531 709# SEKTRK 352 463 706# | SECMSK 326 457 505 533# SECRMS 29 378# SEKCMD 392 703# SEKDMA 366 541 708# SEKDSK 277 334 481 518 592 705# SEKNSK 456 511 707# SEKNSK 456 511 707# SEKSEK 359 455 506 531 709# SEKTRK 352 463 706# SEKUNT 704# | | | | | | | | | | | | | | | SECTRN 29 378#<br>SEKCMD 392 703#<br>SEKDMA 366 541 708#<br>SEKDSK 277 334 481 518 592 705#<br>SEKHST 456 511 707#<br>SEKSEC 359 455 506 531 709#<br>SEKSEC 359 455 506 531 709#<br>SEKNTK 352 463 706# | SECTRN 29 378#<br>SEKOMA 366 703#<br>SEKOMA 366 541 708#<br>SEKOSK 277 334 481 518 592 705#<br>SEKNST 456 511 707#<br>SEKNSC 359 455 506 531 709#<br>SEKTRK 352 463 706#<br>SEKURT 704# | | | | | | | | | | | | | | | SEKCMD 392 703#<br>SEKDMA 366 541 708#<br>SEKDSK 277 334 481 518 592 705#<br>SEKHST 456 511 707#<br>SEKSEC 359 455 506 531 709#<br>SEKSEC 352 463 706#<br>SEKUNT 704# | SEKOMD 392 703# SEKOMD 366 541 708# SEKDSK 277 334 481 518 592 705# SEKHST 456 511 707# SEKHST 456 511 707# SEKSEC 359 455 506 531 709# SEKTRK 352 463 706# SEKURT 704# | | | | 505 | 533# | | | | | | | | | | SEKDMA 366 541 708#<br>SEKDSK 277 334 481 518 592 705#<br>SEKHST 456 511 707#<br>SEKSEC 359 455 506 531 709#<br>SEKTRK 352 463 706#<br>SEKUNT 704# | SEKDMA 366 541 708#<br>SEKDSK 277 334 481 518 592 705#<br>SEKHST 456 511 707#<br>SEKSEC 359 455 506 531 709#<br>SEKTRK 352 463 706#<br>SEKUNT 704# | | | | | | | | | | | | | | | SEKDSK 277 334 481 518 592 705#<br>SEKHST 456 511 707#<br>SEKSEC 359 455 506 531 709#<br>SEKTRK 352 463 706#<br>SEKUNT 704# | SEKDSK 277 334 481 518 592 705#<br>SEKHST 456 511 707#<br>SEKSEC 359 455 506 531 709#<br>SEKTRK 352 463 706#<br>SEKUNT 704# | | | | | | | | | | | | | | | SEKHST 456 511 707#<br>SEKSEC 359 455 506 531 709#<br>SEKTRK 352 463 706#<br>SEKUNT 704# | SEKHST 456 511 707#<br>SEKSEC 359 455 506 531 709#<br>SEKTRK 352 463 706#<br>SEKUNT 704# | | | | | | | | | | | | | | | SEKSEC 359 455 506 531 709#<br>SEKTRK 352 463 706#<br>SEKUNT 704# | SEKSEC 359 455 506 531 709#<br>SEKTRK 352 463 706#<br>SEKUNT 704# | | | | | 518 | 592 | 705# | | | | | | | | SEKTRK 352 463 706#<br>SEKUNT 704# | SEKTRK 352 463 706#<br>SEKUNT 704# | | | | | | | | | | | | | | | SEKUNT 704# | SEKUNT 704# | | | | | 531 | 709# | | | | | | | | | | | | | 463 | 706# | | | | | | | | | | | | SEL1 279# 291 | | | | | | | | | | | | | | | 2FF1 5.43# 531 | | SEL1 | 279# | 291 | | | | | | | | | | | 79 230# Notes Banked Physical Driver Copyright (C) 1982, Balcones Computer Corporation Transferred to Public Domain - (PD) 1983 After executing this program by entering BANK x: (where x is any valid CP/M disk drive A-P). The BANK program will load a physical disk driver into memory. This physical driver is executed when drive x: is accessed by CP/M. This particular disk driver will map normal CP/M files onto the address space of the alternate memory bank (bank 0) in the 820-II. This utility demonstrates the flexibility of the logical to physical disk mapping in the 820-II. The BANK program moves the physical disk driver up to high memory. It then updates the entry for drive x: in the logical to physical disk drive mapping table telling the system to use physical disk driver #3 when CP/M requests service from drive x:. The execution address of the BANK driver is then placed in entry #3 of the physical disk driver address table. If BANK is executed by entering: A>BANK P: Then doing a A>DIR P: would display the following directory: BOOT .ROM : OPTION .ROM : SCREEN .MEM : EXPAND .RAM Entering: A>STAT P: \*. \* will display the following: Recs Bytes Ext Acc 12k 1 R/O P:BOOT.ROM 256 32k 1 R/W P: EXPAND. RAM 16 2k 1 R/W P:OPTION.ROM 24 1 R/W P:SCREEN.MEM Bytes Remaining On P: Ok The files map to the following memory addresses in bank 0: BOOT . ROM 0000h-2fffh EXPAND.RAM 4000h-bfffh OPTION, ROM 17ffh-1fffh SCREEN, MEM 3000h-3bffh The BANK program can also be a very useful tool in that after it has been executed a high level language program can access items in the alternate memory bank as disk files on drive x: Of particular interest is the file SCREEN.MEM, notice that it is 24 records long. Each record (128 bytes) corresponds to a line on the CRT (only the first 80 bytes of each record are in the display window). The first record of the file corresponds to the first line of the CRT only if the CRT has not been 59 59 60 61 MACRO-80 3.44 09-Dec-81 permitted to scroll since the last clear screen command was sent to it. Subttl Constants & Program Mover page ``` 62 63 64 F000 Monitr equ 0f000h :Base address of resident monitor 65 66 F033 Xcrtmv equ monitr+33h :Crt <-> Ram Move LDIR Simulator F036 Xgets1 monitr+36h equ :Get driver select table address to hi FF3C Bavail eau Off3ch :Pointer to beginning of available memory FF3E Off3eh Eavail equ ;Pointer to end of available memory 70 71 0005 bdos equ 72 005C dfcb 5ch eau 73 74 FA80 drvadr 0fa80h eau ;address for Bank driver 75 0000 stack equ 76 77 .z80 79 0000 Aseg Org 100h 81 0100 18 5A jr loadit 82 83 0102 43 6F 70 79 db 'Copyright (C) 1982 Balcones Computer Corporation' 84 0106 72 69 67 68 74 20 28 43 010A 010E 29 20 31 39 87 0112 38 32 20 42 61 6C 63 6F 0116 89 011A 6E 65 73 20 0116 43 6F 6D 70 91 0122 75 74 65 72 92 0126 20 43 6F 72 012A 70 6F 72 61 012E 74 69 6F 6E 0132 20 54 72 61 Transferred to Public Domain - (PD) 1983'.26 0136 6E 73 66 65 97 013A 72 72 65 64 98 013E 20 74 6F 20 0142 50 75 62 6C 100 0146 69 63 20 44 101 014A 6F 6D 61 69 6E 20 2D 20 102 014E 103 0152 28 50 44 29 104 20 31 39 38 0156 105 015A 33 1A 106 107 108 0150 CD 03D8 loadit: call req822 ;see if machine is 820-II 109 015F 3A 005C 1 d a. (dfcb) 110 0162 28 30 111 0163 1r z, bnkusg 112 0165 F5 push af CD 03F8 113 0166 call ckspac :see if room for driver 114 0169 F1 af pop 115 016A 3D dec a 116 016B 4F c,a ``` | 122 | 0177 | ED | В0 | | | ldir | | | |-----|-------|-----|------|------|---------|--------|------------------|---------------------------| | 123 | 0179 | 26 | 00 | | | 1 d | h,0 | ;indicate register return | | 124 | 017B | | F036 | | | call | XGets1 | get select table address | | 125 | 017E | C1 | | | | pop | bc | • • | | 126 | 017F | E5 | | | | push | h1 | | | 127 | 0180 | 09 | | | | add | hl,bc | | | 128 | 0181 | 09 | | | | add | hl,bc | | | 129 | 0.182 | 36 | 03 | | | 1d | (h1),3 | | | 130 | 0184 | 23 | | | | inc | h1 | | | 131 | 0185 | 36 | 00 | | | 1 d | (h1),0 | | | 132 | 0187 | E1 | | | | pop | h1 | | | 133 | 0188 | 11 | 0026 | | | 1d | de,2*16+3*2 | | | 134 | 0188 | 19 | | | | add | hl,de | | | 135 | 018C | D1 | | | | pop | de | | | 136 | 018D | 73 | | | | 1d | (h1),e | | | 137 | 018E | 23 | | | | inc | h1 | | | 138 | 018F | 72 | | | | 1d | (h1),d | | | 139 | 0190 | 0E | OD | | | 1 d | c,13 | | | 140 | 0192 | C3 | 0005 | | | qį | bdos | | | 141 | | | | | | | | | | 142 | 0195 | 1.1 | 019D | | bnkusg: | 1d | de,bnkmsq | | | 143 | 0198 | 0E | 09 | | | ld | c.9 | | | 144 | 019A | | 0005 | | | jp | bdos | | | 145 | | | | | | | | | | 146 | 0190 | 55 | 73 6 | 1 67 | bnkmsg: | db - | 'Usage: BANK x | :\$' | | 147 | 01A1 | 65 | 3A 2 | 0 42 | | | | • | | 148 | 01A5 | 41 | 4E 4 | B 20 | | | | | | 149 | 01A9 | 78 | 3A 2 | 4 | | | | | | 150 | | | | | | | | | | 151 | DIAC | | | | | ds | 200h-103h-(\$-16 | oadit)1 | | 152 | 0259 | | | | driver: | | | | | 153 | | | | | | .phase | Drvadr | | | 154 | | | | | | | | | | 155 | | | | | | Subttl | Bank Driver | | | 156 | | | | | | page | | | | | | | | | | | | | | 15 | 7 | | | | | | | | |------|-----|------|-----|--------------|----------|------|--------------|----------------------------------| | 15 | | | | | | | | | | 15 | | FA80 | 7 E | | | | . (1.1) | | | | | | 4F | | banked: | | a,(hl) | get driver op; | | 16 | | FAB1 | | | | 1 d | c,a | | | 16 | | FA82 | 23 | | | inc | . h1 | | | 16 | | FA83 | 30 | | | inc | a | | | 16 | | FA84 | 28 | 51 | | jr | z,selbnk | ;if select op | | 16 | 4 . | FA86 | 23 | | | inc | hì | | | 16 | 5 | FA87 | 23 | | | inc | hì | | | 16 | 6 | FA88 | 56 | | | 1 d | d.(hl) | :set track | | 16 | 7 | FA89 | 23 | | | inc | hl | , see thack | | . 16 | | FASA | 23 | | | inc | h) | | | 16 | | FABB | 7 E | | | 1d | a.(h)) | | | 17 | | FABC | 0F | | | | a.(111) | ;set sector | | | | | 5F | | | rrca | | | | 17 | | FABD | | | | ld | e,a | | | 17 | | FABE | 23 | | | inc | hl . | | | 17 | | FA8F | 23 | | | inc | hl | | | 17 | | FA90 | 7 E | | | 1 d | a,(h1) | :set transfer address | | 17 | 5 | FA91 | 23 | | | inc | h1 | | | 17 | 6 | FA92 | 66 | | | 1 d | h,(hl) | | | . 17 | 7 | FA93 | 6F | | | 1 d | 1,a | | | 17 | A | FA94 | 0.6 | 00 | | 1d | b.0 | preset crtldir op | | 17 | | FA96 | 7 C | 00 | | 1d | a,h | ;preset cition op | | 18 | | FA97 | | CO | | | | | | 18 | | | | | | сp | 0c0h | | | | | FA99 | | 01 | | jr | nc,bank1 | ;if transfer outside banked area | | 18 | | FA9B | 05 | | | dec | ь | ;set ram->crt | | 18 | | FA9C | 79 | | bank1: | 1 d | a,c | ;set read/write op | | 18 | | FA9D | В7 | | | or | a | | | 18 | 5 | FA9E | 28 | 02 | | jr | z,bank2 | :if write | | 18 | 6 | FAAO | 06 | 01 | | 1 d | b, 1 | ;set crt->ram | | 18 | 7 | FAA2 | C5 | | bank2: | push | bc | ;save direction op | | 18 | Ŕ | FAA3 | B2 | | | or | d | ;check directory track | | 18 | | FAA4 | | FAC8 | | jp | m,bank6 | ; if directory operation | | 19 | | FAA7 | | 30 | | | 030h | ; ir directory operation | | 19 | | FAA9 | 79 | 30 | | cp | | | | 19 | | | | 0000 | | 1d | a,c | ;set read/write switch | | | | FAAA | | 0080 | | 1 d | bc,128 | | | 19 | | FAAD | | 05 | | jr | c,bank3 | ; if not within screen memory | | 19 | | FAAF | В7 | | | or | a | | | 19 | | FAB0 | | 05 | | jr | nz,bank4 | ;if read | | 19 | | FAB2 | 0 E | 50 | | 1 d | c.80 | only write one line; | | 19 | 7 | FAB4 | В7 | | bank3: | or | а | :test read/write | | 19 | 8 | FAB5 | 28 | 01 | | ir | z,bank5 | ; if write | | 19 | 9 | FAB7 | EB | | bank4: | ex | de .hl | ;set read | | 20 | | FAB8 | F 1 | | bank5: | pop | af | get mover op to A | | 20 | | FAB9 | | 73 FAC4 | builles. | ld | (stksav),sp | use high stack | | 20 | | FABD | | 0000 | | | | ;use might stack | | 20 | | | | | | 1d | sp,stack | | | | | FACO | | F033 | | call | Xcrtmv | ;move it to/from crt bank | | 20 | | FAC3 | 31 | 0000 | | 1 d | sp,0 | | | 20 | | FAC4 | | | stksav | equ | <b>\$</b> -2 | | | 20 | 6 | FAC6 | ΑF | | | xor | a | ;always succeeds | | 20 | 7 | FAC7 | C9 | | | ret | | | | 20 | 8 | FACB | | FADB | bank6: | 1d | de,Direct | ;set directory address | | 20 | | FACE | OD. | <del>-</del> | | dec | C | , | | 21 | | FACC | | 01 | | jr | nz,bank7 | ;if directory write | | 21 | | FACE | EB | ٠. | | ex | de,hl | , in directory write | | 21 | | IACE | 6.0 | | | e ^ | ue, iii | | | | endix I | 223 | | * | | | | vi | | | | |-----|---------|-----|------|-------------|---------|-------|---------------|----------------------------------|----------------------------|--|--| | | 3 | 224 | | | | | | | | | | | | ₽. | 225 | FADB | 00 | Direct: | db | 0 | | | | | | | ₹. | 226 | FADC | 42 4F 4F 54 | D CC | dc | 'B00T R' | | | | | | | _ | 227 | FAEO | 20 20 20 20 | | uc | BOOT K | | | | | | | | 228 | FAE4 | D2 | | | | | | | | | | | 229 | FAE5 | 4F 4D | | db | 'OM' | | | | | | | | | | 00 00 00 40 | | | | | | | | | | | 230 | FAE7 | 00 00 00 40 | | db | 00,00,00,64 | | | | | | | | 231 | FAEB | 01 02 03 04 | | db | 01,02,03,04 | | 0000h-1fffh | | | | | | 232 | FAEF | 05 06 00 00 | | db | 05,06,00,00 | ; | 2000h-2fffh | | | | | | 233 | FAF3 | 00 00 00 00 | | db | 00,00,00,00 | | | | | | | | 234 | FAF7 | 00 00 00 00 | | db | 00,00,00,00 | | | | | | 4 2 | | 235 | | | | | | | | | | | | | 236 | FAFB | 00 | | db | 0 | | | | | | | | 237 | FAFC | 4F 50 54 49 | | db | 'OPTION ROM' | | | | | | | | 238 | FB00 | 4F 4E 20 20 | | | | | | | | | | | 239 | FB04 | 52 4F 4D | | | | | | | | | | | 240 | FB07 | 00 00 00 10 | | db | 00.00.00.16 | ;Bank O Memory locations | 17ffh-1fffh | | | | | | 241 | FBOB | 04 00 00 00 | | db | 04,00,00,00 | , | | | | | | | 242 | FBOF | 00 00 00 00 | | db | 00,00,00,00 | | | | | | | | 243 | FB13 | 00 00 00 00 | | db | 00,00,00,00 | | | | | | | | 244 | FB17 | 00 00 00 00 | | db | 00,00,00,00 | | | | | | | | 245 | 1017 | 00 00 00 00 | | ub | 00,00,00,00 | | | | | | | | 246 | FB1B | 00 | | | 0 | | | | | | | | 247 | FB1C | 53 43 52 45 | | db | | | | | | | | | | | | | db | 'SCREEN MEM' | | | | | | | | 248 | FB20 | 45 4E 20 20 | | | | | | | | | | | 249 | FB24 | 4D 45 4D | | | | | | | | | | | 250 | FB27 | 00 00 00 18 | | db | 0,0,0,24 | | | | | | | | 251 | FB2B | 07 08 00 00 | | db | 07,08,00,00 | Bank O, Memory locations | 3000h-3bffh | | | | | | 252 | FB2F | 00 00 00 00 | | db | 00,00,00,00 | • | | | | | | | 253 | FB33 | 00 00 00 00 | | db | 00,00,00,00 | | | | | | | | 254 | FB37 | 00 00 00 00 | | db | 00,00,00,00 | | | | | | | | 255 | | | | | | | | | | | | | 256 | FB3B | 00 | | db | 0 | | | | | | | | 257 | FB3C | 45 58 50 41 | | db | 'EXPAND RAM' | | | | | | | | 258 | FB40 | 4E 44 20 20 | | | EXTRIB KAM | | | | | | | | 259 | FB44 | 52 41 4D | | | | | | | | | | | 260 | FB47 | 01 00 00 80 | | db | 01,00,00,80h | | | | | | | | 261 | FB4B | O9 OA OB OC | | db | 09,10,11,12 | . Oanti O. Manaani laantiisaa | 4000 | | | | | | 262 | FB4F | OD OE OF 10 | | db | 13,14,15,16 | | 4000h-5fffh<br>6000h-7fffh | | | | | | 263 | | 11 12 13 14 | | | | | | | | | | | | FB53 | 11 12 13 14 | | db | 17,18,19,20 | | 8000h-9fffh | | | | | | 264 | FB57 | 15 16 17 18 | | db | 21,22,23,24 | • | a000h-bfffh | | | | | | 265 | | | | | | | | | | | | | 266 | FB5B | 0000 0000 | dph: | dw | 0,0,0,0 | | | | | | | | 267 | FB5F | 0000 0000 | | | | | | | | | | | 268 | FB63 | FB7F FB6B | | dw | dirbuf,dpb | | | | | | | | 269 | FB67 | 0000 FB7B | | dw | 0,alloc | | | | | | | | 270 | | | | | | | | | | | | | 271 | FB6B | 0002 | dpb: | dw | 2 | ;spt | | | | | | | 272 | FB6D | 04 OF 01 | | db | 4, 15, 1 | ;blkshf, blkmsk, nullmsk | | | | | | | 273 | FB70 | 0018 0003 | | dw | 24,3,128,0,-8 | :dsw.dirm.alloc01,chksiz,trk off | | | | | | | 274 | FB74 | 0080 0000 | | | ,0,,, 0 | ,,_ | | | | | | | 275 | FB78 | FFF8 | | | | | | | | | | | 276 | FB7A | 00 | | ad ba | 0 | 100 5 | | | | | | | | FB/A | UU | | db | 0 | ;128 byte sectors | | | | | | | 277 | | | | | | | | | | ;allocation vector ;directory buffer Subttl System Identification page drvlen equ alloc: ds dirbuf: ds 18 System Identification ``` 286 287 288 :: Verify The machine this program is being run by Murphy or 289 a Xerox 820-II. 290 291 03D8 3A F000 Rea822: 1d a. (monitr) ;make certain system is an 820-II 292 03DB FE C3 Ср 0c3h should be a jump instruction if 820 293 03DD 20 OD ir nz.notii ; if not give error message 294 03DF 2A F001 hl.(monitr+1) :follow reload monitor jump 295 03E2 7 E 1 d a.(h1) 296 03E3 FE F3 ср 0f3h 297 03E5 20 05 nz.notii ; if interrupts not disabled 298 03E7 23 inc hl 299 03E8 7E ١d a.(h1) 300 03E9 FE DB CD 0dbh 301 03EB C8 ret 302 03EC E1 Notii: pop hl :pitch return address 303 03ED 11 0434 1 d de.msq 304 03F0 0E 09 pmsg: ١d c.9 305 03F2 CD 0005 call bdos 306 03F5 C3 0000 jр 307 308 The pointer at Bavail points to the start of free memory, Eavail 309 points to the end of free memory. This test verifies that there 310 is enough space for this program to fit in this un-allocated memory 311 space. If so the Eavail pointer is updated to the start of the driver -1. 312 If not an error message is sent to the console. 313 314 03F8 ED 5B FF3C Ckspac: 1d de.(bavail) ;get pointer to start of free address space 315 03FC 21 FA80 ١d hl.drvadr start of driver 316 03FF В7 317 0400 ED 52 hl.de sbc 318 0402 38 11 c.nroom ; if drvadr < bavail then no space 319 0404 2A FE3E ١d hi.(eavail) get pointer to end of available space 320 0407 11 FBFF ١d de dryadr+drylen 321 040A ED 52 sbc h1.de 322 040C 38 07 c.nroom ; if driver end > end of eavail then no space 323 040E 21 FA80 ١d hl.drvadr :else update end pointer 324 0411 22 FF3E 1 d (eavail),hl 325 0414 C9 ret 326 0415 11 041A ١d nroom: de.nspace 327 0418 18 D6 ir pmsg 328 329 041A 46 72 65 65 Nspace: db 'Free memory space in use,$' 330 041F 20 6D 65 6D 331 0422 6F 72 79 20 332 0426 73 70 61 63 333 042A 65 20 69 6E 334 042E 20 75 73 65 335 0432 2E 24 336 337 0434 54 68 69 73 'This program requires a Xerox 820-II Information Processor.$' 338 0438 20 70 72 6F 339 043C 67 72 61 6D 340 0440 20 72 65 71 ``` | 347 | 045C | 6F | 72 | 6D | 61 | |-----|------|----|----|----|----| | 348 | 0460 | 74 | 69 | 6F | 6E | | 349 | 0464 | 20 | 50 | 72 | 6F | | 350 | 0468 | 63 | 65 | 73 | 73 | | 351 | 046C | 6F | 72 | 2E | 24 | | 352 | | | | | | | 353 | | | | | | | 354 | | | | | | Subttl Symbol Table end | Symbol | Table | | | | | |--------|--------|------|--------|------|--------| | Macros | | | | | | | Symbol | s: | | | | | | FB7B | ALLOC | FA9C | BANK 1 | FAA2 | BANK2 | | FAB4 | BANK3 | FAB7 | BANK4 | FAB8 | BANK5 | | FAC8 | BANK6 | FACF | BANK7 | FA80 | BANKED | | FF3C | BAVAIL | 0005 | BDOS | 0190 | BNKMSC | | 0195 | BNKUSG | 03F8 | CKSPAC | 005C | DECB | | FB7F | DIRBUF | FADB | DIRECT | FB6B | DPB | | FB5B | DPH | 0259 | DRIVER | FA80 | DRVADE | | 017F | DRVLEN | FF3E | EAVAIL | 015C | LOADIT | | F000 | MONITR | 0434 | MSG | 03EC | NOTII | | 0415 | NROOM | 041A | NSPACE | 03F0 | PMSG | | 0308 | REQ822 | FAD7 | SELBNK | 0000 | STACK | | FAC4 | STKSAV | F033 | XCRTMV | F036 | XGETSI | No Fatal error(s) | BANKED | 118 | 159# | | | | |--------|------|------|------|-----|-----| | BAVAIL | 68# | 314 | | | | | BDOS | 71# | 140 | 144 | 305 | | | BNKMSG | 142 | 146# | | | | | BNKUSG | 111 | 142# | | | | | CKSPAC | 113 | 314# | | | | | DFCB | 72# | 109 | | | | | DIRBUF | 268 | 279# | | | | | DIRECT | 208 | 225# | | | | | DPB | 268 | 271# | | | | | DPH | 218 | 266# | | | | | DRIVER | 117 | 152# | 282 | | | | DRVADR | 74# | 153 | 315 | 320 | 323 | | DRVLEN | 121 | 282# | 320 | | | | EAVAIL | 69# | 319 | 324 | | | | LOADIT | 81 | 108# | 151 | | | | MONITR | 64# | 65 | 66 | 291 | 294 | | MSG | 303 | 337# | | | | | NOTII | 293 | 297 | 302# | | | | NROOM | 318 | 322 | 326# | | | | NSPACE | 326 | 329# | | | | | PMSG | 304# | 327 | | | | | REQ822 | 108 | 291# | | | | | SELBNK | 163 | 218# | | | | | STACK | 75# | 202 | | | | | STKSAV | 201 | 205# | | | | | XCRTMV | 65# | 203 | | | | | XGETSL | 66# | 124 | | | | | | | | | | | Title Position encoded keyboard handler Position encoded keyboard handler for the 820-II & 16/8 professional computer. Copyright 1983 (C) XEROX Corporation This is the stand alone rom addition to the Xerox 820-II monitor. It is called once during monitor restart and at that time patches the monitor in ram to call the modified kNp.crt.Screenprint and printer routines. It then moves in its own SIGNON overlay and jumps into it. This SIGNON in addition to selecting the disk driver also moves into ram (in the spare driver area) translation tables and code for k/b and printer routines (crt is run out of rom). There is also a RX BOOT overlay which is selected instead of the Xerox one. This loads the national translation tables from disk and then calls the Xerox BOOT. .z80 ; ; def1 013 subttl Xerox ROM dependant equates page <u>-</u> **Appendix** Position encoded keyboard handler Xerox ROM dependant equates ``` 87 F20E x/f20e1 spact eau 88 F319 0f319h gold equ 89 F360 seltab equ 0f360h 90 F470 fivdpb equ 0f470h 91 F708 rigdpb equ 0f708h 92 F800 tabled equ 0f800h :space for rx code 93 FA11 phytrk equ 0fa11h 94 FF3C availb equ x'ff3c' :bottom available ram memory 95 FF50 intstk equ x'ff50' :temporv stack address 96 FF54 steprt equ Off54h 97 FF5C linbuf equ Off5ch 98 FFAC cursor equ Offach 99 FFB2 leadin equ Offb2h 100 FFB3 attrib equ Offb3h :address of attributes enabled flag 101 FFB4 chrsav equ Offb4h 102 103 Port addressess 104 105 0010 sysctl 1dh 106 001C syspio eau 1ch 107 0005 siodob 05h eau 108 0010 wd1797 equ 10h 109 001E kbdat 1eh eau 110 0019 ctc1 equ x'19' :ctc1 port address 111 112 Other Equates 113 114 0081 x'81' encntr egu ;enable ctc command 115 0001 stentr x'01' stop ctc command equ 116 0000 x'00' rev0 eau ;4.00 Revision Level 117 0001 revi equ x'01' :4.01 Revision Level 118 0064 rev50 eau 5 * 100 - 400 ;5.00 Revision level 119 0030 cnfgoff equ x'3c' :monitor configuration offset 120 0006 cnfbyte equ x'06' ;configuration subroutine byte offset 0008 121 x'08' kblp eau configuration bit id for LPKYBD 122 0008 romofs equ x'08' :PROMPT offset between 4.02 & 4.01 monitor 123 0001 lpkofs x'01' equ :additional sector required for table storage 124 007B upper equ 'z'+1 supper limit for alpha test 125 0061 lower equ 'a' :lower limit for alpha test 126 0020 upascii equ 'a'-'A' ;set to upper case ASCII mask 127 0000 0 zero equ :zero 128 OOFF setflg equ x'ff' :set flag 129 130 Equates 131 132 0004 04 c.five equ 133 0006 06 c.sasi eau 134 0001 o.term equ 0001h 135 0300 sasidl 300h eau 136 137 Internal equates 138 139 001D rtab1 equ 29 :rigid disk tables sector 1 140 001E 30 rtab2 equ 141 0004 ftab1 equ 04 :floppy 142 0005 ftab2 05 eau ``` 09-Dec-81 MACRO-80 3.44 | 177 | 0000 | Pilit | - | 00 | , or race or printer riag in index table | |-----|------|--------|--------|----------------|------------------------------------------| | 148 | 0004 | kbrdtb | equ | 04 | offset of k/b tables in first sector | | 149 | 001A | clrs | equ | 1ah | ;clear screen | | 150 | 001B | esc | equ | 1bh | ;escape key | | 151 | 0004 | eot | equ | 04h | end of text | | 152 | 000D | cr | equ | 0dh | ;carriage return | | 153 | 000A | 1 f | equ | 0ah | ; line feed | | 154 | | | | | | | 155 | | | subttl | RX1984 Restart | | | 156 | | | page | | | | | | | | | | RX1984 Restart ``` 157 158 159 0000 start: 160 .phase rx1984 161 162 RX1984 163 Entry here from Xerox monitor bfore entering SIGNON. 164 165 Input:- 166 hl - cmdtab 167 de - seltab 168 bc - cloc 169 170 171 1800 C5 push bc 172 1801 D5 push de 173 1802 E5 push h1 174 1803 21 0000 ۱d h1.0 175 1806 CD F03C call config get monitor configuration 176 1809 7 C 1 d a.h 177 180A FE 00 CP rev0 178 180C CA 187E jρ z.noload ;skip if below 4.01 179 180F FE 64 СР rev50 180 1811 D2 187E jp nc.noload ;skip if 5.00 or above 181 1814 21 1B1A ١d hl,rv1tbl :4.01 spring board table 182 1817 FE 01 СD rev1 183 1819 28 03 ir z.thxfer ;skip if 4.01 184 181B 21 1829 ١d hl.rv2tbl :4.02+ spring board table 185 181E 11 F06C tbxfer: 1d de, mntrex 186 1821 01 000F ١d bc.itblsz 187 1824 F5 push :save monitor level 188 1825 ED BO ldir ;append monitor table with lpkybd jmp vectors 189 1827 DD 2A FO3D ١d ix.(monitr+cnfgoff+1) :set address at monitor config: 190 182B DD 7E 06 1 d a. (ix+cnfbvte) 191 182E F6 08 ٥r kblp :set low profile bit flag 192 1830 DD 77 06 ١d (ix+cnfbvte).a 193 1833 F 1 pop recover monitor level 194 195 Alter BOOT commnd vectors :: 196 197 1834 DD E1 pop íх :cmdtab address 198 1836 DD E5 push iх 199 1838 DD 36 02 3D' (ix+boff1), low rxboot 1d :assume 4.01 monitor 200 183C DD 36 03 06 (ix+boff1+1),high rxboot 1 d 201 1840 DD 36 18 3D' 1d (ix+boff2).low rxboot 202 1844 DD 36 19 06' ١d (ix+boff2+1),high rxboot 203 1848 FE 01 rev1 :monitor check CD 204 184A 28 10 jr z.soout :skip if 4.01 monitor 205 184C DD 36 02 45' Īd (ix+boff1),low (rxboot+romofs) ;4.02+ monitor boot over addr 206 1850 DD 36 03 06 ١d (ix+boff1+1).high (rxboot+romofs) 207 1854 DD 36 18 45' ١d (ix+boff2),low (rxboot+romofs) 208 1858 DD 36 19 06' (ix+boff2+1).high (rxboot+romofs) 209 210 Alter keyboard interrupt service :: 211 ``` | 216 | | | | | | | |-----|-------|----------|---------|---------|------------------|-----------------------------------------| | 217 | | | :: | Move in | RX SIGNON to o/1 | area and execute it | | 218 | | | : | | | | | 219 | 186C | E1 | | pop | hl | | | 220 | 186D | D1 | | рор | de | | | 221 | 186E | C1 | | рор | bc | | | 222 | 186F | C1 | | рор | bc | throw away return address | | 223 | 1870 | 21 0552' | | Ìd | hl,rxsign | rom address | | 224 | 1873 | 11 FC5D | | 1d | de,tca | ;o/l area | | 225 | 1876 | 01 00EB | | 1 d | bc,rxsig1 | ; length | | 226 | 1879 | ED BO | | ldir | | | | 227 | 1878 | C3 FC5D | | jp | tca | GO SIGN ON | | 228 | 187E | E1 | noload: | pop | hl | | | 229 | 187F | D1 | | pop | de | | | 230 | 1880 | C1 | | pop | bc | | | 231 | 1881 | 3E FF | | 1 d | a,x'ff' | :wrong monitor | | 232 | 1883 | A7 | | and | | ; load signon from monitor | | 233 | 1884 | C9 | | ret | _ | • • • • • • • • • • • • • • • • • • • • | | 234 | 1,554 | 00 | | | | | | 235 | | | | subtti | ROM resident CRT | Driver | | 236 | | | | page | | T T. | | | | | | | | | 237 238 ROW resident CRI Driver ``` 239 Crtdyr - Crt Driver RX Addition. : : 240 241 1885 2A FEAC Rxcrt: 1 d hl, (cursor) set cursor address 242 1888 3A FFB4 1 d a (chrsav) :retrieve character under cursor 243 188B 77 1 d (hl).a :replace character under cursor 244 1880 32 F319 1d (oold),a :bury balcones gold 245 188F 3A FFB2 1 d a. (leadin) set leadin state 246 1892 or 247 1893 C2 0196 nz.crtd2 :if processing escape sequence 248 1896 3A FOE3 ia a, (mask) get keyboard mask 249 1899 Δ1 and ٠. 250 189A 14 c.a 251 189B FE 20 cn 252 189D DA 0196 ip c.crtd2 :if control code 253 1840 CD 18A6 call fonchk :do font translation 254 18A3 C3 0182 ip crtd1 on to XR code 255 256 Subroutine fonchk does the font translation for national :: 257 character sets. 258 entry: C contains the character 259 exit: C contains the translation 260 261 1846 E5 Fonchk: push h1 :save cursor posn. 262 18A7 79 10 a.c get char in a 263 1848 F6 80 and 10000000b :preserve attribute bit 264 1844 F5 push af 265 18AB 21 FFB3 ìa hl.attrib ;point to attribute enabled flag 266 18AF or (h1) :test if set 267 18AF 28 OA z.fon1 :no attribute bit - go do translation 268 1881 11 0100 Ìα de,grpad :check if graphics mode 269 1884 2A F339 1 d hl.(prvatt) :current attribute mode 270 1887 ED 52 sbc hl.de 271 1889 28 OF z.fon2 :grahics mode - no translate 272 1888 79 fon1: Ìα a.c there to do translate 273 18BC CB BF res 7.a :clear attribute bit 274 18BE 21 F960 ١d hl.fontbl ;address of exceptions table 275 1801 01 0000 ld bc.fontsz :size of exceptions table 276 18C4 ED B1 coir ;search for char, in exceptions 277 1806 ΔF 1d c.a :restore char to c 278 18C7 CC 18CF call z.fntran : if found do translation 279 18CA F1 fon2: pop af retrieve attribute bit 280 18CB B١ or С or it in 281 18CC 4F 1d c,a 282 18CD E١ pop hì :retrieve cursor 283 18CE C9 ret 284 285 s/r fntran translates font characters :: 286 entry: (HL) - address+1 of char to be translated in fontbi 287 exit: (c) - translated character 288 289 18CF 28 Fntran: dec :back to byte to be translated 290 1800 01 000D 1d bc.fontsz :size of table 291 18D3 09 add hì,bc ;add to address of char, to be translated ``` Appendix | 348 | 1918 | В7 | | | or | а | | |-----|------|-----|------|-----------------------------------------|---------|------------|---------------------------------------------| | 349 | 1919 | 20 | 22 | | ir | nz,pos04 | | | 350 | 191B | 79 | | | 1d | | ; yes | | 351 | | | | | | a,c | | | | 191C | | 1B | | СР | esc | ;escape char? | | 352 | 191E | | 07 | | jr | nz,pos01 | ;no | | 353 | 1920 | | 1959 | | call | posout | ;output char | | 354 | 1923 | 32 | F9A6 | | 1 d | (escsq),a | ;set escape sequence flag | | 355 | 1926 | C9 | | | ret | | tant anabe andanies tras | | 356 | 1927 | | | pos01: | | | ;not escape char | | 357 | 1927 | CD | 1966 | posor. | call | | | | 358 | | | 00 | | | potran | do translation if neccessary; | | | 192A | | | | jr | nz,pos03 | ;wasn't neccessary | | 359 | 192C | | 7 F | | bit | 7,a | escape marker set? | | 360 | 192E | | 09 | | jr | z.pos02 | :no | | 361 | 1930 | 4F | | | 1 d | c,a | | | 362 | 1931 | 3 E | 18 | | 1 d | a,esc | | | 363 | 1933 | CD | 1959 | | call | posout | ;output escape char | | 364 | 1936 | 79 | 1000 | | ld | | ;output escape char | | 365 | 1937 | | BF | | | a,c | | | | | CB | ВР | | res | 7,a | ;clear escape marker | | 366 | 1939 | | | pos02: | | | escape marker not set; | | 367 | 1939 | | | pos03: | | | ;no translation | | 368 | 1939 | CD | 1959 | | call po | sout | output char | | 369 | 193C | C9 | | | ret | | , | | 370 | 193D | | | pos04: | | | ;escape sequence | | 371 | 193D | ce | FF | pusua: | | Offh | | | 372 | 193F | | 06 | | сÞ | | ;3rd_byte? | | | | | 06 | | jr | nz,pos05 | ;no 2nd | | 373 | 1941 | 79 | | | ١d | a,c | | | 374 | 1942 | | 1959 | | call | posout | ;output char | | 375 | 1945 | 18 | 0D | | ir | pos06 | | | 376 | 1947 | 79 | | pos05: | 1 d | a,c | ;2nd byte of escape sequence | | 377 | 1948 | CD | 1959 | ,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,, | call | posout | output byte | | 378 | 194B | | 1986 | | call | poesc | | | 379 | 194E | | 04 | | | | search escape table for char | | | | | | | jr | nz,pos06 | ;not present2 byte sequence | | 380 | 1950 | | FF | | ld | a,Offh | ;set sequence for 3rd byte | | 381 | 1952 | | 01 | | jr | pos07 | | | 382 | 1954 | ΑF | | pos06: | xor | a | end of 2 byte sequence | | 383 | 1955 | 32 | F9A6 | pos07: | 1 d | (escsq),a | toggle escape sequence flag | | 384 | 1958 | C9 | | • | ret | | , | | 385 | 1959 | 47 | | posout: | | b.a | | | 386 | 195A | | F03F | siox1; | | siordy | | | 387 | 195A | | | STOXI: | | | | | | | | F066 | | call | z,idle | | | 388 | 1960 | | F8 | | jr | z,siox1 | | | 389 | 1962 | 78 | | | ld | a,b | | | 390 | 1963 | D3 | 05 | | out | (siodpb),a | | | 391 | 1965 | C9 | | | ret | | | | 392 | | | | | | | | | 393 | | | | 11 . | 004000 | | | | 394 | | | | | Potran | | er translation if neccessary and returns | | | | | | ; | | | indicate if translation has been done. | | 395 | | | | ; | | input- a | char for translaation | | 396 | | | | ; | | | | | 397 | | | | ; | | output- a | (translated) char | | 398 | | | | | | | set if char is translated (otherwise reset) | | 399 | | | | į | | - | | | 400 | 1966 | 21 | F97A | Potran: | 1.4 | hl.prntbl | .anint avanations table | | 401 | 1969 | | 0016 | FULL An: | | | print exceptions table | | | | | | | 1 d | bc,prntsz | ;size of table | | 402 | 196C | | B 1 | | cpir | | | | 403 | 196E | CO | | | ret | nz | ;no match - don't translate | | | | | | | | | | ROM resident CRT Driver ``` 460 199A CB 7F hit cmd.a .command byte? 461 1990 28 17 ir z.kvpos skip to position byte handler 462 199E 18 01 cmdb ir skip to command byte handler 463 1940 nochar equ ¢ 464 1940 7 A peknoc2:1d a.d :clear command byte (non-valid position byte) 465 19A1 32 F9A7 :save command-status byte cmdb: 1 d (cmdstat).a 466 1944 CB SE bit mouse.a :mouse cmd? 467 1946 28 05 z.neknoc skip if not mouse ir 468 1948 21 F95D 1.0 hl msthl 469 19AB CB BE res xv.(h1) 470 1940 CD 1466 peknoc: call stpctcl :reset repeat flag 471 1980 37 peknoc1:scf this no the position byte 472 1981 D1 pekex: pop de recover registers 473 19B2 C3 F9B7 ai lokext :imp instead of ret - small interrupt stack 474 1985 5.6 kypos: 1d e.a ;save position code 475 1986 21 F9A7 1 d hl.cmdstat :fetch command byte 476 1989 CB 7F bit cmd.(h1) out of sync check 477 19BB 28 FO ir z.peknoc quit if no command byte 478 19BD CB 5F hit mouse.(hl) :test for mouse movement 479 19BF C2 1A7D nz.mice in skin if mouse moved 480 19C2 CB 76 hit ustrk.(hl) :test key posistion 481 19C4 20 20 ir nz.upstrk : jump if special upstroke 482 1906 CD 19DB call ctrtst :test for control codes 483 1909 28 D5 ir z.peknoc2 quit if non printable control character 484 19CB CD 19FF call tblsel :select translation table 485 19CF CD 1A23 call alphtst :test for alpha lock char 486 19D1 CD 1A3D call rotst ;test for repeat keys 487 1904 21 F9A7 charout:1d hl.cmdstat :fetch command byte 488 1907 72 ١d (h1).d :clear command byte (valid position byte) 489 19D8 Α7 and а :clear carry 490 1909 18 06 jr pekex 491 492 Character is tested for the lock, shift, and ctrl key station. :: 493 494 input a - key station code 495 496 output z - set if lock, shift, or ctrl key station 497 498 19DB E5 Ctrtst: push ;save registers 499 19DC 21 F953 14 hl.ctrltb ;non printable char table 500 19DF 01 0006 14 bc.cntctr :byte count of table 501 19E2 ED B1 cpir :search table 502 19E4 E 1 pop h1 503 19F5 C9 ret 504 505 :: The up-stroke is tested for special up-stroke key-stations. 506 507 input a - key station code 508 strkup - user enable flag 509 510 output a - translated up-stroke key-station code 511 512 19E6 21 F95D Upstrk: 1d hl.mstbl :user enable up-stroke flag CB 5E strkup.(h1) 513 19E9 bit 514 19EB 28 83 z.nochar :quit if user inhibited ir 515 19ED 21 F959 1d hl.ups :exception key-station table ``` Appendix KOM resident CRI Driver ``` 572 input hl - command-status address 573 a - translated character 574 575 output a - upper case exception 576 577 1A30 21 F935 Alphexc:ld hl.captab ;lock exception table 578 1A33 01 0003 1 d bc,cptbsz :table size 579 1A36 ED B1 cpir :search 580 1A38 CO ret nz auit if not found 581 1A39 23 inc h1 :get exception 582 1A3A 23 inc h1 583 1A3B 7 E 1 d a,(h1) 584 1A3C Ca ret 585 586 Checks for repeat character. If repeat character, the millisec :: 587 timer is vector address is modified and the timer is set up 588 for 0.5 second. The timer is kicked off. 589 590 input a - translated character 591 592 1A3D 21 F940 Rptst: ١d hl.rptbl ;repeat char table 593 1A40 01 0013 ١d bc, cntrp :number of repeat chars 594 1A43 ED B1 cpir :test for repeat chars 595 1845 CO ret nz ; quit if not repeat char 596 1A46 2A F93C ld hl,(tick) :millisec count 597 1A49 22 F9A8 1 d (millignt),hl :save it in table 598 1A4C 21 F9AA 1 d hl,rptchar repeat char save address 599 1A4F 77 1 d (h1).a ;save repeat char F5 600 1A50 af push 601 1A51 23 inc :repeat flag address 602 1A52 36 FF ١d (hl), setflg ;set repeat flag 603 1A54 2A FF12 ١d h1.(ctcvec+2) :get 1 millisec interrupt vector 604 1A57 22 F9AC 1 d (save).hl :save it 605 1454 21 F9D0 1 d hl, rptclk kybd repeat key timer 606 1A5D 22 FF12 ١d (ctcvec+2).hl substitute it 607 1460 3F 81 1 d a.encntr :enable millisec timmer 608 1A62 D3 19 out (ctc1).a :do it 609 1A64 F 1 DOD af ;recover character 610 1A65 C9 ret 611 612 ;; This routine stops the millisecond timer and restores the 613 original timer vector 614 615 1A66 21 F9AB Stpctc1:1d hl,rptflg :fetch repeat char flag 616 1469 7 E ١d a.(hl) 617 1A6A Α7 and а ;set flags 618 1A6B C8 ret quit if no repeat keys 619 1A6C 72 ١d (h1),d ; clear repeat char flag 620 1A6D 2A F9AC ١d hl.(save) ;original 1 millisec interrupt address 621 1A70 22 FF12 1 d (ctcvec+2),hl :restore it 622 1A73 3A F20E 1 d a.(spact) ;fetch screen print flag 623 1A76 Α7 and CO 624 1A77 ret nz :don't kill timer, if screen printing 625 1A78 3E 01 1 d a.stcntr stop timer 626 1A7A D3 19 out (ctc1).a ``` ret 627 1A7C C9 1d ix.(msptr) :fetch user's table 683 1484 DD 2A F95E ``` 747 output a = mstbl 748 749 1800 7 A Mice2: 1d a.d :msb position test вс 750 1801 h 38 04 ;skip if msb too big 751 1802 in c,mice21 752 1804 7B ١d a.e :1sb position test 753 1805 BD ср 754 30 01 1806 nc.mice22 :skip if lsb is not too big 755 1808 EB mice21: ex de.hl :force maximum limit 756 3A F95D 1809 mice22: 1d a.(mstbl) :mouse table 757 1B0C CB 4F complement xy flag bit xy,a 758 28 04 180E ir z.mice23 759 1B10 CB 8F res xy,a 760 1812 18 02 mice24 761 1B14 CB CF mice23: set xv.a 762 1816 32 F95D mice24: 1d (mstbl).a :update table 763 1B19 C9 ret 764 765 :: Jump table for keyboard translator and interrupt handler. 766 Exit points and monitor adjustment points for the SIGNON 767 : overlay and boot overlay 768 769 1B1A C3 F9AF Rv1tb1: jp lokybd :4.01 monitor lpkybd jump table 770 C3 F167 181D mkey2 jр 771 1820 C3 F18F mkev5 jρ 772 1B23 C3 FC3D mpnext jр 773 1826 C3 FA95 jp. mprmt0 774 000F itblsz egu $-rv1tb1 775 776 1829 C3 F9AF rv2tbl: jp lokybd :4.02 monitor lpkybd jump table 777 1B2C C3 F167 jp mkey2 778 1B2F C3 F18F jρ mkev5 779 C3 FC45 1832 jp mpnext+romofs 780 1B35 C3 FA9D ip mprmt0+romofs 781 782 The keyboard tables are restored to the original default values ;; 783 that are stored in rom : 784 785 1B38 C5 Movtbl: push bc D5 786 1B39 push de 787 1B3A E5 oush h1 788 21 034A 1B3B 1 d hl.tables 789 1B3E 11 F800 1 d de.tabled 790 1841 01 0159 1 d bc,tablex 791 ED BO 1844 ldir 792 1846 E 1 h1 pop 793 1847 D 1 pop de 794 1848 C 1 bc DOD 795 1849 C9 ret ``` x or y max value 745 746 .dephase subttl RAM resident (Tables) page Position encoded keyboard handler ROM resident CRT Driver 796 797 798 799 Appendix J | 804 | 0010 | | · | | .radix | 16 | | |------------|--------------|----------------------------|---|------------|---------|----------------------------------------|---------------------------------------| | 805<br>806 | | | | ;; | k/b uns | hifted table | | | 807<br>808 | F800 | 00 1B 31 32 | | ;<br>Tabl: | defb | 00h,1bh,31h,32h,33h,34h,35h,36h | ;nul,esc,1,2,3,4,5,6 | | 809<br>810 | F804<br>F808 | 33 34 35 36<br>37 38 39 30 | | | defb | 37h,38h,39h,30h,2dh,3dh,08h,09h | ;7,8,9,0,-,=,bs,tab | | 811<br>812 | F80C<br>F810 | 2D 3D 08 09<br>71 77 65 72 | | | defb | 71h,77h,65h,72h,74h,79h,75h,69h | ;q,w,e,r,t,y,u,i | | 813<br>814 | F814<br>F818 | 74 79 75 69<br>6F 70 5B 5D | | | defb | 6fh,70h,5bh,5dh,0dh,0ee,61h,73h | ;o,p,[,],cr,lctrl,a,s | | 815<br>816 | F81C<br>F820 | 0D EE 61 73<br>64 66 67 68 | | | defb | 64h,66h,67h,68h,6ah,6bh,6ch,3bh | ;d,f,g,h,j,k,l,; | | 817<br>818 | F824<br>F828 | 6A 6B 6C 3B<br>27 DA EC 2E | | | defb | | · · · · · · · · · · · · · · · · · · · | | 819 | F82C | 7A 7B 63 76 | | | | 27h,0ah,0ec,2eh,7ah,78h,63h,76h | ;',lf,lshift,.,z,x,c,v | | 820<br>821 | F830<br>F834 | 62 6E 6D 2C<br>2E 2F ED 1E | | | defb | 62h,6eh,6dh,2ch,2eh,2fh,0ed,1eh | ;b,n,m,,,,/,rshift,help | | 822<br>823 | F838<br>F83C | EF 20 EB F1<br>F2 F3 F4 F5 | | | defb | 0ef,20h,0eb,0f1,0f2,0f3,0f4,0f5 | ;rctr1,sp,f1,f2,f3,f4,f5 | | 824<br>825 | F840<br>F844 | F6 F7 F8 F9<br>FA FB FC 37 | | | defb | 0f6,0f7,0f8,0f9,0fa,0fb,0fc,37h | ;f6,f7,f8,f9,f10,f11,f12,7 | | 826<br>827 | F848<br>F84C | 38 39 2C 34<br>35 36 BD 31 | | | defb | 38h,39h,2ch,34h,35h,36h,0bd,31h | ;8,9,,,4,5,6,=enter,1 | | 828<br>829 | F850<br>F854 | 32 33 30 E7<br>82 84 83 80 | | | defb | 32h,33h,30h,0e7,82h,84h,83h,80h | ;2,3,0,next,darr,larr,rarr,h | | 830 | F858 | 81 E6 FD 7F | | | defb | 81h,0e6,0fd,7fh,2bh,2dh,2ah,2fh | ;uarr,prev,acc,del,+,-,mul,d | | 831<br>832 | F85C<br>F860 | 28 2D 2A 2F<br>FO 18 8E 8F | | | defb | 0f0,18h,8eh,8fh,0a0,0a2,0a4 | ;ins,can,msw1,msw2,rx1,rx2,r | | 833<br>834 | F864 | AO A2 A4 | | | | | | | 835<br>836 | | | | :: | k/b shi | fted | | | 837<br>838 | F867<br>F86B | 00 1B 21 40<br>23 24 25 5E | | Shtab: | defb | 00h, 1bh, 21h, 40h, 23h, 24h, 25h, 5eh | ;nul,esc,!,@,#,\$,%,^ | | 839<br>840 | F86F<br>F873 | 26 2A 28 29<br>5F 2B 08 09 | | | defb | 26h,2ah,28h,29h,5fh,2bh,08h,09h | ;&,*,(,),_,+,bs,tab | | 841 | F877 | 51 57 45 52 | | | defb | 51h,57h,45h,52h,54h,59h,55h,49h | ;Q,W,E,R,T,Y,U,I | | 842<br>843 | F87B | 54 59 55 49<br>4F 50 7B 7D | | | defb | 4fh,50h,7bh,7dh,0dh,0ee,41h,53h | ;0,P,{,},cr,lcrt1,A,S | | 844<br>845 | F883<br>F887 | OD EE 41 53<br>44 46 47 48 | | | defb | 44h,46h,47h,48h,4ah,4bh,4ch,3ah | ;D,F,G,H,J,K,L,: | | 846<br>847 | F88B<br>F88F | 4A 4B 4C 3A<br>22 OA EC 2E | | | defb | 22h,0ah,0ec,2eh,5ah,58h,43h,56h | ;", lf, lshift,,Z,X,C,V | | 848<br>849 | F893<br>F897 | 5A 58 43 56<br>42 4E 4D 3C | | | defb | 42h,4eh,4dh,3ch,3eh,3fh,0ed,1eh | ;B,N,M,<,>,?,rshift.help | | 850<br>851 | F89B<br>F89F | 3E 3F ED 1E<br>EF 20 EB F1 | | | defb | Oef,20h,0eb,0f1,0f2,0f3,0f4,0f5 | ;rctr1,sp,lock,f1,f2,f3,f4,f | | 852<br>853 | F8A3<br>F8A7 | F2 F3 F4 F5<br>F6 F7 F8 F9 | | | defb | 0f6,0f7,0f8,0f9,0fa,0fb,0fc,37h | ;f6,f7,f8,f9,f10,f11,f12,7 | | 854 | FBAB | FA FB FC 37 | | | 0610 | 010,017,010,019,018,010,016,37h | ;10,17,10,19,710,711,712,7 | | • | | | | | | | | | | | | |----------|------------|--------------|-----|----------|-----|------------|------------------|---------|-----------------------|------------------|---------------------------------------------| | bendix J | 855 | FBAF | | 39 | | | | defb | 38h,39h,2ch,34h, | 35h,36h,0bd,31h | ;8,9,,,4,5,6,=enter,1 | | <u>م</u> | 856<br>857 | F8B3<br>F8B7 | | 36<br>33 | | | | defb | 32h,33h,30h,0e7, | 825 845 835 805 | ;2,3,0,next,darr,larr,rarr,h | | č | 858 | F8BB | 82 | 84 | 83 | 80 | | | | | | | _ | 859<br>860 | F8BF<br>F8C3 | | E6 | | | | defb | 81h,0e6,0fd,7fh, | 2bh,2dh,2ah,2fh | ;uarr,prev,acc,del,+,-,mul,d | | | 861 | F8C7 | FO | 18 | 8E | 8F | | defb | Of0.18h.8eh.8fh. | 0a1.0a3.0a5 | ;ins,can,msw1,msw2,rx1,rx2,r | | | 862 | F8CB | A 1 | ΑЗ | Α5 | | | | | | , ,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,, | | | 863<br>864 | | | | | | ;; | k/b cod | ied. | | | | | 865 | | | | | | ; | K/D COU | | | | | | 866 | FBCE | | 9B | | | Cdtab: | defb | 00h,9bh,91h,92h, | 93h,94h,95h,96h | ;nul,esc,1,2,3,4,5,6 | | | 867<br>868 | F8D2<br>F8D6 | | 94<br>98 | | | | defb | 97h,98h,99h,90h, | 1fh 9ah 88h 89h | ;7,8,9,0,-,=,bs,tab | | | 869 | F8DA | 1 F | 9 A | 88 | 89 | | | 0711,0011,0011,0011, | , 54, 55, 55 | ,,,0,3,0, ,-,03,180 | | | 870<br>871 | FBDE<br>FBE2 | | 17<br>19 | | | | defb | 11h,17h,05h,12h, | 14h,19h,15h,09h | ;q,w,e,r,t,y,u,i | | | 872 | F8E6 | | 10 | | | | defb | Ofh, 10h, 1bh, 1dh, | Adh Ose Olb 13h | ;o,p,[,],cr,lctrl,a,s | | | 873 | F8EA | 8D | EE | 01 | 13 | | | | | | | | 874<br>875 | FBEE<br>FBF2 | 04 | 06<br>0B | 07 | 08 | | defb | 04h,06h,07h,08h, | 0ah,0bh,0ch,7eh | ;d,f,g,h,j,k,1,~ | | | 876 | F8F6 | | 8A | | | | defb | 60h,08a,0ec,0ae, | lah.18h.03h.16h | ;',lf,lshift,.,z,s,c,v | | | 877 | FBFA | | 18 | | | | | | | | | | 878<br>879 | FBFE<br>F902 | 70 | 0E<br>5C | ED. | 1 C<br>9 F | | defb | 02h,0eh,0dh,1ch, | 7ch,5ch,0ed,9eh | ;b,n,m,,, ,rshift,help | | | 880 | F906 | EF | 00 | EВ | D1 | | defb | Oef,00h,0eb,0d1, | 0d2,0d3,0d4,0d5 | ;rctr1,sp,lock,f1,f2,f3,f4,f | | | 881<br>882 | F90A<br>F90E | | D3<br>D7 | | | | | | | | | | 883 | F912 | | DB | | | | defb | 0d6,0d7,0d8,0d9, | 0da,0db,0dc,0b7 | ;f6,f7,f8,f9,f10,f11,f12,7 | | | 884 | F916 | 88 | В9 | AC | 84 | | defb | 0b8,0b9,0ac,0b4, | 0b5,0b6,0fe,0b1 | ;8,9,,,4,5,6,=enter,1 | | | 885<br>886 | F91A<br>F91E | | B6<br>B3 | | | | defb | 052 052 050 0-7 | 025 045 025 1-5 | 0.00 | | | 887 | F922 | 02 | 04 | 03 | 1 E | | derb | 0b2,0b3,0b0,0c7, | uzn,u4n,u3n, ien | ;2,3,0,next,darr,larr,rarr,h | | | 888 | F926 | | C6 | | | | defb | 01h,0c6,0dd,0ff, | Oab,Oad,Oaa,Oaf | ;uarr,prev,acc,del,+,-,mul,d | | | 889<br>890 | F92A<br>F92E | | AD<br>DE | | | | defb | 0d0,0de,8eh,8fh, | 008 009 009 | ;ins,can,msw1,msw2,rx1,rx2,r | | | 891 | F932 | | C9 | | | | 00.0 | 000,000,000,000,0111, | 000,000,000 | ; 1115, Call, 1115W1, 1115W2, 17X1, 17X2, 1 | | | 892<br>893 | 0004 | | | | | | | •• | | | | | 894 | 000A | | | | | | .radix | 10 | | | | | 895 | F935 | | 00 | | | captab: | | 0,0,0 | ;table of excep | tions requiring shifting for | | | 896<br>897 | F938<br>0003 | 00 | 00 | 00 | | cptex: | | 0,0,0 | | (3 excepts then 3 translates) | | | 898 | F93B | 00 | | | | cptbsz | | (\$-captab)/2<br>0 | ;size of table | | | | 899 | F93C | F4 | | | | shftlck<br>tick: | defb | low hifsec | | all keys to shift table if lock set | | | 900 | F930 | 01 | | | | tick: | defb | high hlfsec | ;isb - repeat c | nar speed | | | 901 | F93E | 3F | | | | tock: | defb | | ;msb | | | | 902 | F93F | 00 | | | | tock: | defb | low tenths | ;lsb | | | | | | UU | | | | | | high tenths | ;msb | | | | 903 | 01F4 | | | | | hlfsec | equ | 500 | ;0.5 second cou | nt | | | 904 | 003F | | | | | tenths | equ | 63 | ;16 chars/sec | | | | 905 | | | | | | | | | | | | | 906 | F940 | | OA | | 20 | rptb1: | defb | x'08',x'0a',x'0c | 1',x'20' | ;bs,lf,cr,sp | | | 907 | F944 | | 2E | | | | defb | x'2d',x'2e',x'2f | | :-,/ | | | 908 | F947 | | 58 | | | | defb | x'3d',x'58',x'78 | | ;=,X,x,de1 | | _ | 909 | F94B | | 82 | | | | defb | x'81',x'82',x'83 | 3′,×′84′ | ;ucur,dcur,rcur,lcur | | 19 | 910 | F94F | ΕO | ΕO | ΕO | ΕO | rptex: | defb | x'e0',x'e0',x'e0 | )′,×′e0′ | ;16 TBD repeat keys | | _ | | | | | | | | | | | | Appendix J | 915 | F958 | EU | | | | | ctrlex: | đb | x'e0' | : 19 TB | D additional key stations | |------------|--------------|-----|----|-----|-----|--|----------|--------|-------------------------|-----------------------------------------|---------------------------------| | 916 | 0006 | | | | | | cntctr | equ | \$-ctrltb | , | | | 917 | 0159 | | | | | | tablex | equ | \$-tabl | | | | 918 | | | | | | | | | | | | | 919 | F959 | ΕO | | | | | ups: | defb | x'e0',x'e0' | ;upstroke exception ke | | | 920 | F95B | E0 | E0 | | | | upsx: | defb | x'e0',x'e0' | ;upstroke char or code | translations | | 921 | 0002 | | | | | | upssz | equ | (\$-ups)/2 | ;size | | | 922 | F95D | 00 | | | | | mstbl: | defb | 0 | ;mouse table | | | 923 | 0007 | | | | | | msf1g | equ | 7 | ;mouse translator enab | | | 924 | 0006 | | | | | | mintrp | equ | 6 | ;user interrupt with ml | byte else user polls | | 925 | 0003 | | | | | | strkup | equ | 3 | ;upstroke user enable | flag | | 926 | 0001 | | | | | | ху | equ | 1 | ;set for x delta else | v delta | | 927 | 0000 | | | | | | msmov | equ | 0 | ; mouse table contains | | | 928 | F95E | 000 | 00 | | | | msptr: | defw | 0 | ;user address containing | ng the following table | | 929 | 0160 | | | | | | ktabsz | equ | \$-tabl | ;size of k/b tables | - | | 930 | | | | | | | | | | | | | 931 | | | | | | | ;; | | ranslation table. | | | | 932 | | | | | | | ; | first | the exception code | s | | | 933 | | | | | | | ; | | | | | | 934 | F960 | | | | 40 | | Fontbl: | defb | 23h,3ch,3eh,40h, | ,5bh,5ch,5dh,5eh | ;#,<,>,@,[,].^ | | 935 | F964 | | | | 5E | | | | | | | | 936 | F968 | | 78 | 7 C | 7 D | | | defb | 60h,7bh,7ch,7dh, | ,7eh | ;`,{, ,},~ | | 937 | F96C | 7 E | | | | | | | | | | | 938 | | | | | | | | | | | | | 939 | | | | | | | ;; | Now th | eir translations | | | | 940 | | | | | | | ; | | | | | | 941 | F96D | | | 3E | | | | defb | 23h,3ch,3eh,40h, | ,5bh,5ch,5dh,5eh | | | 942 | F971 | | | | 5E | | | | | _ | | | 943 | F975 | | | / ( | 7D | | | defb | 60h,7bh,7ch,7dh, | , 7eh | | | 944 | F979<br>000D | 7 E | | | | | | | (0.5 | | | | 945<br>946 | 0000 | | | | | | fontsz | equ | (\$-fontb1)/2 | size of font tables | | | 946 | | | | | | | | 0-4-4- | r translation tabl | 14 | | | 948 | | | | | | | ;; | | the exception code | | | | 949 | | | | | | | : | 11151 | the exception code | :5 | | | 950 | F97A | 21 | 23 | 2A | 28 | | Protbl: | defh | 21h, 23h, 2ah, 2bh, | 2ch 2ch 3ch 3ch | ;!,#,*,+,,,,,,, | | 951 | F97E | | | | 3E | | Fillion. | derb | 2111, 2511, 2811, 2511, | 2011, 2011, 3011, 3011 | ;:,*,*,*,,,,, | | 952 | F982 | | | | 5D | | | defb | 40h 5hh 5ch 5dh | 5eh.60h.7bh.7ch | ;@,[,],^,`,{, | | 953 | F986 | | | | 7 C | | | | 1011,0011,0011,0011, | , , , , , , , , , , , , , , , , , , , , | 14,11,111,11,111 | | 954 | F98A | | | FF | | | | defb | 7dh,7eh,x'ff',x' | ff'.x'ff'.x'ff' | ; } , ~ , TBD , TBD , TBD , TBD | | 955 | F98E | FF | FF | | | | | | | | 131 1.001.001.001.00 | | 956 | | | | | | | | | | | | | 957 | | | | | | | :: | Now th | e translations | | | | 958 | | | | | | | ; | | | | | | 959 | F990 | 21 | 23 | 2A | 2B | | | defb | 21h,23h,2ah,2bh, | 2ch, 2eh, 3ch, 3eh | | | 960 | F994 | | | -3C | | | | | | | | | 961 | F998 | | | 5C | | | | defb | 40h,5bh,5ch,5dh, | 5eh,60h,7bh,7ch | | | 962 | F99C | | | | 7 C | | | | | • | | | 963 | F9A0 | | | FF | FF | | | defb | 7dh,7eh,x'ff',x' | 'ff',x'ff',x'ff' | | | 964 | F9A4 | FF | FF | | | | | | | | | | 965 | 0016 | | | | | | prntsz | equ | (\$-prntb1)/2 | ; size of printer table | | | 966 | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | RAM resident (Tables) | 967 | F9A6 | 00 | | escsq: | defb | 0 | escape sequence flag | |------|-------|------|----------|----------|---------|-----------------|----------------------------------------------| | 968 | | | | | | | ;0=> no sequence in progress | | 969 | | | | | | | ;1b=> expecting 2nd byte | | 970 | | | | | | | ;ff=> expecting 3rd byte | | 971 | F9A7 | 00 | | cmdstat: | | 00 | comand-status byte; | | 972 | 0007 | | | cmd | equ | 7 | command-status flag | | 973 | 0006 | | | ustrk | equ | 6 | ;up stroke | | 974 | 0005 | | | yneg | equ | 5 | ;mouse y axis negative | | 975 | 0004 | | | xneg | equ | 4 | ;mouse x axis negative | | 976 | 0003 | | | mouse | equ | 3 | :mouse active | | 977 | 0002 | | | ctrl | equ | 2 | control key active | | 978 | 0001 | | | shift | equ | 1 | ;shift key active | | 979 | 0000 | | | lock | equ | 0 | ;lock key active | | 980 | F9A8 | 0000 | ) | millent: | | Ō | current millisecond count | | 981 | F9AA | 0.0 | | rptchar: | | ō | repeat character | | 982 | F9AB | 00 | | rptflg: | | ŏ | :repeat flag | | 983 | F9AC | 0000 | <b>.</b> | save: | defw | 0 | | | 984 | FOAE | 0.0 | • | romram: | | 0 | ;save address of the interrupt vector | | 985 | 0007 | 0.0 | | | | | rom/ram memory bank status | | 986 | DIAF | | | siderom | | 7 | ;ram side | | | UTAF | | | olsiz | equ | \$-tabled | | | 987 | | | | | | | | | 988 | | | | ;; | k/b int | errupt handler | for the low profile position encoded k/b. | | 989 | | | | : | | | pt service routine inputs two or three | | 990 | | | | ; | bytes f | rom the keyboar | rd port. The first byte is the cmd/status | | 991 | | | | ; | byte. | Appropriate int | formation is saved in memory and the return | | 992 | | | | : | | | s invoked. The second and third byte(mouse) | | 993 | | | | : | is posi | tion encoded da | ata or mouse displacement is analyzed, | | 994 | | | | | | | n to the existing keyboard handler if the | | 995 | | | | : | | | otherwise it is truncated and a return | | 996 | | | | : | | | oked. All registers saved except for the | | 997 | | 2 | | • | A regis | | oked. All registers saved except for the | | 998 | | • | | • | A regis | ter. | | | 999 | | | | • | | | | | 1000 | | | | ; | input~ | keyboard input | t port (data complemented) kbdat | | | | | | ; | | | | | 1001 | | | | : | output- | | t - Command byte or truncated character | | 1002 | | | | ; | | Carry flag res | set - Translated character in A register | | 1003 | | | | : | | | | | 1004 | F9AF | DB | | Lpkybd: | in | a,(kbdat) | ;read k/b port | | 1005 | F9B1 | | 9BE | | call | romside | ;switch to romside | | 1006 | F9B4 | C3 | 1996 | | jp | pekhdl | :decode posn, enc. k/b | | 1007 | | | | | | | ; jp instead of call - interrupt stack small | | 1008 | F9B7 | CD I | 908 | lpkext: | call | ramside | restore original memory side | | 1009 | F9BA | DO | | | ret | nc | return to xerox code with char. | | 1010 | | | | | | | ;here if command byte | | 1011 | F9BB | C 1 | | | рор | bc | throw away return address | | 1012 | F9BC | 18 3 | RR . | | ir | rptc1k2 | return from interrupt (via xerox) | | 1013 | . 550 | | ,,, | | J. | PECIKZ | (via xerox) | | 1014 | | | | | | | | | 1015 | | | | ; ; | | | tus of the current side of memory | | | | | | | and swi | tches to romsid | De. | | 1016 | | | | ; | | | | | 1017 | | | | ; | output | romram= status | s of syspio | | 1018 | | | | ; | | | | | 1019 | F9BE | F5 | | Romside: | | af | ;save register | | 1020 | F9BF | DB 1 | | | in | a,(syspio) | ;read ram/rom status | | 1021 | F9C1 | | 9AE | | 1 d | (romram),a | ;save it | | 1022 | F9C4 | CB F | F | | set | siderom.a | force rom side | .dephase Appendix 1077 1078 1079 MACRO-80 3.44 09-Dec-81 subttl Overlay (signon) Appendix J rev1 Appendix J 1135 FCC5 FE 01 Overlay (signon) ``` 1136 ECC7 28 03 ;skip if 4.01 ir z.sign7 1137 FCC9 21 1008 ١d hl.xrsign+sigoff :4.02+ level location 1138 FCCC 11 FCE6 sian7: ١d de sign6 : but it in our signon message 1139 FCCF 01 0004 1 d bc.4 1140 FCD2 ED BO ldir 1141 FCD4 CD F293 call crtoff ; disable rom bank 1142 FCD7 CD F075 call pnext 1143 FCDA 1 A defb clrs :clear screen 1144 FCDB 18 38 defb esc, '8' :set low light as default mode 1145 FCDD 38 32 30 20 '820-II v ' defm 1146 FCE1 49 49 20 76 1147 FCE5 20 1148 ECE6 00 00 00 00 sian6: 0.0.0.0 :****** space for the XR rev value defb 1149 FCEA 20 1F 1C 20 defm ' ',31,28,' 1983 Xerox Corp' 1150 FCEE 31 39 38 33 1151 FCF2 20 58 65 72 1152 FCF6 6F 78 20 43 1153 FCFA 6F 72 70 1154 FCFD 20 28 76 1 (41 defm 1155 FDOO 30 31 33 defm ver/100+'0'.(ver mod 100)/10+'0'.(ver mod 10)+'0' 1156 FD03 29 OD OA defb ')',cr,lf 1157 FD06 0 A defb 1 f 1158 FD07 4C 20 2D 20 defm 'L - Load System' 1159 FDOB 4C 6F 61 64 1160 FDOF 20 53 79 73 1161 FD13 74 65 6D 1162 FD16 OD OA defb cr.lf 1163 1164 if o.term 1165 FD18 48 20 2D 20 defm 'H - Host Terminal' 1166 FD1C 48 6F 73 74 1167 FD20 20 54 65 72 1168 FD24 6D 69 6E 61 1169 FD28 6C 1170 FD29 OD OA defb cr.lf 1171 endif 1172 1173 if o.term 1174 FD2B 54 20 2D 20 defb 'T - Typewriter' 1175 FD2F 54 79 70 65 1176 FD33 77 72 69 74 1177 FD37 65 72 1178 FD39 OD OA defb cr,1f 1179 endif 1180 1181 FD3B 07 04 defb 7,eot 1182 1183 FD3D CD F006 devour: call const 1184 FD40 CA F003 iρ z.warm :go enter monitor 1185 FD43 CD F009 call conin 1186 FD46 18 F5 devour 1187 OOEB rxsigl equ $-signon 1188 1189 .dephase 1190 subttl Overlay (boot) 1191 ``` page | 1197 | FC5D | 21 FF5D | | | 1 d | hl.linbuf+1 | ;4.02 overlay start address | |------|------|------------|--|--------|------|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 1198 | FC60 | 7 E | | boot1: | 1d | a,(h1) | scan command line | | 1199 | FC61 | 2C | | | inc | 1 | Toolin sommend Title | | 1200 | FC62 | D6 OD | | | sub | cr | | | 1201 | FC64 | 28 OB | | | jr | z,boot2 | ; if no parameter, boot from A: | | 1202 | FC66 | FE 13 | | | cp. | ' '-cr | ; I To parameter, boot from A: | | 1203 | FC68 | 28 F6 | | | jr | z,boot1 | skip leading blanks | | 1204 | FC6A | D6 34 | | | sub | 'A'-cr | , and reading branks | | 1205 | FC6C | D8 | | | ret | c c. | if invalid drive | | 1206 | FC6D | FE 10 | | | ср | 16 | , iii iiivariid di ive | | 1207 | FC6F | 3F | | | ccf | ,, | | | 1208 | FC70 | D8 | | | ret | c | if bad drive | | 1209 | FC71 | 4F | | boot2: | ld | c,a | set boot drive selected | | 1210 | FC72 | C6 41 | | | add | a.'A' | , see book of the selected | | 1211 | FC74 | 32 FD72 | | | ld | (bootd).a | set up error message | | 1212 | FC77 | 2E 00 | | | 1d | 1,0 | set A: | | 1213 | FC79 | C5 | | | push | bc | ,364 4. | | 1214 | FC7A | E5 | | | push | hl | | | 1215 | FC7B | CD FD89 | | | call | swap | switch boot drive with A: | | 1216 | FC7E | 21 FD6E | | | ld | hl.booter | set boot error return | | 1217 | FC81 | E5 | | | push | hl | , out book circle recent | | 1218 | FCB2 | 0E 00 | | | ld | c.0 | ;then boot from A: | | 1219 | FC84 | CD FO1B | | | call | select | The section A. | | 1220 | FC87 | CO | | | ret | nz | if drive not configured or density error | | 1221 | FC88 | 3E FF | | | ld | a,-1 | , o not com igaied or density error | | 1222 | FCBA | 12 | | | 1d | (de),a | | | 1223 | FC8B | 11 000A | | | 1 d | de.10 | set dpb address offset within dph | | 1224 | FCBE | 19 | | | add | hl.de | The special control of the special spe | | 1225 | FC8F | 5E | | | 1 d | e.(hl) | set dpb address | | 1226 | FC90 | 23 | | | inc | hl | , | | 1227 | FC91 | 56 | | | 1 d | d.(h1) | | | 1228 | FC92 | CD FOIE | | | call | home | | | 1229 | FC95 | 1 A | | | 1 d | a,(de) | get low sectors per track | | 1230 | FC96 | 32 FD6D | | | 1 d | (boots),a | inform boot loader | | 1231 | FC99 | B7 | | | or | a | | | 1232 | FC9A | 20 20 | | | jr | nz,boot3 | ; if not rigid | | 1233 | FC9C | 21 000D | | | 1d | h1,13 | set reserved track offset within dpb | | 1234 | FC9F | 19 | | | add | h1,de | | | 1235 | FCA0 | 4E | | | 1 d | c,(h1) | get reserved tracks | | 1236 | FCA1 | 23 | | | inc | h1 | | | 1237 | FCA2 | 46 | | | 1d | b,(h1) | | | 1238 | FCA3 | 0B | | | dec | bc | ;point behind directory | | 1239 | FCA4 | ED 43 FA11 | | | ١d | (phytrk),bc | ;do implied seek | | 1240 | | | | | | | ;here for rigid | | 1241 | FCAB | 0E 1D | | | 1 d | c,rtab1 | first rigid sector | | 1242 | FCAA | 21 ED80 | | | l d | hl,bootbf | buffer | | 1243 | FCAD | CD F024 | | | call | read | ; layout and k/b tables | | 1244 | FCB0 | CO | | | ret | nz | · · · | | 1245 | FCB1 | 0E 1E | | | 1 d | | ;2nd rigid sector | | 1246 | FCB3 | 21 EE80 | | | ١d | hl,bootbf+x'100 | )';buffer | | | | | | | | | | Appendix J | | Overlay | | keyboard nandre | MACKU- | 80 3.44 | 09-Dec | | | |---|---------|------|---------------------------|--------|---------|----------|------------------|-------------------------------------------| | | | | | | | | | | | | 1247 | FCB6 | CD F024 | | | call | read | ;layout and k/b tables | | | 1248 | FCB9 | CO . | | | ret | nz | | | | 1249 | FCBA | 18 20 | | | jr | rxb01 | | | | 1250 | FCBC | | | boot3: | | | ;here for floppy | | | 1251 | FCBC | FE 1B | | | cp | 27 | ;double density? | | | 1252 | FCBE | DA FD52 | | | jp | c,boot4 | ;no - exit | | | 1253 | FCC1 | 0E 04 | | | ١d | c,ftab1 | first floppy sector; | | | 1254 | FCC3 | 21 ED80 | | | ld | hl,bootbf | ;buffer | | | 1255 | FCC6 | CD F024 | | | call | read | ; layout table and half of k/b | | | 1256 | FCC9 | CO | | | ret | nz | | | | 1257 | FCCA | 0E 05 | | | 1d | c,ftab2 | second floppy sector | | | 1258 | FCCC | 21 EE00 | | | 1 d | hl,bootbf+128 | | | | 1259 | FCCF | CD F024 | | | call | read | midle third of k/b tables | | | 1260 | FCD2 | CO | | | ret | nz . | | | | 1261 | FCD3 | 0E 06 | | | 1 d | c.ftab2+lpkofs | third floppy sector | | | 1262 | FCD5 | 21 EE80 | | | 1 d | hl,bootbf+128+1 | | | | 1263 | FCD8 | CD F024 | | | call | read | ; last third of k/b tables | | | 1264 | FCDB | CD | | | ret | nz | , | | | 1265 | FCDC | | | rxb01: | | | ;check tables are present | | | 1266 | FCDC | 3A ED80 | | | 1 d | a.(bootbf+lang) | ;language no. set? | | | 1267 | FCDF | FE E5 | | | ср | 0e5h | , | | | 1268 | FCE1 | 28 6F | | | ir | z,boot4 | ;no - exit | | | 1269 | FCE3 | 3A ED81 | | | 1 d | | ;k/b tables present? | | | 1270 | FCE6 | FE 6B | | | ср | 'k' | , Kr B tables present | | | 1271 | FCE8 | 20 68 | | | jr | nz,boot4 | :no - exit | | | 1272 | FCEA | 3A ED82 | | | 1 d | | font tables present? | | | 1273 | FCED | FE 66 | | | ср | 'f' | , rone tables present. | | | 1274 | FCEF | 20 61 | | | jr | nz.boot4 | ;no - exit | | | 1275 | FCF1 | 3A ED83 | 1.1 | | 1d | | printer tables prsent? | | | 1276 | FCF4 | FE 70 | | | ср | 'p' | , printer tables prisent. | | | 1277 | FCF6 | 20 5A | | | ir | nz.boot4 | ;no - exit | | | 1278 | FCF8 | 21 ED84 | | | 1 d | | b ;move in k/b tables | | | 1279 | FCFB | 11 F800 | | | 1 d | de.tabled | - ( | | | 1280 | FCFE | 01 0160 | | | 1 d | bc.ktabsz | | | | 1281 | FD01 | ED BO | | | ldir | 00,1110052 | | | | 1282 | FD03 | 0E 1F | | | 10 | c.ctab2+lokofs | ;3rd rigid sector | | | 1283 | FD05 | 3A FD6D | | | ld | | rigid or floppy? | | | 1284 | FD08 | B7 | | | or | a | , g . d | | | 1285 | FD09 | 28 02 | | | ir | z,boot5 | ;rigid | | | 1286 | FDOB | OE 07 | | | id | | :floppy - 4th sector | | | 1287 | FDOD | 21 ED80 | | boot5: | ld | hl bootbf | | | | 1288 | FD10 | CD F024 | | | call | read | font and print tables | | | 1289 | FD13 | CO . | | | ret | nz | , ront and print tables | | | 1290 | FD14 | 3A ED80 | | | ld | a,(bootbf) | ;configured? | | | 1291 | FD17 | FE E5 | | | ср | 0e5h | ; com igai ea | | | 1292 | FD19 | 28 37 | | | jr | | :no -exit | | | 1293 | FD1B | 21 ED80 | | | 1d | hl,bootbf | ;no -exit<br>;move font & print tables in | | | 1294 | FDIE | 11 F960 | | | 1 d | de.fontbl | imove runt a print tables in | | | 1295 | FD21 | 01 0046 | | | 1d | bc,fontsz*2+prn | +*2 | | | 1296 | FD24 | ED B0 | | | ldir | oc, rontsz+z+prn | 182+2 | | | 1297 | 1024 | ED 80 | | | Tu II | | | | | 1297 | | | | | 01+0- | SIOOUT | | | | 1298 | | | | ; ; | aiter | 310001 | | | | 1300 | FD26 | DD 2A F019 | | ; | 1 d | ( | £) -: | | | 1300 | FD26 | DD 2A F019<br>DD 36 00 C3 | | | | | f);sicout address | | | 1301 | FD2E | DD 36 00 C3 | | | ld<br>ld | (ix),0c3h | ; jump instruction | | í | 1302 | FD2E | DD 30 01 FC | | | 10 | (ix+1),low rxsi | 00 | | • | | | | | | | | | | | 130 | 8 | FD3A | DD | 36 12 | 85 | | 1 d | (ix+crtcall), low | exect | |----------|-------|---|-------|-----|-------|----|---------|--------|-------------------|----------------------------------------------| | | 130 | | FD3E | | 36 13 | | | ld | (ix+crtcall+1), | high cycat | | | 131 | | FD42 | | 21 F2 | | | id | | ;address of screenprint patch | | | 131 | | FD46 | | 36 00 | | | ld | (ix),0c3h | : jump instruction | | | 131 | | FD4A | | 36 01 | | | ld | (ix+1),low scrpr | | | | 131 | | FD4E | | 36 02 | | | ld | | | | | 131 | | FD52 | UU | 30 02 | 10 | | 10 | (ix+2),high scrp | | | | | | | | | | boot4: | | | there to exit | | | . 131 | | FD52 | C1 | | | | pop | bc | throw away booter return | | | 131 | | FD53 | C1 | | | | pop | bc | ;get disk swap parameters | | | 131 | | FD54 | E1 | | | | pop | h l | | | | 131 | | FD55 | | FD89 | | | call | swap | ;swap them back for xerox boot | | | 131 | | FD58 | C1 | | | | pop | bc | throw away return address; | | | 132 | | FD59 | | 0000 | | | 1 d | h1,0 | | | | 132 | | FD5C | | F03C | | | call | config | get monitor configuration | | | 132 | 2 | FD5F | 7 C | | | | 1 d | a,h | | | | 132 | 3 | FD60 | 21 | 1188 | | | 1 d | hl.xrboot~romofs | s ;assumed 4.01 monitor boot overlay address | | | 132 | 4 | FD63 | FE | 01 | | | ср | rev1 | | | | 132 | 5 | FD65 | 28 | 03 | | | ir | z.boot6 | ;skip if 4.01 | | | 132 | | FD67 | | 11C0 | | | ld | hl.xrboot | ;address of 4.02+ monitor boot overlay | | | 132 | | FD6A | | F078 | | boot6: | jp | prhoff | enter xerox code to execute boot | | | 132 | | FD6D | 00 | | | boots: | | 0 | ;workbyte to save disk type | | | 132 | | . 000 | | | | 50013. | derb | • | ; workbyte to save disk type | | | 133 | | | | | | | 0 | D+ F D | | | | 133 | | | | | | :: | pooter | - Boot Error Prod | cessor. | | | 133 | | FD6E | | F075 | | | | | | | | 133 | | | | FU/5 | | Booter: | | pnext | | | | | | FD71 | 07 | | | | defb | 7 | | | | 133 | | FD72 | | 3A 54 | | bootd: | defm | 'd:Tables Load e | error.' | | | 133 | | FD76 | | 6C 65 | | | | | | | | 133 | | FD7A | | 4C 6F | | | | | | | | 133 | | FD7E | | 20 65 | | | | | | | | 133 | | FD82 | 72 | 6F 72 | 2E | | | | | | | 133 | 9 | FD86 | 04 | | | | defb | eot | | | | 134 | 0 | FD87 | C 1 | | | | pop | bc | ;switch drives back | | | 134 | 1 | FD88 | E1 | | | | pop | h1 | · | | | 134 | 2 | | | | | | | | | | | 134 | 3 | | | | | :: | Swap - | swap logical driv | ves . | | | 134 | | | | | | ; | | | | | | 134 | | | | | | : | Entry: | C = first drive | a index 0-15 | | | 134 | | | | | | : | | L = second drive | | | | 134 | | | | | | | | E - Second di IVe | e moex, o is | | | 134 | | FD89 | 06 | 00 | | Swap: | 1 d | b.0 | :clear upper indices | | | 134 | | FD8B | 60 | | | Swap: | ld | h.b | crear upper indices | | | 135 | | FD8C | | F360 | | | 1d | | | | | | | FD8F | | F 360 | | | | de,seltab | ;set select table address | | | 135 | | | 29 | | | | add | hl,hl | | | - ▶ | 135 | | FD90 | 19 | | | | add | hl,de | | | Ó | 135 | | FD91 | EB | | | | ex | de,hl | ;set second address to DE, get seltab to HL | | ō | 135 | | FD92 | 09 | | | | add | hl,bc | | | æ | 135 | | FD93 | 09 | | | | add | hl,bc | ;set first address to HL | | _ ₹ | 135 | | FD94 | | 02 | | | 1d | b,2 | | | Appendix | 135 | | FD96 | 4E | | | swap1: | 1 d | c,(h1) | ;swap two bytes | | × | 135 | 8 | FD97 | 1 A | | | | 1 d | a (de) | • | | _ | - | | | | | | | | | | | | | | | | | | | | | | ``` 1359 FD98 77 (h1),a ١d 1360 FD99 79 ١d a.c 1361 12 FD9A 1d (de),a 1362 FD9B 23 inc h1 1363 FD9C 1.3 inc de 1364 FD9D 10 F7 dinz swan1 ; if swap not complete 1365 FD9F C9 ret 1366 .dephase 1367 1368 0788 romtop: 1369 0788 defs (romsiz-x'24')-(romtop-start),-1 1370 1371 ;; Drctry is a table containing the RAM addresses of the keyboard 1372 tables. This table is located on ROM side of memory. The 1373 ROM address must be offset by x'1800' since resides in 1374 the fourth 2kx8 ROM slot. This directory is helpful if future 1375 release require the RAM tables to reside in a different RAM 1376 location 1377 1378 07DC ' F97A Drctry: defw prntbl :print exception table 1379 07DE ' F960 defw fontbl ;font exception table 1380 07E0' F95D defw mstbl ;mouse table 1381 07E2 F959 defw ups :upstroke table 1382 07E4' F958 defw ctrlex ;function key inhibit expansion table 1383 07E6 F953 defw ctrltb :function key inhibit table 1384 07E8 F94F defw rptex repeat key expansion table 1385 O7EA F940 defw rptbl repeat key table 1386 07EC' F93C defw tick repeat speed table 1387 07EE' F93B shftlck defw ;shift lock flag 1388 07F0' F938 defw cptex :alpha lock expansion table 1389 07F2' F935 defw captab ;alpha lock table 1390 07F4 F8CE defw cdtab :code + table 1391 07F6' F867 defw shtab :shift table 1392 07F8' F800 defw tabl ;unshifted table 1393 1394 07FA' OΒ defb ;revision level 1395 07FB' 00 FF lpid: defb x'00',x'ff' :low profile kybd id 1396 1397 define checkword to let xerox know :: 1398 that we are present 1399 1400 07FD' AA 55 defb Oaah.55h :id 1401 O7FF' 00 defb ;space for checksum 1402 1403 Subttl Symbol Table 1404 end ``` | | FC60 | B00T1 | FC71 | BOOT2 | FCBC | BOOT | |---|--------------|----------|--------------|-----------------|--------------|--------------| | | FD52 | BOOT4 | FDOD | B00T5 | FD6A | BOOT | | | ED80 | BOOTBF | FD72 | BOOTD | FD6E | BOOT | | | FD6D | BOOTS | 0004 | C.FIVE | 0006 | C.SA | | | F935 | CAPTAB | F8CE | CDTAB | 19D4 | CHAR | | | FFB4 | CHRSAV | 001A | CLRS | 0007 | CMD | | | 19A1 | CMDB | 1A1F | CMDB 1 | F9A7 | CMDS | | | 0006 | CNFBYTE | 003C | CNFGOFF | 0006 | CNTC | | | 0013 | CNTRP | F091 | CONFG | F03C | CONF | | | F009 | CONIN | F006 | CONST | 0003 | CPTB | | | F938 | CPTEX | 000D | CR | 0012 | CRTC | | | 0182 | CRTD1 | 0196 | CRTD2 | F293 | CRTO | | | 0019 | CTC1 | FF10 | CTCVEC | 0002 | CTRL | | | F958 | CTRLEX | F953 | CTRLTB | 19DB | CTRT | | | FFAC | CURSOR | FD3D | DEVOUR | 07DC | DRCT | | | 0081 | ENCNTR | 0004 | EOT | 001B | ESC | | | F9A6 | ESCSQ | 0007 | ESCTSZ | 0010 | FCRT | | | F470 | FIVDPB | 18CF | FNTRAN | 1888 | FON1 | | | 18CA | FON2 | 18A6 | FONCHK | 0002 | FONT | | | F960 | FONTBL | 000D | FONTSZ | 0004 | FTAB | | | 0005 | FTAB2 | 0006 | FTAB3 | F319 | GOLD | | | 0 1 DD | GRPAD | 01F4 | HLFSEC | FOIE | HOME | | | F066 | IDLE | FF50 | INTSTK | 000F | JTBL | | | 001E | KBDAT | 0008 | KBLP | 000A | KBOF | | | FA07 | KBRAMEND | 0001 | KBRD | 0004 | KBRD | | | FF1A | KBVEC | F06F | KEY2 | F072 | KEY5 | | | 0160 | KTABSZ | F06C | KYBOLP | 1985 | KYP0 | | | 0000 | LANG | FFB2 | LEADIN | A000 | LF | | | FF5C | LINBUF | 0000 | LOCK | 0061 | LOWE | | | 07FB | LPID | F987 | LPKEXT | 0001 | LPKO | | | F9AF | LPKYBD | F0E3 | MASK | 1A7D | MICE | | | 1AEB | MICEI | 1 A F 1 | MICE11 | 1AF8 | MICE | | | 1800 | MICE2 | 1808 | MICE21 | 1809 | MICE | | | 1814 | MICE23 | 1816 | MICE24 | 1AB3 | MICE | | | 1AB8 | MICEY | F9A8 | MILLCNT | 0006 | MINT | | | F167 | MKEY2 | F18F | MKEY5 | F06C | MNTR | | | F000 | MONITR | 0003 | MOUSE | 1838 | MOVT | | | FC3D | MPNEXT | FA95 | MPRMTO<br>MSPTR | 0007 | MSFL<br>MSTB | | | 0000 | MSMOV | F95E | | F95D | | | | 19A0 | NOCHAR | 187E<br>0208 | NOLOAD | 0001 | O.TE<br>PEKE | | | 01AF | OLSIZ | 19AD | OLSIZ3 | 19B1<br>19B0 | PEKN | | | | PEKHDL | 198F | PEKNOC | | PHYT | | | 19A0<br>F075 | PEKNOC2 | 1986 | PESCTB | FA11 | | | | | PNEXT | | POESC | 1927 | POSO | | • | 1939 | POSO2 | 1939 | POSO3 | 193D | POSO | | | 1947 | P0\$05 | 1954 | POSO6 | 1955 | POSO | | | 1914 | POSEND | 1959 | POSOUT | 1966 | POTR | | | F078 | PRBOFF | 0003 | PRNT | F97A | PRNT | | | 0016 | PRNTSZ | FA62 | PROMPT | F339 | PRVA | | : | 1983 | PTR01 | F9C8 | RAMSIDE | F024 | READ | | | | | | | | | | | | | | | | | | | | | | | | | | Symbol | Table | nay boar | 0 11011 | O Tel | MACKO 00 3,44 | 09-Dec | |--------|---------|----------|---------|---------|---------------|---------| | 0000 | REVO | | 0001 | REV1 | 0064 | REV50 | | F708 | RIGDPB | | 190C | RMPOSEN | | RMSIDE | | 8000 | ROMOFS | | F9AE | ROMRAM | F9BE | ROMSIDE | | 0800 | ROMSIZ | | 0788' | ROMTOP | F940 | RPTBL | | F9AA | RPTCHAR | | F9D0 | RPTCLK | F9ED | RPTCLK | | F9F9 | RPTCLK2 | | F94F | RPTEX | F9AB | RPTFLG | | 1A3D | RPTST | | 001D | RTAB1 | 001E | RTAB2 | | -181A | RVITBL | | 1829 | RV2TBL | 1800 | RX1984 | | FCDC | RXB01 | | 063D' | RXBOOT | 1885 | RXCRT | | OOEB | RXSIGL | | 0552' | RXSIGN | F9FC | RXSI00 | | 0300 | SASIDL | | F9AC | SAVE | FIEC | SAVSTK | | 18EC | SCR01 | | 18F2 | SCR02 | 1904 | SCR03 | | 18D6 | SCRPRT | | F01B | SELECT | F360 | SELTAB | | OOFF | SETFLG | | F93B | SHFTLCK | | SHIFT | | F867 | SHTAB | | 0007 | SIDEROM | | SIGNI | | FC85 | SIGN2 | | FC8C | SIGN3 | FCA2 | SIGN3A | | FCAA | SIGN4 | | FCE6 | SIGN6 | FCCC | SIGN7 | | FC5D | SIGNON | | 0060 | SIGOFF | 0005 | SIODPB | | 0019 | SIOFF | | F03F | SIORDY | 195A | SIOX1 | | 185C | SOOUT | | F20E | SPACT | F22F | SPRNT 1 | | F.232 | SPRNT2 | | 00001 | START | 0001 | STCNTR | | FF54 | STEPRT | | 1466 | STPCTC1 | 0003 | STRKUP | | FD89 | SWAP | | FD96 | SWAP 1 | 001D | SYSCTL | | 001C | SYSPIO | | FF18 | SYSVEC | F800 | TABL | | F800 | TABLED | | 034A' | TABLES | 0159 | TABLEX | | 19FF | TBLSEL | | 181E | TBXFER | FC5D | TCA | | 003F | TENTHS | | F93C | TICK | F93E | TOCK | | 0020 | UPASCII | | 007B | UPPER | F959 | UPS | | 0002 | UPSSZ | | 19E6 | UPSTRK | F95B | UPSX | | 0006 | USTRK | | 000D | VER | F003 | WARM | | 0010 | WD1797 | | 0004 | XNEG | 1100 | XRBOOT | | 1078 | XRSIGN | | 0001 | XY | 0005 | YNEG | | 0000 | ZERO | | | | | | | | | | | | | | No Fatal error(s) | B00T4 | 1252 | 1268 | 1271 | 1274 | 1277 | 1292 | 1314# | | | | | | |---------|------|-------|-------|------|------|------|-------|------|------|------|------|------| | BOOT5 | 1285 | 1287# | | | | | | | | | | | | BOOT6 | 1325 | 1327# | | | | | | | | | | | | BOOTBF | 84# | 1242 | 1246 | 1254 | 1258 | 1262 | 1266 | 1269 | 1272 | 1275 | 1278 | 1287 | | | 1290 | 1293 | | | | | | | | | | | | BOOTD | 1211 | 1334# | | | | | | | | | | | | BOOTER | 1216 | 1332# | | | | | | | | | | | | BOOTS | 1230 | 1283 | 1328# | | | | | | | | | | | C.FIVE | 132# | 1102 | 1105 | | | | | | | | | | | C.SASI | 133# | 1110 | | | | | | | | | | | | CAPTAB | 577 | 895# | 897 | 1389 | | | | | | | | | | CDTAB | 537 | 866# | 1390 | | | | | | | | | | | CHAROUT | 487# | 523 | 718 | | | | | | | | | | | CHRSAV | 101# | 242 | | | | | | | | | | | | CLRS | 149# | 1143 | | | | | | | | | | | | CMD | 460 | 476 | 972# | | | | | | | | | | | CMDB | 462 | 465# | | | | | | | | | | | | CMDB 1 | 536 | 539 | 542 | 545 | 547# | | | | | | | | | CMDSTAT | 465 | 475 | 487 | 971# | | | | | | | | | | CNFBYTE | 120# | 190 | 192 | | | | | | | | | | | CNFGOFF | 119# | 189 | | | | | | | | | | | | CNTCTR | 500 | 916# | | | | | | | | | | | | CNTRP | 593 | 911# | | | | | | | | | | | | CONFG | 86# | 1087 | | | | | | | | | | | | CONFIG | 57# | 175 | 1132 | 1321 | | | | | | | | | | CONIN | 52# | 1185 | | | | | | | | | | | | CONST | 51# | 1183 | | | | | | | | | | | | CPTBSZ | 578 | 897# | | | | | | | | | | | | CPTEX | 896# | 1388 | | | | | | | | | | | | CR | 152# | 1156 | 1162 | 1170 | 1178 | 1200 | 1202 | 1204 | | | | | | CRTCALL | 50# | 1308 | 1309 | 1170 | 1170 | 1200 | 1202 | 1204 | | | | | | CRTD1 | 66# | 254 | 1003 | | | | | | | | | | | CRTD2 | 67# | 247 | 252 | | | | | | | | | | | CRTOFF | 76# | 1141 | 252 | | | | | | | | | | | | | | 000 | | | | | | | | | | | CTC1 | 110# | 608 | 626 | | | | | | | | | | | CTCVEC | 41# | 603 | 606 | 621 | | | | | | | | | | CTRL | 538 | 977# | | | | | | | | | | | | CTRLEX | 915# | 1382 | | | | | | | | | | | | CTRLTB | 499 | 913# | 916 | 1383 | | | | | | | | | | DRCTRY | 1378# | | | | | | | |----------|-------|-------|------|------|------|------|------| | ENCNTR | 114# | 607 | | | | | | | EOT | 151# | 1181 | 1339 | | | | | | ESC | 150# | 325 | 351 | 362 | 1144 | | | | ESCSQ | 347 | 354 | 383 | 967# | | | | | ESCTSZ | 426 | 432# | | | | | | | FCRTOF | 49# | 1307 | | | | | | | FIVDPB | 90# | 1112 | | | | | | | FNTRAN | 278 | 289# | | | | | | | FON 1 | 267 | 272# | | | | | | | FON2 | 271 | 279# | | | | | | | FONCHK | 253 | 261# | | | | | | | FONT | 146# | 1272 | | | | | | | FONTBL | 274 | 306 | 934# | 945 | 1294 | 1379 | | | FONTSZ | 275 | 290 | 306 | 307 | 311 | 945# | 1295 | | FTAB1 | 141# | 1253 | | | | | | | FTAB2 | 142# | 1257 | 1261 | | | | | | FTAB3 | 143# | 1286 | | | | | | | GOLD | 88# | 244 | | | | | | | GRPAD | 68# | . 268 | | | | | | | HLFSEC | 899 | 900 | 903# | | | | | | HOME | 55# | 1228 | | | | | | | IDLE | 59# | 387 | | | | | | | INTSTK | 95# | 1047 | | | | | | | JTBLSZ. | 186 | 774# | | | | | | | KBDAT | 109# | 1004 | | | | | | | KBLP | 121# | 191 | | | | | | | KBOFF | 48# | 213 | 214 | 215 | | | | | KBRAMEND | | 1075# | 1129 | | | | | | KBRD | 145# | 1269 | | | | | | | KBRDTB | 148# | 1278 | | | | | | | KBVEC | 43# | 212 | | | | | | | KEY2 | 62# | 1064 | | | | | | | KEY5 | 63# | 1065 | | | | | | | KTABSZ | 929# | 1280 | | | | | | | KYBDLP | 61# | 214 | 215 | | | | | | KYPOS | 461 | 474# | | | | | | | LANG | 144# | 1266 | | | | | | | LEADIN | 99# | 245 | | | | | | | LF . | 153# | 1156 | 1157 | 1162 | 1170 | 1178 | | | LINBUF | 97# | 1197 | | | | | | | LOCK | 541 | 562 | 979# | | | | | | LOWER | 125# | 566 | | | | | | | LPID | 1395# | | | | | | | | LPKEXT | 473 | 1008# | | | | | | | LPKOFS | 123# | 1245 | 1261 | 1282 | 1286 | | | | MICEZI | 751 | /55# | | | | | | | | | | | |---------|-------|------|------|------|------|------|------|------|----|----|----|----| | MICE22 | 754 | 756# | | | | | | | | | | | | MICE23 | 758 | 761# | | | | | | | | | | | | MICE24 | 760 | 762# | | | | | | | | | | | | MICEX1 | 698# | 715 | | | | | | | | | | | | MICEY | 685 | 700# | | | | | | | | | | | | MILLCNT | 597 | 980# | 1054 | 1059 | 1062 | | | | | | | | | MINTRP | 714 | 924# | | | | | | | | | | | | MKEY2 | 72# | 770 | 777 | | | | | | | | | | | MKEY5 | 73# | 771 | 778 | | | | | | | | | | | MNTREX | 60# | 185 | | | | | | | | | | | | MONITR | 39# | 51 | 52 | 53 | 54 | 55 | 56 | 57 | 58 | 59 | 60 | 61 | | | 62 | 63 | 64 | 65 | 189 | 1300 | 1307 | | | | | | | MOUSE | 466 | 478 | 976# | | | | | | | | | | | MOVTBL | 785# | | | | | | | | | | | | | MPNEXT | 80# | 772 | 779 | | | | | | | | | | | MPRMTO | 79# | 773 | 780 | | | | | | | | | | | MSFLG | 680 | 923# | | | | | | | | | | | | MSMOV | 713 | 927# | | | | | | | | | | | | MSPTR | 683 | 928# | | | | | | | | | | | | MSTBL | 468 | 512 | 679 | 712 | 756 | 762 | 922# | 1380 | | | | | | NOCHAR | 463# | 514 | 518 | 681 | | | | | | | | | | NOLOAD | 178 | 180 | 228# | | | | | | | | | | | O.TERM | 134# | 1164 | 1173 | | | | | | | | | | | OLSIZ | 986# | | | | | | | | | | | | | OLSIZ3 | 1076# | 1127 | | | | | | | | | | | | PEKEX | 472# | 490 | | | | | | | | | | | | PEKHDL | 457# | 1006 | | | | | | | | | | | | PEKNOC | 467 | 470# | 477 | | | | | | | | | | | PEKNOC1 | 471# | 699 | | | | | | | | | | | | PEKNOC2 | 464# | 483 | | | | | | | | | | | | PESCTB | 425 | 430# | 432 | | | | | | | | | | | PHYTRK | 93# | 1239 | | | | | | | | | | | | PNEXT | 64# | 1142 | 1332 | | | | | | | | | | | POESC | 378 | 425# | | | | | | | | | | | | POS01 | 352 | 356# | | | | | | | | | | | | POSO2 | 360 | 366# | | | | | | | | | | | | POS03 | 358 | 367# | | | | | | | | | | | | POS04 | 349 | 370# | | | | | | | | | | | | POS05 | 372 | 376# | | | | | | | | | | | | POSO6 | 375 | 379 | 382# | | | | | | | | | | | POS07 | 381 | 383# | | | | | | | | | | | | | | | | | | | | | | | | | | pendix J | POTRAN<br>PRBOFF | 319<br>65# | 357<br>1327 | 400# | 000 | 000 | 07-4 | 0,, | 303# | 710 | 413 | | |----------|------------------|------------|----------------|------|-------|------|------|------|------|-------|------|------| | <u>a</u> | PRNT | 147# | 1275 | | | | | | | | | | | ₹. | PRNTBL | 400 | 950# | 965 | 1378 | | | | | | | | | <br> | PRNTSZ<br>PROMPT | 401 | 405 | 965# | 1295 | | | | | | | | | | PROMPT | 78#<br>77# | 269 | | | | | | | | | | | | PTR01 | 409 | 417# | | | | | | | | | | | | RAMSIDE | 1008 | 1029# | 1072 | | | | | | | | | | | READ | 56# | 1243 | 1247 | 1255 | 1259 | 1263 | 1288 | | | | | | | REVO | 116# | 177 | | 1233 | .233 | 1200 | 1200 | | | | | | | REV1 | 117# | 182 | 203 | 1135 | 1324 | | | | | | | | | REV50 | 118# | 179 | | | | | | | | | | | | RIGDPB | 91# | 1111 | | | | | | | | | | | | RMPOSEND | | 336# | 1071 | | | | | | | | | | | RMSIDE2 | 1023 | 1031# | | | | | | | | | | | | ROMOFS | 122# | 205 | 206 | 207 | 208 | 779 | 780 | 1134 | 1195 | 1196 | 1323 | | | ROMRAM | 984# | 1021 | 1030 | | | | | | | | | | | ROMSIDE | 1005 | 1019# | 1070 | | | | | | | | | | | ROMSIZ | 38# | 1369 | | | | | | | | | | | | ROMTOP | 1368# | 1369 | | | | | | | | | | | | RPTBL<br>RPTCHAR | 592<br>598 | 906# | 911 | 1385 | | | | | | | | | | RPTCHAR | 605 | 981#<br>1046# | 1063 | | | | | | | | | | | RPTCLK1 | 1057 | 1061# | | | | | | | | | | | | RPTCLK2 | 1012 | 1053 | 1060 | 1065# | | | | | | | | | | RPTEX | 910# | 1384 | 1000 | 1000# | | | | | | | | | | RPTFLG | 615 | 982# | 1051 | | | | | | | | | | | RPTST | 486 | 592# | | | | | | | | | | | | RTAB1 | 139# | 1241 | 1245 | | | | | | | | | | | RTAB2 | 140# | 1282 | | | | | | | | | | | | RV1TBL | 181 | 769# | 774 | | | | | | | | | | | RV2TBL | 184 | 776# | | | | | | | | | | | | RX1984 | 37# | 160 | | | | | | | | | | | | RXB01 | 1249 | 1265# | | | | | | | | | | | | RXBOOT | 199 | 200 | 201 | 202 | 205 | 206 | 207 | 208 | 1194# | | | | | RXCRT. | 241# | 1308 | 1309 | | | | | | | | | | | RXSIGL<br>RXSIGN | 225<br>223 | 1187#<br>1085# | | | | | | | | | | | | RXSIGN | 1069# | 1302 | 1303 | | | | | | | | | | | SASIDL | 135# | 1113 | 1303 | | | | | | | | | | | SAVE | 604 | 620 | 983# | | | | | | | | | | | SAVSTK | 40# | 1046 | 903# | | | | | | | | | | | SCR01 | 309 | 315# | | | | | | | | | | | | SCR02 | 317 | 319# | | | | | | | | | | | | SCR03 | 320 | 323 | 329# | | | | | | | | | | | SCRPRT | 301# | 1312 | 1313 | | | | | | | | | | | | | | | | | | | | | | | | SIGNI | 1100# | 1100 | | | | | | |---------|-------|-------|-------|------|------|------|------| | SIGN2 | 1104 | 1107# | | | | | | | SIGN3 | 1090 | 1110# | | | | | | | SIGN3A | 1119# | 1124 | | | | | | | SIGN4 | 1109 | 1.116 | 1125# | | | | | | SIGN6 | 1138 | 1148# | | | | | | | SIGN7 | 1136 | 1138# | | | | | | | SIGNON | 1087# | 1187 | | | | | | | SIGOFF | 70# | 1134 | 1137 | | | | | | SIODPB | 107# | 390 | | | | | | | SIOFF | 47# | 1300 | | | | | | | SIORDY | 58# | 386 | | | | | | | SIOX1 | 386# | 388 | | | | | | | SOOUT | 204 | 212# | | | | | | | SPACT | 87# | 622 | | | | | | | SPRNT1 | 74# | 1310 | | | | | | | SPRNT2 | 75# | 332 | | | | | | | START | 159# | 1369 | | | | | | | STCNTR | 115# | 625 | | | | | | | STEPRT | 96# | 1108 | | | | | | | STPCTC1 | 470 | 615# | | | | | | | STRKUP | 513 | 925# | | | | | | | SWAP | 1215 | 1318 | 1348# | | | | | | SWAP1 | 1357# | 1364 | | | | | | | SYSCTL | 105# | 1093 | 1095 | | | | | | SYSPIO | 106# | 1020 | 1031 | 1088 | 1097 | 1101 | | | SYSVEC | 42# | 43 | | | | | | | TABL | 540 | 808# | 917 | 929 | 1392 | | | | TABLED | 92# | 789 | 802 | 986 | 1076 | 1126 | 1279 | | TABLES | 788 | 801# | 1125 | | | | | | TABLEX | 790 | 917# | | | | | | | TBLSEL | 484 | 532# | | | | | | | TBXFER | 183 | 185# | | | | | | | TCA | 44# | 224 | 227 | 1086 | 1195 | | | | TENTHS | 901 | 902 | 904# | | | | | | TICK | 596 | 899# | 1386 | | | | | | TOCK | 901# | 1061 | | | | | | | UPASCII | 126# | .568 | | | | | | | UPPER | 124# | 564 | | | | | | | UPS | 515 | 919# | 921 | 1381 | | | | | UPSSZ | 516 | 520 | 921# | | | | | | UPSTRK | 481 | 512# | | | | | | | | | | | | | | | Notes **J38** | | | Attributes | | | | | |------------------------|------------|--------------------------------|-------------|--|--|--| | | | U57, U58 ROMs | 43 | | | | | | | Configuration sector | 225 | | | | | | | Enable, Disable | 189 | | | | | | | General | 183 | | | | | | | Set mode | 191 | | | | | Α | | Auto-repeat keys | | | | | | | | - ASCII | 195 | | | | | | | - LPK | 205 | | | | | A66 Control Switch | 249, 250 | | | | | | | Abbreviations, list of | N1 | | | | | | | Access cover | | | | | | | | - 40 CPS | 238, 239 | | | | | | | - 20 CPS | 227,228 | | | | | | | Access times, disk | 207-211 | В | | | | | | Accessible 1-second | | | | | | | | interrupt 17 | 1, 174, B1 | | | | | | | Accessing BIOS | 151 | BDOS, General | 5 | | | | | Allocation, CRT RAM | 45 | <b>BIOS Entry points</b> | A2-A5 | | | | | Alpha lock key | | Banked Physical Driver lis | ting App. I | | | | | - ASCII | 197 | Device Initialization | 133,134 | | | | | - LPK | 205, 206 | <b>Execute Physical Driver</b> | 161,162 | | | | | Altitude requirements | 18 | Op. Sys. Int. 152, 174-17 | 6,178-181 | | | | | Application programm | ing 41, | Physical Driver Address Ta | ble C3 | | | | | 42, 151, 152 | , 155, 170 | Programmable Functions 170 | | | | | | ASCII keyboard | | Backspace or cursor left | 187 | | | | | ROM, How it Works | 133 | Bank switching | | | | | | Dimensions | 13 | Example | D4 | | | | | Product Codes | 3 , | System PIO | 134 | | | | | General | 195-199 | Z80-A Example | 171,172 | | | | | CTRL key | | Banked physical driver | | | | | | Alpha lock key | | listing | 11-112 | | | | | Auto-repeat keys | | Basic monitor calls | D1-D3 | | | | | Function key priorit | ty | Baud rate | | | | | | Function key uses | | I/O Channel | 135 | | | | | Key code chart | | Command | 144 | | | | | Main key array | | Generator | 136 | | | | | Numeric key pad | | Host Terminal | 145 | | | | | Repeat keystations | | Port assignments | 156 | | | | | Asynchronous, General | 135 | Printer port | 135 | | | | | I/O Port # | 157 | Table | K1 | | | | | Port selection | 42 | 이 보지 않아 됐다. 그리 하지 하고 있다 | | | | | Index | Bell (tone, speaker) | | Business graphics, (desc.) | 16, 17 | |-------------------------|--------------|----------------------------|---------| | Control code | 187 | CRT control | 183 | | Description | 47 | CRT Controller | 43 | | Port assignment | 157 | CRT entry points | 158-160 | | BIOS | | CRT font selection | 43,134 | | CP/M-80 2.2 | 5, 151 | Attributes | 44 | | CP/M-86 1.0 | 151 | Attribute selection | 7 | | Accessing | 151,152 | Configuration sector | 225 | | Cold boot | A1 | Display specification | 15 | | Console input | 167, 168, A2 | Graphics mode | | | Console output | 168, A2 | - 40 CPS | 243 | | Console status | 167, A2 | - 20 CPS | 232 | | Entry vector table | A1-A5 | Memory allocation | 45 | | Example | 152 | Prog. considerations | 186-193 | | Home disk | A2 | Scroll register | 46 | | IOBYTE-directed I/O | 167-169 | | | | Interface | 151, 152 | | | | Jump table | 151 | | | | List device 153, | 154, 167-169 | | | | List output | A2 | | | | List status | A5 | C | | | Printer output (IOBYTE) | 168 | | | | Printer status (IOBYTE) | 169 | | | | Punch output | A2 | CCP, Description | 5 | | Read sector | A4 | CP/M-80, (disk contents) | 6-9 | | Reader input | A2 | Accessing BIOS | 151,152 | | Sector translate | 152, A5 | Digital Research files | 6, 7 | | Select disk | 152, A3 | Entry Vector Table | B1 | | Set DMA address | A4 | Prog. considerations | A1-A5 | | Set sector | A3 | Xerox files | 7-9 | | Set track | A3 | CP/M-86, (disk contents) | 9, 10 | | Vectors | 151 | Accessing BIOS | 151,152 | | Warm boot | A1 | Digital Research files | 9, 10 | | Write sector | A4 | Xerox files | 10 | | Bit mask, keyboard | 225 | CPU, (general) | 2 | | Break switch, printer | 240 | ROM | 133,134 | | Bus, system | | Description | 41-44 | | Connector | 27 | Go To Command | 140 | | Electrical/environmenta | al 18 | System display | 183 | | Specification | 28-32 | CRT, (general) 3, 1 | 58, 183 | | | | CRT output | 158 | | | | RAM | 41,45 | | Block move | 160 | Character sets (pictures) | ) | |-----------------------------|------------|---------------------------|----------| | Direct CRT display | 160 | Graphics | 185 | | Entry points | 158-162 | Text | 184 | | Fast CRT output | 159 | Character spacing | | | Font selection | 43,134 | - 40 CPS | 251 | | IOBYTE | 167,168 | - 20 CPS | 235 | | Read sector | 162 | Clear screen | 188, 190 | | Select media format | 161,162 | Clear to end of line | 188, 193 | | Set direct CRT cursor | 159 | Clear to end of screen | 188, 193 | | Write sector | 162 | Clock | | | CRT controller, (genera | al) 43,44 | 8086 speed | 2 | | Attributes | 16, 17, 44 | 1-second interrupt | 174 | | Control signals (sync & v | rideo) 43 | Z80-A speed | 2. | | Design | 16, 17 | Code charts | K1-K2 | | Font ROMs | -43 | Baud rate table | K1 | | Functional description | 16 | Cold boot | 151, A1 | | CTC (Counter Timer Circuit) | 42, 134 | Cold start | 177 | | Cabling requirements: | | Cold start loader listing | G1-G6 | | - 40 CPS | 252 | Command codes: | | | - 20 CPS | 236 | 40 CPS | 242-244 | | Capacity, disk | 207-211 | Carriage movement | | | Carriage return, disp. c | ode 188 | Control codes | | | Carriage movement | | Hex codes | 245 | | - 40 CPS | 242 | Margins & formattir | ıg | | - 20 CPS | 231 | Miscellaneous comm | nands | | Caution, rigid disk | 47 | Paper movement | | | Centronics Interface | 2, 43, 135 | Printing | | | Channel A | | Remote Diagnostics | | | SIO Controller | 135, 136 | WP commands | | | Description | 42 | 20 CPS | 231-233 | | Entry points | 165 | Carriage movement | | | Channel B | | Control codes | | | SIO Controller | 135,136 | Hex codes | 234 | | Description | 42 | Margins & formatting | ıg | | Entry points | 163,164 | Miscellaneous comm | nands | | Character codes, displa | • | Paper movement | | | Character delete | 192 | Printing | | | Character devices | 153, 154 | Remote Diagnostics | | | Character insert | 192 | WP commands | 100 | | Character sets (informa | ation) | Command set (monitor) | 137-149 | | ROM | 43 | Summary table | 137 | | | 45.65 | | | | Copy memory Display memory Extended memory test Fill memory Go to Host Terminal Input Load from disk Modify memory Output Protocol Read disk sector Typewriter Verify memory block Write disk sector | | Control codes , display Backspace or cursor left Bell (tone) Carriage return Clear to end of line Clear to end of the screen Clear screen and home cursor Cursor down or line feed Cursor left or backspace Cursor right Cursor up Display next character direct Escape Home cursor Horizontal tab | |------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Communications: | | Line feed or cursor down | | SIO Controller | 135, 136 | Restore previous attribute mode | | SIO Ports, description | 42 | Set cursor character | | Baud rate command | 144 | Control key, keyboard | | Comm channel (Port #s) | 156, 157 | - ASCII 197 | | Connector (J4) | 19 | - LPK 206 | | Host Terminal | 144-146 | Control panel indicators - | | IOBYTE | 167, 168 | 40 CPS 239, 240 | | Input Data | 165 | Break switch | | Input ready status | 165 | Cover | | Output status | 165 | Form feed | | Port (J9), description | 5 | Here is switch | | Protocol command | 148, 149 | Line feed | | Settings, 40 CPS Printer | 249,250 | Overflow | | Strapping Options | 25, 26 | Parity | | Configuration sector | 225, 226 | Power indicator | | Configuration status | 181 | Print chk | | Connectors | * | Printwheel select | | (see Hardware Connecto | • | Reset | | Console devices | 153, 154 | Ribbon/paper | | Console input IOBYTE | 167 | Scroll | | BIOS entry point | A2 | Spacing select | | Console output IOBYTE | | Control panel switches - | | BIOS entry point | A2 | 20 CPS 228 | | Console status IOBYTE | 167 | Form feed | | BIOS entry point | A2 | Line feed | | | | Pause | Index | Power indicator | | Get Config Status | 181 | |--------------------------|----------|--------------------------|-----------| | Reset | | Host Terminal | 144-146 | | Control sequences, CRT | | Pass 8 bits/keyboard | 190 | | Codes | 187, 188 | Pass 7 bits/keyboard | 190 | | Table | 186 | Data format, (LPK) | 200, 201 | | Copy memory, | | Daughter board | 47 | | (Monitor Command | ) 140 | ROSR monitor | | | Counter Timer Circuit | 134 | SASI interface | | | Cover switch, (40 CPS) | 240 | Floppy connectors | 38 | | CRT memory block mov | e 160 | J1 connector | 19 | | CRT output | 158 | Rigid connector | 39 | | FAST CRT output | 159 | Devices, character & ph | ysical | | CRT RAM | | assignments | 153, 154 | | Memory allocation | 45 | Device names, logical | | | Scroll register | 46 | & physical | 153, 154 | | CTRL key, keyboard | | Diablo printers | | | - ASCII | 197 | - 40 CPS (630 | ) 237-252 | | - LPK | 206 | - 20 CPS (620 | ) 227-236 | | Cursor, (general) | 186 | Diagnostics, remote pri | nter | | Cursor keys | | - 40 CPS | 244 | | - ASCII | 195 | - 20 CPS | 233 | | - LPK | 200 | Digital Research | | | Cursor control codes | | CP/M-80 files | 6-9 | | Up, Down, Left, Right | 187 | CP/M-86 files | 9,10 | | Host Terminal cursor con | trol 147 | Dimensions | 13 | | | | 8" Floppy disks | | | | | 8" Rigid disk | | | | | 5¼" Floppy disks | | | | | 40 CPS Printer | | | | | 20 CPS Printer | | | D | | ASCII keyboard | | | | | Display/Processor | | | | | Low profile keyboard | | | DC system power | 18 | Direct CRT display | 160 | | DTR, SIO default | 135 | Disable attributes | 189 | | Daisy-chain | | Disk access connector (J | 12) 33 | | SIO Controller | 42 | Description | 34-37 | | Rigid/floppy interface | 47 | Disk connector (J1) | 19 | | Data bits | | Floppy | 38 | | SIO defaults | 135 | Illustration | 20 | | Baud rate command | 144 | Rigid | 39 | | Configuration sector | 225 226 | Disk drive format | 14 | Index | Disk drive storage | 14 | Dimensions 13 | |--------------------------|----------|---------------------------------| | Disk drives | 3, 5 | Graphics character set 185 | | Access times | 207-211 | Programming considerations 186 | | Caution | 47 | Text character set 184 | | Connector | 47 | Display, control codes 186-188 | | Dimensions | 13 | Backspace or left cursor | | Specifications | 207-212 | Bell (tone) | | Access times | | Carriage return | | Bytes per sector | | Clear to end of line | | Capacity | | Clear to end of the screen | | Encoding method | | Clear screen and home cursor | | Formats | | Cursor down or line feed | | Heat dissipation | | Cursor left or backspace | | Latency | | Cursor right | | Power dissipation | | Cursor up | | Recording density | | Display next character direct | | Sectors per track | | Escape | | Transfer rates | | Home cursor | | Voltage requireme | nts | Horizontal tab | | Disk driver | | Line feed or cursor down | | Execute physical | 161,162 | Restore previous attribute mode | | Firmware | 47 | Set cursor character | | Media identification | 213 | Display, functional desc. 16 | | Disk mapping | | Display, escape codes 189-193 | | Description | 48 | Display manipulation 186, 189 | | Device mapping | 153, 154 | Display memory command 138 | | Drive mapping table | C2 | Display next character 188 | | Interleave | 223,224 | Display/Processor 13, 183-193 | | Disk parameter block | | Display specifications 15 | | (DPB) | 214-218 | Pixel resolution | | 8" Floppies | | Refresh rate | | 8" 10 Mb rigid | | Video bit rate | | 5¾" Floppies | | Video rate | | Translate tables | | Documented system | | Disk parameter header | | storage C1, C2 | | (DPH) | 213-218 | Double density, | | Select media format | 161 | Select Media Format 161 | | Value(s) returned | 162 | Downcounter 42 | | Display 3, 15-17, 183-19 | 13 | Drive mapping tables C2 | | Attributes | 16, 183 | Drive selection | | Business graphics | 16 | PIO Controller 134 | | Character mode | 183 | Description 43 | | Dual parallel port PIO Controller | 134 | Printers (40 & 20 CPS) | 252,236 | |---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------| | Description | 43 | Disk drives | 207-211 | | Description | 73 | Display | 15 | | | | Expansion slot | 18 | | | | (See also Hardware Con | | | E | | Electrical interface | | | _ | | 40 CPS Printer | 246-250 | | | | A66 control switch | | | 8" Disk access times | 207-211 | EIA interface | | | 8" Drives, dimensions | 13 | HPR05 circuit board | | | 8" Floppy disks | | Dipswitch module | A | | Double-sided | 210,216 | Dipswitch module | | | Interleave | 223,224 | Enable attributes | 189 | | | 11,217,218 | Enter key, unique code | | | • | 09, 215, 216 | Entry points, CRT | 158-160 | | Track formats | 221,222 | Entry vector table | A1-A5 | | 820-II Device mapping | , | Environmental reg. | 18 | | General | 153, 154 | Altitude | | | Character devices | , | Humidity | | | IOBYTE | | Temperature | | | | | | | | Logical device names | | Escape codes | 189-193 | | Logical device names<br>Physical device names | | Escape codes Character delete | 189-193 | | • | | • | 189-193 | | Physical device names | | Character delete | 189-193 | | Physical device names Physical devices 8086 | 156 | Character delete<br>Character insert | 189-193 | | Physical device names<br>Physical devices | 156<br>157 | Character delete<br>Character insert<br>Clear screen | 189-193 | | Physical device names Physical devices 8086 I/O Port assignments | | Character delete<br>Character insert<br>Clear screen<br>Clear to end of line | 189-193 | | Physical device names Physical devices 8086 I/O Port assignments CPU Port # | 157 | Character delete Character insert Clear screen Clear to end of line Clear to end of screen | 189-193 | | Physical device names Physical devices 8086 I/O Port assignments CPU Port # Configuration status | 157<br>181 | Character delete Character insert Clear screen Clear to end of line Clear to end of screen Disable attributes | 189-193 | | Physical device names Physical devices 8086 I/O Port assignments CPU Port # Configuration status Description | 157<br>181<br>2, 6, 48 | Character delete Character insert Clear screen Clear to end of line Clear to end of screen Disable attributes Enable attributes | 189-193 | | Physical device names Physical devices 8086 I/O Port assignments CPU Port # Configuration status Description Dual CP/M-80/86 | 157<br>181<br>2, 6, 48<br>158 | Character delete Character insert Clear screen Clear to end of line Clear to end of screen Disable attributes Enable attributes Line delete | | | Physical device names Physical devices 8086 I/O Port assignments CPU Port # Configuration status Description Dual CP/M-80/86 Host Terminal | 157<br>181<br>2, 6, 48<br>158<br>147<br>155 | Character delete Character insert Clear screen Clear to end of line Clear to end of screen Disable attributes Enable attributes Line delete Line insert | yboard | | Physical device names Physical devices 8086 I/O Port assignments CPU Port # Configuration status Description Dual CP/M-80/86 Host Terminal Lock instruction | 157<br>181<br>2, 6, 48<br>158<br>147<br>155<br>napping154 | Character delete Character insert Clear screen Clear to end of line Clear to end of screen Disable attributes Enable attributes Line delete Line insert Pass 8 data bits from ke | yboard | | Physical device names Physical devices 8086 I/O Port assignments CPU Port # Configuration status Description Dual CP/M-80/86 Host Terminal Lock instruction Logical/Physical device in | 157<br>181<br>2, 6, 48<br>158<br>147<br>155<br>napping154 | Character delete Character insert Clear screen Clear to end of line Clear to end of screen Disable attributes Enable attributes Line delete Line insert Pass 8 data bits from ke | yboard | | Physical device names Physical devices 8086 I/O Port assignments CPU Port # Configuration status Description Dual CP/M-80/86 Host Terminal Lock instruction Logical/Physical device in Memory expansion PWE | 157<br>181<br>2, 6, 48<br>158<br>147<br>155<br>napping 154<br>3 132<br>9-11 | Character delete Character insert Clear screen Clear to end of line Clear to end of screen Disable attributes Enable attributes Line delete Line insert Pass 8 data bits from ke Position the cursor | yboard | | Physical device names Physical devices 8086 I/O Port assignments CPU Port # Configuration status Description Dual CP/M-80/86 Host Terminal Lock instruction Logical/Physical device in Memory expansion PWE Operating system files | 157<br>181<br>2, 6, 48<br>158<br>147<br>155<br>napping 154<br>3 132<br>9-11 | Character delete Character insert Clear screen Clear to end of line Clear to end of screen Disable attributes Enable attributes Line delete Line insert Pass 8 data bits from key Position the cursor Set blink attribute | yboard | | Physical device names Physical devices 8086 I/O Port assignments CPU Port # Configuration status Description Dual CP/M-80/86 Host Terminal Lock instruction Logical/Physical device in Memory expansion PWE Operating system files Operating system interfi- Schematics System bus connector | 157<br>181<br>2, 6, 48<br>158<br>147<br>155<br>napping 154<br>3 132<br>9-11<br>ace 151<br>128-132<br>27-32 | Character delete Character insert Clear screen Clear to end of line Clear to end of screen Disable attributes Enable attributes Line delete Line insert Pass 8 data bits from key Position the cursor Set blink attribute | yboard | | Physical device names Physical devices 8086 I/O Port assignments CPU Port # Configuration status Description Dual CP/M-80/86 Host Terminal Lock instruction Logical/Physical device in Memory expansion PWE Operating system files Operating system interfices Schematics System bus connector Electrical Requirements | 157<br>181<br>2, 6, 48<br>158<br>147<br>155<br>napping 154<br>3 132<br>9-11<br>ace 151<br>128-132<br>27-32 | Character delete Character insert Clear screen Clear to end of line Clear to end of screen Disable attributes Enable attributes Line delete Line insert Pass 8 data bits from key Position the cursor Set blink attribute Set graphic mode Set inverse video | yboard | | Physical device names Physical devices 8086 I/O Port assignments CPU Port # Configuration status Description Dual CP/M-80/86 Host Terminal Lock instruction Logical/Physical device in Memory expansion PWE Operating system files Operating system interfi- Schematics System bus connector | 157<br>181<br>2, 6, 48<br>158<br>147<br>155<br>napping 154<br>3 132<br>9-11<br>ace 151<br>128-132<br>27-32 | Character delete Character insert Clear screen Clear to end of line Clear to end of screen Disable attributes Enable attributes Line delete Line insert Pass 8 data bits from key Position the cursor Set blink attribute Set graphic mode Set inverse video Set low intensity | yboard | | Physical device names Physical devices 8086 I/O Port assignments CPU Port # Configuration status Description Dual CP/M-80/86 Host Terminal Lock instruction Logical/Physical device in Memory expansion PWE Operating system files Operating system interfices Schematics System bus connector Electrical Requirements | 157<br>181<br>2, 6, 48<br>158<br>147<br>155<br>napping 154<br>3 132<br>9-11<br>ace 151<br>128-132<br>27-32 | Character delete Character insert Clear screen Clear to end of line Clear to end of screen Disable attributes Enable attributes Line delete Line insert Pass 8 data bits from key Position the cursor Set blink attribute Set graphic mode Set inverse video Set low intensity Escape sequences | yboard<br>yboard | | Etch 1 CPU Specifications 251,252 J9 - strapping options 25 FIFO 48, 166 Schematics 109-116 Variables C Serial I/O Ports 42 Fast CRT output 155 Etch 2 CPU Fill memory command 135 J9 - strapping options 26 5¼" Disk access times 207, 208 Keyboard FIFO 48, 166 5¼" Drives, dimensions 13 Schematics 117-124 5¼" Floppy disks 207, 208 Serial I/O Ports 42 Disk Parameter Header 213 Even parity, host terminal 145 Double-sided 208, 215 Examples Interleave 223, 224 Bank switching D4 Single-sided 207, 214 Host Terminal 145, 146 Track formats 219, 220 List device status 152 Floppy disks 213-226 | |----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Schematics 109-116 Variables C Serial I/O Ports 42 Fast CRT output 159 Etch 2 CPU Fill memory command 139 J9 - strapping options 26 5¼" Disk access times 207, 208 Keyboard FIFO 48, 166 5¼" Drives, dimensions 13 Schematics 117-124 5¼" Floppy disks 207, 208 Serial I/O Ports 42 Disk Parameter Header 213 Even parity, host terminal 145 Double-sided 208, 219 Examples Interleave 223, 224 Bank switching D4 Single-sided 207, 214 Host Terminal 145, 146 Track formats 219, 226 List device status 152 Floppy disks 213-226 | | Serial I/O Ports 42 Fast CRT output 155 Etch 2 CPU Fill memory command 135 J9 - strapping options 26 5¼" Disk access times 207, 208 Keyboard FIFO 48, 166 5¼" Drives, dimensions 13 Schematics 117-124 5¼" Floppy disks 207, 208 Serial I/O Ports 42 Disk Parameter Header 213 Even parity, host terminal 145 Double-sided 208, 219 Examples Interleave 223, 224 Bank switching D4 Single-sided 207, 214 Host Terminal 145, 146 Track formats 219, 226 List device status 152 Floppy disks 213-226 | | Etch 2 CPU Fill memory command 133 J9 - strapping options 26 5¼" Disk access times 207, 208 Keyboard FIFO 48, 166 5¼" Drives, dimensions 13 Schematics 117-124 5¼" Floppy disks 213 Serial I/O Ports 42 Disk Parameter Header 213 Even parity, host terminal 145 Double-sided 208, 215 Examples Interleave 223, 224 Bank switching D4 Single-sided 207, 214 Host Terminal 145, 146 Track formats 219, 226 List device status 152 Floppy disks 213-226 | | 19 - strapping options 26 5¼" Disk access times 207, 208 | | Keyboard FIFO 48, 166 5¼" Drives, dimensions 13 Schematics 117-124 5¼" Floppy disks Serial I/O Ports 42 Disk Parameter Header 213 Even parity, host terminal 145 Double-sided 208, 215 Examples Interleave 223, 224 Bank switching D4 Single-sided 207, 214 Host Terminal 145, 146 Track formats 219, 226 List device status 152 Floppy disks 213-226 | | Schematics 117-124 5½" Floppy disks Serial I/O Ports 42 Disk Parameter Header 213 Even parity, host terminal 145 Double-sided 208, 215 Examples Interleave 223, 224 Bank switching D4 Single-sided 207, 214 Host Terminal 145, 146 Track formats 219, 220 List device status 152 Floppy disks 213-226 | | Serial I/O Ports 42 Disk Parameter Header 213 Even parity, host terminal 145 Double-sided 208, 215 Examples Interleave 223, 224 Bank switching D4 Single-sided 207, 214 Host Terminal 145, 146 Track formats 219, 226 List device status 152 Floppy disks 213-226 | | Even parity, host terminal 145 Double-sided 208, 219 Examples Interleave 223, 224 Bank switching D4 Single-sided 207, 214 Host Terminal 145, 146 Track formats 219, 220 List device status 152 Floppy disks 213-226 | | ExamplesInterleave223,224Bank switchingD4Single-sided207,214Host Terminal145,146Track formats219,220List device status152Floppy disks213-226 | | Bank switching D4 Single-sided 207, 214 Host Terminal 145, 146 Track formats 219, 220 List device status 152 Floppy disks 213-226 | | Host Terminal 145, 146 Track formats 219, 220 List device status 152 Floppy disks 213-226 | | List device status 152 Floppy disks 213-226 | | ,,,, | | | | Monitor calls/BASIC D1-D3 Connector (J1) | | Protocol command 148,149 Illustration 20 | | Start/Stop 8086 155 Disk parameter block (DPB) 214-218 | | Z-80A Assembly Language 171-173 Disk parameter header (DPH) 213 | | Execute physical driver 161, 162 Interleave 223, 224 | | Expansion slot, (general) 6 Track formats 219-222 | | Electrical 18 Font generator, I/O Port # 157 | | Extended memory Font ROMs (U57 & U58) 43 | | test command 139 Font selection 43, 44, 134 | | 40 CPS Printer 249, 250 | | Form feed | | -40 CPS 239 | | F - 20 CPS 228 | | Format, floppy disks 219-222 | | Front cover switches | | 4.03 ROM 135 -40 CPS 238, 239 | | 40 CPS Printer 237-252 -20 CPS 227, 228 | | DC1/DC3 237 Function key | | HPR05 Priority - ASCII 196 | | Description 237,238 -LPK 205 | | Interface 247-249 Uses - ASCII 196 | | Access cover 238, 239 - LPK 205 | | Command codes 242-244 Functional description 4, 5 | | Cont. panel switches 239, 240 BDOS | | Electrical interface 246-250 BIOS | | Font selection 249,250 CCP | | Operating codes 241 ROSR | | Operating systems | | - Interface | 33 | |--------------------------|-----------|--------------------------|-------| | Ports | | Floppy disk (J1) | | | System monitor - ROM | | - Connector | 19 | | | | - Illustration | 20 | | | | - Interface | 38 | | | | Keyboard connector (J | 2) 19 | | | | Paraliel port (J8) | | | G | | - Connector | 23 | | | | - Illustration | 21 | | | | - Picture | 24 | | General Purpose PIO | | Power supply (J5 & 6) | 22 | | Ports A & B, Description | 43 | Printer connector (J3) | 19 | | Specifications | 135 | Rigid disk (J1) | | | Get address of time- | | - Connector | 19 | | of-day variables | 180 | - Illustration | 20 | | Get config status | 181 | - Interface | 39 | | Get disk map table | | System bus connector ( | (J13) | | address | 178, 179 | - Connector | 27 | | Go to command | 140, 141 | - Description | 28-32 | | Graphics character set | 185 | Video connectors (J7) | 22 | | Mode | 183 | Hardware description | 2-4 | | | | Disk drives | | | | | Display | | | | | Keyboards | | | | | Printers | | | н | | System board | | | | | Hardware handshaking | 148 | | | | Hardware interface | 5, 6 | | HMI/VMI | | COMM port | • | | - 40 CPS | 241 | Disk drive | | | - 20 CPS | 230 | Expansion slot | | | HPR05 desc 40 CPS | 237, 238 | Keyboard | | | Hardware connectors | 19-39 | Parallel port | | | COMM connector ( | 14) 19 | Printer | | | COMM port (J9) cor | nnector | Hardware scrolling | 46 | | - Etch 1 Ci | | Head Step Rate, | | | - Etch 2 Cf | PU 26 | Configur.com | 8 | | Daughter board | | Configuration sector | 225 | | - Floppy | 38 | Here Is Switch, (40 CPS) | 239 | | - Rigid | 39 | Hex codes | | | Disk access (J12) | | - 40 CPS | 245 | | - Descript | ion 34-37 | - 20 CPS | 234 | | 3 Coc. pt | | | | | Home cursor (ESC code) | 188 | GP-PIO channel B | | |--------------------------|----------|----------------------------|------------| | Home disk, BIOS | A2 | SIO channel A | | | Horizontal Motion Index | | SIO channel B | | | - 40 CPS | 241 | Z80-A | | | - 20 CPS | 230 | Baud rate | | | Horizontal tab - display | 187 | Double density sele | ect | | Host computer | 144 | Font generator | | | • | 144-148 | Scroll register | | | Baud rate | | Single density selec | t . | | Channel | | Speaker | | | Command set | | Interleave, (floppy disks) | 223, 224 | | Data bits | | Interrupt mode 2 | 41, C1 | | Monitor output command | | Interrupt vectors | C1, C2 | | Option Summary | | СТС | , | | Parity | | GP PIO | | | Port | | SIO | | | Stop bits | | Disk | | | Humidity requirements | 18 | System PIO | | | | | Interrupts | | | | | CTC | 134 | | | | GP PIO | 135 | | 1 1 | | SIO | 135 | | | | Daisy-chain vectori | | | | | Disk | 34-37 | | I/O Channel, | | Expansion slot | 28-32 | | setting baud rate | 144 | System PIO | .134 | | IOBYTE | | System 110 | .134 | | CP/M-80, device mapping | 153 | | | | CP/M-86, device mapping | 154, 155 | | | | Console input | 167 | | | | Console output | 168 | J | | | Console status | 167 | | | | Directed I/O | 167-169 | | | | Printer output | 168 | J1 (Disk access) 19, | 20, 38, 39 | | Printer status | 169 | J2 (Keyboard) | 19 | | Input command (Monitor | ) 141 | J3 (Printer) | 19 | | Input/output | | J4 (Communications) | 19 | | Port assignments 1 | 56, 157 | J5 (Power supply) | 22 | | 8086 | | J6 (Power supply) | 22 | | CRT | | J7 (Video) | 22 | | СТС | | J8 (Parallel connector) | 23, 24, 43 | | GP-PIO channel A | | J9 (Parallel port, Etch 1) | 25 | | | | | | | J9 (Parallel port, Etch 2) J11 (Option connector) J12 connector | 26<br>43, 135<br>33-37 | Line feed switch (40 CPS) 239<br>Line feed or cursor down 187<br>Line insert 192 | |-----------------------------------------------------------------|------------------------|----------------------------------------------------------------------------------| | J13 connector | 27-32 | List device 153, 154, 167-169 | | Jump vectors 151, 158, | A1-A5 | List output, BIOS A2 | | • | | List status, BIOS A4 | | | | Listings: Appendix | | | | BIOS jump table H | | | | ROM E | | K | | Banked physical driver 1 | | | | Cold start loader G | | | | Macros & Symbols F | | Key code chart: | | Position-encoded kybd handler J | | - ASCII | 198, 199 | Load from disk command 142 | | - LPK | 202-204 | Logical device names | | Keyboards 3, 5, 1 | 95-206 | 820-II 153 | | FIFO variables | C1 | 16/8 154 | | ROM | 133 | Logical to Physical Disk | | ASCII | 195-199 | Mapping Table 178, 179, C2 | | Bit mask | 224, 225 | Logical/physical | | Connector (J2) | 19 | translate tables 213 | | Data input 15 | 7-165,C1 | Low profile keyboard 200-206 | | Device Mapping | 153, 154 | Auto-Repeat | | Dimensions | 13 | Cursor keys | | Enter key, unique codes | 204 | Data format | | Handler | 201 | Dimensions | | Input (System PIO) | 43,166 | Enter key, unique codes | | Input channel | 134 | Function key uses | | Interface (FIFO variables) | 48, C1 | Key code chart | | Low profile | 200-206 | Keyboard handler | | Product Codes | 3 | Main key array | | Status | 166 | Numeric key pad | | Translation tables | 201 | Low profile ROM 133, 134, 204 | ı М | LST 153, 154, 167-169 | | | | |-----------------------|-----|-----------------|------------------| | (device mapping) | | MS-DOS | 10, 11, 151 | | Line delete | 192 | Macros & Symbol | s listing F1-F24 | | Main key array | | Protocol | | |----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------| | - ASCII | 195 | ROSR | | | - LPK | 200 | Read disk sector | | | Margin & formatting co | des | Typewriter | | | - 40 CPS | 242 | Verify memory block | | | - 20 CPS | 231 | Write disk sector | | | Memory allocation | 44, 45 | Monitor entry vector ta | ble B1 | | Memory banks | 41-43 | More interrupt vectors | C2 | | Memory contents | 138 | • | | | Memory pointers | C2 | | | | Memory size: RAM/ROM | VI 2 | | | | Microsoft 10, 11 | , 151, D1 | N | | | Miscellaneous functions | 177-182 | | | | Cold start | | | | | Get configuration status | | Numeric key pad | | | Get disk map table addre | ess | - ASCII | 195 | | Get TOD variable | | - LPK | 200 | | Start screen print | | | | | Warm start | | | | | Miscellaneous printer co | odes: | | | | - 40 CPS | 243 | | | | - 20 CPS | 232 | 0 | | | | | | | | | rs C1, C2 | | | | Mode 2 Interrupt Vector | rs C1, C2<br>135, 136 | | | | Mode 2 Interrupt Vector | 135, 136 | 1-second interrupt | 170, 174 | | Mode 2 Interrupt Vector<br>Modem 42, | 135, 136 | 1-second interrupt<br>Offset, display | 170, 174<br>46 | | Mode 2 Interrupt Vector<br>Modem 42,<br>(channel, baud rate gene | 135, 136<br>erator) | • | • | | Mode 2 Interrupt Vector<br>Modem 42,<br>(channel, baud rate gene<br>Modes of operation | 135, 136<br>erator) | Offset, display | • | | Mode 2 Interrupt Vector Modem 42, (channel, baud rate gene Modes of operation (Host terminal) | 135, 136<br>erator)<br>145 | Offset, display Operating codes: | 46 | | Mode 2 Interrupt Vector Modem 42, (channel, baud rate gene Modes of operation (Host terminal) Modify memory | 135, 136<br>erator)<br>145<br>138, 139 | Offset, display<br>Operating codes:<br>- 40 CPS | 241-244<br>230-233 | | Mode 2 Interrupt Vector Modem 42, (channel, baud rate gene Modes of operation (Host terminal) Modify memory Monitor calls in BASIC | 135, 136<br>erator)<br>145<br>138, 139<br>D1-D3 | Offset, display<br>Operating codes:<br>- 40 CPS<br>- 20 CPS | 241-244<br>230-233<br>1 13 | | Mode 2 Interrupt Vector Modem 42, (channel, baud rate gene Modes of operation (Host terminal) Modify memory Monitor calls in BASIC Monitor commands | 135, 136<br>erator)<br>145<br>138, 139<br>D1-D3<br>137-149 | Offset, display Operating codes: - 40 CPS - 20 CPS Operating environment | 241-244<br>230-233<br>1 13 | | Mode 2 Interrupt Vector Modem 42, (channel, baud rate gene Modes of operation (Host terminal) Modify memory Monitor calls in BASIC Monitor commands Summary table | 135, 136<br>erator)<br>145<br>138, 139<br>D1-D3<br>137-149 | Offset, display Operating codes: - 40 CPS - 20 CPS Operating environment Operating mode switch | 241-244<br>230-233<br>1 13<br>es: | | Mode 2 Interrupt Vector Modem 42, (channel, baud rate gene Modes of operation (Host terminal) Modify memory Monitor calls in BASIC Monitor commands Summary table Baud rate | 135, 136<br>erator)<br>145<br>138, 139<br>D1-D3<br>137-149 | Offset, display Operating codes: - 40 CPS - 20 CPS Operating environment Operating mode switch - 40 CPS | 241-244<br>230-233<br>1 13<br>es:<br>238-240 | | Mode 2 Interrupt Vector Modem 42, (channel, baud rate gene Modes of operation (Host terminal) Modify memory Monitor calls in BASIC Monitor commands Summary table Baud rate Copy memory | 135, 136<br>erator)<br>145<br>138, 139<br>D1-D3<br>137-149 | Offset, display Operating codes: - 40 CPS - 20 CPS Operating environment Operating mode switch - 40 CPS - 20 CPS | 241-244<br>230-233<br>1 13<br>es:<br>238-240 | | Mode 2 Interrupt Vector Modem 42, (channel, baud rate gene Modes of operation (Host terminal) Modify memory Monitor calls in BASIC Monitor commands Summary table Baud rate Copy memory Display memory | 135, 136<br>erator)<br>145<br>138, 139<br>D1-D3<br>137-149 | Offset, display Operating codes: - 40 CPS - 20 CPS Operating environment Operating mode switch - 40 CPS - 20 CPS Operating System | 46 241-244 230-233 1 13 es: 238-240 227-230 | | Mode 2 Interrupt Vector Modem 42, (channel, baud rate gene Modes of operation (Host terminal) Modify memory Monitor calls in BASIC Monitor commands Summary table Baud rate Copy memory Display memory Extended memory test | 135, 136<br>erator)<br>145<br>138, 139<br>D1-D3<br>137-149 | Offset, display Operating codes: - 40 CPS - 20 CPS Operating environment Operating mode switch - 40 CPS - 20 CPS Operating System General | 46 241-244 230-233 1 13 es: 238-240 227-230 4,5 151-182 | | Mode 2 Interrupt Vector Modem 42, (channel, baud rate gene Modes of operation (Host terminal) Modify memory Monitor calls in BASIC Monitor commands Summary table Baud rate Copy memory Display memory Extended memory test Fill memory | 135, 136<br>erator)<br>145<br>138, 139<br>D1-D3<br>137-149 | Offset, display Operating codes: - 40 CPS - 20 CPS Operating environment Operating mode switch - 40 CPS - 20 CPS Operating System General Interface | 46 241-244 230-233 1 13 es: 238-240 227-230 4,5 151-182 | | Mode 2 Interrupt Vector Modem 42, (channel, baud rate gene Modes of operation (Host terminal) Modify memory Monitor calls in BASIC Monitor commands Summary table Baud rate Copy memory Display memory Extended memory test Fill memory Go to | 135, 136<br>erator)<br>145<br>138, 139<br>D1-D3<br>137-149 | Offset, display Operating codes: - 40 CPS - 20 CPS Operating environment Operating mode switch - 40 CPS - 20 CPS Operating System General Interface Output codes, keyboard - ASCII | 46 241-244 230-233 1 13 es: 238-240 227-230 4,5 151-182 ds: | | Mode 2 Interrupt Vector Modem 42, (channel, baud rate gene Modes of operation (Host terminal) Modify memory Monitor calls in BASIC Monitor commands Summary table Baud rate Copy memory Display memory Extended memory test Fill memory Go to Host Terminal | 135, 136<br>erator)<br>145<br>138, 139<br>D1-D3<br>137-149 | Offset, display Operating codes: - 40 CPS - 20 CPS Operating environment Operating mode switch - 40 CPS - 20 CPS Operating System General Interface Output codes, keyboard - ASCII | 46 241-244 230-233 1 13 es: 238-240 227-230 4,5 151-182 ds: 198,199 | | Mode 2 Interrupt Vector Modem 42, (channel, baud rate gene Modes of operation (Host terminal) Modify memory Monitor calls in BASIC Monitor commands Summary table Baud rate Copy memory Display memory Extended memory test Fill memory Go to Host Terminal Input | 135, 136<br>erator)<br>145<br>138, 139<br>D1-D3<br>137-149 | Offset, display Operating codes: - 40 CPS - 20 CPS Operating environment Operating mode switch - 40 CPS - 20 CPS Operating System General Interface Output codes, keyboard - ASCII - Low Prof | 46 241-244 230-233 1 13 es: 238-240 227-230 4,5 151-182 ds: 198,199 file 202-204 | | Mode 2 Interrupt Vector Modem 42, (channel, baud rate gene Modes of operation (Host terminal) Modify memory Monitor calls in BASIC Monitor commands Summary table Baud rate Copy memory Display memory Extended memory test Fill memory Go to Host Terminal Input Load from disk | 135, 136<br>erator)<br>145<br>138, 139<br>D1-D3<br>137-149 | Offset, display Operating codes: - 40 CPS - 20 CPS Operating environment Operating mode switch - 40 CPS - 20 CPS Operating System General Interface Output codes, keyboard - ASCII - Low Prof Output command | 46 241-244 230-233 1 13 es: 238-240 227-230 4,5 151-182 ds: 198,199 file 202-204 141,142 | | Overflow Switch (40 CP | S) 240 | Printer | 4, 5, 19, 135 | |----------------------------|--------------|-------------------------|----------------| | | | Position-encoded key | board | | | | Handler | 201 | | P | | Listing | J1-J38 | | | | Position the cursor | 191, 192 | | | | Power indicator: | • | | PIO, (general) 43 | , 134, 135 | - 40 CPS | 239 | | Paper movement, print | er: | - 20 CPS | 228 | | - 40 CPS | 243 | Power on sequence | 133-136 | | - 20 CPS | 231 | Power supply (J5 & 6) | 22 | | Parallel I/O controller | 134, 135 | Print Chk switch (40 Cl | PS) 240 | | Bank switching | • | Printers, general | 4, 227-252 | | Floppy drive select | | A66 Control switch | 249,250 | | Floppy side select | | 40 CPS | 237 | | Font selection | | 20 CPS | 227 | | Keyboard input channel | | Baud rate command | 144 | | Parallel port | 2, 6, 43 | Baud rate generator | 136 | | Connector | 23,24 | Buffer | 238, 251 | | Parallel printer | 43, 135 | Channel | 42 | | Parity | | Connector (J3) | 19 | | Host Terminal | 145, 146 | Dimensions | 13 | | 40 CPS switch | 240 | Entry points | 163,164 | | 20 CPS switch | 229 | Output | 163,164 | | Pass upper bit of data | | Overview | 163 | | from keyboard | 190 | Port 42 | , 43, 135, 136 | | Pause switch (20 CPS) | 228 | Status | 163 | | Physical device names | | Printing commands | | | 820-11 | 153 | - 40 CPS | 243 | | 16/8 | 154 | - 20 CPS | 232 | | Physical Disk Interleave | 223, 224 | Printwheel selection (4 | 10 CPS) 238 | | Physical driver | | Product code numbers | 3,4 | | Address table | C3 | Programmable | | | Request block 161, 1 | 162, 176, C3 | functions: | 170-176 | | Physical format, disk | | 1-second interrupt | | | drives | 219-222 | Processing while I/O pe | nding | | Physical to Logical Device | ce | Sample program | | | Mapping | 167 | Soft disk error | | | Pixel resolution | 15 | Soft error recording | | | Ports | | System exit points | | | Communication 4, 5, 19, | 25, 26, 135 | Programming conside | rations: | | General | 4 | BIOSA1-A5 | | | Parallel | 23, 24 | CRT Control codes | 187, 188 | | CRT Escape codes | 189-193 | Refresh RAM | 43 | |-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------| | Display | 186-193 | Memory | 183 | | Escape sequences | | Rate | 15 | | - 40 CPS | 242, 243 | Remote Diagnostics: | | | - 20 CPS | 231,232 | - 40 CPS | 243,244 | | Printer control codes | | - 20 CPS | 232,233 | | - 40 CPS | 245 | Repeat keystations: | | | - 20 CPS | 234 | - ASCII | 195 | | Proportional spacing ( | HMI/VMI) | - LPK | 205 | | - 40 CPS | 241 | Reserved | | | - 20 CPS | 230 | ASCII Keys | 198, 199 | | Protocol command | 148, 149 | Low Profile Keys | 202-204 | | XON/XOFF | | Ports | 157 | | Hardware handshake | | Tracks | 214-218 | | Serial printers | | Reset Switch (40 CPS) | 239 | | Punch output, BIOS | A2 | Reset, Power on | 133-136 | | | | Resident monitor | | | | | commands | 137-149 | | | | Resolution, screen | . 15 | | R | | Restore previous attrib | ute | | | | mode | 187 | | | | | | | | | Ribbon/Paper switch (40 | CPS) <b>240</b> | | RAM, CRT | 41-46 | · | 19, 20, 39 | | RAM, CRT Attributes | 41-46 | • | • | | • | 41-46 | • | • | | Attributes | 41-46 | Rigid disk conn. (J1) | • | | Attributes<br>Driver | 41-46 | • | • | | Attributes<br>Driver<br>Font Selection | 41-46 | Rigid disk conn. (J1) | • | | Attributes<br>Driver<br>Font Selection<br>Memory Allocation | 41-46 | Rigid disk conn. (J1) | 19, 20, 39 | | Attributes Driver Font Selection Memory Allocation Offset | 41-46 | Rigid disk conn. (J1) S 7 data bits (SIO controll | 19, 20, 39<br>er) 110 | | Attributes Driver Font Selection Memory Allocation Offset Power on Refresh RAM Scroll Register | | Rigid disk conn. (J1) S 7 data bits (SIO controll 1797 - Western Digital | 19, 20, 39<br>er) 110<br>279-302 | | Attributes Driver Font Selection Memory Allocation Offset Power on Refresh RAM Scroll Register ROM 5, 41, 42, 13 | 3-136, 158 | Rigid disk conn. (J1) S 7 data bits (SIO controll 1797 - Western Digital 6-8k ROM | 19, 20, 39<br>er) 110<br>279-302<br>2, 42 | | Attributes Driver Font Selection Memory Allocation Offset Power on Refresh RAM Scroll Register ROM 5, 41, 42, 13 ROM listings | 3-136, 158<br>E1-E110 | Rigid disk conn. (J1) S 7 data bits (SIO controll 1797 - Western Digital 6-8k ROM 16/8 physical device ma | er) 110<br>279-302<br>2, 42<br>pping | | Attributes Driver Font Selection Memory Allocation Offset Power on Refresh RAM Scroll Register ROM 5, 41, 42, 13 ROM listings ROM/O.S. Interface | 3-136, 158<br>E1-E110<br>158 | Rigid disk conn. (J1) S 7 data bits (SIO controll 1797 - Western Digital 6-8k ROM 16/8 physical device ma | 19, 20, 39<br>er) 110<br>279-302<br>2, 42 | | Attributes Driver Font Selection Memory Allocation Offset Power on Refresh RAM Scroll Register ROM 5, 41, 42, 13 ROM listings ROM/O.S. Interface ROSR 5, 41, 44, 47, 13 | 3-136, 158<br>E1-E110<br>158<br>33-136, 170 | Rigid disk conn. (J1) S 7 data bits (SIO controll 1797 - Western Digital 6-8k ROM 16/8 physical device ma | er) 110<br>279-302<br>2, 42<br>pping | | Attributes Driver Font Selection Memory Allocation Offset Power on Refresh RAM Scroll Register ROM 5, 41, 42, 13 ROM listings ROM/O.S. Interface ROSR 5, 41, 44, 47, 13 RS232 (See Comm port | 3-136, 158<br>E1-E110<br>158<br>33-136, 170 | Rigid disk conn. (J1) S 7 data bits (SIO controll 1797 - Western Digital 6-8k ROM 16/8 physical device ma 153, 154 | er) 110<br>279-302<br>2, 42<br>pping<br>, 167-169 | | Attributes Driver Font Selection Memory Allocation Offset Power on Refresh RAM Scroll Register ROM 5, 41, 42, 13 ROM listings ROM/O.S. Interface ROSR 5, 41, 44, 47, 13 RS232 (See Comm port | 3-136, 158<br>E1-E110<br>158<br>33-136, 170<br>:)<br>135, 136 | Rigid disk conn. (J1) S 7 data bits (SIO controll 1797 - Western Digital 6-8k ROM 16/8 physical device ma 153, 154 Application programs Communication channe | er) 110<br>279-302<br>2, 42<br>pping<br>, 167-169 | | Attributes Driver Font Selection Memory Allocation Offset Power on Refresh RAM Scroll Register ROM 5, 41, 42, 13 ROM listings ROM/O.S. Interface ROSR 5, 41, 44, 47, 13 RS232 (See Comm port RTS Read disk sector comm | 3-136, 158<br>E1-E110<br>158<br>33-136, 170<br>:)<br>135, 136<br>and 143 | Rigid disk conn. (J1) S 7 data bits (SIO controll 1797 - Western Digital 6-8k ROM 16/8 physical device ma 153, 154 Application programs Communication channe IOBYTE Logical device names | er) 110<br>279-302<br>2, 42<br>pping<br>, 167-169 | | Attributes Driver Font Selection Memory Allocation Offset Power on Refresh RAM Scroll Register ROM 5, 41, 42, 13 ROM listings ROM/O.S. Interface ROSR 5, 41, 44, 47, 13 RS232 (See Comm port RTS Read disk sector comm | 3-136, 158<br>E1-E110<br>158<br>33-136, 170<br>:)<br>135, 136<br>land 143<br>162, A5 | Rigid disk conn. (J1) S 7 data bits (SIO controll 1797 - Western Digital 6-8k ROM 16/8 physical device ma 153, 154 Application programs Communication channe IOBYTE Logical device names Physical device names | er) 110<br>279-302<br>2, 42<br>pping<br>, 167-169 | | Attributes Driver Font Selection Memory Allocation Offset Power on Refresh RAM Scroll Register ROM 5, 41, 42, 13 ROM listings ROM/O.S. Interface ROSR 5, 41, 44, 47, 13 RS232 (See Comm port RTS Read disk sector comm Read sector Reader input | 3-136, 158<br>E1-E110<br>158<br>33-136, 170<br>:)<br>135, 136<br>land 143<br>162, A5<br>A2 | Rigid disk conn. (J1) S 7 data bits (SIO controll 1797 - Western Digital 6-8k ROM 16/8 physical device ma 153, 154 Application programs Communication channe IOBYTE Logical device names Physical device names Physical devices | er) 110<br>279-302<br>2, 42<br>pping<br>, 167-169 | | Attributes Driver Font Selection Memory Allocation Offset Power on Refresh RAM Scroll Register ROM 5, 41, 42, 13 ROM listings ROM/O.S. Interface ROSR 5, 41, 44, 47, 13 RS232 (See Comm port RTS Read disk sector comm | 3-136, 158<br>E1-E110<br>158<br>33-136, 170<br>:)<br>135, 136<br>land 143<br>162, A5 | Rigid disk conn. (J1) S 7 data bits (SIO controll 1797 - Western Digital 6-8k ROM 16/8 physical device ma 153, 154 Application programs Communication channe IOBYTE Logical device names Physical device names | er) 110<br>279-302<br>2, 42<br>pping<br>, 167-169 | | Z80-A CPU | Select media format 161 | |--------------------------------------------|------------------------------------| | SA 1403 | Serial I/O Controller 42, 135, 136 | | Processing while I/O pending 174 | Async modem port | | Soft Error Recording 176 | Baud rate | | SA 1403D controller 254-278 | Channel B | | <b>SA400L</b> 207, 214, 219, 220, 223, 224 | Printer port | | <b>SA450</b> 208, 215, 219, 220, 223, 224 | Set blink attribute 191 | | SA800 209, 215, 216, 221, 224 | Set cursor character 187 | | SA850 210, 216, 221, 224 | Set DMA address A4 | | <b>SA1004</b> 211,217,218,223,224 | Set direct CRT cursor 159 | | SASI interface 47 | Set graphic character 191 | | SIO, (general) 42 | Set inverse video 191 | | SIO Channels: | Set low intensity 191 | | - A 135, 136 | Set sector A3 | | - B 135, 136, 163, 164 | Set track A3 | | SIO controller 42, 135, 136 | Shugart - 1403D 253-278 | | SIO-B | Side selection 43, 134, 161 | | Input data 163 | Single density 161 | | Input ready status 163 | Skewing 223, 224 | | Output data 163 | Soft disk error 176 | | Output ready status 164 | Soft error recording 176 | | Sample programs | Spacing select (40 CPS) 238 | | Z80-A assembly 171-173 | Speaker (bell, tone) 47, 157 | | Monitor calls - BASIC D1-D3 | Specifications | | Bank switching D4 | - 820-II & 16/8 13-16 | | Schematics 109-132 | Dimensions | | Screen attributes - see Attributes | Disk drive format | | Screen codes 186-193 | Disk drive storage | | Screen print 182 | Display | | Screen resolution: | Electrical | | Description 16 | Operating environment | | Specification 15 | Specifications | | Scroll switch (40 CPS) 239 | 40 CPS 251, 252 | | Scroll register 45, 46 | Cabling requirements | | Hardware scrolling | Character set | | Offset | Character spacing | | Sectors per track 207-211 | Power requirements | | Sector translate, BIOS A5 | Print buffer | | Table 213 | Print line | | Vector 152 | Printwheels | | Sectran 152, A5 | 20 CPS 235, 236 | | Seldsk 152, A3 | Cabling requirements | | Jelusk 132, A3 | Cabing requirements | | Character set | | Operating codes | | |-------------------------------|------------|-----------------------------|------------| | Character spacing | | Operating mode switches | | | Power requirements | | Specifications | | | Print buffer | | Vertical motion index (VMI) | | | Print line | | Temperature req. | 18 | | Printwheels | | Text character set | 184 | | Start screen print | 182 | Theory of Operation | 41-48 | | Storage capacity | 207-211 | 6-8k ROM memory | | | Strapping options, | | 64k RAM | | | Comm port | 25, 26 | CPU | | | Strobe, printer | 135 | CRT controller | | | Synchronous | | СТС | | | I/O Port # | 157 | PIO Controller | | | Port selection | 42 | SIO Controller | | | System board | 2 | Bus expansion | | | System bus | 18, 48 | Daughter board | | | Connector (J13) | 27-32 | Dual parallel ports | | | System configuration | 181 | Memory allocation | | | System display | 183-193 | Parallel keyboard interfa | ce | | Graphics character set | | Scroll register | | | Programming considerations | | Serial I/O ports | | | Text character set | | Speaker | | | System exit points | 170-176 | Time constant | | | System monitor, | | Time-of-day and | | | ROM | 4, 133-136 | timer variables 47 | 7, 180, C4 | | System PIO | 43, 134 | Timer variables | 180, C4 | | System storage | C1 | Tone generator | 47, 157 | | • | | (speaker, bell) | | | | | Track format, disk | | | | | drives | 207-211 | | Т | | Transfer rates | 207-211 | | | | Typewriter command | 144 | | 20 CPS Printer | | | | | Dimensions | 13 | | | | General | 227-237 | V | | | Cabling requirem | ents | | | | Command codes | | Vector table | B1 | | Control panel switches | | Verify command | 140 | | Front cover switches | | Vertical Motion Index: | | | Horizontal motion index (HMI) | | - 40 CPS | 241 | | Power indicator | | - 20 CPS | 230 | | | | | | 16 | Video bit rate | 15 | |----------------------|----| | Video connector (J7) | 22 | | Video rate | 15 | Z 2, 41, 42, 47-108 133, 158, C1, C2 171-173 49-108 ## W Z80-A WD1797 174, 176, 279-302 Assembly language ex. Warm boot Α1 **Zilog Reprint** Warm start 177 Western Digital General 174,176 Reprint 279-302 WP commands: 40 CPS printer 243 20 CPS printer 232 Write disk sector command 143 Write sector, BIOS 162, A4 ## X | XON/XOFF protocol | 148 | |-------------------|-----| | Xerox files | | | CP/M-80 disk | 7-9 | | CP/M-86 disk | 10 | | Xtended memory | | | test command | 139 | Index 18 Index