Owner's Manual

**Model 2422** 

# Multimode Floppy Disk Controller



California Computer Systems

# CCS MODEL 2422 FLOPPY DISK CONTROLLER OWNER'S MANUAL

COPYRIGHT 1980

CALIFORNIA COMPUTER SYSTEMS 250 CARIBBEAN DRIVE SUNNYVALE, CA 94086

MANUAL NO. 89000-02422

# TABLE OF CONTENTS

| CHAPTER | 1 | INTRODUCTION<br>1.1 BUS COMPATIBILITY 1-1<br>1.2 DISKETTE COMPATIBILITY 1-1<br>1.3 USER OPTIONS 1-2<br>1.4 THE BOOT/MONITOR ROM 1-2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |   |
|---------|---|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|
| CHAPTER | 2 | <pre>SETUP AND INSTALLATION 2.1 2422 SETUP</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |   |
| CHAPTER |   | THE 2422 ROM-RESIDENT FIRMWARE       3-1         3.1 COLD-START ENTRY       3-1         3.2 PAGE 0 RAM USED BY FIRMWARE       3-1         3.3 THE FIRMWARE DISK ROUTINES       3-2         3.3.1 Diskette Format       3-2         3.3.2 The Primitive Disk Routines       3-3         3.3.3 Disk Parameters For Disk       0perations         0perations       3-4         3.4 THE BOOTSTRAP LOADER       3-4         3.5 THE MONITOR       3-5         3.5.1 The Monitor's Memory Space       3-5         3.5.2 The IOBYTE and the Basic I/O       3-6         3.5.3 Bringing Up The Monitor       3-8         3.5.4 Monitor Commmands       3-8         3.5.5 Error Messages       3-9         3.5.6 Command Description       3-11 | L |
| CHAPTER | 4 | THEORY OF OPERATION         4.1 THE 2422 REGISTERS       4-1         4.2 THE SYSTEM INTERFACE       4-2         4.2.1 The Bank Select Circuitry       4-2         4.2.2 Selecting the 2422 Registers       4-3         4.2.3 Memory-Mapped I/O       4-3         4.2.4 Selecting the ROM       4-4         4.2.5 The Board Select Line and LED       4-5         4.2.6 PHANTOM* and FF Detect       4-5         4.2.7 The Data Bus       4-6                                                                                                                                                                                                                                                                                           | 3 |

i

# CHAPTER 1

# INTRODUCTION

California Computer System's 2422 Floppy Disk Controller is an S-100 compatible board which can control four drives in any combination of 5.25" and 8" two-sided or single-sided drives. It can read and write both single-density (FM) and double-density (MFM) soft-sectored diskettes. An on-board 2K ROM contains monitor firmware designed for systems using CCS's 2810 Z-80 CPU and bootstrap loader for loading in CP/M from disk.

# 1.1 BUS COMPATIBILITY

The 2422 is compatible with the IEEE proposed standards for the S-100 bus, thus making it bus compatible with most of the S-100 systems currently on the market. The drive busses are designed primarily to be plug-compatible with Shugart 800/850 and 400/450 drives and any drives using the same drive bus. However, some additional signals common to other drives have also been incorporated. See Appendix A for the signals used by the system and disk drive busses.

# 1.2 DISKETTE COMPATIBILITY

Western Digital's FD1793 disk controller chip used by the 2422 reads and writes diskettes which conform to the IBM 3740 format standard for single-density diskettes or the IBM System 34 format standard for double-density diskettes and which contain 128, 512, 256, or 1024 bytes per sector. Because of its format requirements, it cannot read diskettes formatted by the 1771 disk controller chip, although the 1771 can read diskettes formatted

and the second

. .

|                   |        | 4.2.8       ROM Wait Circuitry       4-6         4.2.9       Auto Wait       4-6         4.3       DISK DRIVE INTERFACE       4-8         4.3.1       The Clock Signal       4-8         4.3.2       The Read Clock Generator       4-8         4.3.3       Read Data Pulse Width       4-9         4.3.4       Write Precompensation       4-10         4.3.5       Head Load Timing       4-11 |
|-------------------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| APPENDIX          |        | THE 2422 DISK CONTROLLER BUSSES<br>A.1 THE SYSTEM BUS A-3<br>A.1.1 Address and Data lines A-3<br>A.1.2 CPU Status Signals A-3<br>A.1.3 Control Inputs A-3<br>A.1.4 Control Outputs A-4<br>A.1.5 The Power Lines A-4<br>A.1.6 The 2422 System Bus Pin<br>Assignments A-5                                                                                                                          |
| ×                 |        | A.2 THE 2422 DISK DRIVE BUSSES A-6<br>A.2.1 The Disk Drive Busses Pin<br>Assignments A-8                                                                                                                                                                                                                                                                                                         |
| APPENDIX          | В      | 2422 PROGRAMMING INFORMATION<br>B.1 THE 2422 ADDRESSABLE REGISTERS B-3<br>B.1.1 Control Register 1 B-4                                                                                                                                                                                                                                                                                           |
|                   |        | B.1.2 Status Register 1 B-5<br>B.1.3 Control Register 2 B-6                                                                                                                                                                                                                                                                                                                                      |
| -14 <sup>61</sup> | *)<br> | B.1.4 Status Register 2 B-6<br>B.1.5 Bank Select Port B-8                                                                                                                                                                                                                                                                                                                                        |
| 2                 |        | B.2 DISKETTE FORMAT B-9                                                                                                                                                                                                                                                                                                                                                                          |
|                   |        | Diskette B-10                                                                                                                                                                                                                                                                                                                                                                                    |
|                   |        | B.2.2 Formatting a Double-density<br>Diskette B-11                                                                                                                                                                                                                                                                                                                                               |
| APPENDIX          | С      | 1793 DATA SHEET                                                                                                                                                                                                                                                                                                                                                                                  |
| APPENDIX          |        | TECHNICAL INFORMATION<br>PARTS LIST                                                                                                                                                                                                                                                                                                                                                              |
| 1                 |        | BUS INTERFACE SCHEMATIC C-7<br>DRIVE INTERFACE SCHEMATIC C-9                                                                                                                                                                                                                                                                                                                                     |
| APPENDIX          | E      | FIRMWARE LISTING                                                                                                                                                                                                                                                                                                                                                                                 |
| APPENDIX          | F      | LIMITED WARRANTY                                                                                                                                                                                                                                                                                                                                                                                 |

ii

#### INTRODUCTION

by the 1793. The utility program COPY provided with CCS's CP/M package reformats diskettes formatted by the 1771 so that the 1793 can read them.

#### 1.3 USER OPTIONS

The 2422 incorporates a number of optional features that are jumper-selected or configured. These are described fully in Chapter Two. In addition, CCS makes available an address decoding ROM that can be inserted in U21 to allow memory mapping of the 2422 registers to addresses FFF8h-FFFDh.

# 1.4 THE BOOT/MONITOR ROM

The on-board ROM contains a bootstrap loader for loading CP/M into memory from disk and the MOSS 2.2 Disk Monitor. Both the bootstrap loader and the MOSS monitor take advantage of the Both Z-80's large instruction set and thus cannot cannot be used with an 8080 CPU. The MOSS monitor is designed to work specifically with CCS's Model 2810 Z-80 CPU. The 2422 gives you the choice of having CP/M loaded automatically on system power-on and reset, or of having the monitor entered on power on or reset. The monitor command allows you to boot in CP/M from the monitor. Once Boot is loaded, the monitor and bootstrap loader can CP/M be software-disabled, the Loader program supplied with CCS's CP/M package doing so automatically. When the ROM is enabled and addressed, the ROM LED lights and the 2422 generates the PHANTOM signal which allows memory overlay of all devices which share the ROM's memory space and recognize the PHANTOM signal.

Those of you who want to alter the firmware or design your own will find programming information on the 2422 in Appendix B.

# CHAPTER 2

# SETUP AND INSTALLATION

#### 2.1 2422 SETUP

Your 2422 Floppy Disk Controller is designed to be flexible enough to fit different systems and different customer needs. This flexibility is achieved in part by on-board jumpers which allow you to selectively enable/ disable features or configure them to fit your needs. Each jumper-enabled or configured feature is discussed in a section below. In Appendix E, you will find a board layout on which the jumpers are clearly indicated, labeled, and referenced to the appropriate section below.

# 2.1.1 FAST-SEEK SELECT JUMPER

If you are not using a voice coil drive, remove the FAST SEEK jumper plug entirely. If you are using a voice coil drive, the FAST SEEK jumper allows you to either software-enable or hardware-enable the fast seek mode. Placing the jumper plug at the SFT position as shown in Figure 2-1 allows you to enable fast seeks by writing a 0 to bit 4 of Control Register 2. Placing the jumper plug at the HRD postion permanently enables fast seeks. If you are planning to use the CCS firmware/software supplied with the 2422, fast seeks will be enabled only if you set the jumper to the HRD position, since the CCS software does not enable the fast seek mode.



FIGURE 2-1

# 2.1.2 BANK-BYTE SELECT JUMPERS

The 2422 Disk Controller can be hardware assigned to one of eight banks, or levels of 64K. To do so, place the jumper plug on the BANK BYTE jumper header which corresponds to the bank level to which you want this board assigned. For example, putting the plug on header DO assigns this board to bank 0. Once you have assigned this board to a bank, you can in turn select that bank and enable the board by outputting to port 40 a data byte with a logic 1 in the bit position corresponding to the bank level. If you plan to use the version of CP/M supplied by CCS, assign the board to bank 0. The Loader program on disk disables the monitor and bootstrap loader firmware by outputting a hex 01 to port 40h. If you have your 2422 assigned to any other bank than bank 0, your board will be disabled.

#### 2.1.3 MEMORY-MAP ENABLE JUMPER

As mentioned in the introduction, CCS makes available to its 2422 users a control ROM which allows the registers on the 2422 to be memory mapped. If you plan to use the memory-map option, you can enable/disable memory mapping through the M MAP jumper. Position OFF of the M MAP jumper disables memory mapping; the opposite position enables it. The CCS firmware does not make use of memory mapping.

# 2.1.4 PARTIAL-ROM ENABLE JUMPER

By setting the PR EN jumper to ON, you allow the portion of the ROM containing the basic I/O routines and the primitive disk routines used by the monitor to be available after CP/M is loaded in. This portion of the ROM, located at F600h-F7FFh, contains essentially the same basic I/O routines as the CCBIOS on disk. If you are planning to tailor the CCBIOS to your system, you may wish to have your customized BIOS call some of the routines located in the ROM. This will give you the greater reliability of ROM memory and save some disk space. If you do not wish the basic I/O portion of the ROM to remain in memory after CP/M is loaded in, set the PR EN jumper to OFF.

# 2.1.5 ROM WAIT STATE ENABLE JUMPER

The on-board ROM has the relatively slow memory access time of 450 nsecs. A CPU running at 4 MHz will not provide the access time needed by the ROM. The access time of the 1793 registers when they are memory mapped is also slow, about 350 nsecs. The ROM WAIT jumper, when set to ON, allows you to place the CPU in one Wait state per cycle in which either the ROM or the 1793 is selected. Some CPUs, such as CCS's Model 2810 Z-80 CPU, use pin 98 of the bus to indicate whether the CPU is operating at 2 or 4 MHz. If your CPU does so, setting the jumper to 4 MHz allows the 2422 to place the CPU in a Wait state only when the CPU is operating at 4 MHz. OFF completely disables the ROM Wait circuitry.

# 2.1.6 BANK ENABLE JUMPER

jumper allows you three options in using the The BANK EN bank-select system to enable the board. Position ON makes the bank-select system fully operable, so that to enable the board, you must software-select the bank this board resides in by outputting the correct data byte to port 40h. Postion RST disqualifies the bank-select system on system power-on and reset, allowing the board to be enabled after you turn on or reset your system without its bank software-selected first. being Otherwise, the bank-select system functions as usual. Position completely disgualifies the bank-select system, permanently OFF enabling the board. Note that in the last two cases, the Bank LED will be lit when the board is enabled through disgualifying the bank-select system. If you are using the version of CP/M supplied by CCS, set BANK EN to RST or OFF, since the board must be enabled on reset. If you are operating with one disk controller in your system, the OFF position is probably the wiser choice since it eliminates the possibility of accidently disabling the board.

# 2.1.7 BOOT ENABLE JUMPER

The BOOT EN jumper allows you to choose between three methods of enabling/disabling the bootstrap loader and monitor firmware. If you set the BOOT EN jumper to OFF, neither the bootstrap loader or the monitor firmware can be accessed. If you have set the PR EN jumper to OFF, the entire ROM will then be disabled. If you set the BOOT EN jump to position A, the

bootstrap loader and monitor are enabled when your system is turned on or reset and disabled when any data byte is output to port 40h. Because port 40h is the Bank Select Port as well, you must also have the BANK EN jumper set to RST or OFF so that the board is enabled on reset or power on. If you are planning to use the CCS version of CP/M supplied with your board, set the BOOT EN jumper to position A. This allows the bootstrap loader and monitor to be disabled automatically when CP/M is loaded. Position B of the BOOT EN jumper allows the bootstrap loader and monitor to be enabled/disabled entirely through software control. Writing a 0 to bit 1 of Control Register 2 enables them; a 1 disables them.

# 2.1.8 Auto Boot Enable Jumper

If you are using the ROM-resident firmware, this jumper allows you to choose whether or not CP/M will be loaded or the monitor entered on power-on and reset. If you set this jumper to OFF, the monitor will be entered on power-on and reset. CP/M can then be loaded in under monitor control by use of the Boot command. For those who plan to use the 2422 in a system with a 2810 Z-80 CPU and wish to use the initialization firmware provided for the on-board port, the AUTO BOOT jumper should be set to OFF. This allows you to synchronize the baud rate of the 2810's port to the baud rate of your console device by hitting the carriage return key two to three times. This brings up the monitor, allowing CP/M to be booted in at will. If you set the AUTO BOOT jumper to ON, CP/M will be booted in on power-on and reset. Since only the bootstrap loader portion of the ROM will be accessed, this setting frees the user of the constraint of using the 2422 in a system with a 2810 Z-80 CPU. However, the user must then provide his own console initialization routine in the BIOS.

# 2.1.9 Auto Wait Select Jumper

The disk drive cannot read or write data on the disk as fast as the CPU can send or receive data. Thus there are times when the CPU must wait for the data register in the disk controller chip to become ready to receive a data byte from or transmit a data byte to the CPU. The state of the DRQ (Data Request) line from the 1793 indicates whether or not the data register is ready for data transfer. If it is low, the data register is not ready. If you set the AUTO WAIT jumper to DATA, you can force the CPU into a Wait state every time the CPU tries to read or

write to the data register when the DRQ line is low. By setting it to STAT1, you force the CPU into a Wait state every time it tries to read Board Status Register 1 when the DRQ line is low. In both cases, the CPU will remain in a Wait state until the DRQ line goes high again. Both forms of the Auto Wait are also enabled/ disabled through software control. Writing a 1 to bit 7 of Control Register 1 enables Auto Waits; a 0 to bit 7 disables them.

# 2.1.10 INTERRUPT JUMPERS

The interrupt jumpers allow you to tie DRQ and/or INTRQ to either the Interrupt line, pINT, the Nonmaskable Interrupt line, NMI, or any of the 8 Vectored Interrupt lines, VIO-VI7. INTRQ, when active, indicates that a command has been completed and that the 1793 is awaiting a new command. DRQ, when active, indicates that the data buffer either has a byte to be read or is empty and requires a new byte to transmit, depending on the nature of the disk operation in progress. Either or both of these lines can be used to generate interrupts and thus request servicing from the processor. To generate a Vectored Interrupt 2 by the active INTRQ, for example, run a bus wire from the INTRQ pad to the VI2 pad and solder it in.

# 2.2 SYSTEM SETUP FOR FIRMWARE COMPATIBILITY

In order for the bootstrap loader and monitor firmware to work as described in Chapter 3, you must have a power-on jump circuit somewhere in your Z-80 system set to force the CPU to jump to location F000h when you turn your system on or reset it. Any RAM sharing the ROM's memory space must be disabled while the firmware is being accessed. If your RAM board accepts the PHANTOM signal output by the 2422 when the ROM is selected, the RAM will automatically be disabled. On CCS memory boards, this entails jumper-enabling the PHANTOM signal. If your RAM board uses the same bank-select system as the 2422, you also can configure your board so that the memory block sharing memory space with the 2422 ROM is assigned to bank 0 and disabled on power-on or reset. When the Loader program from disk is loaded, it outputs a hex 01 to port 40h. This disables the bootstrap and monitor firmware as it enables the RAM. Please note that if you use this method you must have at least 256 bytes of low RAM memory enabled on reset; to be safe it would be wise to enable all RAM except that which directly conflicts with the ROM. For example, if you own CCS's Model 2065 64K Dynamic RAM board, you

would assign the board to bank 0 and configure it to be bank-disabled on reset, with the first three 16K blocks bank-independent and the last 16K block bank-dependent. Note that if you want the basic I/O portion of the ROM enabled after CP/M is loaded, you will have to use the PHANTOM line to disable the RAM sharing its memory space.

The monitor and basic I/O routines require some additional set up. They are designed to work in a system with a Model 2810 Z-80 CPU configured as follows: SER EN, JMP EN, and PHANTOM set ON and SER ADDRESS SELECT set to 20h. The 2/4 MHz switch should also be set to 4 MHz if you are planning to read or write doubledensity diskettes; the firmware design does not allow doubledensity diskettes to be read or written when the CPU is operating at 2 MHz. In addition, your terminal must be set as described in section 2.2.2 of the 2810 Owner's Manual to work with the console driver routines.

# 2.3 INSTALLATION

Because we can not anticipate what drive or drives you will be using the 2422 board with, we can not give specific installation instructions. However, there are some general instructions we can give. If you plan to use more than one drive, you must make sure that the common lines are terminated in the last drive on the cable only. This may mean removing jumper plugs or resistor packs: see your manual. You must also enable the appropriate Drive Select line to each drive, usually accomplished by moving a jumper plug. Some signals, such as TWO-SIDED, may also require some user-configuration to be enabled.

The cable assemblies needed to connect the 2422 with your drives are not not supplied with the 2422. For the 5.25" drives and the 8" drives you need 34 and 50 conducter flat-ribbon cables, respectively. The connectors you need are as follows:

Mating Connectors for the 2422:

5.25" drives (J1) = Ansley #609-3430 or equivalent 8" drives (J2) = Ansley #609-5030 or equivalent

Back Panel Connectors:

5.25" drives = Ansley #609-3416 or equivalent 8" drives = Ansley #609-5016 or equivalent

Mating Connectors to the Drive P. C. Board:

5.25" drives = Ansley #609-5015M or equivalent 8" drives = Ansley #609-3415M or equivalent

If you assemble your own cables, be sure that the pin 1 strip of the cable (usually marked by an outside colored stripe) matches pin 1 of all the connectors. Owners of Shugart, Memorex, and other bus-compatible drives can simply install the assembled cables and connect them, being careful to match pin 1s. Owners of the Per Sci drives will have to do some rewiring, since the Per Sci drive bus differs from the 2422. Section A.2.1 in Appendix A shows the pinouts for J1 and J2.

# CHAPTER 3

# THE 2422 ROM-RESIDENT FIRMWARE

# 3.1 COLD-START ENTRY

The firmware cold-start entry point is F000h. If you set a power-on jump circuit to this address, the CPU will jump to the cold-start entry point when your system is turned on or reset. The cold-start initialization routine loads the low RAM locations called to by the Z-80 restart commands with jump vectors to the It then finds the highest continuous restart error message. active RAM address and locates the monitor stack and work space Next it checks the state of the Auto Boot bit in the below it. board's Status Register 1; if the Auto boot bit is 0 the initialization routine passes control to the bootstrap loader, The monitor work which then loads in CP/M as described below. space is overwritten as CP/M is loaded in. If the Auto Boot bit is 1, the initialization routine continues, initializing the 2810 Z-80 CPU's serial port. When it has synchronized the serial port's baud rate to the console's baud rate, it turns control over to the monitor executive.

# 3.2 PAGE O RAM USED BY FIRMWARE

The following locations in page 0 of system memory are used by the the firmware. Except where noted, these locations should be reserved.

| Address                                                                                               | Contents                                                                                                                                                                                                                                                                                                                                           |
|-------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0000h-0002h                                                                                           | These locations contain the warm-start vector<br>for the monitor. When CP/M is loaded, they are<br>overwritten by the warm-start vector for CP/M.                                                                                                                                                                                                  |
| 0003h                                                                                                 | This location contains the Intel Standard IOBYTE loaded during cold-start initialization and used for monitor I/O (see section 3.5.2).                                                                                                                                                                                                             |
| 0008h-000Ah<br>0010h-0012h<br>0018h-001Ah<br>0020h-0022h<br>0028h-002Ah<br>0030h-0032h<br>0038h-003Ah | During cold-start initialization these locations<br>called by the Z-80 restart commands are loaded<br>with jump vectors to the restart error message<br>(see section 3.5.5.) They can be overwritten by<br>valid restart routines. In addition, locations<br>0008h-000Ah are used for software breakpoint<br>processing by the monitor GO command. |
| 0040h-0053h                                                                                           | These locations contain disk parameters used by<br>the bootstrap loader and the monitor. They are<br>described in more detail in section 3.3.1.<br>Locations 0040-004Fh are defined by CP/M as user<br>scratchpad locations; 0050-0053h are unused by<br>present versions of CP/M but are held reserved.                                           |
| 0080h-017Fh                                                                                           | Temporary buffer used by the bootstrap loader<br>and CP/M to store the Loader program from disk.                                                                                                                                                                                                                                                   |

# 3.3 THE FIRMWARE DISK ROUTINES

# 3.3.1 DISKETTE FORMAT

The primitive disk routines used by the monitor and the bootstrap loader are designed to read or write disks which conform to the IBM 3740 and System 34 standards for soft-sectored diskette format. Although strictly speaking these standard apply to 8" diskettes only, they can be adapted for 5.25" diskettes. Since the firmware routines are designed for diskettes conforming to the IBM format standards, it might be helpful if we discuss diskette format in general and the IBM standards in particular.

Track numbering on a diskette begins at its circumference with Track 00 and proceeds toward the center; thus the innermost

track on an 8" diskette with the standard 77 tracks is track 76. Each track on side 0 of a two-sided diskette has an associated track on side 1; these track-pairs are often called cylinders. Unlike track numbering, sector numbering starts with 1, the number given to the first sector immediately following the index pulse. The number of sectors on a track is dependent on disk size, data density, an number of bytes per sector.

The IBM 3740 standard for single-density diskettes allows sector sizes of 128, 256, and 512 bytes; the System 34 standard for double-density diskettes allow sectors sizes of 256, 512, and 1024 bytes. (The 1793 can format single-density diskettes in 1024-byte sectors and double-density diskettes in 128-byte sectors as well, but those additional sector sizes have no practical advantage.) Before each sector is an unique address or ID field specifying the track number, diskette side, sector number, and sector size. In addition, the ID fields and data fields must be separated by gaps and sync fields of a minimum length. Figure B-1 of Appendix B illustrates the IBM format standard for singledensity 8" diskettes. The 1793 adds an additional constraint to diskette format: it expects gaps to consist of FFh data bytes, followed by 00h. As a result it cannot read diskettes formatted by a 1771 disk controller chip. (The 1771 can, however, read disks formatted by the 1793.) The utility program COPY supplied by CCS with CP/M allows disks formatted by the 1771 to be reformatted so that the 1793 can read them.

# 3.3.2 THE PRIMITIVE DISK ROUTINES

The firmware contains two routines for sector reads and writes: DREAD and DWRITE. The bootstrap loader calls DREAD for reading the first two sectors of Track 00; the monitor Read and Write commands use both routines. DREAD and DWRITE both transfer sector at a time and automatically determine disk size, one sector size, and density format if the disk has not been accessed before. They conform to the CP/M calling conventions and return a 0 in the A register if the disk operation was successful and a non-zero if it was not successful after ten tries. Both routines reside in the upper 1/2K of ROM which can remain enabled after CP/M is loaded in. Thus they can be called to from a user's BIOS. The entry point for DREAD is F6EAh; for DWRITE, F6EBh.

# 3.3.3 DISK PARAMETERS FOR DISK OPERATIONS

DREAD and DWRITE use locations 0040h-0053h to store the disk parameters they need. Below are the definitions and addresses of some of the more useful disk parameters:

| Address         | Name   | Description                                                                                                        |
|-----------------|--------|--------------------------------------------------------------------------------------------------------------------|
| 0040h           | DISKNO | Stores the number of the currently-<br>selected drive: 0, 1, 2, or 3.                                              |
| 0041h           | TRACK  | Stores the number of the current track.                                                                            |
| 0042h           | SECTOR | Stores the number of the current sector.                                                                           |
| 0043h           | SIDE   | Stores the byte written to Control<br>Register 2 to select disk side. (90h =<br>side 0; D0h = side 1)              |
| 0045h           | TWOSID | Stores 0 if the disk in the currently-<br>selected drive is one-sided; 1 if it is<br>two-sided.                    |
| 004Ah           | CUNIT  | Stores the byte last written to Control<br>Register 1, giving information on the<br>currently-selected drive unit. |
| 004Ch           | HSTBUF | Stores the starting address in memory<br>for disk transfers to and from memory.                                    |
| 004Eh-<br>0053h | IDSV   | Stores the ID field information from a sector in the currently-selected drive.                                     |

# 3.4 THE BOOTSTRAP LOADER

The bootstrap loader, when entered at F55Eh, reads in at locations 80h through 17Fh the contents of the first two sectors of track 00, side 0 of the disk in drive A and then transfers control to them. The sectors must contain a Loader program for loading CP/M into memory and transferring control to it. In addition, Track 00 of this disk must be formatted in 128-byte single-density sectors. If the bootstrap loader encounters an error, it jumps to the Disk Error routine in the monitor portion of the ROM. If you were booting CP/M in from the monitor so that the 2810 CPU's serial port had been initialized, you will receive the Disk Error message as described in section 3.5.5 and control will be returned to the monitor. If you were booting in CP/M directly on system power-on or reset, your system will "hang." When it is finished reading in the Loader program, the bootstrap loader leaves some disk parameters in memory:

DISKNO=0 SIDE=0 TRACK=00 SECTOR=3 CUNIT=21 for a single-density 5.25" diskette 31 for a single-density 8" diskette 61 for a double-density 5.25" diskette 71 for a double-density 8" diskette IDSV + 3=00 if diskette sector size is 128 01 if diskette sector size is 256 02 if diskette sector size is 512 03 if diskette sector size is 1024

After it is loaded, the Loader program in the disk supplied by CCS outputs hex 01 to port 40h. If the BOOT EN jumper has been set to postion A, this simultaneously disables the bootstrap and monitor firmware and enables any RAM assigned to bank 0 and with a bank select port of 40h.

# 3.5 THE MONITOR

CCS's MOSS 2.2 Disk Monitor is designed to allow you to control a system using a 2810 Z-80 CPU from the console keyboard. It allows you to display a block of memory in hex and ASCII, to move, change, and verify memory, and to transfer control to another program in memory with breakpoints set. You can also output or input a data byte to or from any I/O port and command the monitor to read and write floppy disks.

For the MOSS 2.2 Monitor to work exactly as described below, your 2422 Disk Controller board and 2810 Z-80 CPU must be configured as described in sections 2.1 and 2.2.

# 3.5.1 THE MONITOR'S MEMORY SPACE

In addition to the memory the ROM occupies and the page 0 addresses specified in section 3.2, the monitor requires some high RAM locations for the system stack and temporary storage area. The monitor scans the available memory until it finds the highest active RAM address and then counts down 56 bytes to store the breakpoints, registers, and register restore routine. It locates the system stack below that: you should reserve at least 88 bytes of high RAM memory for the monitor's use.

# 3.5.2 THE IOBYTE AND THE BASIC I/O ROUTINES

The monitor's basic I/O routines are essentially the same as those used by CCBIOS. They are designed for a system using CCS's 2810 Z-80 CPU, configured as described in section 2.2. As with the primitive disk routines, they reside in the last 1/2K of the ROM, allowing them to be available after CP/M is loaded, should you wish them to be. Section 3.5.2.3 below contains information tailoring this portion of the ROM to fit your system's needs, on if your are using a system with a different CPU or wish to provide driver routines for other peripherals. Please note that the method of initializing the console interface's baud rate described in the sections on bringing up the monitor and in the Y command is highly dependent on the hardware configuration of the 2810's serial port. the description on the monitor's Thus operation in these sections will probably not be valid if you alter the firmware to work with a different console interface.

# 3.5.2.1 The IOBYTE

The basic I/O routines in this portion of the ROM implement IOBYTE function, as developed in the Intel MDS system and as the used by CP/M. The IOBYTE function allows the user to assign а physical device to one or more of four logical I/O categories: Console, List, Punch, and Reader. The current physical to logical device assignments are stored in the IOBYTE at location 0003h. The IOBYTE can be altered through the MOSS monitor Assign command or the CP/M STAT command. When an I/O routine, such as Console Input, is called, the routine loads the IOBYTE, using it to determine the currently assigned physical device, and then jumps to the driver routine called by the physical device assignment. For the allowable physical assignments in each logical category, see the Assign Command, section 3.5.4.1. In each logical category, the firmware provides only the Teletype assignment with driver routines. These routines are designed to drive the serial port on the 2810 CPU. Please note that the physical assignment names do not have to accurately describe the actual peripheral used; the actual physical device driven by the teletype assignment routines could easily be a CRT. For all physical device assignments other than the teletype, the I/O routines jump to location F462h, the location of the monitor I/O error message, resulting in the I/O Error message being displayed and control returned to the monitor as described in section 3.5.5.

# 3.5.2.2 The Basic I/O Routines

The user may call the following basic I/O routines from his own programs while in the monitor or from his own customized BIOS if the PR EN jumper is set ON.

| Name   | Address | Description                                                                               |
|--------|---------|-------------------------------------------------------------------------------------------|
|        |         |                                                                                           |
| CI     | F646    | Console Input                                                                             |
| *CONI  | F68F    | Console Input, strips ASCII parity bit                                                    |
| *CO    | F600    | Console Output                                                                            |
| *CSTS  | F623    | Console Status Input                                                                      |
| *LO    | F610    | List Output                                                                               |
| *LSTAT | F669    | List Status Input                                                                         |
| *RI    | F656    | Paper Tape Reader Input                                                                   |
| *PO    | F67C    | Papar Tape Punch Output                                                                   |
| PRTWA  | F698    | Prints ASCII string on console. String must be terminated by bit 7 set in last character. |
| PRTWD  | F695    | Same as above, only does carriage return, line feed first                                 |
| CRLF   | F6A9    | Generates carriage return, line feed sequence to start new line on console                |

The starred routines are CP/M compatible routines, basically the the same as the following routines used in the CCBIOS: CONIN, CONOUT, CONST, LIST, LISTST, READER, and PUNCH. They perform the basic IOBYTE handling as described above. Again, actual driver routines exist only for the teletype assignment for each logical category. These driver routines conform to the CP/M calling conventions, passing the data in the C register for any output and in the A register for any input. PRTWA, PRTWD, and CRLF are not routines used by a CP/M BIOS, however they are useful routines which are available as long as the Basic I/O portion of the ROM is accessible. CI is an alternative console input routine which does not strip the parity bit.

# 3.5.2.3 Customizing the Basic I/O Routines

As mentioned before, the monitor's basic I/O routines are designed to drive the console interface on the 2810 Z-80 CPU. Should you wish to add drivers for other peripheral devices or to use another console interface, you will have to alter the ROM firmware. There are two ways to do so. You can reprogram the ROM so that the jump instruction associated with a particular physical device assignment forces the CPU to jump to your peripheral's driver routine. For example, to add a line printer to your system, you would change the jump instructions at locations F61D and F676 so that they contained the beginning

address of your printer driver routines. Or you can, if you have CCS's 2810 Z-80 CPU and peripheral cards, use memory overlay techniques. Since the 2422 board generates, but does not receive, the PHANTOM signal, its ROM has to be moved to the CPU board. There the jump vectors called by the physical assignments can be overlaid with new jump vectors by the peripheral board's ROM.

# 3.5.3 BRINGING UP THE MONITOR

To enter the monitor, turn your system on or reset it. This results automatically in a cold-start entry into the monitor. Set your terminal to the baud rate at which you wish to operate. You have a choice of any baud rate between 2 and 56K baud. To allow the 2810 CPU's serial port to be initialized to the baud rate, hit the carriage return key until the monitor responds with

# MOSS VERS 2.2

The maximum number of carriage returns needed before the monitor responds is three. When the monitor prompt appears, you may start entering commands.

# 3.5.4 MONITOR COMMANDS

The MOSS Monitor commands must conform to a specific format. The general form is

# -CE1 E2 E3

where - is the prompt, C is the command character and El-E3 are the address and data entries, if any. The essential parts of a command are as follows:

THE COMMAND CHARACTER: The monitor is controlled by one-character commands entered from the keyboard in response to the monitor prompt, a dash (-). No space is allowed between the prompt and the command character.

ADDRESS AND DATA ENTRIES: The general form for an address is a four digit hex number; for data, a two digit hex number. Leading zeros need not be entered; the monitor will supply them. No space is allowed between the command character and the first address or data entry. Subsequent entries must be separated by a delimiter. The monitor looks at only the last four address

characters or last two data characters before a delimiter. So if you make a mistake while typing an entry, keep typing until the last two or four characters are correct.

DELIMITERS: The MOSS Monitor recognizes three delimiters: a carriage return [CR], a space, or a comma. A carriage return indicates to the monitor that the current command is complete and should be executed. Either a space or a comma can mark the end of an address or data entry. In our command examples we will generally use a space as a delimiter, unless a comma makes the command form clearer. Please note, however, that you can use the space and the comma interchangeably. In certain commands a space or a comma can also be interchanged with a carriage return. These are commands for which the Monitor expects a fixed number of entries (and hence delimiters) following the command character.

#### SAMPLE COMMAND

The following commands to display the block of memory OFFBh to 100Ah are all equivalent. Although the spacing is not free-form, some variety in the command form is allowed. Note that the display command requires two and only two address parameters, so that the last delimiter can be a comma or a space as well as a carriage return.

> -DOFFB 100A[CR] -DFFB,100A, -DFFB,100A[CR] -DFFB 100A[space] -D0EF0FFB,100A[space]

# 3.5.5 ERROR MESSAGES

The MOSS monitor detects four types of error conditions and responds with a different error message for each. They are as follows:

COMMAND ERROR: Should you make an invalid entry, the command will be aborted, a warm boot of the system will occur, and the error message

# ????

will be printed, followed by the monitor prompt.

I/O ASSIGNMENT ERROR: As described in section 3.3, the Assign command allows you to assign a physical device to a logical peripheral category. When an I/O routine involving the logical category is called, the CPU will jump to the driver routine indicated by the physical assignment. If there is no driver routine, it will jump instead to the I/O Assignment Error routine. This routine sets the IOBYTE to its default value, outputs the error message

# I/O ERR

and does a warm boot of the system.

RESTART ERROR: During cold-start initialization, jump-vectors to a restart error message are loaded in the memory locations called by the Z-80 restart instructions. This is done to prevent a jump to a restart address without code. A restart error causes the message

#### RST ERR

to be displayed and a warm boot of the system to occur.

DISK ERROR: The monitor, when executing the Read, Write, or Boot commands, will output the following error message and status information if it is unable to execute the command:

# DSK ERR U XX T XX S XX C XX E XX

The first three hex bytes identify which physical record the monitor was unable to read or write. U gives the unit or drive number (0-3), T the track number and S the sector number of the record where the error occured. C and E give the operation status at the time of the error. They reflect the contents of two of the 1793's internal registers: C shows the last command loaded in the Command register; E gives the contents of the Status register.

#### 3.5.6 COMMAND DESCRIPTION

# 3.5.6.1 Assign (A)

you The Assign command allows to change the physical-to-logical device assignments and thus choose the peripherals you wish to work with while in the monitor. The IOBYTE function as developed by Intel for the MDS systems divides peripherals into four logical categories: Console, typically a teletype or a CRT; Reader, a paper tape reading device; Punch, a paper tape punching device; and List, a hard-copy printing device. Each of the four logical categories may have one of four devices assigned to them. The possible physical physical-to-logical assignments are as follows:

- (C) Console
  - (T) Teletype
    - (C) CRT
    - B) Batch Mode (input from logical reader device; output to logical list device)
    - (1) User Console #1
- (R) Reader
  - (T) Teletype
    - (P) Paper tape reader
    - (1) User reader #1
    - (2) User reader #2
- (P) Punch
  - (T) Teletype
  - (P) High speed paper tape punch
  - (1) User punch #1
  - (2) User punch #2
- (L) List
  - (T) Teletype
  - (L) High speed line printer (CRT in CP/M)
  - (1) User list #1 (High speed line printer in CP/M)
  - (2) User list #2 (User list # 1 in CP/M)

To assign a physical device to a logical device category, enter

-AX

where X equals either C,R,P, or L, the logical device codes. If you enter a character other than these four, the computer will return with ???? and another prompt. If you enter a valid logical device code, the computer will return immediately with a prompt for the physical device code. Enter

-Y

where Y equals the physical device code. Should you enter a delimiter only or a nonvalid device code, the device assignment will remain the same.

EXAMPLE:

Entering

#### -AR-P

assigns a high speed paper tape reader to the Reader logical device category.

Since the firmware contains driver routines only for the teletype assignment, you should receive the I/O error message if you attempt I/O operations with any other physical device without having altered the firmware first.

3.5.6.2 Boot (B)

The Boot command allows you to load in CP/M from disk under console control. Entering

-B

causes the bootstrap loader to load CP/M in from the disk in drive A and control to be transferred from the monitor to CP/M. When CP/M is loaded, the CP/M sign on message will appear, followed by the CP/M prompt. Should the bootstrap loader be unable to read in the first two sectors on Track 00, it will respond with the Disk Error message.

3.5.6.3 Display (D)

This command allows you to display the contents of a specified block of memory. The general form for the command is

# -DA1 A2

where Al and A2 are the first and last bytes, respectively, of the memory block.

The resulting display divides the memory into 16 bytes per line. Each line begins with the starting address of the 16 byte block, followed by the hex contents and their ASCII equivalents. The contents of addresses with the same last hex digit are aligned in vertical columns. Periods represent data for which there are no ASCII equivalents. As the display fills the screen, it automatically scrolls up. To freeze the display, type a control-S. To start it again, hit any key on the keyboard. Should you wish to escape from the display mode, hitting any key on the keyboard will abort the routine and return control to the monitor.

#### EXAMPLE

Entering

# DF453 F4C8

# results in the following display:

E1 00 00 AF 32 45 52 D2 44 AD 20 53 AD 4D 4F 53 53 OF D3 24 11 A3 A3 C2 AD 7D B4 C2 BD E1 F9 C3 B5 52 3A AD 32 20 32 26 A3 19 E5 00 00 C3 2F 4F 20 AD 20 54 3F 3F BF 0D 8A 3E DB 26 2B DB 20 2B 83300044 5224 FF 90836051 04450EE 0600AE89 D20D529E 2455F2B9 ERRDSK ERR: E-. - S-MOSS .S\$.@.bj[&# ##B-te)\..e) }4B=ta>.S F4CO

# 3.5.6.4 Fill (F)

The fill command allows you to fill a block of memory with a specified constant. The general command form is

# -FA1 A2 C

where Al and A2 are the addresses of the first and last bytes of the memory block and C is the constant in hexidecimal.

# EXAMPLE

Entering

# -F10AA 10BB 1

fills the memory block 10AAh to 10BBh with the constant 1.

3-14

# 3.5.6.5 Goto (G)

The G command allows you to transfer control from the monitor to another program. It allows you to specify the entry address and to set up to two breakpoints for returning control to the monitor. When the monitor encounters a breakpoint, it saves the contents of the Z-80 registers in the system's temporary storage and outputs to the console device an asterisk followed by the address after the break. It then returns the prompt. You can use the Examine Register command (X) at this time to examine or change the saved registers.

The general form for the G command is

-GA B1 B2

where A is the entry address, and Bl and B2 are the addresses of the breakpoints. There are many allowed variations on this command, however, which makes it a powerful and convenient command. You have the option of establishing 0, 1, or 2 breakpoints: simply enter a [CR] when you have established the number of breakpoints you wish. If you enter the maximum, two, a delimiter (a comma or space) is all that is necessary to begin command execution.

You may also begin execution of the program at the PC address saved in the register storage area. Thus you can return control to the address where the program stopped when it encountered a breakpoint, or to the address you have loaded in the saved PC register through the Examine Register command. Note that since all breakpoints are cleared when any breakpoint is encountered, you must specify any desired breakpoints in the command if you use it this way. The form of the command for transferring program control to the address in the PC register is

> -G[CR] (no breakpoints) or -G,Bl,B2 (breakpoints set)

There are two more points regarding breakpoints that ought to be mentioned. Because breakpoints are generated by the monitor inserting a RST 8 instruction (CF) into the program at the breakpoint location, breakpoints can be set only in programs residing in RAM. Further, a breakpoint must be inserted at an op code location. If it is inserted in an operand or data field, it will not be executed.

# 3.5.6.6 Hex Number Addition (H)

This command provides an easy way to add or subtract hex addresses. Entering

# -HA1 A2

where Al and A2 are the hex addresses results in the output

# AS AD

where AS=Al+A2 and AD=Al-A2. Note that if the sum is greater than FFFF, the carried one is lost. If A2 is greater than Al, A2 will be subtracted from Al + 10000h.

3.5.6.7 Input (I)

This general purpose input command allows you to read a data byte from any input port. To do so, enter

-IA

where A is the port address in hex. The monitor will respond by printing the data byte in binary.

3.5.6.8 Move (M)

The M command moves a block of data to a specified address. The general form for the command is

# -MA1 A2 AD

where Al and A2 are the addresses of the first and last bytes of the memory block and AD is the destination address.

When using this command, be careful not to locate the destination address within the source block. Since the block is moved byte by byte, starting with the byte with the lowest address, the data being transferred will write over the original contents of the section of the source block that follows the destination address.

# 3.5.6.9 Output (O)

This general purpose output command allows you to output a data byte to any output port. Enter

-OA D

where A is the port address and D is the data in hex.

Please note that if the BOOT EN jumper is set to position A and you output to port 40h, you will disable the monitor portion of the ROM. The results of doing so are unpredictable.

# 3.5.6.10 Parameters (P)

The P command allows you to specify three parameters concerning the diskette selected for disk operations: the number of the unit it is in (U); the number of sectors it has per track; (S); and whether it is a one-sided or two-sided diskette. These parameters must be set before you attempt a disk read or write; however, they do not need to be reset until the parameters are no longer valid. The form of the command is:

# -PU S D

U is a number 0 through 3, where 0 selects drive A, 1 selects drive B, etc. If you try to assign a number greater than 3, the monitor will return with ???? and the prompt. S is the number of sectors per track in hex. It is dependent on the number of bytes per sector, the diskette size and the density format. The following table shows the allowable number of sectors per track for a diskette of a given size and format:

| BYTES  | 8" DISI        | KETTES         | 5.25" DISKETTES |                |
|--------|----------------|----------------|-----------------|----------------|
| SECTOR | SINGLE-DENSITY | DOUBLE-DENSITY | SINGLE-DENSITY  | DOUBLE-DENSITY |
| .128   | 1Ah (26d)      |                | 12h (18d)       |                |
| 256    | Fh (15d)       | 1Ah (26d)      | Ah (10d)        | 12h (18d)      |
| 512    | 8h             | Fh (15d)       | 5               | Ah (10d)       |
| 1024   |                | 8              |                 | 5              |

Note the firmware does not support 1024-byte sectors in double-density and 128-bytes in double-density. The last parameter, D, is 0 for a one-sided diskette; 1 for a two-sided diskette.

# 3.5.6.11 Parameters 2 (Q)

The Q command allows you to set the starting track, side, and sector number for disk reads or writes. Enter

# -QT D S

where T is the beginning track number, D is the disk side, and S is the beginning sector number. If you plan to be transferring contiguous data to or from the disk, these parameters need to be set only prior to the first disk access. They must be reset for noncontiguous memory or sectors. T is the track number in hexidecimal. In practice, T will probably be a number between 0 and 4Ch (76d), inclusive, although the monitor will accept any value up to FFh. D is either a 0 or 1, depending on which side of the disk you wish the read or write to be performed on. S is the sector number in hexidecimal. It will always be a number between 1 and 1Ah, inclusive. Should you assign a track number or sector number greater than the number of tracks or sectors on the disk, you will get the Disk Error message when you use the Read or Write commands.

# 3.5.6.12 Read (R)

The R command allows you to transfer data from a disk into a specified area of memory. The R command sets the memory parameters; the disk parameters must have already been set by the P and Q commands. Enter

# -RA1 A2

where Al is the start address in memory and A2 is the end The R command does only complete sector transfers. address. Thus if the end address is reached before a sector is completely transferred into memory, the data will overflow the specified memory area. If the diskette is single-sided and the last sector in a track is reached before the read into memory is complete, the drive head steps, in to the next track and the sector pointer is reset to 1. The number of sectors per track set by the P command determines whether or not the end of the track is In the case of track overflow on side 0 of а reached. double-sided diskette, the read continues on the same track on

side 1. A track overflow on side 1 causes the head to step in and read the next track on side 0.

Please remember that reading double-density diskettes requires a 4 MHz CPU.

# 3.5.6.13 Substitute (S)

The substitute command allows you to examine the contents of a specific memory location and alter them if you desire. Begin the S command by entering

-SA,

where A is the address of the memory location you wish to examine. The computer will immediately respond with the data contents followed by a prompt:

# -SA,D-

If you wish to leave the data unaltered, simply enter a delimiter. If the delimiter is a space or a comma, the computer will respond with the contents of the next consecutive memory location and another prompt. If it is a carriage return, the command is terminated and control is returned to the monitor. Should you wish to alter the data, enter the desired data followed by a delimiter: a carriage return if you want to terminate the command or a space or a comma if you wish to review the next memory location. You also have the option of reviewing the previous memory location by hitting the line feed key. You can continue examining and altering memory byte by byte in this way as long as you wish. To make it easier for you to keep track of where you are, on every 8-byte boundary (that is, an address ending with either 0 or 8, the monitor will do a line feed and print the address along with the data.

# 3.5.6.14 Test (T)

The test command provides a quick way to test RAM memory for hard data bit failures without destroying the contents of the RAM. To test a block of memory for bit failures, enter

# -TA1 A2

where Al and A2 are the addresses of the first and last bytes in the block, respectively. The monitor will respond by printing the address of any byte in error, followed by an 8-bit

representation of the byte in which a one indicates an erroneous bit. For example, should bit 4 of location A3F8h be in error, the monitor outputs the following display

# A3F8 00001000

If you wish to freeze the display type a Control-S. To start it again, hit any key. Hitting any key while the command is executing returns you to the monitor.

#### 3.5.6.15 Verify (V) -

You can use the V command to compare two blocks of memory and verify that they are the same. Type

# -VAl A2 AV

where Al and A2 are the addresses of the first and last byte in the source block and AV is the starting address of the block to be verified. Should the two blocks match, the monitor will return with the prompt. Should the contents of two bytes sharing the same relative address differ, the monitor will display the source address and byte, followed by a dash and the corresponding byte in the block being verified. During the execution of the command, the display can be frozen or control returned to the monitor as described in previous section.

### 3.5.6.16 Write (W) -

The W command allows you to transfer a specified block of memory to a disk. The W command sets the memory parameters; the disk parameters must have been already set by the P and Q commands. (Mind your P's and Q's before doing Reads and Writes). Enter

# -WA1 A2

where Al is the start address of the memory block and A2 is the end address. The write routine checks to see if the end address in memory has been reached only after it has completed a sector write. If the end address is reached before a sector write is completed, the routine will continue to pull data from memory until the sector is filled. During disk writes, track overflow is handled as described in the Read command. Please note the writing of double-density diskettes requires a 4 MHz CPU.

# 3.5.6.17 Examine (X)

The X command is a very useful command when used in conjunction with the G command's breakpoint facilities. Entering

-X[CR, space or comma]

causes the Z-80 registers currently stored in the system stack area to be displayed for examination. These registers are the main and alternate accumulator and general purpose registers, the Interrupt register (I), the Program Counter register (P), the Stack Pointer register (S), the two Index Registers (X and Y) and the Refresh register (R). In addition, the contents of the memory locations addressed by the main and alternate H and L registers are also displayed (M and M'). The registers are displayed in the following four-row format

> A-xx B-xx C-xx D-xx E-xx F-xx H-xx L-xx M-xx P-xxxx S-xxxx I-xx A'-xx B'-xx C'-xx D'-xx E'-xx F'-xx H'-xx L'-xx M'-xx X-xxxx Y-xxxx R-xx

where xx equals a two digit hex byte and xxxx equals a four digit hex address.

To examine or alter the contents of one register, enter

-Xr[CR, space or comma] or -X'r[CR, space or comma]

where r is a main register and r' is an alternate register. (Note that if you wish to examine the X, Y, or R registers, you must preface the register character with the prime mark.) The monitor will return with the contents of the register and a prompt:

#### -Xr,Dh-

As in the substitute memory command, you have the option of altering the memory (entering the desired contents followed by a delimiter) or leaving the contents unchanged (entering a delimiter). A carriage return terminates the command; a space or a comma causes the contents of the next register to be displayed. Note that altering the contents of the H and L registers changes the contents of the registers themselves; if you wish to alter the contents of the memory location pointed to by them, alter the M register.

# 3.5.6.18 Initialize Baud Rate (Y)

To change the baud rate of your system without a system reset, use the Y command. Enter

# -Y (no delimiter)

and then set the baud rate of your terminal to any baud rate between 2 and 56K baud. Hit the carriage return key until the monitor returns with the prompt. The maximum number of carriage returns required is three.

3.5.6.19 Zleep (Z)

You can use the Z command to prevent unauthorized use of your system. Entering

# -Z (no delimiter)

locks up the system so it will not respond to anything other than the ASCII bell character (control G). Entering two consecutive bell characters will unlock the system, returning control to the monitor without altering anything.

# CHAPTER 4

# THEORY OF OPERATION

This chapter is organized into three parts: The 2422 program accessible registers, the system bus interface, and the disk drive interface. We do not discuss the operation of the 1793; such a discussion is beyond the scope of this manual. Instead we concentrate on our unique circuitry external to the 1793. We have, however, included its data sheet in Appendix C for those of you who need information on its operation. If you consult it, please keep in mind that the data sheet covers the entire 1790 family; certain portions may not be applicable to the 1793.

In this chapter, active-low signals are indicated with an asterisk following the signal name.

# 4.1 THE REGISTERS

The 1793 contains five addressable registers: the Command register (write only), the Status register (read only), the Track register, the Sector register, and the Data register. On the 2422, these registers are addressed as four I/O ports, 30-33h, the Command and Status registers sharing the same address. Programming information on these registers can be found in the 1793 data sheet in Appendix C. In addition, the 2422 contains four registers external to the 1793: Status registers 1 and 2 (read only) and Control registers 1 and 2 (write only). These registers are addressed as two I/O ports, 34h and 04h, the status registers being selected during Read cycles and the control registers during Write cycles. The status registers consist of two 8-bit buffers, U25 and U26. When enabled by being addressed during a Read cycle, these chips gate selected signals from the drive busses, the system bus, and the control registers onto the data, bus to be read by the CPU. Control registers 1 and 2, when

# THEORY OF OPERATION

addressed during a write cycle, latch the command bits on the data bus and output high or low signals to the disk drive busses, the CPU and drive interface circuitry, and the 1793. They are cleared by pRESET\* or EXT CLR\*. Control Register 1 consists of a 7-bit latch, Ul3, which latches data bits D0-D6, and an independent flip-flop, U34b, which latches D7, the Auto Wait bit. The Auto Wait bit is latched by a separate flip-flop so that it can be reset not only by pRESET\* and EXT CLR\*, but also by the INTRQ signal from the 1793 (see section 4.2.8, "Auto Wait"). Control Register 2 consists of a 3-bit latch, Ul2. For the bit definitions of the external control/status registers, see Appendix B.

# 4.2 THE SYSTEM INTERFACE

# 4.2.1 THE BANK SELECT CIRCUITRY

The 2422 registers and the on-board ROM cannot be selected unless the internal signal BANK SELECT\* is active low. This signal is the Q\* output of the flip-flop U30b; the complementary Q output is used to light the Bank LED. The conditions under which BANK SELECT\* is active low depend on the setting of the If the BANK EN jumper has been set to OFF, EN jumper. BANK disabling the bank select circuitry, the Preset input to flip-flop U30b is jumpered to ground, forcing BANK SELECT\* permanently low, thus circumventing the Bank Select circuitry. If the jumper is set to position ON, the Clear input to the flip-flop is jumpered to the pRESET\* and EXT CLR\* signals from system bus. If either goes low, as they both would during the power-on or system reset, the flip-flop is cleared, and BANK SELECT\* is forced inactive high. After both pRESET\* and EXT CLR\* release the Clear input, the BANK SELECT\* line can be set low if the flip-flop is clocked while its D input is high. The flip-flop is clocked when pWR\* goes high at the end of an I/O write cycle to port 40h. The state of the D input is determined by the Bank Select Byte being written to port 40h at this time. Only if the Bank Select Byte has a 1 in the bit position that is jumpered on BANK BYTE jumpers will the D input be high, resulting in the active BANK SELECT\*. Finally, if the BANK EN jumper has been set to RST, the flip-flop's Preset input has been jumpered to pRESET\* and EXT CLR\*. During power-on or reset, then, BANK SELECT\* is forced active low. In this case, BANK SELECT\* will go inactive high only if the flip-flop is clocked when its D input in other words, if the user selects another bank for is low; operation.

#### 4.2.2 SELECTING THE 2422 REGISTERS

The decoding of the port addresses is accomplished primarily by U22, an address-decoding ROM. When it is enabled by either the active sOUT or sINP, it decodes the register address on the low-byte address lines into one of four outputs. One output goes low for address 40h and is used for clocking the bank select flip-flop, as described in the previous section. Another output goes low for addresses in the 30-33h range. It is ORed with BANK SELECT\*; when both signals are low, the result is the active signal CONTROLLER SELECT\*. This signal is tied to the 1793's Chip Select input, enabling the 1793 when it is active. Selection of the individual registers within the 1793 is performed by address lines AO and Al, tied to the 1793's two address inputs.

The two remaining outputs of U22 are used to select the external registers. One goes low for either address 04h or 34h. When it is ORed with the active BANK SELECT\*, the result is the active 04/34 SELECT\* line. This line enables a 2- to 4-line decoder, U45a. The final output of U22, which goes low for address 34h, is input to this decoder, along with the WR line (high whenever MWRITE or pWR\* is active). U45a decodes these two inputs into the four enable lines to the external registers: CNTRL1\*, STAT1\*, CNTRL2\*, STAT2\*.

#### 4.2.2.1 Memory-mapping of the Registers

As mentioned before, the 2422 has optional memory-mapped I/O capabilities. U21, when installed, maps the all 2422 registers, expect for the Bank Select register, to the last six bytes but one of a 64K bank; that is, locations FFF8-FFFD. When U21 is enabled by an output of address-decoding ROM U23 going low in response to an FF on the high-order address line, U21 decodes a low-byte address in the F8-FD range into three outputs which correspond to the 30-33, 04/34, and 34 outputs of U22 and are tied to them. Thus if U21 receives an address in the range of F8-FB, for example, it pulls U22's 30-33 output low, resulting in CONTROLLER SELECT\* as described above. Table 4-1 shows the registers' memory locations and the corresponding port addresses.

| RAM Location | Port Address |
|--------------|--------------|
|              |              |
| FFF8         | 30           |
| FFF9         | 31           |
| FFFA         | 32           |
| FFFB         | 33           |
| FFFC         | 34           |
| FFFD         | 04           |

# TABLE 4-1 MEMORY-MAPPED I/O ADDRESSES

## 4.2.3 SELECTING THE ROM

The ROM has two enable inputs, both of which must be active low for the ROM to be enabled. One enable input is pulled low whenever pWR\* and MWRITE are both inactive. The other enable input is pulled low by ROM SELECT\*, the output of the ROM Select circuitry which is active whenever one of the enabled portions of the ROM is addressed while BANK SELECT\* is active. Once the ROM is enabled, address lines A0-AlO, input directly to the ROM itself, select one location in the ROM's 2K of memory.

The ROM Select circuitry is designed to distinguish the Basic I/O portion of the ROM so that it can be enabled independently of the monitor/bootstrap portion of the ROM. TO do so, U23, an address decoding ROM, decodes a high-byte address byte in the range of FO-F7 into two outputs when it is enabled by sINP, sOUT, and sINTA being inactive while BANK SELECT\* is active. One goes low for a high byte address of F6 or F7, indicating an address in the range of the Basic I/O portion of the ROM; the other goes low for any address in the ROM's range. Since the bootstap loader and monitor are needed only before CP/M loaded, the latter output of the decoding ROM is qualified by is the signal BOOT ENABLE\*. Only if BOOT ENABLE\* is low can the ouput pull ROM SELECT\* low.

state of the BOOT ENABLE\* line can be controlled one of The three ways, depending on the setting of the BOOT EN jumper. If the BOOT EN jumper is set to OFF, BOOT ENABLE\* is set permanently If the jumper is set to position A, the BOOT ENABLE line high. is jumpered to the Q output of flip-flop U30a. This flip-flop cleared by PRESET\* or EXT CLR\*, thus forcing the BOOT ENABLE\* is line low during system power-on or reset and enabling the ROM. The flip-flop can then be clocked by an I/O write to port 40h. BOOT Since the D input to the flip-flop is tied high, ENABLE\* goes high when the flip-flop is clocked. Because the bank the board resides in is also selected by an output to port 40h, the BANK SELECT\* line must be either set permanently low or set low

on reset if this method of enabling/disabling the bootstrap loader is to work. If the BOOT EN jumper is set to position B, BOOT ENABLE\* is jumpered to the BOOT\* signal from Control Register 2. Thus the state of BOOT ENABLE\* is entirely software controlled: writing a 0 to bit 7 of Control Register 2 pulls BOOT ENABLE\* low; a 1 pulls it high.

Once CP/M is loaded and BOOT ENABLE\* is high, disabling the monitor and bootstrap loader portions of the ROM, the basic I/O portion can still be accessed if the PR EN jumper is set ON. This allows the F6-F7 output of the address decoding ROM to pull ROM SELECT\* low when it goes low and thus enable the ROM.

# 4.2.4 THE BOARD SELECT LINE AND LED

CONTROLLER SELECT\*, 04/34 SELECT\*, and ROM SELECT\* are NANDed together by U32a, the output of which is BOARD SELECT. If any of these three lines is low, BOARD SELECT is pulled high, lighting the Board Select LED. BOARD SELECT, when inactive, disables the data bus buffers.

# 4.2.5 PHANTOM\* AND FF DETECT

The FF Detect circuitry is used to detect unused locations the on-board ROM so that when an unused location is addressed in PHANTOM\* is forced high, allowing another device to respond to the address. When an empty location in the ROM is addressed, the ROM outputs an FFh, or all ones. Only if an unused location is addressed will this be the case. An 8-input NAND gate, U40, monitors the internal data lines for this condition. As long as a non-FF byte is being transferred, the NAND gate's output is high. This high is in turn NANDed with pDBIN and BOARD SELECT. If both signals are high, the output of the NAND gate, PHANTOM\*, is low and enables the Data In buffer. When the internal data lines contain an FF, the FF-detect NAND gate goes low, disabling PHANTOM\* and the Data In buffer (input to the CPU). Thus another device can respond to the memory read without interference from the ROM.

#### 4.2.6 THE DATA BUS

During Write cycles, the 2422's internal bi-directional data is driven by U38, an 8-bit buffer. When enabled by either bus MWRITE or pWR\* being active when BOARD SELECT is active, this chip gates the data bits on the Data Out bus (output from the CPU) onto the 2422's internal data bus. When the chip is disabled, its outputs are in a high impedance state. The Data In is driven by U39, another 8-bit buffer. When enabled by bus BOARD SELECT, pDBIN, and the output from the FF Detect circuitry being high, this chip gates the data bits on the 2422's internal data bus onto the Data In bus. When disabled, its outputs are also in a high impedance state.

#### 4.2.7 ROM WAIT CIRCUITRY

The purpose of the ROM Wait circuitry is to increase the memory access time allowed to the ROM and to the registers in the disk controller when they are memory mapped. One Wait state per memory cycle in which either the ROM or the registers are addressed is sufficient for this purpose. If the ROM WAIT jumper is set to ON, pREADY is forced low only when either ROM SELECT\* or CONTROLLER SELECT\* is low when pSYNC is high. pSYNC is used to ensure that that pREADY is pulled low in every cycle in which the ROM or disk controller chip is selected and that it remains low only long enough to generate one Wait state. If the ROM WAIT jumper is set to 4 MHZ, the state of pREADY is further qualified by the 2\*/4 MHZ signal. Only when the 2\*/4 MHZ signal is high, indicating the CPU is operating at 4 MHZ, can pREADY go low.

#### 4.2.8 AUTO WAIT CIRCUITRY

The Auto Wait circuitry is designed to force the CPU into as many Wait states as needed when the disk controller is not ready for transfer of data. It uses the state of the DRQ (Data Request) line from the 1793 to determine the data register's readiness for data transfer. As mentioned before, the user has a choice of two types of Auto Waits: one type generates Wait states when Status register 1 is read when DRQ is low; the other generates Wait states when the data register is selected when DRQ Both types of Auto Waits are enabled by writing a 1 to is low. 7 of Control Register 1. Addressing Control Register 1 bit clocks the Auto Wait flip-flop, U43b. The D input of the flip-flop is tied to data line DO7. If bit 7 is high, the Q

output of the flip-flop will be pulled high; the Q\* low. Only if the outputs of the flip-flop are in these states will either type Auto Wait be enabled. The Auto Wait flip-flop is cleared by pRESET\*, EXT CLR\*, or INTRQ.

#### 4.2.8.1 Status Register 1 Wait

The Q\* signal from flip-flop U43b is ORed with DRQ. If Q\* is high, the output of the OR gate will always be high, regardless of the state of DRQ, thus disqualifying DRQ and disabling the Auto Wait cicuitry. If it is low, a low on DRQ pulls the OR gate's output low. This low is then ORed with STAT1\*, which, if active, pulls the OR gate's output low. If the AUTO WAIT jumper has been set to STAT, this low pulls pREADY low.

#### 4.2.8.2 Data Register Wait

The Q signal from flip-flop U43b is ANDed with the inverted DRQ. If both signals are high, the resulting high output from the AND gate pulls the Clear input to flip-flop U43a high, allowing the flip-flop to be clocked and its outputs change state. The flip-flop is clocked by the output of U45b, which is used as a a 2- to l-line decoder. U45b is enabled by the active CONTROLLER SELECT\* and decodes address bits A0 and A1. When enabled, its output goes low when A0 and A1 are high, indicating the data register is being selected. This low is inverted and clocks the flip-flop. Since the flip-flop's D input is tied high, Q\* will go low. This low, if the AUTO WAIT jumper is set to DATA, pulls pREADY low.

# 4.3 THE DISK DRIVE INTERFACE

#### 4.3.1 THE CLOCK SIGNAL

The 1793 Disk Controller chip needs a 2 MHz signal at its CLK input when it is operating with 8" drives and a 1 MHz CLK input when operating with 5.25" drives. All timing on the 2422 board is controlled by a 16 MHz crystal. IC U15, a binary counter, divides the 16 Mhz signal by 2, 4, 8 and 16. The 1 and 2 MHz signals from the divide-by-16 and -8 outputs are input to U16a, a 4-to-1-line multiplexer, the output of which is tied to the CLK input of 'the 1793. The Select input controlling the output of this multiplexer is the MAXI\*/MINI signal from Control Register 1. When the signal is low, selecting the 8" drive, the output of U16a is the 2 MHz clock. When the signal is high, selecting a 5.25" drive, the output of U16a is the 1 MHz clock.

## 4.3.2 THE READ CLOCK SIGNAL

The 1793 can separate the data bits from the mingled clock and data bit stream from the disk drive. To do so, however, it needs a Read Clock signal, RCLK, which provides the data and clock "windows" required to separate the data bits from the clock bits. RCLK must be phased so it frames a data or a clock pulse during one phase of its cycle. To do so, RCLK's nominal cycle should equal the Read Data cycle time: 2 usecs for an 8" double density disk, 4 usecs for an 8" single density disk or a 5.25" double density disk, and 8 usecs for a 5.25" single density disk.

To acheive a RCLK of the correct frequency, the 8 MHz, 4 MHz, and 2 MHz signals from the binary counter UL5 are multiplexed by UL6b, a 4-to-1-line multiplexer. MAXI\* and DDEN\* (Double Density) control the select lines of the multiplexer. Thus the multiplexer outputs the following clock rates for the following states of MAXI\* and DDEN\*:

| MAXI* | DDEN* | SIGNAL RATE |
|-------|-------|-------------|
|       |       |             |
| 0     | 0     | 8 MHz       |
| 0     | 1     | 4 MHz       |
| 1     | 0     | 4 MHz       |
| 1     | 1     | 2 MHz       |

Table 4-2

4-8

The above rates are 16X the desired RCLK frequency for each combination of drive size and format density. The output of the multiplexer is used to clock an 8-bit parallel-out serial shift register, Ul7. The eight outputs of this shift register go high successively as the shift register is clocked; the time it takes for the eight output to go high, then, is equal to the length of one phase of RCLK.

shift register is used in combination with a couple of The flip-flops and NAND gates to detect approximately when pulses in the read data stream occur. The two flip-flops are triggered by the pulses in the Read data stream and are set by the count-3 and count-6 outputs from the shift register. This enables the circuitry to detect whether a pulse occurs before count 3, between and including counts 3 and 5, or after count 5. If the pulse occurs before count 3, the circuitry is set to clock the Read Clock flip-flop, Ul8b, on count 7. The Q output of this flip-flop is the RCLK signal to the 1793. If the pulse occurs on or between counts 3 and 5, the Read Clock flip-flop is clocked on Another flip-flop, clocked and cleared by the same count 8. signals used by the shift-register and set by the count 8 output of the shift register, allows the circuitry to clock the Read Clock flip-flop on count 9, if the pulse occurs after count 5. The delay between the pulse being received and the Read Clock flip-flop being clocked ensures that the pulse will fall well within the window provided by RCLK. As the Read Clock flip-flop clocked, the shift register is cleared. It then counts to is eight to create an opposite phase of the desired length and on the eighth count clocks the Read Clock flip-flop. Since the Q\* output of the Read Clock flip-flop is its D input, the state of RCLK will then change again. This process continues, creating an RCLK signal of the needed rate and phasing. Since the Read Data pulses should occur within 16-count intervals (or some multiple of 16), pulses which occur before count 3 or after count 6 will tend to move toward the middle counts, since they clock the Read Clock flip-flop on counts 7 and 9, not 8. The result is an RCLK signal synchrononized to the Read Data pulses so that each pulse occurs in the middle of the same phase of RCLK.

#### 4.3.3 RAW READ SIGNAL

The 1793 recommends that the Read Data pulses be approximately 250 nsecs in width so that they fall entirely within the window provided by RCLK. The 2422 employs a monostable multivibrator, U3a, to ensure that the pulses are approximately 250 nsecs in length. U3a is clocked by the rising edge of each pulse in the inverted READ DATA stream and is set generate a negative-going pulse of 250 nsecs each time it is

4-9

clocked. The output of this chip forms the Read Data input, RAW READ\*, to the 1793.

#### 4.3.4 WRITE PRECOMPENSATION

On a double-density formatted diskette, certain bit patterns may cause a bit to shift from its nominal write position and appear at the read data separator early or late enough not to fall within its window when the diskette is being read. Write precompensation rectifies this problem during disk writes by shifting such a bit from its nominal position in the opposite direction to its known read shift. The 1793 is smart enough to recognize the bit patterns that cause a bit to shift and puts out the signals EARLY and LATE to indicate that the bit being output should be write precompensated either early or late. Since write precompensation is usually necessary only for data written on tracks on the inner half of the disk, the 1793 also puts out the signal TG43 to indicate that the head is positioned over a track greater than 43. The 2422, when operating in the double density mode, uses these signals to write bits needing precompensation 160 nsecs early or late.

The 160 nsec interval is provided by a monostable multivibrator, U29a. The positive-going data and clock pulses from the 1793 are inverted, and the trailing edge of a pulse triggers the monostable multivibrator. It then puts out a series of positive-going pulses of 160 nsecs until it is retriggered by a new Write Data pulse.

The direction of the shift is provided by a shift register, The active low clock or data pulse from the 1793 which U19. triggers the multivibrator also pulls low the load input to the shift register, loading in the values on its parallel inputs. The shift register is then clocked by the 160 nsec pulses from the multivibrator. When the shift register is clocked, it outputs the value on its G input and shifts the values on its inputs down one. The inputs of primary interest are the EARLY\*, LATE\*, and NO PRECOMP\* signals. The EARLY\* and LATE\* signals are the EARLY and LATE signals from the 1793 qualified by both TG43 and DDEN. Only if TG43 and DDEN are both active can either the EARLY\* or LATE\* NO PRECOMP\* is active whenever both EARLY\* be active. signals and LATE\* are inactive. These signals, EARLY\*, NO PRECOMP\*, and LATE\*, are the G, F, and E inputs to the register, respectively. As the register is clocked successively, they are each output in turn. A low output from the shift register clocks a second monostable vibrator, U29b, the output of which is the Write Data The 200 nsec low-going pulse which results from the stream. vibrator being clocked is the clock or data pulse to be written

to the disk. Thus if EARLY\* is low, the shift register output goes low, clocking U29b, the first time the register is clocked--in other words, just after it has been loaded. If NO PRECOMP\* is low, the output of the register does not go low until the register is clocked a second time, or 160 nsecs later. If LATE\* is low, the shift register must be clocked three times after it has been loaded before its output goes low. Thus bits that are to be written early or late are shifted 160 nsecs in either direction from the NO PRECOMP, or nominal, position.

## 4.3.5 HEAD LOAD TIMING

After the 1793 has given a Head Load Command, it pulls the HLD output high and waits to start read or write operations until it receives an high signal on its Head Load Timing input, indicating that the head is engaged and operable. The 2422 ensures that HLT goes active after a sufficient delay from HLD. The rising edge of HLD clocks U3b, a monostable multivibrator, which outputs a negative-going pulse of about 50 msecs, the HLT signal. When this signal becomes high again, the 1793 assumes that the head is engaged.

# APPENDIX A

# THE 2422 DISK CONTROLLER BUSSES

# THE SYSTEM BUS

# A.1 THE 2422 SYSTEM BUS

The following are definitions of the system bus signals used by the 2422. With the exception of 2\*/4 MHZ, the signals used conform to the IEEE proposed standards for the S-100 bus. Active low signals are indicated by an asterisk following the signal name.

# A.1.1 ADDRESS AND DATA LINES

- A0-A15 The 16-bit parallel address lines.
- DIO-DI7 The 8-bit parallel data input lines to the CPU.

DO0-DO7 The 8-bit parallel data output lines from the CPU.

# A.1.2 CPU STATUS SIGNALS

- sINTA The Interrupt Acknowledge signal indicates the CPU has accepted an interrupt.
- sOUT The Output signal indicates the CPU is executing an output instruction.
- sINP The Input signal indicates the CPU is executing an input instruction.
- 2\*/4 MHZ When high, this signal indicates the CPU is operating at 4 MHz. When low, it indicates the CPU is operating at 2 MHz.

#### A.1.3 CONTROL INPUTS

- pSYNC The Sync signal indicates the presence of status bits on the Data Out bus.
- pDBIN The Data Bus In signal indicates that the CPU is conditioned to read data bits on the Data In bus.
- pWR\* The Write signal indicates the presence of valid data on the output bus.

#### THE SYSTEM BUS

- pRESET\* The system Reset signal resets the CPU and bus slaves. It is generated during power-on and often by a front panel switch.
- EXT CLR\* When active, the External Clear signal resets the bus slaves. It is also generated during power-on and often by a front panel switch.
- MWRITE The Memory Write signal indicates that the current data on the data out bus is to be written into the memory location specified by the address bus. Often generated by front panel devices, it usually is used for front panel memory deposit.
- A.1.4 CONTROL OUTPUTS
- pRDY The Ready signal allows an addressed bus slave to hold the CPU in a Wait state until the slave is ready for data transfer.
- PHANTOM\* The Phantom signal controls memory overlay. On the 2422 board, it is used to allow the on-board ROM to take precedence over memory devices sharing the same memory space.
- pINT\* (jumper-enabled) The Interrupt signal allows external devices to request service from the CPU.
- NMI\* (jumper-enabled) The Nonmaskable Interrupt signal allows external devices to assert an interrupt request that cannot be masked off by the CPU.
- VIO\*- (jumper-enabled) The Vectored Interrupt lines are used VI7\* to allow interrupt arbitration between eight levels of interrupt request priorites. They are ususally input to an interrupt arbitrating device which then asserts pINT\* to the CPU and outputs the appropriate vectoring data.

## A.1.5 THE POWER LINES

+8 VOLTS The unregulated +8 volts power line.
+16 VOLTS The unregulated +16 volts power line.
-16 VOLTS The unregulated -16 volts power line.

A-4

A.1.6 THE 2422 SYSTEM BUS PIN ASSIGNMENTS

2422 BUS CONNECTOR PINOUT

+BV 51 + 8V 1 +16V 2 52 -16V E 1 I з Г 53 VIO 4 54 EXT CLR E VIO 4 VI1 5 VI2 6 E 55 56 E . VIS 7 -67 VI4 B VI5 0 58 -C 59 VI6 010 -60 VI7 11 NMI 12 61 62 13 63 14 64 15 65 16 66 17 67 18 68 MWRITE 19 69 20 70 21 71 22 72 pRDY 73 pINT 0 23 24 74 25 75 PRESET pHLDA 26 76 pSVNC 77 pWR 27 28 78 pDBIN A5 29 79 AO A4 30 80 A1 A3 31 -81 A2 A15 32 82 A6 A12 33 83 A7 A9 34 84 A8 DO1 35 85 A13 DO0 36 86 A14 A10 37 87 A11 Г \_ DO4 38 88 DO2 DO5 39 F 89 DO3 DO6 40 90 D07 -DI2 41 91 DI4 DI3 42 92 D15 DI7 43 93 DI6 44 04 DI1 7 BOUT 45 95 DIO aINP 46 96 97 GWO 47 48 98 2/4 MHZ 1 49 99 GND 50 100 GND 

C

IRCUIT

SI

DE

COMPONENT SID

Ē

TOP VIEW

A.2 THE 2422 DISK DRIVE BUSSES

The following signals are used by the disk controller board to interface to both size drives.

## OUTPUTS:

- DS1\*- When a Drive Select line is active low, the DS4\* corresponding drive is enabled. The other drives will ignore all signals until selected.
- MOTOR ON\* When active low, the Motor On signal turns on the motor to all drives accepting the signal.
- STEP\* Each negative going pulse of this signal steps the read/write head forward or backward one pulse. For MFM the pulse width is 2us; for FM it is 4us. The stepping rate for multiple steps is determined by the Step Command.
- DIRC The Direction signal determines the direction the read/write head steps. If it is low when STEP\* goes active, the head steps in one track toward the center. If it is high when STEP\* goes active, the head steps out one track toward the perimeter, or track 00.
- WRITE When the Write Gate is active low, current flows into GATE\* the read/write head, enabling diskette write operations.
- WRITE The Write Data signal is the combined clock and data DATA\* pulses that are written on the diskette. The pulse width is approximately 200 nsecs.
- SIDE This signal indicates which side of a two-sided disk SELECT\* should be used for reading or writing. A high selects side 0; a low, side 1.

#### INPUTS:

- INDEX\* The Index Pulse goes low for a minimum of 10us when the drive detects the index hole.
- TRK 00\* When low, this signal indicates that the read/write head is positioned over Track 00.

A-6

## THE 2422 DISK DRIVE BUSSES

- WPRT\* The Write Protect signal goes low if the currently selected drive contains a write-protected diskette. It is sampled whenever the 1793 receives a write command and terminates that command if it is active low. (On some drives, write-protection detect circuitry is optional.)
- WRITE This signal is the intermingled clock and data pulses DATA\* received directly from the drive. Each recorded flux transistion results in a negative pulse.

The following signals are available on the 8" drive bus only.

READY\* This signal indicates that the disk drive is ready for operation.

TWO- This signal goes active low when a two-sided diskette SIDED\* is in the currently selected drive.

HLD\* When low, this signal tells the drive to load the read/write head against the diskette.

# APPENDIX B

.....

# 2422 PROGRAMMING INFORMATION

# THE 2422 ADDRESSABLE REGISTERS

# B.1 THE 2422 ADDRESSABLE REGISTERS

The 2422 Floppy Disk Controller contains 9 accessible registers for controlling disk operations. They are addressed as six I/O ports or, if the memory map decoding ROM has been installed, six memory locations. Five of these registers are internal to the FD1791: the Status register (read-only), the Command register (write-only), the Track register, the Sector register, and the Data register. Four registers are external: Control registers 1 and 2 (write-only) and Status Registers 1 and 2 (read-only). In addition, the 2422 contains a write-only register for bank selection. The registers are addressed as follows:

|     | ADDRESS | REGIST   | ER          |
|-----|---------|----------|-------------|
| I/0 | Memory* | Read     | Write       |
| 30  | FFF8    | Status   | Command     |
| 31  | FFF9    | Track    | Track       |
| 32  | FFFA    | Sector   | Sector      |
| 33  | FFFB    | Data     | Data        |
| 34  | FFFC    | Status 1 | Control 1   |
| 04  | FFFD    | Status 2 | Control 2   |
| 40  |         |          | Bank Select |

\* Memory Map address decoding ROM must be installed.

# Table B-1

The FD1793 Data Sheet included with this manual gives bit descriptions for each of the 1793's internal registers. Descriptions of the external registers follow.

# B.1.1 CONTROL REGISTER 1

Summary:

| BIT 7 | BIT 6 | BIT 5 | BIT 4 | BIT 3 | BIT 2 | BIT 1 | BIT O |
|-------|-------|-------|-------|-------|-------|-------|-------|
| AUTO  | DDEN  | MOTOR | MINI  | DS1   | DS2   | DS3   | DS4   |

TABLE B-2 CONTROL REGISTER 1

All the bits are reset by power-on, reset, or external clear.

#### Bit Definitions:

- BIT 7 Auto Wait. A l written to bit 7 enables Auto Waits. A O disables them. Auto Waits are disabled after reset or after INTRQ, indicating the 1793 has finished executing a command, goes active.
- BIT 6 Double Density. A 1 written to bit 6 conditions the 2422 for reading and writing double-density formatted diskettes. A 0 in bit 6 conditions the 2422 for single-density diskettes. Bit 6 is set to 0 on reset.
- BIT 5 Motor On. Bit 5 controls the state of the MOTOR ON\* signal. A 0 written to bit 5 forces MOTOR ON\* low, turning on the motors of all drives accepting the signal. A 1 written to bit 5 forces MOTOR ON\* high, turning off the drives' motors. MOTOR ON\* is set high on reset.
- BIT 4 Mini. A 0 written to bit 4 conditions the 2422 for operation with 5.25" (mini) drives. A 1 conditions the 2422 for operation with 8" drives. 8" drive operation is selected on reset.
- BITS 3-0 Drive Select 1-4. These bits control the state of the Drive Select lines to the individual drives. A l written to one of the Drive Select bits activates the Drive Select line to the corresponding drive, selecting the drive for disk operations. Only one drive should be selected at a time. The Drive Select bits are set to 0 on reset.

B-4

#### THE 2422 ADDRESSABLE REGISTERS

#### B.1.2 STATUS REGISTER 1

Summary:

| BIT 7 | BIT 6        | BIT 5 | BIT 4 | BIT 3 | BIT 2 | BIT 1 | BIT O |
|-------|--------------|-------|-------|-------|-------|-------|-------|
| DRQ   | AUTO<br>BOOT | HLD   | DS1   | DS2   | DS3   | DS4   | INTRQ |

# TABLE B-3 STATUS REGISTER 1

Bit Definitions:

- BIT 7 DRQ. Bit 7 reflects the state of the DRQ (Data Request) signal from the 1793. During disk writes, a 1 in bit 7 indicates that the 1793's data register is empty and can accept a new byte to be written to disk. During disk reads, it indicates the 1793's data register holds a data byte to be read by the CPU. A 0 in bit 7 indicates the data register is not ready for data transfer with the CPU.
- BIT 6 Auto Boot. Bit 6 is used by the CCS firmware during cold-start initialization to determine whether CP/M or the monitor is to be entered. It reflects the state of the Auto Boot jumper. If the AUTO BOOT jumper is set ON, bit 6 is set to 0, causing the cold-start initialization routine to turn control over to the bootstrap loader. If the AUTO BOOT jumper is set OFF, bit 6 is set to 1, causing the cold-start initialization routine to turn control over to the monitor executive.
- BIT 5 Head Load. Bit 5 reflects the state of the HLD\* signal from the 1793. A 1 in bit 5 indicates that the read/write head of the currently-selected drive is loaded.
- BITS 4-1 Drive Select 1-4. A 1 in one of the Drive Select bits indicates that the corresponding drive has been selected for disk operations.
- BIT 0 Interrupt Request. Bit 0 reflects the state of the INTRQ signal from the 1793. This signal goes high when the 1793 has finished executing the current command in the command register and is awaiting a new command.

# B.1.3 CONTROL REGISTER 2

Summary:

| BIT 7 | BIT 6  | BIT 5 | BIT 4 | BIT 3 | BIT 2 | BIT 1 | BIT O |
|-------|--------|-------|-------|-------|-------|-------|-------|
| BOOT  | SIDE   | don't | FAST  | don't | don't | don't | don't |
|       | SELECT | care  | Seek  | care  | care  | care  | care  |

#### TABLE B-4 CONTROL REGISTER 2

All bits are reset by power-on, reset, or external clear.

Bit Definitions:

- BIT 7 Boot. If the BOOT EN jumper has been set to position B, bit 7 enables/disables the monitor/bootstrap loader firmware. A 0 written to bit 7 enables the firmware; a l disables it. This bit is set to 0 on reset.
- BIT 6 Side Select. This bit controls the state of the SIDE SELECT signal to the currently-selected two-sided drive. A l written to bit 6 selects side 0 of a two-sided diskette for a read or write. A 0 written to bit 6 selects side 1 of a two-sided diskette. Side 0 is selected on reset.
- BIT 4 Fast Seek. If the FAST SEEK jumper is set to SFT, bit 4 enables/disables the fast seek mode for voice-coil drives. A 0 written to bit 4 enables the fast seek mode; a 1 disables it. The fast seek mode is disabled on reset.

#### B.1.4 STATUS REGISTER 2

Summary:

| BIT 7 | BIT 6         | BIT 5 | BIT 4 | BIT 3   | BIT 2 | BIT 1 | BIT O   |
|-------|---------------|-------|-------|---------|-------|-------|---------|
| DRQ   | TWO-<br>SIDED | DDEN  | INDEX | 2/4 MHZ | WPRT  | MINI  | TRACKOO |

TABLE B-5 STATUS REGISTER 2

B-6

# THE 2422 ADDRESSABLE REGISTERS

Bit Definitions:

- BIT 7 DRQ. Bit 7 reflects the state of the DRQ signal from the 1793. During disk writes, a 1 in bit 7 indicates that the 1793's data register is empty and requires a new byte. During disk reads, a 1 in bit 7 indicates that the 1793's data register holds a data byte to be read by the CPU. A 0 in bit 7 indicates that the 1793's register is not ready for data transfer.
- BIT 6 Two-sided. Bit 6 reflects the state of the signal TWO-SIDED\* from the currently-selected two-sided drive. A 0 in bit 6 indicates a two-sided disk is in the drive.
- BIT 5 Double-density. A 1 in bit 5 indicates that the 2422 has been conditioned to read or write double-density formatted diskettes. A 0 indicates the 2422 has been conditioned for single-density diskettes.
- BIT 4 Index. Bit 4 reflects the state of the INDEX\* signal from the currently- selected drive. It is set to 0 for a minimum of 10 usecs when the drive detects the index hole on the diskette.
- BIT 3 2/4 MHZ. Bit 3 reflects the state of the signal on pin 98 of the system bus. In many systems this signal indicates the operating frequency of the processor. For such a system, a 1 in bit 3 indicates a 4 MHz operating frequency; a 0 indicates a 2 MHz operating frequency.
- BIT 2 Write Protect. Bit 2 reflects the state of the WPRT\* signal from the currently-selected drive. (On some drives write protect detection circuitry is an optional feature. See your manual.) A 0 in bit 2 indicates a write-protected diskette is in the currently selected drive.
- BIT 1 Mini. A 1 in bit 1 indicates that the 2422 is conditioned for operation with a 5.25" drive. A 0 indicates that the 2422 is conditioned for an 8" drive.
- BIT 0 Track 00. The CCS software uses this bit to determine whether the currently selected drive is a 5.25" or 8" drive. When the head is positioned over Track 00, bit 0 will be low for a 5.25" drive and high for an 8" drive.

# THE 2422 ADDRESSABLE REGISTERS

B.1.5 BANK SELECT PORT

To select the bank the 2422 is assigned to, output a data byte to port 40h with a 1 in the bit position corresponding to the bank level. Depending on the setting of the BANK EN jumper, this register is either cleared to 0 (Bank Disabled) or preset to 1 (Bank Enabled) on system power-on or reset.

If the BOOT EN jumper has been set to position A, writing any byte to port 40h disables the bootstrap loader and monitor firmware.

B-8

#### DISKETTE FORMAT

## B.2 DISKETTE FORMAT

Figure B-1 below is an illustration of the IBM 3740 format for an 8" single-density diskette. The format differs slightly for а double-density diskette; see Table B-7 below and the 1793 data sheet for differences. There is no IBM standard for 5.25" diskettes; the 2422 software is designed to read and write 5.25" diskettes of a format adapted from the IBM 8" standards for 5.25" and 8" diskettes. For the actual singleand double-density formats used by the utility program CCSINIT in initializing diskettes, see Tables B-6 and B-7 below.



A Pre-index gap. The 1793 expects all FF's.

2 6 bytes of 00 in FM. 12 bytes of 00 in MFM.

A Post-index gap. The 1793 expects all FF's.

A ID FIELD

AM1 (Address Mark 1) = Hex FE. Identifies ID field. Track No. = A value usually between hex 00 and 4C, inclusive. (0 and 76 decimal.)

Side No. = Hex 00 for one-sided diskettes and side 0 of two-sided diskettes. Hex 01 for side 1 of two-sided diskettes.

Sector No.= Sector number in hex.

Sector Size = Hex 00 for 128 bytes per sector. Hex 01 for 256 bytes per sector. Hex 02 for 512 bytes per sector. Hex 03 for 1024 bytes per sector.

- S Cyclic Redundancy Check bytes. CRC bytes are generated during disk writes. Used during disk reads to verify data is read correctly. CRC includes all data in ID and data fields starting with address mark.
- B Post-ID gap. The 1793 expects all FF's.

A DATA FIELD

AM2=hex FB. Identifies data field. User data = 128, 256, 512, or 1024 bytes.

B Post-data gap. The 1793 expects all FF's.

#### FIGURE 3-1 IBM 3740 FORMAT STANDARD

# B.2.1 FORMATTING A SINGLE-DENSITY DISKETTE

Table B-6 below shows IBM-compatible formats for single-density 5.25" and 8" diskettes. These formats are both used by the CCSINIT utility program; the 8" diskette format conforms to the format specified by the 1793 data sheet.

| 7                                                          | NUMBER<br>OF BYTES<br>5.25" 8                         |                        | HEX VALUE OF<br>BYTE WRITTEN                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|------------------------------------------------------------|-------------------------------------------------------|------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Write<br>bracketed<br>field<br>once for<br>every<br>sector | $ \begin{array}{cccccccccccccccccccccccccccccccccccc$ | .†<br>3*2 <sup>n</sup> | <pre>FF (Gap 4)<br/>00 (Sync Field8" only)<br/>FC (Index Mark8" only)<br/>FF (Gap 18" only)<br/>00 (Sync Field)<br/>FE (ID Address Mark)<br/>Track Number<br/>Side Number (00 or 01)<br/>Sector Number<br/>Sector Size<br/>00 = 128 bytes<br/>01 = 256 bytes<br/>02 = 512 bytes<br/>03 = 1024 bytes<br/>F7 (CRC request)<br/>FF (Gap 2)<br/>00 (Sync Field)<br/>FB (Data Address Mark)<br/>Data (n=sector size indi-<br/>cator; data fill=E5)<br/>F7 (CRC request)<br/>FF (Gap 3)<br/>FF (m=variable number of<br/>bytes; continue writing<br/>until 1793 interrupts<br/>out.)</pre> |
|                                                            |                                                       |                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |

tCRC request is one byte; two CRC bytes actually written to disk.

TABLE B-6

# DISKETTE FORMAT

.

# B.2.2 FORMATTING A DOUBLE-DENSITY DISKETTE

Table B-7 below shows IBM-compatible formats for double-density 5.25" and 8" diskettes. Both of these formats are used by the utility program CCSINIT; the 8" diskette format conforms to the format specified by the 1793 data sheet.

| a                                                          | NUMBER<br>OF BYTES<br>5.25"                                                                                           | 8"                                                                                                      | HEX VALUE OF<br>BYTE WRITTEN                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Write<br>bracketed<br>field<br>once for<br>every<br>sector | 32<br>-<br>-<br>-<br>8<br>3<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1 | $ \begin{array}{c} 80\\ 12\\ 3\\ 1\\ 50\\ 12\\ 3\\ 1\\ 1\\ 1\\ 1\\ 1\\ 1\\ 1\\ 1\\ 1\\ 1\\ 1\\ 1\\ 1\\$ | <pre>4E (Gap 4)<br/>00 (Sync Field-8" only)<br/>F6 (8" only)<br/>FC (Index Mark8" only)<br/>4E (Gap 18" only)<br/>00 (Sync Field)<br/>F5<br/>FE (ID Address Mark)<br/>Track No.<br/>Side No. (00 or 01)<br/>Sector No.<br/>Sector Size<br/>00 = 128 bytes<br/>01 = 256 bytes<br/>02 = 512 bytes<br/>03 = 1024 bytes<br/>F7 (CRC Request)<br/>4E (Gap 2)<br/>00 (Sync Field)<br/>F5<br/>FB (Data Address Mark)<br/>Data (n=sector size indi-<br/>cator; data fill=E5tt)<br/>F7 (CRC request)<br/>4E (Gap 3)<br/>4E (m = variable number<br/>of bytes; continue<br/>writing until 1793<br/>interrupts out.)</pre> |
|                                                            |                                                                                                                       |                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |

tCRC request is one byte; two CRC bytes actually written to disk.
ttCP/M requires an E5h fill character, while the IBM-format
specifies 40h as the fill character.

TABLE B-7

# APPENDIX C

# 1793 DATA SHEET

#### WESTERN DIGITAL R P 0 C 0 0 N

# FD 179X-02 Floppy Disk Formatter/Controller Family

# FEATURES

- TWO VFO CONTROL SIGNALS
- SOFT SECTOR FORMAT COMPATIBILITY
- AUTOMATIC TRACK SEEK WITH 0 VERIFICATION
- ACCOMMODATES SINGLE AND DOUBLE 0 DENSITY FORMATS IBM 3740 Single Density (FM) IBM System 34 Double Density (MFM)
- READ MODE Single/Multiple Sector Read with Automatic Search or Entire Track Read Selectable 128 Byte or Variable length Sector
- 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
- WRITE PRECOMPENSATION
- WINDOW EXTENSION 0
- 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 | 1793 | 1795 | 1797 |
|-----------------------|------|------|------|------|
| Single Density (FM)   | х    | X    | х    | X    |
| Double Density (MFM)  | Х    | X    | Х    | X    |
| True Data Bus         |      | X    |      | X    |
| Inverted Data Bus     | Х    |      | Х    |      |
| Write Precomp         | Х    | X    | Х    | X    |
| Side Selection Output |      |      | Х    | X    |

#### APPLICATIONS

FLOPPY DISK DRIVE INTERFACE SINGLE OR MULTIPLE DRIVE CONTROLLER/ FORMATTER

NEW MINI-FLOPPY CONTROLLER



# FD179X SYSTEM BLOCK DIAGRAM

0861 YAM

#### **GENERAL DESCRIPTION**

The FD179X are 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

# **PIN OUTS**

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 bidirectional 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 fabricated in N-channel Silicon Gate MOS technology and is TTL compatible on all inputs and outputs. 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. On these devices, DDEN must be left open.

| 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 on this input resets the device and<br>loads HEX 03 into the command register. The Not<br>Ready (Status Bit 7) is reset during MR ACTIVE.<br>When MR is brought to a logic high a RESTORE<br>Command is executed, regardless of the state of<br>the Ready signal from the drive. Also, HEX 01 is<br>loaded into sector register. |  |  |
| . 20          | POWER SUPPLIES           | Vss       | Ground                                                                                                                                                                                                                                                                                                                                       |  |  |
| 21            |                          | Vcc       | +5V ±5%                                                                                                                                                                                                                                                                                                                                      |  |  |
| 40            |                          | VDD       | +12V ±5%                                                                                                                                                                                                                                                                                                                                     |  |  |
|               | INTERFACE:               |           | _                                                                                                                                                                                                                                                                                                                                            |  |  |
| 2             | WRITE ENABLE             | WE        | A logic low on this input gates data on the DAI into the selected register when $\overline{CS}$ is low.                                                                                                                                                                                                                                      |  |  |
| 3             | CHIP SELECT              | ĊŚ        | A logic low on this input selects the chip and ena-<br>bles 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{CS}$ is low.                                                                                                                                                                                                                    |  |  |
| 5,6           | REGISTER SELECT<br>LINES | A0, A1    | These inputs select the register to receive/<br>transfer data on the DAL lines under RE and WE<br>control:<br>A1 A0 RE WE                                                                                                                                                                                                                    |  |  |
|               |                          |           | 00Status RegCommand Reg01Track RegTrack Reg10Sector RegSector Reg11Data RegData Reg                                                                                                                                                                                                                                                          |  |  |
| 7-14          | DATA ACCESS LINES        | DAL0-DAL7 | Eight bit inverted Bidirectional bus used for trans-<br>fer of data, control, and status. This bus is receiver<br>enabled by WE or transmitter enabled by RE.                                                                                                                                                                                |  |  |
| 24            | CLOCK                    | CLK       | This input requires a free-running square wave clock for internal timing reference, 2 MHz for 8" drives, 1 MHz for mini-drives.                                                                                                                                                                                                              |  |  |

| PIN<br>NUMBER | PIN NAME                           | SYMBOL   | FUNCTION                                                                                                                                                                                                                                                                                                                                   |
|---------------|------------------------------------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 38            | DATA REQUEST                       | DRQ      | This open drain output indicates that the DR con-<br>tains assembled data in Read operations, or the<br>DR is empty in Write operations. This signal is<br>reset when serviced by the computer through<br>reading or loading the DR in Read or Write opera-<br>tions, respectively. Use 10K pull-up resistor to +5.                        |
| 39            | INTERRUPT<br>REQUEST               | INTRQ    | This open drain output is set at the completion of any<br>command and is reset when the STATUS register is<br>read or the command register is written to. Use 10K                                                                                                                                                                          |
| FLOPPY DI     | SK INTERFACE:                      |          | pull-up resistor to +5.                                                                                                                                                                                                                                                                                                                    |
| 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 occurring<br>while Early is active (high) should be shifted early<br>for write precompensation.                                                                                                                                                                                                        |
| 18            | LATE                               | LATE     | Indicates that the write data pulse occurring while<br>Late is active (high) should be shifted late for write<br>precompensation.                                                                                                                                                                                                          |
| 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 motors.                                                                                                                                                                                          |
| 23            | HEAD LOAD TIMING                   | HLT      | When a logic high is found on the HLT input the head is assumed to be engaged.                                                                                                                                                                                                                                                             |
| 25            | READ GATE (1791/3)                 | RG       | A high level on this output indicates to the data<br>separator circuitry that a field of zeros (or ones)<br>has been encountered, and is used for synchroni-<br>zation.                                                                                                                                                                    |
| 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 $S = 1$ , SSO is set to a logic 1. When $S = 0$ , SSO is set to a logic 0. 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<br>the data stream must be provided to this input.<br>Phasing (i.e. RCLK transitions) relative to RAW<br>READ is important but polarity (RCLK high or low)                                                                                                                                 |
| 27            | RAW READ                           | RAW READ | is not.<br>The data input signal directly from the drive. This<br>input shall be a negative pulse for each recorded<br>flux transition.                                                                                                                                                                                                    |
| 28            | HEAD LOAD                          | HLD      | The HLD output controls the loading of the Read-Write head against the media.                                                                                                                                                                                                                                                              |
| 29            | TRACK GREATER<br>THAN 43           | TG43     | This output informs the drive that the Read/Write head is positioned between tracks 44-76. This output is valid only during Read and Write Commands.                                                                                                                                                                                       |
| 30            | WRITE GATE                         | WG       | This output is made valid before writing is to be performed on the diskette.                                                                                                                                                                                                                                                               |

| PIN<br>NUMBER | PIN NAME                  | SYMBOL    | FUNCTION                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|---------------|---------------------------|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31            | WRITE DATA                | WD        | A 250 ns (MFM) or 500 ns (FM) 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<br>for a logic high before Read or Write commands<br>are performed. If Ready is low the Read or Write<br>operation is not performed and an interrupt is<br>generated. Type I operations are performed re-<br>gardless of the state of Ready. The Ready input<br>appears in inverted format as Status Register bit<br>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 func-                                                                                                                                                                       |
|               |                           |           | tions 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 |
| 34            | TRACK 00                  | TR00      | the Data Field.<br>This input informs the FD179X that the Read/Write<br>head is positioned over Track 00.                                                                                                                                                                                                                                                                                                                                   |
| 35            | INDEX PULSE               | <b>AI</b> | 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<br>is received. A logic low terminates the command<br>and sets the Write Protect Status bit.                                                                                                                                                                                                                                                                                                 |
| 37            | DOUBLE DENSITY            | DDEN      | This pin selects either single or double density op-<br>eration. When $\overline{DDEN} = 0$ , double density is<br>selected. When $\overline{DDEN} = 1$ , single density is<br>selected. This line must be left open on the 1792/4                                                                                                                                                                                                          |

#### ORGANIZATION

The Floppy Disk Formatter block diagram is illustrated on page 5. The primary sections include the parallel processor interface and the Floppy Disk interface.

Data Shift Register—This 8-bit register assembles serial data from the Read Data input (RAW READ) during Read operations and transfers serial data to the Write Data output during Write operations.

Data Register—This 8-bit register is used as a holding register during Disk Read and Write operations. In Disk Read operations the assembled data byte is transferred in parallel to the Data Register from the Data Shift Register. In Disk Write operations information is transferred in parallel from the Data Register to the Data Shift Register. When executing the Seek command the Data Register holds the address of the desired Track position. This register is loaded from the DAL and gated onto the DAL under processor control.

Track Register—This 8-bit register holds the track number of the current Read/Write head position. It is incremented by one every time the head is stepped in (towards track 76) and decremented by one when the head is stepped out (towards track 00). The contents of the register are compared with the recorded track number in the ID field during disk Read, Write, and Verify operations. The Track Register can be loaded from or transferred to the DAL. This Register should not be loaded when the device is busy.



#### FD179X BLOCK DIAGRAM

Sector Register (SR)—This 8-bit register holds the address of the desired sector position. The contents of the register are compared with the recorded sector number in the ID field during disk Read or Write operations. The Sector Register contents can be loaded from or transferred to the DAL. This register should not be loaded when the device is busy.

**Command Register (CR)**—This 8-bit register holds the command presently being executed. This register should not be loaded when the device is busy unless the new command is a force interrupt. The command register can be loaded from the DAL, but not read onto the DAL.

Status Register (STR)—This 8-bit register holds device Status information. The meaning of the Status bits is a function of the type of command previously executed. This register can be read onto the DAL, but not loaded from the DAL.

**CRC Logic**—This logic is used to check or to generate the 16-bit Cyclic Redundancy Check (CRC). The polynomial is:  $G(x) = x^{16} + x^{12} + x^5 + 1$ .

The CRC includes all information starting with the address mark and up to the CRC characters. The CRC register is preset to ones prior to data being shifted through the circuit.

Arithmetic/Logic Unit (ALU)—The ALU is a serial comparator, incrementer, and decrementer and is used for register modification and comparisons with the disk recorded ID field.

Timing and Control—All computer and Floppy Disk Interface controls are generated through this logic. The internal device timing is generated from an external crystal clock.

The FD1791/3 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 density (FM) is assumed.

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 (DAL) and associated control signals. The DAL are used to transfer Data, Status, and Control words out of, or into the FD179X. The DAL are three state buffers that are enabled as output drivers when Chip Select (CS) and Read Enable (RE) are active (low logic state) or act as input receivers when CS and Write Enable (WE) are active.

When transfer of data with the Floppy Disk Controller is required by the host processor, the device address is decoded and  $\overrightarrow{CS}$  is made low. The address bits A1 and A0, combined with the signals  $\overrightarrow{RE}$  during a Read operation or  $\overrightarrow{WE}$  during a Write operation are interpreted as selecting the following registers:

| A1-A0 |   | READ (RE)       | WRITE (WE)       |  |  |  |
|-------|---|-----------------|------------------|--|--|--|
| 0     | 0 | Status Register | Command Register |  |  |  |
| 0 1   |   | Track Register  | Track Register   |  |  |  |
| 1     | 0 | Sector Register | Sector Register  |  |  |  |
| 1     | 1 | Data Register   | Data Register    |  |  |  |

During Direct Memory Access (DMA) types of data transfers between the Data Register of the 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.

#### FLOPPY DISK INTERFACE

The 179X has two modes of operation according to the state of  $\overline{\text{DDEN}}$  (Pin 37). When  $\overline{\text{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. When the clock is at 2 MHz, the stepping rates of 3, 6, 10, and 15 ms are obtainable. When CLK equals 1 MHz these times are doubled.

# HEAD POSITIONING

Five commands cause positioning of the Read-Write head (see Command Section). The period of each positioning step is specified by the r field in bits 1 and 0 of the command word. 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.

The rates (shown in Table 1) can be applied to a Step-Direction Motor through the device interface.

Step—A 2  $\mu$ s (MFM) or 4  $\mu$ s (FM) pulse is provided as an output to the drive. For every step pulse issued, the drive moves one track location in a direction determined by the direction output.

**Direction (DIRC)**—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.

When a Seek, Step or Restore command is executed an optional verification of Read-Write head position can be performed by setting bit 2 (V = 1) in the command word to a logic 1. The verification operation begins at the end of the 15 millisecond settling time after the head is loaded against the media. The track number from the first encountered ID Field is compared against the contents of the Track Register. If the track numbers compare and the ID Field Cyclic Redundancy Check (CRC) is correct, the verify operation is complete and an INTRQ is generated with no errors. 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.

**Table 1. STEPPING RATES** 

| CLK |    | 2 MHz  | 2 MHz  | 1 MHz  | 1 MHz  | 2 MHz  | 1 MHz  |
|-----|----|--------|--------|--------|--------|--------|--------|
| DD  | EN | 0      | 1      | 0      | 1      | x      | x      |
| R1  | RO | 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  |

The Head Load (HLD) output controls the movement of the read/write head against the media. HLD is activated at the beginning of a Type I command if the h flag is set (h = 1), at the end of the Type I command if the verify flag (V = 1), or upon receipt of any Type II or III command. Once HLD is active it remains active until either a Type I command is received with (h = 0 and V = 0); or if the FD179X is in an idle 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 a status bit 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.

# **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 a special byte in the "ID" field. If this Sector length byte in the ID field is zero, then the sector length is 128 bytes. If 01 then 256 bytes. If 02, then 512 bytes. If 03, then the sector length is 1024 bytes. 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, the FD179X requires RAW READ Data (Pin 27) signal which is a 250 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) 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. VFOE will go active 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  $\overline{WF}/\overline{VFOE}$  is not used, leave open or tie to a 10K resistor to +5.

## **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 signal can be activated.

Writing is inhibited when the Write Protect input is . 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 FD179X 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 ( $\overline{DDEN} = 1$ ) and 250 ns pulses in MFM ( $\overline{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 line 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. 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 accept eleven commands. Command words should only be loaded in the Command Register when the Busy status bit is off (Status bit 0). The one exception is the Force Interrupt command. Whenever a command is being executed, the Busy status bit is set. When a command is completed, an interrupt is generated and the Busy status bit is reset. The Status Register indicates whether the completed command encountered an error or was fault free. For ease of discussion, commands are divided into four types. Commands and types are summarized in Table 2.

| Table 2. | COMMAND | SUMMARY |
|----------|---------|---------|
|----------|---------|---------|

|              |                  | BITS |   |   |   |                |    |                |       |
|--------------|------------------|------|---|---|---|----------------|----|----------------|-------|
| TYPE COMMAND |                  | 7    | 6 | 5 | 4 | 3              | 2  | 1              | 0     |
| 1            | Restore          | 0    | 0 | 0 | 0 | h              | ۷  | $r_1$          | r.    |
| 1            | Seek             | 0    | 0 | 0 | 1 | h              | ٧  | $\mathbf{r}_1$ | ro    |
| 1            | Step             | 0    | 0 | 1 | u | h              | ٧  | $\mathbf{r}_1$ | $r_0$ |
| 1            | Step In          | 0    | 1 | 0 | u | h              | ۷  | rı             | ro    |
| 1            | Step Out         | 0    | 1 | 1 | u | h              | ۷  | $\mathbf{r}_1$ | ro    |
| II           | Read Sector      | 1    | 0 | 0 | m | $F_2$          | Е  | $F_1$          | 0     |
| 11           | Write Sector     | 1    | 0 | 1 | m | F <sub>2</sub> | Е  | F۱             | a     |
| 111          | Read Address     | 1    | 1 | 0 | 0 | 0              | E  | 0              | 0     |
| 111          | Read Track       | 1    | 1 | 1 | 0 | 0              | Е  | 0              | 0     |
| 111          | Write Track      | 1    | 1 | 1 | 1 | 0              | Е  | 0              | 0     |
| IV           | Force Interrrupt | 1    | 1 | 0 | 1 | 13             | 12 | lı             | 10    |

Note: Bits shown in TRUE form.

# Table 3. FLAG SUMMARY

| TY               | PEICOMMANDS                                                      |
|------------------|------------------------------------------------------------------|
| h                | = Head Load Flag (Bit 3)                                         |
|                  | h = 1, Load head at beginning<br>h = 0, Unload head at beginning |
| V                | = Verify flag (Bit 2)                                            |
|                  | V = 1, Verify on destination track<br>V = 0, No verify           |
| r <sub>1</sub> r | o = Stepping motor rate (Bits 1-0)                               |
|                  | Refer to Table 1 for rate summary                                |
| u                | = Update flag (Bit 4)                                            |
|                  | u = 1, Update Track register<br>u = 0, No update                 |

Table 4. FLAG SUMMARY

| TYPE II & III COMMANDS                                                |           |            |            |      |  |  |  |  |
|-----------------------------------------------------------------------|-----------|------------|------------|------|--|--|--|--|
| m = Multiple Record flag (Bit 4)                                      |           |            |            |      |  |  |  |  |
| m = 0, Single Record                                                  |           |            |            |      |  |  |  |  |
| m = 1, Multiple Records<br>a <sub>0</sub> = Data Address Mark (Bit 0) |           |            |            |      |  |  |  |  |
|                                                                       | B (Data   |            | 11 0)      |      |  |  |  |  |
| $a_0 = 0, F$<br>$a_0 = 1, F$                                          | 8 (Delete | ed Data    | Mark)      |      |  |  |  |  |
| E = 15                                                                | ms Dela   | y (2MHz)   | )          |      |  |  |  |  |
| E =                                                                   | 1, 15 ms  | s delay    |            |      |  |  |  |  |
| E = 0                                                                 | , no 15 r | ns delay   |            |      |  |  |  |  |
| $(F_2)$ S = Side                                                      | Select Fl | ag (179    | 1/3 only)  |      |  |  |  |  |
| S = 0, Co                                                             |           |            |            |      |  |  |  |  |
| S = 1, Co                                                             | mpare fo  | or Side 1  |            |      |  |  |  |  |
| ( $F_1$ ) C = Side                                                    | Compare   | e Flag (   | 1791/3 o   | nly) |  |  |  |  |
| C = 0, di                                                             |           |            | 1.00%      |      |  |  |  |  |
| C = 1, enable side select compare                                     |           |            |            |      |  |  |  |  |
| $(F_1)$ <u>S = Side</u>                                               | Select F  | lag        |            |      |  |  |  |  |
| (Bit 1, 1795/7 only)                                                  |           |            |            |      |  |  |  |  |
| S = 0 Update SSO to 0                                                 |           |            |            |      |  |  |  |  |
| S = 1 Up                                                              | odate SS  | O to 1     |            |      |  |  |  |  |
| $(F_2)$ b = Sector Length Flag                                        |           |            |            |      |  |  |  |  |
|                                                                       |           |            |            |      |  |  |  |  |
| (Bit 3, 1975/7 only)                                                  |           |            |            |      |  |  |  |  |
|                                                                       | 1         | Sector Lei | nath Field |      |  |  |  |  |
|                                                                       |           |            | V          |      |  |  |  |  |
|                                                                       | 00        | 01         | 10         | 11   |  |  |  |  |
| b = 0                                                                 | 256       | 512        | 1024       | 128  |  |  |  |  |
|                                                                       |           |            |            |      |  |  |  |  |

#### Table 5. FLAG SUMMARY

256

512

1024

128

| TYPE IV COMMAND                               |   |
|-----------------------------------------------|---|
| li = Interrupt Condition flags (Bits 3-0)     |   |
| I0 = 1, Not-Ready to Ready Transition         |   |
| I1 = 1, Ready to Not-Ready Transition         |   |
| l2 = 1, Index Pulse                           |   |
| I3 = 1, Immediate Interrupt                   |   |
| $I_3 - I_0 = 0$ , Terminate with no Interrupt |   |
|                                               | - |

# **TYPE I COMMANDS**

b = 1

The Type I Commands include the Restore, Seek, Step, Step-In, and Step-Out commands. Each of the Type I Commands contains a rate field (ror1), which determines the stepping motor rate as defined in Table 1. The Type I Commands contain a head load flag (h) which determines if the head is to be loaded at the beginning of the command. If h = 1, the head is loaded at the beginning of the command (HLD output is made active). If h = 0, HLD is deactivated. Once the head is loaded, the head will remain engaged until the FD179X receives a command that specifically disengages the head. If the FD179X is idle (busy = 0) for 15 revolutions of the disk, the head will be automatically disengaged (HLD made inactive).

The Type I Commands also contain a verification (V) flag which determines if a verification operation is to take place on the destination track. If V = 1, a verification is performed, if V = 0, no verification is performed.

During verification, the head is loaded and after an internal 15 ms delay, the HLT input is sampled. When HLT is active (logic true), the first encountered ID field is read off the disk. The track address of the

ID field is then compared to the Track Register; if there is a match and a valid ID CRC, the verification is complete, an interrupt is generated and the Busy status bit is reset. If there is not a match but there is valid ID CRC, an interrupt is generated, and Seek Error Status bit (Status bit 4) is set and the Busy status bit is reset. If there is a match but not a valic 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. If an ID field with a valid CRC cannot be found after four revolutions of the disk, the FD179X terminates the operation and sends an interrupt, (INTRQ).

The Step, Step-In, and Step-Out commands contain an Update flag (U). When U = 1, the track register is updated by one for each step. When U = 0, the track register is not updated.

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 I COMMAND FLOW

# **RESTORE (SEEK TRACK 0)**

Upon receipt of this command the Track 00 (TROO) input is sampled. If TROO 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 TROO is not active low, stepping pulses (pins 15 to 16) at a rate specified by the riro field are issued until the TROO input is activated. At this time the Track Register is loaded with zeroes and an interrupt is generated. If the TROO input does not go active low after 255 stepping pulses, the FD179X terminates operation, interrupts, and sets the Seek error status bit. A verification operation takes place if the V flag is set. The h bit allows the head to be loaded at the start of command. Note that the Restore command is executed when MR goes from an active to an inactive state.



TYPE I COMMAND FLOW

#### 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.

#### 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 theriro 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 flag is on, the Track Register is incremented by one. After a delay determined by the r1r10 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 flag is on, the Track Register is decremented by one. After a delay determined by the riro 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.

#### 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 13.

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 en-

countered ID field is read and a comparison is again made. If there was a match, the Sector Number of the ID field is compared with the Sector Register. If there is not a Sector match, the next encountered ID field is read off the disk and comparisons again made. If the ID field CRC is correct, the data field is then located and will be either written into, or read from 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.



| Sector                       | Length Table                           |
|------------------------------|----------------------------------------|
| Sector Length<br>Field (hex) | Number of Bytes<br>in Sector (decimal) |
| 00                           | 128                                    |
| 01                           | 256                                    |
| 02                           | 512                                    |
| 03                           | 1024                                   |

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 until the sector regis-



TYPE II COMMAND

ter 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.

If the Sector Register exceeds the number of sectors on the track, the Record-Not-Found status bit will be set.

The Type II commands also contain side select compare flags. When C = 0, no side comparison is made. When C = 1, the LSB of the side number is read off the ID Field of the disk and compared with the contents of the (S) flag. If the S flag compares with the side number recorded in the ID field, the 179X continues with the ID search. If a comparison is not made within 5 index pulses, the interrupt line is made active and the Record-Not-Found status bit is set.

The 1795/7 READ SECTOR and WRITE SECTOR commands include a 'b' flag. The 'b' 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 'b' flag should be set to a one. The 's' flag allows direct control over the SSO Line (Pin 25) and is set or reset at the beginning of the command, dependent upon the value of this flag.

#### **READ SECTOR**

Upon receipt of the Read Sector command, the head is loaded, the Busy status bit set, and when an ID field is encountered that has the correct track number, correct sector number, correct side number, and correct CRC, the data field is presented to the computer. The Data Address Mark of the data field must be found within 30 bytes in single density and 43 bytes in double density of the last ID field CRC byte; if not, the 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



TYPE II COMMAND



**TYPE II COMMAND** 

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 command).

At the end of the Read operation, the type of Data Address Mark encountered in the data field is recorded in the Status Register (Bit 5) as shown below:

| STATUS<br>BIT 5 | ×                              |   |
|-----------------|--------------------------------|---|
| 1               | Deleted Data Mark<br>Data Mark | 1 |

#### WRITE SECTOR

Upon receipt of the Write Sector command, the head is loaded (HLD active) and the Busy status bit is set. When an ID field is encountered that has the correct track number, correct sector number, correct side number, and correct CRC, a DRQ is generated. The FD179X counts off 11 bytes in single density and 22 bytes in double density from the CRC field and the Write Gate (WG) output is made active if the DRQ is serviced (i.e., the DR has been loaded by the computer). If DRQ has not been serviced, the command is terminated and the Lost Data status bit is set. If the DRQ has been serviced, the WG is made active and six bytes of zeros 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 ao field of the command as shown below:

| ao | Data Address Mark (Bit 0) |
|----|---------------------------|
| 1  | Deleted Data Mark         |
| 0  | Data Mark                 |

The FD179X 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 zeros 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 in MFM. The WG output is then deactivated.

#### 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<br>ADDR |   | SECTOR<br>ADDRESS |   | CRC<br>1 | CRC<br>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. 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 h:dex pulse and continues until the next index pulse. As each byte is assembled it is transferred to the Data Register and the Data Request is generated for each byte. No CRC checking is performed. Gaps are included in the input data stream. The accumulation of bytes is synchronized to each Address Mark encountered. Upon completion of the command, the interrupt is activated. RG is not activated during the Read Track Command. An internal side compare is not performed during a Read Track.

### WRITE TRACK

Upon receipt of the Write Track command, the head is loaded and the Busy Status bit is set. Writing starts with the leading edge of the first encountered index pulse and continues until the next index pulse, at which time the interrupt is activated. The Data Request is activated immediately upon receiving the command, but writing will not start until after the first byte has been loaded into the Data Register. If the DR has not been loaded by the time the index pulse is encountered the operation is terminated making the device Not Busy, the Lost Data Status Bit is set. and the Interrupt is activated. If a byte is not present in the DR when needed, a byte of zeros is substituted. Address Marks and CRC characters are written on the disk by detecting certain data byte patterns in the outgoing data stream as shown in the table below. 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.

|     |        |                 |      | D FIELD | LENGIN |     | 2   |     |               | DATA FIELD | 1   | 2   |
|-----|--------|-----------------|------|---------|--------|-----|-----|-----|---------------|------------|-----|-----|
| GAP | 0.7750 | TRACK<br>NUMBER | SIDE | SECTOR  | SECTOR | CRC | CRC | GAP | 1997/107675-1 | DATA FIELD | CRC | CRC |

In MFM only, IDAM and DATA AM are preceded by three bytes of A1 with clock transition between bits 4 and 5 missing.





**TYPE III COMMAND WRITE TRACK** 

H

DDEN : 0

DOES DSR 1 F7

NO (FM)

NO

YES

YES

WRITE 2 CRC CHARS CLK + FF

YES (MFM)

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   | Write 00 thru F4 with CLK = FF         | Write 00 thru F4, in MFM     |
| F5           | Not Allowed                            | Write A1* in MFM, Preset CRO |
| F6           | Not Allowed                            | Write C2** in MFM            |
| F7           | Generate 2 CRC bytes                   | Generate 2 CRC bytes         |
| F8 thru FB   | Write F8 thru FB, Clk = C7, Preset CRC | Write F8 thru FB, in MFM     |
| FC           | Write FC with Clk = D7                 | Write FC in MFM              |
| FD           | Write FD with Clk = FF                 | Write FD in MFM              |
| FE           | Write FE, Clk = C7, Preset CRC         | Write FE in MFM              |
| FF           | Write FF with Clk = FF                 | Write FF in MFM              |

\*Missing clock transition between bits 4 and 5

200

\*\*Missing clock transition between bits 3 & 4



э



## TYPE IV COMMAND

#### FORCE INTERRUPT

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 an interrupt will be generated when the condition specified in the lo through lo field is detected. The interrupt conditions are shown below:

- Io = Not-Ready-To-Ready Transition
- In = Ready-To-Not-Ready Transition
- I2 = Every Index Pulse
- Is = Immediate Interrupt (requires reset, see Note)
- **NOTE:** If  $I_0 I_3 = 0$ , there is no interrupt generated but the current command is terminated and busy is reset. This is the only command that will enable the immediate interrupt to clear on a subsequent Load Command Register or Read Status Register.

#### STATUS DESCRIPTION

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 format of the Status Register is shown below:

|    |    |    | (BI | TS) |    | 19 |    |
|----|----|----|-----|-----|----|----|----|
| 7  | 6  | 5  | 4   | 3   | 2  | 1  | 0  |
| S7 | S6 | S5 | S4  | S3  | S2 | S1 | SO |

Status varies according to the type of command executed as shown in Table 6.

## 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 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 FD179X raises the Data Request signal. At this point in time, the user loads the data register with desired data to be written on the disk. For every byte of information to be written on the disk, a data request is generated. 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 thru FE in the data register, this is interpreted as data address marks with missing clocks or CRC generation. For instance, in FM an FE pattern will be interpreted as an ID address mark (DATA-FE, CLK-C7) and the CRC will be initialized. 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.

## 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                           |
| 1                  | F7 (2 CRC's written)         |
| 11                 | FF (or 00)                   |
| 6                  | 00                           |
| 1                  | FB (Data Address Mark)       |
| 128                | Data (IBM uses E5)           |
| 1                  | F7 (2 CRC's written)         |
| 27                 | FF (or 00)                   |
| 247**              | FF (or 00)                   |

\*Write bracketed field 26 times

\*\*Continue writing until FD179X interrupts out. Approx. 247 bytes.

1-Optional '00' on 1795/7 only.



IBM TRACK FORMAT

## 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                           |
|        | 1                  | FC (Index Mark)              |
|        | 50*                | 4E                           |
|        | 12                 | 00                           |
|        | 3                  | F5                           |
|        | 1                  | FE (ID Address Mark)         |
|        | 1                  | Track Number (0 thru 4C)     |
| *<br>- | 1                  | Side Number (0 or 1)         |
|        | 1                  | Sector Number (1 thru 1A)    |
|        | 1                  | 01                           |
|        | 1                  | F7 (2 CRCs written)          |
|        | 22                 | 4E                           |
|        | 12                 | 00                           |
|        | 3                  | F5                           |
|        | 1                  | FB (Data Address Mark)       |
|        | 256                | DATA                         |
|        | 1                  | F7 (2 CRCs written)          |
|        | 54                 | 4E                           |
|        | 598**              | 4E                           |
| _      |                    |                              |

\*Write bracketed field 26 times \*\*Continue writing until FD179X interrupts out.

Approx. 598 bytes.

## ELECTRICAL CHARACTERISTICS MAXIMUM RATINGS

VDD With Respect to Vss (Ground) =15 to -0.3V Max. Voltage to Any Input With =15 to -0.3V Respect to Vss

 $V_{DD} = ID \text{ ma Nominal}$   $V_{CC} = 35 \text{ ma Nominal}$ 

## **OPERATING CHARACTERISTICS (DC)**

TA = 0°C to 70°C,  $V_{DD}$  = + 12V ± .6V,  $V_{SS}$  = OV,  $V_{CC}$  = + 5V ± .25V

#### **1. NON-IBM FORMATS**

Variations in the IBM format are possible to a limited extent if the following requirements are met: sector size must be a choice of 128, 256, 512, or 1024 bytes; gap size must be according to the following table. Note that the Index Mark is not required by the 179X. The minimum gap sizes shown are that which is required by the 179X, with PLL lock-up time, motor speed variation, etc., adding additional bytes.

|         | 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 | 24 bytes 4E<br>3 bytes A1 |
| **      | 4 bytes 00  | 8 bytes 00                |
| Gap IV  | 16 bytes FF | 16 bytes 4E               |

\*Byte counts must be exact.

\*\*Byte counts are minimum, except exactly 3 bytes of A1 must be written.

| Operating Temperature | 0°C to 70°C     |
|-----------------------|-----------------|
| Storage Temperature   | -55°C to +125°C |

| SYMBOL | CHARACTERISTIC      | MIN. | MAX. | UNITS | CONDITIONS             |
|--------|---------------------|------|------|-------|------------------------|
| hı.    | Input Leakage       |      | 10   | μA    | $V_{IN} = V_{DD}$      |
| lo.    | Output Leakage      |      | 10   | μA    | VOUT = VDD             |
| VIH    | Input High Voltage  | 2.6  |      | . v   |                        |
| VIL    | Input Low Voltage   |      | 0.8  | V     |                        |
| Voн    | Output High Voltage | 2.8  |      | V     | $l_0 = -100 \ \mu A$   |
| VOL    | Output Low Voltage  |      | 0.45 | V     | $l_0 = 1.6 \text{ mA}$ |
| Pp     | Power Dissipation   |      | 0.5  | W     |                        |

## TIMING CHARACTERISTICS

 $T_A = 0^{\circ}C$  to 70°C,  $V_{DD} = + 12V \pm .6V$ ,  $V_{SS} = 0V$ ,  $V_{CC} = +5V \pm .25V$ 

## **READ ENABLE TIMING**

| SYMBOL | CHARACTERISTIC         | MIN. | TYP. | MAX. | UNITS | CONDITIONS            |
|--------|------------------------|------|------|------|-------|-----------------------|
| TSET   | Setup ADDR & CS to RE  | 50   |      |      | nsec  |                       |
| THLD   | Hold ADDR & CS from RE | 10   |      |      | nsec  |                       |
| TRE    | RE Pulse Width         | 400  |      |      | nsec  | $C_L = 50 \text{ pf}$ |
| TDRR   | DRQ Reset from RE      |      | 400  | 500  | nsec  |                       |
| TIRR   | INTRQ 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_L = 50 \text{ pf}$ |



**READ ENABLE TIMING** 

## WRITE ENABLE TIMING

| SYMBOL | CHARACTERISTIC         | MIN. | TYP. | MAX.  | UNITS | CONDITIONS |
|--------|------------------------|------|------|-------|-------|------------|
| TSET.  | Setup ADDR & CS to WE  | 50   |      |       | nsec  |            |
| THLD   | Hold ADDR & CS from WE | 10   |      | a a c | nsec  |            |
| TWE    | WE Pulse Width         | 350  |      |       | nsec  |            |
| TDRR   | DRQ Reset from WE      |      | 400  | 500   | nsec  |            |
| TIRR   | INTRQ Reset from WE    |      | 500  | 3000  | nsec  | See Note 5 |
| TDS    | Data Setup to WE       | 250  |      |       | nsec  |            |
| TDH    | Data Hold from WE      | 70   |      |       | nsec  |            |

## INPUT 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 |      | nsec  | 1800 ns @ 70°C |
| Тс     | RCLK Cycle Time       |      | 1500 |      | nsec  | 1800 ns @ 70°C |
| Txı    | RCLK hold to Raw Read | 40   |      |      | nsec  | See Note 1     |
| TX2    | Raw Read hold to RCLK | 40   |      |      | nsec  |                |





INPUT DATA TIMING

WRITE ENABLE TIMING

| SYMBOL | CHARACTERISTICS                         | MIN. | TYP.      | MAX.  | UNITS | CONDITIONS |
|--------|-----------------------------------------|------|-----------|-------|-------|------------|
| Тwp    | Write Data Pulse Width                  | 450  | 500       | 550   | nsec  | FM         |
|        |                                         | 150  | 200       | 250   | nsec  | MFM        |
| Twg    | Write Gate to Write Data                |      | 2         | 5     | μsec  | FM         |
|        | · · · ·                                 |      | 1         | ÷.,   | µsec  | MFM        |
| Tbc    | Write data cycle Time                   |      | 2,3, or 4 |       | µsec. | ±CLK Error |
| Ts     | Early (Late) to Write Data              | 125  |           |       | nsec  | MFM        |
| Th     | Early (Late) From<br>Write Data         | 125  |           |       | nsec  | MFM        |
| Twf    | Write Gate off from WD                  |      | 2         |       | μsec  | FM         |
|        |                                         |      | 1         |       | μsec  | MFM        |
| Twdl   | WD Valid to Clk                         | 100  |           |       | nsec  | CLK=1 MHZ  |
|        |                                         | 50   |           | a. s. | nsec  | CLK=2 MHZ  |
| Twd2   | WD Valid after CLK                      | 100  |           |       | nsec  | CLK=1 MHZ  |
|        | 1 C C C C C C C C C C C C C C C C C C C | 30   |           |       | nsec  | CLK=2 MHZ  |

## WRITE DATA TIMING: (ALL TIMES DOUBLE WHEN CLK = 1 MHz)



## WRITE DATA TIMING

## MISCELLANEOUS TIMING:

| SYMBOL                                                                                                          | CHARACTERISTIC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | MIN.   | TYP. | MAX.  | UNITS  | CONDITIONS  |
|-----------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|------|-------|--------|-------------|
| TCD1                                                                                                            | Clock Duty (low)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 230    | 250  | 20000 | nsec   |             |
| TCD2                                                                                                            | Clock Duty (high)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 200    | 250  | 20000 | nsec   |             |
| TSTP                                                                                                            | Step Pulse Output                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 2 or 4 |      |       | μsec   | See Note 5  |
| TDIR                                                                                                            | Dir Setup to Step                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |        | 12   |       | μsec   | ± CLK ERROF |
| TMR                                                                                                             | Master Reset Pulse Width                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 50     |      |       | μsec   |             |
| TIP                                                                                                             | Index Pulse Width                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 10     |      |       | μsec   | See Note 5  |
| TWF                                                                                                             | Write Fault Pulse Width                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 10     |      |       | μsec   | Oce Note 5  |
| and a state of the second s | <ul> <li>A second se<br/>second second s</li></ul> |        |      |       | Thomas |             |



**MISCELLANEOUS TIMING** 

#### 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 <u>= 1 MHz</u>.
- 4. RCLK may be high or low during RAW READ (Polarity is unimportant).
- 5. Times double when clock = 1 MHz.

## Table 6. STATUS REGISTER SUMMARY

| BIT        | ALL TYPE I<br>COMMANDS | READ<br>ADDRESS | READ<br>SECTOR | READ<br>TRACK | WRITE<br>SECTOR  | WRITE<br>TRACK   |
|------------|------------------------|-----------------|----------------|---------------|------------------|------------------|
| <b>S</b> 7 | 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                  | 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 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.<br>1 = Deleted Data Mark. 0 = Data Mark. On any Write: It indicates a Write Fault. This bit<br>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.                                                                                                                                                                   |



This is a preliminary specification with tentative device parameters and may be subject to change after final product characterization is completed.

Information furnished by Western Digital Corporation is believed to be accurate and reliable. However, no responsibility is assumed by Western Digital Corporation for its use; nor any infringements of patents or other rights of third parties which may result from its use. No license is granted by implication or otherwise under any patent or patent rights of Western Digital Corporation. Western Digital Corporation reserves the right to change said circuitry at anytime without notice.

WESTERN DIGITAL

)

3128 REDHILL AVENUE, BOX 2180 NEWPORT BEACH, CA 92663 (714) 557-3550,TWX 910-595-1139

APPENDIX D

## TECHNICAL INFORMATION

)

| QTY<br>                                                                                                                                                                                                                                                                                                                                                                                  | REF NO.                                                                                                                                                                                                                                     | DESCRIPTION                                                                                                                                                                                                                                                                                                                                 | • | CCS PART NO.*                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| Capac                                                                                                                                                                                                                                                                                                                                                                                    | Capacitors                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                             |   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |
| 2<br>1<br>1<br>1<br>1<br>4                                                                                                                                                                                                                                                                                                                                                               | C1,C8<br>C2<br>C3,4,9,10<br>C5<br>C6<br>C7<br>C11,12,13,14                                                                                                                                                                                  | 56pf 500v 10% Mica<br>.47uf 50v 20% Monolythic<br>4.7 35v 20% Tantalum<br>.01uf 50v 20% Ceramic Disk<br>20pf 500v 10% Mica<br>10pf 500v 10% Mica<br>.luf 50v 20% Monolythic                                                                                                                                                                 |   | 42215-55605<br>42034-24746<br>42804-54756<br>42142-21036<br>42215-52005<br>42215-51005<br>42034-21046                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |  |
| ICs                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                             | /3                                                                                                                                                                                                                                                                                                                                          |   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |
| 1<br>2<br>4<br>1<br>2<br>2<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>2<br>2<br>1<br>4<br>1<br>2<br>3<br>1<br>2<br>1<br>1<br>1<br>1<br>1<br>2<br>1<br>1<br>2<br>1<br>1<br>2<br>1<br>1<br>2<br>1<br>1<br>2<br>1<br>1<br>1<br>2<br>1<br>1<br>1<br>2<br>1<br>1<br>1<br>2<br>1<br>1<br>1<br>2<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1 | U1<br>U2<br>U3,29<br>U4,18,30,43<br>U5<br>U6,27<br>U7,33<br>U8<br>U9<br>U10<br>U11<br>U12<br>U13<br>U14<br>U15<br>U16<br>U17<br>U19<br>U20,32<br>U22,23<br>U24<br>U25,26,38,39<br>U28<br>U31,34<br>U35,36,37<br>U40<br>U41,42<br>U44<br>U45 | 7805, +5v Regulator<br>78L12, +12v Regulator<br>74LS123<br>74LS74<br>74LS03<br>74LS04<br>74LS00<br>FD1793<br>7407<br>75468<br>75368<br>74LS175<br>74LS175<br>74LS175<br>74LS197<br>74LS153<br>74LS164<br>74LS165<br>74LS10<br>5623 (74S287) 256 x 4 ROM<br>2716, 2K x 8 EPROM<br>74LS244<br>74LS32<br>74LS367<br>74LS30<br>75451<br>74LS139 | • | 32000-07805<br>32000-17812<br>30000-00132<br>30000-0003<br>30000-00004<br>30000-00000<br>31900-01793<br>30200-07407<br>30300-00468<br>30200-74368<br>30200-74368<br>30200-00175<br>30000-00175<br>30000-00175<br>30000-00197<br>30000-00153<br>30000-00165<br>30000-00165<br>30000-00165<br>30000-00165<br>30000-00165<br>30000-00165<br>30000-00165<br>30000-00165<br>30000-00165<br>30000-00165<br>30000-00165<br>30000-00165<br>30000-00165<br>30000-00165<br>30000-00165<br>30000-00165<br>30000-00165<br>30000-00165<br>30000-00165<br>30000-00165<br>30000-00165<br>30000-00165<br>30000-00165<br>30000-00165<br>30000-00100<br>30000-000000<br>30000-000000<br>30000-0000000<br>30000-0000000<br>30000-00000000<br>30000-00000000000000000000000000000000 |  |  |  |  |
| Resis                                                                                                                                                                                                                                                                                                                                                                                    | tors                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                             |   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |
| 3<br>1                                                                                                                                                                                                                                                                                                                                                                                   | R1,2,3<br>R4                                                                                                                                                                                                                                | 220 ohm 1/4W 5%<br>7.5K 1/4W 5%                                                                                                                                                                                                                                                                                                             |   | 40002-02215<br>40002-07525                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |

\* Use CCS part numbers when ordering spares or replacements.

| CONT | INUED    |                             |               |
|------|----------|-----------------------------|---------------|
| QTY  | REF NO.  | DESCRIPTION                 | CCS PART NO.* |
|      |          |                             |               |
| 1    | R5       | 1K 1/4W 5%                  | 40002-01025   |
| 1    | R6       | 220K 1/4W 5%                | 40002-02245   |
| 2    | R7,8     | 470 ohm 1/4W 5%             | 40002-04715   |
| 1    | R9       | 11K 1/4W 5%                 | 40002-01135   |
| 1    | R10      | 4.7K 1/4W 5%                | 40002-04725   |
| 1    | Zl       | 150 ohm x 7 20% SIP Network | 40930-71516   |
| 4    | Z2,3,4,5 | 2.7K x 7 20% SIP Network    | 40930-72726   |

## Sockets

| 14     | XU3,10-12,16,<br>19,21-23,29,<br>35-37,45              | 16-Pin Sockets | 58102-00160 |
|--------|--------------------------------------------------------|----------------|-------------|
| 20     | XU4-7,9,14,15,<br>17,18,20,27,<br>28,30-34,40<br>43,44 | 14-Pin Sockets | 58102-00140 |
| 1      | XU8                                                    | 40-Pin Socket  | 58102-00400 |
| 5      | XU13,25,26,38,<br>39                                   | 20-Pin Sockets | 58102-00200 |
| 1<br>2 | XU24                                                   | 24-Pin Socket  | 58102-00240 |
| 2      | XU41,42                                                | 8-Pin Socket   | 58102-00080 |

## Miscellaneous

| 3      | CR1-3              | LEDs, Rectangular Red          | 37400-00001 |
|--------|--------------------|--------------------------------|-------------|
| 1      | Jl                 | Header, Right Angle 2 x 17-Pin | 56005-02017 |
| 1<br>5 | J2                 | Header, Right Angle 2 x 25-Pin |             |
|        | W1,10,11,15,<br>16 | Header Strip, 1 x 3-Pin        | 56004-01003 |
| 8<br>3 | W2-9               | Header Strip, 1 x 2-Pin        | 56004-01002 |
| 3      | W12,13,14          | Header Strip, 1 x 4-Pin        | 56004-01004 |
| 1      | Yl                 | 16 MHz Crystal .01%            | 48231-60003 |
| 1      | - 1                | Heatsink, 220, .5"             | 60022-00001 |
| 9      | -                  | Berg jumper plugs              | 56200-00001 |
| 1      | -                  | Screw, 6-32 x 5/16"            | 71006-32051 |
| 1      |                    | Nut, Hex Kep 6-32              | 73006-32001 |
| 2      | -                  | PCB Extractor, Non-locking     | 60010-00001 |
| 2      | -                  | Roll Pin Extractor Mounting    | 60010-00000 |
| 1      | -                  | PC Board, Rev A                | 02422-00002 |
| 1      | - 1                | Manual, Rev A                  | 89000-02422 |

## A.2.1 THE DISK DRIVE BUSSES PIN ASSIGNMENTS



TOP VIEW

A-8



BOARD LAYOUT

#### SPECIFICATIONS

## 2422 DISK CONTROLLER SPECIFICATIONS

## BOARD MEASUREMENTS:

Board: 10" L x 5" W Connector: 6.35" L x .3" W (2.125" from right of board) 0.125" pin spacing Component Height: less than .5" Weight: approximately 11 ounces

#### POWER

Supply: Unregulated +8, +16, -16 volts Maximum power draw: .800 amps at +8 volts Power Dissipation: less than 8 watts

#### ENVIRONMENTAL REQUIREMENTS

Temperature: 0 to 70 degrees Celsius Humidity: 0 to 90% noncondensing SCHEMATIC

)





-5

S. 1.

## SCHEMATIC

÷

×

y . 1911

t.

1

## APPENDIX E

# FIRMWARE LISTING

| CP/M MACRO ASSEM 2.0                                                                                                                                                                                                                                                                                                                 | #001 DISK MC                                                                                                                                                                                           | DSS 2.2 MONITOR                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ;                                                                                                                                                                                                                                                                                                                                    | TITLE 'DISK M<br>MACLIB Z80<br>PAGE 68                                                                                                                                                                 | MOSS 2.2 MONITOR'                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| DISK                                                                                                                                                                                                                                                                                                                                 | MOSS MONITOR (VI                                                                                                                                                                                       | ERSION 2.2)                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| , 14 JU<br>All R                                                                                                                                                                                                                                                                                                                     | NE 1980<br>IGHTS RESERVED H                                                                                                                                                                            | BY ROBERT B. MASON                                                                                                                                                                                                                                                                                                                                                                                                                                |
| F000 = MOSS:<br>F000 = ROM:<br>0000 = WSVEC:<br>0002 = NBKPTS:<br>0013 = CTRLS:<br>000D = CR:<br>000A = LF:<br>000C = FMFD:<br>0007 = BELL:<br>0003 = IOBYTE:<br>0020 = SDATA:<br>0021 = SINTEN:<br>0022 = SIDENT:<br>0023 = SLCTRL:<br>0024 = SMDMCT:<br>0025 = SLSTAT:<br>0026 = SMDMST:                                           | EQU 13H<br>EQU 0DH<br>EQU 0AH<br>EQU 0CH<br>EQU 7<br>EQU 7                                                                                                                                             | ROM START ADDRESS<br>VECTOR FOR WARM RESTART<br>NUMBER OF BREAKPOINTS<br>ASCII DC3<br>ASCII CARRIAGE RETURN<br>ASCII LINE FEED<br>ASCII CNTRL CHAR TO RING THE BELL<br>ADDRESS OF I/O CONTROL BYTE<br>SERIAL DATA PORT BASE ADDRESS<br>SERIAL INTERRUPT ENABLE REGISTER<br>SERIAL INTERRUPT IDENTIFICATION REGISTER<br>SERIAL LINE CONTROL REGISTER<br>SERIAL LINE STATUS REGISTER<br>SERIAL LINE STATUS REGISTER<br>SERIAL MODEM STATUS REGISTER |
| 0006 = SPSV:                                                                                                                                                                                                                                                                                                                         | EQU 6                                                                                                                                                                                                  | ;STACK POINTER SAVE LOCATION                                                                                                                                                                                                                                                                                                                                                                                                                      |
| REGIS                                                                                                                                                                                                                                                                                                                                | TER STORAGE DISH<br>L SYSTEM STACK I                                                                                                                                                                   | PLACEMENTS FROM<br>LOCATION.                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 0015 = ÅLOC:<br>0013 = BLOC:<br>0012 = CLOC:<br>0011 = DLOC:<br>0010 = ELOC:<br>0014 = FLOC:<br>0030 = LLOC:<br>0034 = PLOC:<br>0035 = TLOC:<br>0025 = TLOCX:<br>0020 = LLOCX:                                                                                                                                                       | $\begin{array}{ccc} EQU & 15H \\ EQU & 13H \\ EQU & 12H \\ EQU & 11H \\ EQU & 10H \\ EQU & 10H \\ EQU & 31H \\ EQU & 30H \\ EQU & 30H \\ EQU & 34H \\ EQU & 35H \\ EQU & 25H \\ EQU & 20H \end{array}$ |                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 0009 =       ÅPLOC:         000B =       BPLOC:         000A =       CPLOC:         000D =       DPLOC:         000C =       EPLOC:         000F =       HPLOC:         000F =       LPLOC:         000F =       LPLOC:         000F =       LPLOC:         0005 =       YLOC:         0002 =       RLOC:         0003 =       ILOC: | EQU 9<br>EQU 11<br>EQU 10<br>EQU 13<br>EQU 12<br>EQU 8<br>EQU 15<br>EQU 14<br>EQU 7<br>EQU 5<br>EQU 2<br>EQU 3                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| DISK                                                                                                                                                                                                                                                                                                                                 | CONTROLLER UNIQU                                                                                                                                                                                       | JE EQUATES                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 0030 = DSTAT<br>0030 = DCMMD<br>0031 = DTRCK<br>0032 = DSCTR                                                                                                                                                                                                                                                                         | EQU 30H<br>EQU DSTAT<br>EQU DSTAT+1<br>EQU DSTAT+2                                                                                                                                                     | DISK STATUS PORT<br>DISK COMMAND PORT<br>DISK TRACK PORT<br>DISK SECTOR PORT                                                                                                                                                                                                                                                                                                                                                                      |

8

| CP/M MACRO ASSE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | M 2.0                                                                                                       | #002                                                                            | DISK MOS                                                                                                                            | SS 2.2 MONITOR                                                                                                                                                                                                                                                            |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0033 =<br>0034 =<br>0034 =                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | DDATA<br>DFLAG<br>DCNTL                                                                                     | EQU<br>EQU<br>EQU                                                               | DSTAT+3<br>DSTAT+4<br>DSTAT+4                                                                                                       | DISK DATA PORT<br>DISK FLAG PORT<br>DISK CONTROL PORT                                                                                                                                                                                                                     |
| 0040 =<br>0041 =<br>0042 =<br>0043 =<br>0044 =<br>0045 =<br>0045 =<br>0046 =<br>0048 =<br>0048 =<br>0048 =                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | JISKNO:<br>TRACK:<br>SECTOR:<br>SIDE:<br>SPT:<br>TWOSID:<br>STATAT:<br>STATUS:<br>CMND:<br>LUNIT:<br>CUNIT: | EQU<br>EQU<br>EQU<br>EQU<br>EQU<br>EQU<br>EQU<br>EQU<br>EQU<br>EQU              | SPT+1<br>46H<br>47H<br>STATUS+<br>49H<br>LUNIT+1                                                                                    | SIDE SELECT HOLD AREA<br>SECTORS PER TRACK HOLD<br>SINGLE/DOUBLE SIDED SWITCH HOLD<br>STEP RATE SAVE AREA                                                                                                                                                                 |
| 004B =<br>004C =<br>004E =<br>0080 =                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | RWFLG:<br>HSTBUF:<br>IDSV:<br>TBUF:                                                                         | EQU<br>EQU<br>EQU<br>EQU                                                        | 4BH<br>4CH<br>4EH<br>80H                                                                                                            | HOST BUFFER ADDRESS<br>DISK ID SAVE AREA                                                                                                                                                                                                                                  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | JUMP                                                                                                        | TARGETS                                                                         | FOR BASI                                                                                                                            | C INPUT/OUTPUT                                                                                                                                                                                                                                                            |
| F000 C35BF0<br>F003 C346F6<br>F006 C356F6<br>F009 C300F6<br>F00C C37CF6<br>F00F C310F6<br>F012 C323F6<br>F012 C323F6<br>F015 C36AF1<br>F018 C365F1<br>F018 C365F1<br>F018 C38AF0<br>F01E C394F6<br>F021 C394F6<br>F024 C3CFF3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | CONIN:<br>READER:<br>CONOUT:<br>PUNCH:<br>LIST:<br>CONST:                                                   | JMP<br>JMP                                                                      | INIT<br>CI<br>RI<br>CO<br>PO<br>LO<br>CSTS<br>IOCHK<br>IOSET<br>MEMCK<br>RTS<br>RTS<br>REST                                         | COLD START<br>CONSOLE INPUT<br>READER INPUT<br>CONSOLE OUTPUT<br>PUNCH OUTPUT<br>LIST OUTPUT<br>CONSOLE STATUS<br>PUT IOBYTE INTO (A)<br>(C) HAS A NEW IOBYTE<br>MEMORY LIMIT CHECK<br>IODEF- DEFINE USER I/O ENTRY POINTS<br>SPCL- I/O CONTROL<br>BREAKPOINT ENTRY POINT |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | TBL C                                                                                                       | ONTAINS<br>EXECUTI                                                              | THE ADDRI                                                                                                                           | ESSES OF THE ACTION ROUTINES<br>IT TO LOOK UP THE DESIRED ADDRESS.                                                                                                                                                                                                        |
| F027 F8F0<br>F029 52F1<br>F028 ACF1<br>F028 ACF1<br>F028 ACF1<br>F027 3CF1<br>F033 FDF52<br>F0333 FDF52<br>F0337 409F1<br>F035 409F1<br>F035 509F1<br>F035 509F1<br>F0335 509F1<br>F0035 509F1<br>F0040<br>F0040<br>F0040<br>F0040<br>F0040<br>F0040<br>F0040<br>F0040<br>F0040<br>F0040<br>F0040<br>F0040<br>F0040<br>F0040<br>F0040<br>F0040<br>F0040<br>F0040<br>F0040<br>F0040<br>F0040<br>F0040<br>F0040<br>F0040<br>F0040<br>F0040<br>F0040<br>F0040<br>F0040<br>F0040<br>F0040<br>F0040<br>F0055<br>F0055<br>F0055<br>982<br>F00559<br>F00559<br>F00559<br>F00559<br>F00559<br>F00559<br>F00559<br>F00559<br>F00559<br>F00559<br>F00559<br>F00559<br>F00559<br>F00559<br>F00559<br>F00559<br>F00559<br>F00559<br>F00559<br>F00559<br>F00559<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F0050<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F00550<br>F0050<br>F0050<br>F0050<br>F0050<br>F0050<br>F0050<br>F0050<br>F0050<br>F0050<br>F0050<br>F0050<br>F0050<br>F0050<br>F0050<br>F0050<br>F0050<br>F0 | ŤBL:                                                                                                        | DW<br>DW<br>DW<br>DW<br>DW<br>DW<br>DW<br>DW<br>DW<br>DW<br>DW<br>DW<br>DW<br>D | ASGN<br>BOOT<br>QPRT<br>DISP<br>QPRT<br>FILL<br>GOTO<br>HEXNN<br>INPT<br>QPRT<br>QPRT<br>QPRT<br>QPRT<br>QPRT<br>QPRT<br>QPRT<br>QP | IT TO LOOK OF THE DESIRED ADDRESS.                                                                                                                                                                                                                                        |

E-4

;

## FIRMWARE LISTING

)

| CP/M MACRO ASSEM                                                                                                 | 2.0                     | <b>#</b> 003                                                         | DISK MOSS 2.2 MONITOR                                                                                                                                     |                                     |  |
|------------------------------------------------------------------------------------------------------------------|-------------------------|----------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------|--|
| ; THE COLD INITIALIZATION CODE                                                                                   |                         |                                                                      |                                                                                                                                                           |                                     |  |
| F05C 313F00<br>F05F 2100C3<br>F062 11B2F6<br>F065 0610<br>F067 D5<br>F068 E5                                     | İNIT:<br>INIT1:         | DI<br>LXI<br>LXI<br>MVI<br>PUSH<br>PUSH<br>DJNZ                      | ;DISABLE INTERRUPTS<br>SP,3FH ;USE STACK TO INITIALIZ<br>H,JMP <sup>#</sup> 256 ; WITH RESTART<br>D,RSTER<br>B,16 ;16 TIMES (64 BYTES)<br>H<br>H<br>INIT1 | E RESTARTS<br>ERROR VECTORS         |  |
| F069+10FC<br>F06B 3195F0<br>F06E 3E00<br>F06F                                                                    |                         | LXI<br>MVI<br>ORG                                                    | SP,FAKE-2 ;SET UP TEMPORA<br>A,O ; SKIP THE NEXT INST<br>\$-1 ;SAVE A BYTE HERE                                                                           | RY STACK                            |  |
|                                                                                                                  | MEMSI                   | FOUND.                                                               | TES THE TOP OF CONTIGUOUS RAM.<br>BOTTOM UP UNTIL A NON-RAM LOCA<br>IT THEN TAKES OFF FOR MONITOR W<br>D RETURNS THE VALUE IN (H,L).                      | IT SEARCHES<br>TION IS<br>ORK SPACE |  |
| F070 0100F0<br>F073 21FFFF                                                                                       | ,<br>MEMSIZ:<br>MEMSZ1: | PUSH<br>LXI<br>INR<br>MOV<br>CMA<br>MOV<br>CMP<br>CMA<br>MOV<br>JRNZ | B ;MONITOR START LOCATION<br>B,ROM<br>H,-1 ;START OF MEMORY ADDRES<br>A,M<br>M,A<br>M<br>M,A<br>M<br>M,A<br>M<br>MA,A                                     |                                     |  |
| F07D+2004<br>F07F 7C<br>F080 B8                                                                                  |                         | MOV<br>CMP<br>JRNZ                                                   | A,H ;SEE IF ON MONITOR BORD<br>B<br>MEMSZ1                                                                                                                | ER                                  |  |
| F081+20F3<br>F083 25<br>F084 01DEFF<br>F087 09<br>F088 C1<br>F089 C9                                             | MEMSZ2:                 | DCR<br>LXI<br>DAD<br>POP<br>RET                                      | H ;TAKE OFF WORKSPACE<br>B,EXIT-ENDX-3*NBKPTS+1<br>B ;(B,C) IS UNPREDICTABLE                                                                              | DURING INIT                         |  |
| ROUTINE MEMCHK FINDS THE CURRENT TOP OF CONTIGUOUS MEMORY<br>(LESS THE MONITOR WORKSPACE) AND RETURNS THE VALUE. |                         |                                                                      |                                                                                                                                                           |                                     |  |
| F08A E5 K<br>F08B CD6FF0<br>F08E 7D<br>F08F D63C                                                                 | МЕМСК :                 | PUSH<br>CALL<br>MOV<br>SUI<br>JRNC                                   | H ;SAVE (H,L)<br>MEMSIZ ;GET THE RAM SIZE<br>A,L<br>50 ;TAKE OFF WORK SPACE<br>MEMCKO                                                                     |                                     |  |
| F091+3001<br>F093 25<br>F094 44 N<br>F095 E1<br>F096 C9                                                          | мемско:                 | DCR                                                                  | H<br>B,H<br>H                                                                                                                                             |                                     |  |
| F097 99F0 F<br>F099 F9<br>F09A 1145F4<br>F09D EB<br>F09E 011D00                                                  | ;<br>FAKE:              | DW<br>SPHL<br>LXI<br>XCHG<br>LXI<br>LDIR                             | FAKE+2<br>D,EXIT<br>B,ENDX-EXIT                                                                                                                           |                                     |  |
| FOA1+EDBO<br>FOA3 010600<br>FOA6 D5<br>FOA7 E1<br>FOA8 2B                                                        |                         | LXI<br>PUSH<br>POP<br>DCX<br>LDIR                                    | B,3*NBKPTS<br>D<br>H<br>H                                                                                                                                 |                                     |  |

E-6

CP/M MACRO ASSEM 2.0 #004 DISK MOSS 2.2 MONITOR FOA9+EDBO FOAB 21E8FF FOAE 39 FOAF E5 H,-24 SP LXI DAD PUSH H FOBD 23 FOB1 23 FOB2 220600 FOB5 160A FOB7 C5 FOB8 15 INX H : ADJUST USER STACK LOCATION H SAVE THE STACK INITIAL VALUE INITIALIZE REGISTER STORAGE AREA SHLD SPSV D,10 MVI PUSH INIT2: B DCR D ;LOOP CONTROL JRNZ INIT2 F0B9+20FC ; INSERT I/O INIT CODE HERE CALL DINIT ;SE CALL 18250 ;IN CALL RTS SEE IF AUTO BOOT WANTED FOBB CD59F5 FOBE CD9FF4 INITIALIZE THE 8250 FOC1 CD94F6 FOC4 2190F4 LXI CALL H,LOGMSG ;LOG ONTO THE SYSTEM PRTWD FOC7 CD95F6 JMPR WINIT GO TO MONITOR EXECUTIVE FOCA+1843 ; ROUTINE EXF READS ONE PARAMETER. IT EXPECTS THE FIRST CHARACTER OF THE PARAMETER TO BE IN THE A REGISTER ON ENTRY. ; ; FOCC 0601 FOCE 210000 **ÉXF**: MVI B,1 H,0 EX1 SET UP FOR ONE PARAMETER LXI JMPR ;FIRST CHARACTER IN A ALREADY F0D1+180C ; ROUTINE EXPR READS PARAMETERS FROM THE CONSOLE AND DEVELOPS A 16 BIT HEXADECIMAL FOR EACH ONE. THE NUMBER OF PARAMETERS WANTED IS IN THE B REG ON ENTRY. A CARRIAGE RETURN WILL TERMINATE THE , ; ON ENTRY. A CARRIAGE RETURN WILL TERMINATE THE ENTRY SEQUENCE; A BLANK OR A COMMA WILL END THE CURRENT PARAMETER ENTRY. EACH PARAMETER ONLY TAKES THE LAST 4 DIGITS TYPED IN; ANY EXCESS IS DISCARDED. A NON-HEX DIGIT WILL TERMINATE THE ENTRY SEQUENCE AND CAUSE A WARM BOOT OF THE MON. AS3: DJNZ AS2 ; PART OF THE ASSIGN CODE F0D3+1079 JRNZ ;NON-ZERO IS ERROR EX3: OPRT F0D5+2032 F0D7 05 F0D8 C8 MORE PARAMETERS? NO, RETURN INITIALIZE PARAMETER GET NEXT NUMBER EXPR1: DCR В RZ F0D9 210000 F0DC CD7BF3 F0DF 4F LXI CALL H,O ECHO EXPR: EXO: C,A NIBBLE **EX1:** MOV SAVE CHAR FOR LATER USE FOEO CDBOF3 CALL JRC EX2 ;NOT A NUMBER, JUMP F0E3+3808 F0E5 29 F0E6 29 F0E7 29 F0E8 29 F0E8 29 F0E9 B5 F0EA 6F DAD Η ;MULTIPLY BY 16 H H DAD DAD DAD H ORA L ; ADD ON NEW DIGIT MOV L A L,A EXO JMPR GO GET NEXT DIGIT FOEB+18EF PUT UNDER RETURN ADDRESS ON STACK RESTORE RETURN ADDRESS REGET THE LAST CHARACTER TEST FOR DELIMITER FOED E3 FOEE E5 FOEF 79 XTHL PUSH EX2: Н Ä,C P2C MOV FOFO CDC3F3 CALL JUMP IF NOT CARRIAGE RETURN EX3 JRNC F0F3+30E0 DJNZ QPRT CARRET WITH MORE PARAM MEANS ERROR F0F5+1012

# FIRMWARE LISTING

| CP/M MACRO ASSEM                                                                                                                           | 1 2.0               | #005                                                 | DISK MOS                                                  | SS 2.2 MONITOR                                                                                                                                                                                                   |  |  |
|--------------------------------------------------------------------------------------------------------------------------------------------|---------------------|------------------------------------------------------|-----------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| FOF7 C9                                                                                                                                    |                     | RET                                                  |                                                           |                                                                                                                                                                                                                  |  |  |
| 30 care:<br>Na                                                                                                                             | , MAIN A            | CTION RC                                             | DUTINES                                                   |                                                                                                                                                                                                                  |  |  |
|                                                                                                                                            |                     |                                                      |                                                           | PERIPHERALS                                                                                                                                                                                                      |  |  |
|                                                                                                                                            | ,                   | PERIPHER<br>ALTERS 1<br>CURRENT                      | RALS TO T<br>LOBYTE (N<br>ASSIGNME                        | THE ASSIGNMENT OF PHYSICAL<br>THE FOUR LOGICAL DEVICE TYPES. IT<br>MEMORY LOCATION 0003) TO MATCH THE<br>ENT. THE FOUR LOGICAL DEVICES ARE<br>LIST, AND PUNCH. IN ALL CASES,<br>IS SET UP AS THE DEFAULT DEVICE. |  |  |
| FOF8 CD7BF3<br>FOFB 216EF1<br>FOFE 110500<br>F101 0604<br>F103 BE                                                                          | ASO:                | CMP                                                  | ECHO<br>H,ALT<br>D,APT-AL<br>B,4<br>M                     | IS THIS ONE IT?                                                                                                                                                                                                  |  |  |
| F104+2842                                                                                                                                  |                     | JRZ                                                  | AS1                                                       | ;YES, JUMP                                                                                                                                                                                                       |  |  |
| F106 19<br>F107+10FA                                                                                                                       |                     | DAD<br>DJNZ                                          | D<br>ASO                                                  | ;NO, GO TO NEXT LOGICAL ENTRY                                                                                                                                                                                    |  |  |
|                                                                                                                                            |                     | LXI<br>CALL                                          | H,QMSG<br>PRTWA                                           | GET ADDRESS OF QUESTION MARK MSG                                                                                                                                                                                 |  |  |
|                                                                                                                                            | THE WARM START CODE |                                                      |                                                           |                                                                                                                                                                                                                  |  |  |
| F10F 2A0600                                                                                                                                |                     | LHLD                                                 | SPSV                                                      | ; RESET THE STACK                                                                                                                                                                                                |  |  |
| F112 F9<br>F113 210FF1<br>F116 E5<br>F117 220100<br>F11A 3EC3<br>F11C 320000<br>F11F CDA9F6<br>F122 CD78F3<br>F125 D641                    | WINITA:             | PUSH<br>SHLD<br>MVI<br>STA<br>CALL                   | H<br>WSVEC+1<br>A,OC3H<br>WSVEC<br>CRLF<br>DECHO<br>'A'   | ; RESET RETURN AND WARM START VECTOR<br>; START A NEW LINE<br>;GET THE COMMAND<br>;GET RID OF ASCII ZONE                                                                                                         |  |  |
| F127+38E0<br>F129 FE1A                                                                                                                     |                     | CPI<br>JRNC                                          | QPRT<br>'Z'-'A'+<br>QPRT                                  | ;BAD COMMAND<br>1 ;CHECK UPPER LIMIT<br>;BAD COMMAND                                                                                                                                                             |  |  |
| F12B+30DC<br>F12D 87<br>F12E 5F<br>F12F 1600<br>F131 0602<br>F133 2127F0<br>F136 19<br>F137 7E<br>F138 23<br>F139 66<br>F13A 6F<br>F13B E9 |                     | ADD<br>MOV<br>MVI<br>LXI<br>DAD<br>MOV<br>INX<br>MOV | A<br>E,A<br>D,O<br>B,2<br>H,TBL<br>D<br>A,M<br>H,M<br>L,A | ; DOUBLE IT FOR TABLE OFFSET<br>; SET UP FOR DOUBLE ADD<br>; SET UP FOR TWO PARAMETERS<br>; GET ACTION ROUTINE ADDRESS<br>;LOAD H,L INDIRECT<br>;GO TO ACTION ROUTINE                                            |  |  |
|                                                                                                                                            | , FILL A            | CTION RO                                             | UTINE                                                     |                                                                                                                                                                                                                  |  |  |
|                                                                                                                                            | ;                   | DETERMIN                                             | ED CONST                                                  | LS A BLOCK OF MEMORY WITH A USER-<br>ANT. IT EXPECTS THREE PARAMETERS<br>THE FOLLOWING ORDER:                                                                                                                    |  |  |
|                                                                                                                                            | ;                   | START AD<br>FINISH A<br>FILL VAL                     | DDRESS                                                    |                                                                                                                                                                                                                  |  |  |
|                                                                                                                                            |                     |                                                      | EXPR3<br>M,C                                              | GET THREE PARAMETERS<br>PUT DOWN THE FILL VALUE                                                                                                                                                                  |  |  |

| CP/M MACRO ASSE                                                                                                                                | M 2.0         | #006                                         | DISK MO                                       | SS 2.2 MONITOR                                                                                                                                                                   |
|------------------------------------------------------------------------------------------------------------------------------------------------|---------------|----------------------------------------------|-----------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| F140 CD8FF3                                                                                                                                    |               | CALL<br>JRNC                                 | HILO<br>FIO                                   | INCREMENT AND CHECK THE POINTER                                                                                                                                                  |
| F143+30FA<br>F145 D1<br>F146+18C7                                                                                                              | 4             | POP<br>JMPR                                  | D<br>WINIT                                    | RESTORE STACK POINTER IN CASE<br>STACK WAS OVERWRITTEN                                                                                                                           |
| F148 50<br>F149 0604<br>F14B CD78F3<br>F14E 23<br>F14F BE                                                                                      | Ås1:<br>AS2:  | MOV<br>MVI<br>CALL<br>INX<br>CMP<br>JRNZ     | D,B<br>B,4<br>DECHO<br>H<br>M<br>AS3          | SAVE THE COUNTER RESIDUE<br>LOOP CONTROL<br>GET THE NEW ASSIGNMENT<br>INCREMENT POINTER<br>SEE IF THIS IS IT                                                                     |
| F150+2081<br>F152 68<br>F153-2D<br>F154 42<br>F155 2603<br>F157 05                                                                             |               | MOV<br>DCR<br>MOV<br>MVI<br>DCR<br>JRZ       | L,B<br>L,D<br>H,3<br>B<br>AS5                 | SAVE THE RESIDUE TO FORM ASGT<br>ADJUST VALUE<br>REGET THE LOGICAL RESIDUE<br>SET UP THE IOBYTE MASK<br>ADJUST THIS ONE ALSO<br>NO SHIFT NEEDED                                  |
| F158+2804<br>F15A 29<br>F15B 29                                                                                                                | AS4:          | DAD<br>DAD<br>DJNZ                           | H<br>H<br>AS4                                 | ; SHIFT THE MASKS INTO POSITION<br>;NOT DONE YET, JUMP                                                                                                                           |
| F15C+10FC<br>F15E 3A0300<br>F161 B4<br>F162 AC<br>F163 B5<br>F163 B5<br>F164 4F<br>F165 79<br>F166 320300<br>F169 C9<br>F16A 3A0300<br>F16D C9 | AS5:          | LDA<br>ORA<br>XRA<br>ORA<br>MOV              | IOBYTE<br>H<br>L<br>C,A                       | MASK THE DESIRED ASSIGNMENT IN<br>LOGICAL ASGT BITS NOW OFF<br>PUT IN NEW VALUE                                                                                                  |
| F165 79<br>F166 320300                                                                                                                         | IOSET:        | MOV<br>STA                                   | Ă,Ĉ<br>IOBYTE                                 | ;SAVE NEW ASSIGNMENTS                                                                                                                                                            |
| F169 C9<br>F16A 3A0300<br>F16D C9                                                                                                              | IOCHK:        | RET<br>LDA<br>RET                            | IOBYTE                                        |                                                                                                                                                                                  |
| F16E 4C<br>F16F 32<br>F170 31<br>F171 4C<br>F172 54<br>F173 50<br>F174 32                                                                      | ÅLT:<br>APT:  | DB<br>DB<br>DB<br>DB<br>DB<br>DB<br>DB       | 'L'<br>'2'<br>'L'<br>'T'<br>'P'               | LOGICAL LIST DEVICE TABLE<br>USER DEVICE #2<br>USER DEVICE #1<br>LIST TO HIGH SPEED PRINTER<br>LIST TO TTY<br>LOGIPAL PUNCH DEVICE TABLE<br>USER DEVICE #2                       |
| F174 32<br>F175 31<br>F175 50<br>F177 54<br>F178 52<br>F179 32<br>F17A 31<br>F17B 50<br>F17C 54<br>F17C 54                                     | ART:          | DB<br>DB<br>DB<br>DB<br>DB<br>DB<br>DB<br>DB | '1'<br>'P'<br>'R'<br>'2'<br>'1'<br>'P'<br>'T' | USER DEVICE #1<br>PUNCH TO HIGH SPEED PUNCH<br>PUNCH TO TTY<br>LOGIPAL READER DEVICE TABLE<br>USER DEVICE #2<br>USER DEVICE #1<br>READER TO HIGH SPEED READER<br>READER TO TTY   |
| F17C 54<br>F17D 43<br>F17E 31<br>F17F 42<br>F180 43<br>F181 54                                                                                 | ACT:          | DB<br>DB<br>DB<br>DB<br>DB<br>DB             | 'C'<br>'B'<br>'C'<br>'T'                      | LOGIPAL CONSOLE DEVICE TABLE<br>USER DEVICE #1<br>CONSOLE TO BATCH (PRINTER OR PTR)<br>CONSOLE TO CRT<br>CONSOLE TO TTY                                                          |
| a<br>N                                                                                                                                         | THE E         | OF THE<br>RESPOND<br>CHARACT                 | SYSTEM.<br>TO ANYT<br>ERS. WH<br>IS RETU      | ED TO PREVENT UNAUTHORIZED USAGE<br>THE SYSTEM LOCKS UP AND WILL NOT<br>HING OTHER THAN TWO ASCII BELL<br>EN IT SEES THEM CONSECUTIVELY,<br>RNED TO THE MONITOR WITHOUT ALTERING |
| F182 0602<br>F184 CD8FF6<br>F187 FE07                                                                                                          | BYE:<br>BYE1: | MVI<br>CALL<br>CPI<br>JRNZ                   | B,2<br>CONI<br>BELL<br>BYE                    | SET UP FOR TWO CHARACTERS<br>GO READ THE CONSOLE<br>SEE IF AN ASCII BELL<br>NO, START OVER AGAIN                                                                                 |

| CP/M MACRO ASSEN                                                                                   | M 2.0          | #007                                              | DISK MO                                          | SS 2.2 MONITOR                                                                                                                                                                                                          |
|----------------------------------------------------------------------------------------------------|----------------|---------------------------------------------------|--------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| F189+20F7<br>F18B CD7EF3                                                                           |                | CALL<br>DJNZ                                      | ECH1<br>BYE1                                     | ;ECHO THE BELL<br>;NOT YET, GET NEXT ONE                                                                                                                                                                                |
| F18E+10F4<br>F190 C9                                                                               |                | RET                                               |                                                  | ; RETURN TO MONITOR                                                                                                                                                                                                     |
|                                                                                                    | COMP           | ARE ROUT                                          | INE                                              |                                                                                                                                                                                                                         |
|                                                                                                    | THIS R         | IS DETE<br>DISPLAY                                | ED, ALON                                         | TWO BLOCKS OF MEMORY AGAINST EACH<br>FERENCE IN THE RELATIVE ADDRESSES<br>E ADDRESS OF THE FIRST BLOCK IS<br>G WITH ITS CONTENTS AND THE CONTENTS<br>OCK'S SAME RELATIVE ADDRESS.                                       |
| F191 CD86F3<br>F194 OA<br>F195 C5<br>F196 46<br>F197 B8                                            | ĊOMP:<br>CMPA: | CALL<br>LDAX<br>PUSH<br>MOV<br>CMP<br>JRZ         | EXPR3<br>B<br>B,M<br>B,M<br>CMPB                 | GO GET THREE PARAMETERS<br>GET SOURCE 2 DATA<br>SAVE SOURCE 2 POINTER<br>READ SOURCE 1 DATA<br>COMPARE DATA<br>JUMP IF OK                                                                                               |
| F198+280C<br>F19A F5<br>F19B CDFBF5<br>F19E 78<br>F19F CDF4F5<br>F1A2 F1<br>F1A3 CDE6F5<br>F1A6 C1 | CMPB:          | PUSH<br>CALL<br>MOV<br>CALL<br>POP<br>CALL<br>POP | PSW<br>LADRB<br>A,B<br>DASH1<br>PSW<br>HEX1<br>B | SAVE SOURCE 2 DATA<br>WRITE THE ADDRESS<br>GET SOURCE 1 DATA<br>FORMAT<br>REGET SOURCE 2 DATA<br>OUTPUT IT                                                                                                              |
| F1A7 CD9BF3                                                                                        | CHFD.          | CALL<br>JMPR                                      | HILOXB<br>CMPA                                   | INCREMENT SOURCE 1 POINTER AND SEE IF DONE<br>JUMP IF NOT DONE YET                                                                                                                                                      |
| F1AA+18E8                                                                                          |                |                                                   |                                                  | <ul> <li>Bessendovich Kohn, Deseutrin Christialaetten Pracemas</li> </ul>                                                                                                                                               |
|                                                                                                    | DISPL          |                                                   | N ROUTIN                                         |                                                                                                                                                                                                                         |
|                                                                                                    | ;              | CURRENT<br>MUST SP<br>THE DIS                     | CONSOLE<br>ECIFY TH                              | SPLAYS A BLOCK OF MEMORY ON THE<br>DEVICE (CONSOLE DUMP). THE USER<br>E START AND FINISH ADDRESSES.<br>ORGANIZED TO DISPLAY UP TO 16 BYTES<br>E, WITH ALL COLUMNS ALIGNED SO<br>THE SAME LAST HEX DIGIT IN ITS ADDRESS. |
| F1AC CDA4F6<br>F1AF CDFBF5<br>F1B2 7D<br>F1B3 CDF0F1<br>F1B6 E5                                    | DISP:<br>DIS1: | CALL<br>CALL<br>MOV<br>CALL<br>PUSH               | EXLF<br>LADRB<br>A,L<br>TRPLSP<br>H              | GO GET BLOCK LIMITS<br>DISPLAY THE START ADDRESS<br>SEE IF ON 16 BYTE BOUNDARY<br>SKIP OVER TO RIGHT COLUMN<br>SAVE (H,L)                                                                                               |
| F1B7 7E<br>F1B8 CDE6F5<br>F1BB CD8FF3                                                              | DIS2:          | MOV<br>CALL<br>CALL<br>JRC                        | A,M<br>HEX1<br>HILO<br>DIS7                      | GET THE CONTENTS<br>OUTPUT IT<br>INCREMENT, CHECK POINTER<br>DONE IF CARRY SET                                                                                                                                          |
| F1BE+382A<br>F1CO CDFEF5<br>F1C3 7D<br>F1C4 E60F                                                   |                | CALL<br>MOV<br>ANI<br>JRNZ                        | BLK<br>A,L<br>OFH<br>DIS2                        | ;MAKE COLUMNS<br>;READY FOR NEW LINE?                                                                                                                                                                                   |
| F1C6+20EF<br>F1C8 E1<br>F1C9 7D<br>F1CA E60F<br>F1CC CDF5F1                                        | DIS3:          | POP<br>MOV<br>ANI<br>CALL                         | H<br>A,L<br>OFH<br>TRPL2                         | REGET LINE START ADDRESS<br>SKIP OVER TO RIGHT SPACE                                                                                                                                                                    |
| F1CF 7E<br>F1DC E67F<br>F1D2 4F<br>F1D3 FE20                                                       | DIS4:          | MOV<br>ANI<br>MOV<br>CPI<br>JRC                   | A,M<br>7FH<br>Ç,A                                | GET MEMORY VALUE<br>STRIP OFF PARITY BIT<br>SET UP FOR OUTPUT<br>SEE IF PRINTABLE IN ASCII<br>JUMP IF SO                                                                                                                |
| F1D5+3804<br>F1D7 FE7E                                                                             |                | CPI<br>JRC                                        | DIS5<br>7EH<br>DIS6                              | , our IF BU                                                                                                                                                                                                             |

## FIRMWARE LISTING

| CP/M MACRO ASSE                                                              | CM 2.0           | #008                                      | DISK MO                                        | SS 2.2 MONITOR                                                                                                                          |
|------------------------------------------------------------------------------|------------------|-------------------------------------------|------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------|
| F1D9+3802<br>F1DB 0E2E<br>F1DD CD09F0<br>F1E0 CD9CF3<br>F1E3 7D<br>F1E4 E60F | DIS5:<br>DIS6:   | MVI<br>CALL<br>CALL<br>MOV<br>ANI<br>JRNZ | C,'.'<br>CONOUT<br>HILOX<br>A,L<br>OFH<br>DIS4 | ;ELSE, PRINT A DOT<br>;INCREMENT (H,L) AND SEE IF DONE<br>;NOT DONE, READY FOR NEW LINE?<br>;JUMP IF NOT                                |
| F1E6+20E7<br>F1E8+18C5                                                       |                  | JMPR                                      | DIS1                                           | ;DO THE NEXT LINE                                                                                                                       |
| F1EA 93<br>F1EB CDF0F1                                                       | DIS7:            | SUB<br>CALL<br>JMPR                       | E<br>TRPLSP<br>DIS3                            | ;SKIP OVER TO START ASCII PRINTOUT<br>;GO PRINT THE ASCII                                                                               |
| F1EE+18D8                                                                    | i                |                                           |                                                |                                                                                                                                         |
| F1F0 E60F<br>F1F2 47<br>F1F3 87<br>F1F4 80                                   | TRPLSP:          | ANI<br>MOV<br>ADD<br>ADD                  | OFH<br>B,A<br>A<br>B                           | ;ISOLATE THE LOW FOUR BITS<br>;PREPARE TO SPACE OVER TO RIGHT COLUMN<br>;TRIPLE THE COUNT                                               |
| F1F5 47<br>F1F6 04<br>F1F7 CDFEF5                                            | TRPL2:<br>TRPL1: | MOV<br>INR<br>CALL                        | B,A<br>B<br>BLK                                | PUT BACK INTO B<br>ADJUST COUNTER<br>DO THE SPACING                                                                                     |
| F1FA+10FB<br>F1FC C9                                                         |                  | DJNZ<br>RET                               | TRPL1                                          | NO, DO ANOTHER COLUMN                                                                                                                   |
| FIFC C9                                                                      | ; co TO          | ACTION                                    | DOUTTNE                                        |                                                                                                                                         |
| 8.00 p. 1920                                                                 | ; 00 10          | ACITON                                    | NOOTINE                                        |                                                                                                                                         |
| ě                                                                            | ; AS             | WELL AS                                   | ALLOWING                                       | S CONTROL TO A SPECIFIED ADDRESS.<br>TIVE SETTING OF UP TO TWO BREAKPOINTS<br>ANY CONSOLE INPUT TO BREAKPOINT<br>INTERRUPT 1 IS ACTIVE. |
| F1FD CDC0F3                                                                  | ĠOTO:            | CALL<br>JRC                               | PCHK<br>GO3                                    | ;SEE IF OLD ADDRESS WANTED<br>; YES, JUMP                                                                                               |
| F200+3837                                                                    |                  | JRZ                                       | G00                                            | ; YES, BUT SET SOME BREAKPOINTS                                                                                                         |
| F202+2810<br>F204 CDCCF0                                                     |                  | CALL                                      | EXF                                            | ; TES, BUT SET SOME BREAKPOINTS<br>;GET NEW GOTO ADDRESS                                                                                |
| F207 D1                                                                      |                  | POP                                       | D<br>H,PLOC                                    | ;PUT ADDRESS IN PC LOCATION                                                                                                             |
| F20B 39<br>F20C 72                                                           |                  | DAD<br>MOV                                | SP<br>M,D                                      | LOW BYTE                                                                                                                                |
| F20D 2B                                                                      |                  | DCX<br>MOV                                | H<br>M,E                                       | HIGH BYTE                                                                                                                               |
| F20E 73<br>F20F 79<br>F210 FE0D                                              |                  | MOV<br>CPI                                | A,C<br>CR                                      | ;SEE IF A CR WAS LAST ENTERED                                                                                                           |
| F212+2825                                                                    |                  | JRZ                                       | G03                                            | JODE IT A ON WAS DADT ENTENDD                                                                                                           |
| F214 0602<br>F216 213500<br>F219 39<br>F21A C5                               | GOO:             | MVI<br>LXI<br>DAD                         | B, NBKPT.<br>H, TLOC<br>SP                     | S<br>;POINT TO TRAP STORAGE                                                                                                             |
| F21A C5<br>F21B E5<br>F21C 0602<br>F21E CDD7F0                               | G01:             | PUSH<br>PUSH<br>MVI<br>CALL               | B<br>H<br>B,2<br>EXPR1                         | ; SAVE NUMBER OF BREAKPOINTS<br>; SAVE STORAGE POINTER<br>; SET UP TO GET A TRAP ADDRESS                                                |
| F221 D1<br>F222 E1<br>F223 7A                                                |                  | POP<br>POP<br>MOV                         | D<br>H<br>A, D                                 | GET A TRAP ADDRESS<br>GET THE TRAP ADDRESS INTO (D,E)<br>REGET THE STORAGE ADDRESS<br>INSURE THE TRAP ADDRESS ISN'T ZERO                |
| F224 B3                                                                      |                  | ORA<br>JRZ                                | E<br>GO2                                       | ;JUMP IF SO                                                                                                                             |
| F225+280A                                                                    |                  |                                           |                                                |                                                                                                                                         |
| F227.73                                                                      |                  | MOV                                       | M,E                                            | ;SAVE THE BREAKPOINT ADDRESS                                                                                                            |
| F227.73<br>F228 23<br>F229 72<br>F22A 23<br>F22B 1A                          |                  | MOV<br>INX<br>MOV<br>INX<br>LDAX          | M,E<br>H<br>M,D<br>H<br>D                      | ;SAVE THE BREAKPOINT ADDRESS<br>;SAVE THE INSTRUCTION FROM THE BP ADDRESS                                                               |

#### FIRMWARE LISTING

;

DISK MOSS 2.2 MONITOR CP/M MACRO ASSEM 2.0 #009 F22C 77 F22D 23 F22E 3ECF F230 12 F231 79 F232 FE0D F234 C1 MOV M,A INX H A,RST OR 8 ; INSERT THE BREAKPOINT MVI D STAX REGET THE DELIMITER TO SEE IF WE ARE DONE SETTING BREAKPOINTS UNLOAD THE STACK FIRST Ã,C CR G02: MOV CPI POP B YES, JUMP G03 JRZ F235+2802 ;JUMP IF NOT AT BP LIMIT DJNZ G01 F237+10E1 F239 CDA9F6 F23C E1 F23D 2143F4 CALL POP CRLF G03: GET RID OF STACK JUNK H H,RS9 LXI F240 E5 F241 21CFF3 F241 220900 F247 211800 F24A 39 F24B D1 PUSH H LXI H, REST SET BREAKPOINT JUMP VECTOR ADDRESS д,24 SP 9 H SHLD LXI DAD ADJUST THE STACK GO TO THE DESIRED PLACE F24B F24C POP D PCHL E9 GENERAL PURPOSE INPUT/OUTPUT ROUTINES THESE ROUTINES ALLOW BYTE-BY-BYTE INPUT OR OUTPUT FROM THE CURRENT CONSOLE DEVICE. THEY ARE INVOKED BY THE MONITOR "I" OR "O" COMMAND, THEN ANSWERING THE QUESTIONS WHICH APPEAR ON THE CONSOLE. GET INPUT PORT NUMBER GET PORT # INTO C REGISTER READ VALUE INTO E REGISTER F24D CDD7F0 **İNPT**: CALL EXPR1 250 C1 POP B INP E F251+ED58 GO DO A BINARY PRINT OF THE VALUE JMPR BITS2 F253+1851 GET THE ADDRESS AND DATA FOR OUPTUT DATA VALUE INTO E PORT INTO C DO THE OUTPUT CALL POP POP F255 CDD9F0 F258 D1 F259 C1 **ÓUPT**: EXPR DB E OUTP F25A+ED59 F25C C9 RET MOVE ROUTINE THIS ROUTINE EXPECTS THREE PARAMETERS, ENTERED IN THE FOLLOWING ORD SOURCE FIRST BYTE ADDRESS SOURCE LAST BYTE ADDRESS DESTINATION FIRST BYTE ADDRESS GET THREE PARAMETERS GET NEXT BYTE MOVE IT GO INCREMENT, CHECK SOURCE POINTER NOT THERE YET, GO DO IT AGAIN F25D CD86F3 MOVE: EXPR3 CALL F260 7E F261 02 MOV MOV1: A,M STAX B HILOXB CALL F262 CD9BF3 MOV 1 JMPR F265+18F9 SUBSTITUTE ACTION ROUTINE THIS ROUTINE ALLOWS THE USER TO INSPECT ANY MEMORY LOCATION AND ALTER THE CONTENTS, IF DESIRED AND IF THE ADDRESS IS IN RAM. THE CONTENTS MAY BE LEFT UNALTERED BY ENTERING A SPACE, COMMA, OR A CARRIAGE RETURN. IF A CARRIAGE RETURN IS ENTERED, THE ROUTINE IS TERMINATED. IF A SPACE OR COMMA IS ENTERED, THE ROUTINE PROCEEDS TO THE NEXT LOCATION AND PRESENTS THE USER WITH AN OPPORTUNITY TO ALTER IT.

| CP/M MACRO ASSE                                                                                                                                                                                         | M 2.0                        | #010                                                                                            | DISK MO                                                                     | SS 2.2 MONITOR                                                                                                                                                                                                                                                                                                                                                                                                                 |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------|-------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| F267 CDD7F0<br>F26A E1<br>F26B 7E<br>F26C CDF4F5<br>F26F CDC0F3<br>F272 D8                                                                                                                              | ŠUBS:<br>SUB1:               | CALL<br>POP<br>MOV<br>CALL<br>CALL<br>RC<br>JRZ                                                 | EXPR1<br>H<br>A,M<br>DASH1<br>PCHK<br>SUB2                                  | GO GET ONE PARAMETER<br>GET THE START ADDRESS<br>GET THE CONTENTS OF THE ADDRESS<br>DISPLAY IT ON CONSOLE AND A DASH<br>GET, CHECK CHARACTER<br>DONE IF CARRIAGE RETURN<br>NO CHANGE IF BLANK OR ,                                                                                                                                                                                                                             |
| F273+280F<br>F275 FEOA                                                                                                                                                                                  |                              | CPI<br>JRZ                                                                                      | LF<br>SUB3                                                                  | SEE IF PREVIOUS BYTE WANTED                                                                                                                                                                                                                                                                                                                                                                                                    |
| F277+280D<br>F279 E5<br>F27A CDCCF0<br>F27D D1<br>F27E E1<br>F27F 73<br>F280 79<br>F281 FE0D<br>F283 C8<br>F284 23<br>F285 23<br>F285 23<br>F286 28<br>F287 7D<br>F288 E607<br>F288 E607<br>F28A CCFBF5 | SUB2:<br>SUB3:               | PUSH<br>CALL<br>POP<br>MOV<br>MOV<br>CPI<br>RZ<br>INX<br>INX<br>DCX<br>MOV<br>ANI<br>CZ<br>JMPR | H<br>EXF<br>D<br>H<br>A,C<br>CR<br>H<br>H<br>H<br>A,L<br>7<br>LADRB<br>SUB1 | SAVE MEMORY POINTER<br>GO GET REST OF NEW VALUE<br>NEW VALUE TO E REGISTER<br>RESTORE MEMORY POINTER<br>PUT DOWN NEW VALUE<br>GET THE DELIMITER<br>SEE IF DONE (CARRIAGE RETURN)<br>YES, RETURN TO MONITOR<br>NO, INCREMENT MEMORY POINTER<br>ALLOW A FALL-THROUGH ON THE NEXT INSTRUCTION<br>ADJUST (H,L) AS APPROPRIATE<br>GET LO ADDRESS BYTE<br>SEE IF ON A BOUNDARY<br>CALL IF ON THE BOUNDARY<br>GO DO THE NEXT LOCATION |
| F28D+18DC                                                                                                                                                                                               | ;                            |                                                                                                 |                                                                             |                                                                                                                                                                                                                                                                                                                                                                                                                                |
|                                                                                                                                                                                                         | , SEE<br>NOT                 | IF ANY<br>AN EXHA                                                                               | HARD DAT.<br>USTIVE T                                                       | SPECIFIED BLOCK OF MEMORY TO<br>A BIT FAILURES EXIST. IT IS<br>EST, BUT JUST A QUICK INDICATION<br>RATIVENESS.                                                                                                                                                                                                                                                                                                                 |
| F28F CDA4F6<br>F292 7E<br>F293 F5<br>F294 2F<br>F295 77<br>F296 AE<br>F297 C4A1F2<br>F29A F1<br>F298 77<br>F29C CD9CF3                                                                                  | MTEST:<br>MTEST1:<br>MTEST2: | PUSH<br>CMA<br>MOV<br>XRA<br>CNZ<br>POP<br>MOV<br>CALL                                          | EXLF<br>A,M<br>PSW<br>M,A<br>BITS<br>PSW<br>M,A<br>HILOX                    | READ A BYTE<br>SAVE IT<br>COMPLEMENT IT<br>WRITE IT<br>RESULT SHOULD BE ZERO<br>LOG ERROR IF NOT<br>RESTORE ORIGINAL BYTE<br>POINT TO NEXT AND SEE IF DONE                                                                                                                                                                                                                                                                     |
| F29F+18F1                                                                                                                                                                                               | :                            | JMPR                                                                                            | MTEST1                                                                      | ;NO, CONTINUE                                                                                                                                                                                                                                                                                                                                                                                                                  |
| F2A2 5F<br>F2A3 CDFBF5<br>F2A6 0608<br>F2A8 7B<br>F2A9 07<br>F2AA 5F<br>F2AB 3E18<br>F2AD 17<br>F2AE 4F<br>F2AF CD09F0                                                                                  | BITS:<br>BITS2:<br>BITS1:    | PUSH<br>MOV<br>CALL<br>MVI<br>MOV<br>RLC<br>MOV<br>RAL<br>MOV<br>CALL<br>DJNZ                   | D<br>E,A<br>LADRB<br>B,8<br>A,E<br>E,A<br>A,'0'/2<br>C,A<br>CONOUT<br>BITS1 | SAVE (D,E)<br>SAVE ERROR PATTERN IN E<br>FIRST PRINT THE ADDRESS<br>LOOP CONTROL FOR 8 BITS<br>GET NEXT BIT<br>INTO CARRY<br>SAVE REST<br>BUILD ASCII 1 OR 0<br>CARRY DETERMINES WHICH<br>NOW, OUPTUT IT<br>DO IT AGAIN                                                                                                                                                                                                        |
| F2B2+10F4<br>F2B4 D1<br>F2B5 C9                                                                                                                                                                         |                              | POP<br>RET                                                                                      | D                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                |
|                                                                                                                                                                                                         | ; THE                        | REGISTE                                                                                         | RS STORE                                                                    | MAND INSPECTS THE VALUES OF THE<br>D BY THE LAST ENCOUNTERED BREAKPOINT.<br>DDIFIED IF DESIRED.                                                                                                                                                                                                                                                                                                                                |
| F2B6 23                                                                                                                                                                                                 | żaa:                         | INX                                                                                             | Н                                                                           | ;SKIP OVER TO NEXT ENTRY                                                                                                                                                                                                                                                                                                                                                                                                       |

CP/M MACRO ASSEM 2.0 #011 DISK MOSS 2.2 MONITOR F2B7 23 F2B8 34 F2B9 C8 INX INR H SEE IF AT END OF TABLE COULDN'T FIND MATCH, QUIT SORT OUT BIT 7 OF TABLE SET IT ON TEST VALUE XA: Μ RZ JP F2BA F2C1F2 XAB 80H F2BD F680 ORI JMPR XAC F2BF+1802 F2C1 E67F F2C3 35 F2C4 BE ;RESET BIT 7 TO BE PULLED OUT IN ROM SEE IF THIS IS IT NO, GO TRY AGAIN XAB: ANI 7FH М М XAC: DCR CMP JRNZ XAA F2C5+20EF F2C7 CDFEF5 F2CA CD15F3 F2CD CDF7F5 F2D0 CDC0F3 YES, PREPARE TO SHOW CURRENT VALUE GO PRINT THE VALUE PROMPT A NEW VALUE GET THE INPUT DONE IF CARRIAGE RETURN JUMP IF NO CHANGE DESIRED CALL BLK CALL PRTVAL DASH CALL PCHK F2D3 D8 RC JRZ XF F2D4+2812 TO BE CHANGED, SAVE POINTER GET THE NEW VALUE INTO (H,L) GET THE NEW LOW BYTE ADJUST POINTER PUT IT DOWN RECOVER THE TABLE POINTER GET THE ATTRIBUTES SET THE STACK STRAIGHT SEE IF 8 BIT REGISTER JUMP IF SO F2D4+2012 F2D6 E5 F2D7 CDCCF0 F2DA E1 F2DB 7D F2DC 13 F2DC 13 F2DD 12 F2DF F3 PUSH H CALL POP EXF H A,L D MOV F2DC F2DD F2DE F2DE F2DF INX STAX D Ë3 7E XTHL MOV A,M F2E0 E3 F2E1 07 XTHL RLC JRNC XE F2E2+3003 F2E4 13 F2E5 7C F2E6 12 INX D ; REGISTER PAIR, DO OTHER 8 BITS MOV A,H D STAX F2E7 E1 ;RESTORE THE TABLE POINTER ;SEE IF IT WAS A CR XE: POP H F2E8 79 F2E9 FEOD A,C CR MOV XF: CPI F2E9 FE0D F2EB C8 F2EC 213DF3 F2EF CDC0F3 DONE IF SO GET ADDRESS OF REGISTER LOOK-UP TABLE FIND OUT WHAT ACTION IS WANTED SHOW ALL IF CARRIAGE RETURN RZ LXI H, ACTBL PCHK XMNE: XMNE1: CALL JRC XG F2F2+380B JRZ XMNE1 ; IGNORE BLANKS OR COMMAS F2F4+28F9 CPI ;SEE IF PRIMES WANTED ;NO, MUST BE SINGLE REGISTER .... F2F6 FE27 JRNZ XA F2F8+20BE F2FA 2155F3 H, PRMTB ;YES, SET TABLE ADDRESS XMNE1 ; AND FIND OUT WHICH ONE LXI JMPR F2FD+18F0 XG: A,M C,A F2FF 7E MOV F300 4F F301 3C F302 C8 F303 FCA9F6 F306 CD09F0 MOV SEE IF AT END OF TABLE DONE IF SO START A NEW LINE IF BIT 7 IS SET INR A RZ CM CRLF CALL CONOUT PROMPT FOR A NEW VALUE F306 CD09F0 F309 CDF7F5 F30C CD15F3 F30F CDFEF5 F312 23 CALL DASH CALL PRTVAL FORMATTER POINT TO NEXT ENTRY DO THE NEXT VALUE CALL BLK INX H XG JMPR F313+18EA POINT TO NEXT ENTRY F315 23 F316 7E F317 E63F F319 C602 PRTVAL: INX H GET OFFSET AND ATTRIBUTES BYTE ISOLATE THE OFFSET Ä,M 3FH 2 MOV ANI

ADI

ALLOW FOR RETURN ADDRESS

| CP/M MACRO ASSEN                                                                                                                                                                              | M 2.0        | <i>#</i> 012                                                                    | DISK MO                                                                                                                                | SS 2.2 MONITOR                                                                                                                                            |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|---------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|
| F31B EB<br>F31C 6F<br>F31D 2600<br>F31F 39<br>F320 EB<br>F321 7E<br>F322 0601<br>F324 07                                                                                                      |              | XCHG<br>MOV<br>DAD<br>XCHG<br>MOV<br>MVI<br>RLC                                 | L,A<br>H,O<br>SP<br>A,M<br>B,1                                                                                                         | SWAP POINTERS<br>BUILD THE ADDRESS OF THE REG CONTENTS<br>RE-SWAP THE POINTERS<br>NOW FIND OUT ATTRIBUTES<br>SET UP FOR SINGLE REG VALUE                  |
| F325+300E<br>F327 04<br>F328 07                                                                                                                                                               |              | JRNC<br>INR<br>RLC                                                              | PV1<br>B                                                                                                                               | ;JUMP IF SINGLE REGISTER VALUE WANTED<br>;SET UP FOR REGISTER PAIR                                                                                        |
| F329+300A<br>F32B E5<br>F32C 1A<br>F32D 67<br>F32E 1B<br>F32F 1A<br>F330 6F<br>F331 7E<br>F332 E1                                                                                             |              | JRNC<br>PUSH<br>LDAX<br>MOV<br>DCX<br>LDAX<br>MOV<br>MOV<br>POP<br>DJNZ         | PV1<br>H<br>H,A<br>D<br>L,A<br>A,M<br>H<br>PV2                                                                                         | ;JUMP IF REGISTER PAIR IS NEXT<br>;SPECIAL CASE FOR MEMORY REGISTER<br>;BUILD ADDRESS IN (H,L)<br>;GET THE MEMORY VALUE<br>;RESTORE (H,L)<br>;ALWAYS JUMP |
| F333+1001<br>F335 1A<br>F336 CDE6F5<br>F339 1B                                                                                                                                                | PV1:<br>PV2: | LDAX<br>CALL<br>DCX<br>DJNZ                                                     | D<br>HEX1<br>D<br>PV1                                                                                                                  | GET THE REGISTER CONTENTS<br>OUTPUT THE VALUE<br>ADJUST THE MEMORY POINTER                                                                                |
| F33A+10F9<br>F33C C9                                                                                                                                                                          |              | RET                                                                             |                                                                                                                                        | 5 S. 5                                                                                                                                                    |
| F33D C115<br>F33F 4212<br>F33F 4312<br>F3341 4411<br>F345 4510<br>F345 4614<br>F347 4614<br>F347 4630<br>F349 4C361<br>F349 CDF1<br>F344F 5084<br>F344F 5084<br>F351 5397<br>F353 4903        | ÅCTBL:       | DB<br>DB<br>DB<br>DB<br>DB<br>DB<br>DB<br>DB<br>DB<br>DB<br>DB<br>DB<br>DB      | 80H+'A'<br>'B',BLO<br>'C',CLO<br>'D',DLO<br>'E',ELO<br>'F',FLO<br>'H',HLO<br>'L',LLO<br>80H+'A'<br>'P',PLO<br>'S',SLO<br>'I',ILO       | C<br>C                                                                                                                                                    |
|                                                                                                                                                                                               | REST         | OF Z-80                                                                         |                                                                                                                                        |                                                                                                                                                           |
| F355 C109<br>F357 420B<br>F359 430A<br>F35B 440D<br>F35D 450C<br>F35F 4608<br>F361 480F<br>F363 4C0E<br>F365 CDCF<br>F365 CDCF<br>F365 CDCF<br>F365 5985<br>F369 5985<br>F368 5202<br>F360 FF | ₽̀RMTB:      | DB<br>DB<br>DB<br>DB<br>DB<br>DB<br>DB<br>DB<br>DB<br>DB<br>DB<br>DB<br>DB<br>D | 80H+'A'<br>'B',BPLG<br>'C',CPLG<br>'D',DPLG<br>'E',EPLG<br>'F',FPLG<br>'F',FPLG<br>'L',LPLG<br>80H+'M'<br>'X',XLOG<br>'R',RLOG<br>OFFH |                                                                                                                                                           |
|                                                                                                                                                                                               | GENER        | AL PURPO                                                                        |                                                                                                                                        |                                                                                                                                                           |
| 4                                                                                                                                                                                             | ROUTI        | ACCUMUL                                                                         | ATOR TO I                                                                                                                              | THE LOW ORDER NIBBLE OF THE<br>ITS ASCII EQUIVELANT. IT<br>INTO C FOR LATER OUTPUT.                                                                       |
| F36E E60F                                                                                                                                                                                     | ĊONV:        | ANI                                                                             | OFH                                                                                                                                    | ;STRIP OFF BITS 4-7                                                                                                                                       |

### FIRMWARE LISTING

.

| CP/M MACRO ASSEM 2.0                                                                                                | #013                                                              | DISK MOSS 2.2 MONITOR                                                                                                                                                                                              |
|---------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| F370 C690                                                                                                           | ADI                                                               | 90H ; PUT ON THE ASCII ZONE                                                                                                                                                                                        |
| F372 27<br>F373 CE40<br>F375 27                                                                                     | DAA<br>ACI<br>DAA                                                 | 40H                                                                                                                                                                                                                |
| F372 27<br>F373 CE40<br>F375 27<br>F376 4F<br>F377 C9                                                               | MOV<br>RET                                                        | C,A ;PUT IN OUTPUT PASS REGISTER                                                                                                                                                                                   |
|                                                                                                                     | INE ECHO<br>DEVICE,<br>CONSOLE                                    | READS A BYTE FROM A HALF-DUPLEX CONSOLE<br>, THEN ECHOES THE CHARACTER BACK TO THE<br>.E.                                                                                                                          |
| F378 CDF7F5 DECHO:<br>F37B CD8FF6 ECHO:<br>F37E C5 ECH1:<br>F37F 4F<br>F380 CD09F0<br>F383 79<br>F384 C1<br>F385 C9 | CALL<br>CALL<br>PUSH<br>MOV<br>CALL<br>MOV<br>POP<br>RET          | DASH ;PRINT A DASH<br>CONI ;CONSOLE READ, WRITE ROUTINE<br>B ;SAVE (B,C)<br>C,A ;PASS CHARACTER IN C REGISTER<br>CONOUT ;OUTPUT IT<br>A,C ;PUT CHARACTER BACK INTO A<br>B ; RESTORE (B,C)                          |
| ROU                                                                                                                 | THEN LOAD                                                         | 3 GETS THREE PARAMETERS, DOES A CR, LF AND<br>DS (B,C), (D,E), AND (H,L) WITH THE PARAMETERS.                                                                                                                      |
| F386 04 ÉXPR3<br>F387 CDD9F0<br>F38A C1<br>F38B D1<br>F38C C3AAF6                                                   | INR<br>CALL<br>POP<br>POP<br>JMP                                  | B ;2 IS ALREADY IN THE B REGISTER<br>EXPR ;GET THE PARAMETERS<br>B ;PUT PARAMETERS INTO REGISTERS<br>D<br>CRLFA ;GO DO THE CARRIAGE RETURN SEQUENCE                                                                |
| •                                                                                                                   |                                                                   | O INCREMENTS (H,L). IT THEN CHECKS FOR (AND<br>OWS) A WRAP-AROUND SITUATION. IF IT OCCURS,<br>RRY BIT WILL BE SET ON RETURN. IF NO WRAP-<br>O OCCURRED, (H,L) IS COMPARED TO (D,E) AND<br>AG BITS SET ACCORDINGLY. |
| F38F 23<br>F390 7C<br>F391 B5<br>F392 37<br>F393 C8<br>F394 7B<br>F395 95<br>F396 7A<br>F397 9C<br>F398 C9          | INX<br>MOV<br>ORA<br>STC<br>RZ<br>MOV<br>SUB<br>MOV<br>SBB<br>RET | H ;INCREMENT (H,L)<br>A,H ;TEST IF ZERO<br>L IN (H,L)<br>SET CARRY FOR (H,L)=0<br>RETURN IF (H,L) = 0<br>A,E ;COMPARE (H,L) TO (D,E)<br>L<br>A,D<br>H ;RETURN WITH FLAGS SET                                       |
| ROUT                                                                                                                | CINE HILOX<br>EQUAL, P<br>HERWISE,                                | X INCREMENTS (H,L), COMPARES IT TO (D,E) AND<br>RETURNS CONTROL TO THE MONITOR EXECUTIVE.<br>CONTROL RETURNS TO THE CALLING ROUTINE.                                                                               |
| F399 D1 HILOD:<br>F39A C9<br>F39B 03 HILOXE<br>F39C CD8FF3 HILOXE                                                   | RET<br>INX                                                        | D GET RID OF RETURN ADDRESS<br>RETURN TO MONITOR<br>B INCREMENT (B,C)<br>HILO INC AND CHECK (H,L)<br>HILOD DONE IF CARRY SET                                                                                       |
| F39F+38F8<br>F3A1 CD12F0<br>F3A4 B7<br>F3A5 C8<br>F3A6 CD8FF6<br>F3A9 FE13                                          | CALL<br>ORA<br>RZ<br>CALL<br>CPI<br>JRNZ                          | CONST ;SEE IF CONSOLE BREAK PENDING<br>A ;NONE, RETURN TO CONTINUE<br>;SEE IF WAIT OR BREAK<br>CTRLS<br>HILOD ;JUMP IF BREAK                                                                                       |
| F3AB+20EC<br>F3AD C38FF6                                                                                            | JMP                                                               | CONI ;WAIT FOR ANY INPUT                                                                                                                                                                                           |
| ROUT                                                                                                                | A-F TO                                                            | BLE CONVERTS THE ASCII CHARACTERS 0-9 AND<br>THEIR EQUIVELANT HEXADECIMAL VALUE. IF<br>MARACTER IS NOT IN RANGE, THE CARRY BIT IS SET TO                                                                           |

.

| CP/M MACRO ASS                                                                                                                                                   | EM 2.0           | #014                                                                        | DISK MOSS 2.                                                                      | .2 MONITOR                                                                                                                                                                                                                        |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|-----------------------------------------------------------------------------|-----------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                                                                                                                                  | į                | FLAG TI                                                                     | E ERROR.                                                                          |                                                                                                                                                                                                                                   |
| F3B0 D630<br>F3B2 D8<br>F3B3 FE17<br>F3B5 3F<br>F3B6 D8<br>F3B7 FE0A<br>F3B9 3F<br>F3BA D0<br>F3BB D607<br>F3BD FE0A<br>F3BF C9                                  | NIBBLE           | SUI<br>RC<br>CPI<br>RC<br>CPI<br>CMC<br>CPI<br>RNC<br>SUI<br>CPI<br>RET     | 'G'-'O' CHI<br>'9'-'0'+                                                           | CII TO HEX CONVERSION<br>DONE IF OUT OF RANGE<br>ECK UPPER END<br>TOGGLE THE CARRY BIT<br>DONE IF OUT OF RANGE<br>;SEE IF NUMERIC<br>TOGGLE THE CARRY BIT<br>DONE IF SO<br>;SUBTRACT THE ALPHA BIAS<br>SET CARRY FOR INVALID CHAR |
| 2                                                                                                                                                                | ROUT             | CHECKS                                                                      | IT FOR A DELI<br>ITER, A NON-2<br>S A DELIMITER<br>, IF THE DELI<br>RY BIT IS SET | ACTER FROM THE CONSOLE, THEN<br>IMITER. IF IT IS NOT<br>ZERO CONDITION IS RETURNED.<br>R, A ZERO CONDITION IS RETURNED.<br>IMITER IS A CARRIAGE RETURN,<br>C. A BLANK OR A COMMA RESET THE                                        |
| F3C0 CD7BF3<br>F3C3 FE20<br>F3C5 C8<br>F3C6 FE2C<br>F3C8 C8<br>F3C9 FE0D<br>F3CB 37<br>F3CC C8<br>F3CD 3F<br>F3CE C9                                             | РСНК:<br>Р2С:    | CALL<br>CPI<br>RZ<br>CPI<br>RZ<br>CPI<br>STC<br>RZ<br>CMC<br>RET            | CR ST                                                                             | F, TEST FOR DELIMITER<br>BLANK?<br>KES, DONE<br>NO, COMMA?<br>KES, DONE<br>NO, CARRIAGE RETURN?<br>SHOW IT IN CARRY BIT<br>DONE IF CR<br>EAR CARRY FOR NO DELIMITER                                                               |
|                                                                                                                                                                  | ROUTI            | RESTART                                                                     | 1 INSTRUCTIC<br>RED IN THE SY                                                     | THE REGISTER CONTENTS WHENEVER A<br>ON IS EXECUTED. THE TRAPPED CONTENTS<br>STEM STACK AREA FOR LATER ACCESS AND<br>THE EXAMINE REGISTERS COMMANDS.                                                                               |
| F3CF E5<br>F3D0 D5<br>F3D1 C5<br>F3D2 F5                                                                                                                         | ; INSEF<br>REST: | T INTERF<br>PUSH<br>PUSH<br>PUSH<br>PUSH<br>PUSH                            | JPT DISABLER<br>H ;SAV<br>D<br>B<br>PSW                                           | SOFTWARE AT START OF REST:<br>'E ALL THE REGISTERS                                                                                                                                                                                |
| F3D2 F5<br>F3D3 CD6FF0<br>F3D6 EB                                                                                                                                |                  | CALL<br>XCHG                                                                | MEMSIZ ;GET                                                                       | THE MONITOR'S STACK LOCATION                                                                                                                                                                                                      |
| F3D7 210A00<br>F3DA 39<br>F3DB 0604<br>F3DD EB                                                                                                                   |                  | LXI<br>DAD<br>MVI<br>XCHG                                                   | SP ; T<br>B,4 ;PIC                                                                | UP 10 BYTES IN THE STACK<br>O SKIP OVER TEMP REGISTER SAVE<br>K OFF THE REGISTER VALUES                                                                                                                                           |
| F3DF 72<br>F3E0 2B<br>F3E1 73<br>F3E2 D1                                                                                                                         | RS1:             | DCX<br>MOV<br>DCX<br>MOV<br>POP<br>DJNZ                                     | H<br>M,D ;SAV<br>H<br>M,E<br>D<br>RS1                                             | E IN WORK AREA                                                                                                                                                                                                                    |
| F3E3+10F9<br>F3E5 C1<br>F3E6 OB<br>F3E7 F9<br>F3E8 212500<br>F3E8 39<br>F3EC D5<br>F3ED 1602<br>F3ED 1602<br>F3EF 7E<br>F3F7 7E<br>F3F0 91<br>F3F1 23<br>F3F2 7E | RS2:             | POP<br>DCX<br>SPHL<br>LXI<br>DAD<br>PUSH<br>MVI<br>MOV<br>SUB<br>INX<br>MOV | B ;GET<br>B ;SET<br>H,TLOCX ;SET<br>SP<br>D,NBKPTS ;LO<br>A,M                     | THE BREAKPOINT LOCATION<br>THE MONITOR STACK<br>UP TO RESTORE BREAKPOINTS<br>OP CONTROL FOR N BREAKPOINTS<br>IF A SOFTWARE TRAP                                                                                                   |

E-16

| CP/M MACRO ASSE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | M 2.0        | #015                                                                                                                                       | DISK MO                                                                                                            | SS 2.2 MONITOR                                                                                   |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------|
| F3F3 98                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |              | SBB<br>JRZ                                                                                                                                 | B<br>RS5                                                                                                           | MAYBE, TRY REST OF ADDRESS<br>FOUND ONE, JUMP TO RESET IT                                        |
| F3F4+2806<br>F3F6 23<br>F3F7 23<br>F3F8 15                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | RS3:         | INX<br>INX<br>DCR<br>JRNZ                                                                                                                  | H<br>H<br>D<br>RS2                                                                                                 | ;NOT FOUND, TRY NEXT ONE                                                                         |
| F3F9+20F4<br>F3FB 03<br>F3FC 212000<br>F3FF D1<br>F400 39<br>F401 73<br>F402 23<br>F403 72<br>F403 72<br>F404 C5<br>F405 0E2A<br>F405 0E2A<br>F407 CD09F0<br>F40A D1<br>F40B 3EF4<br>F40D BA                                                                                                                                                                                                                                                                                                                                | RS4:<br>RS5: | INX<br>LXI<br>POP<br>DAD<br>MOV<br>INX<br>MOV<br>PUSH<br>MVI<br>CALL<br>POP<br>MVI<br>CMP                                                  | B<br>H,LLOCX<br>D<br>SP<br>M,E<br>H<br>M,D<br>B<br>C,'&'<br>CONOUT<br>D<br>A,RS9/2<br>D                            | ;STORE USER (H,L)<br>;SAVE (B,C)<br>;TYPE THE BREAK INDICATION<br>:REGET THE BREAKPOINT LOCATION |
| F40E+2809<br>F410 23<br>F411 23<br>F412 73<br>F413 23<br>F415 CDE1F5<br>F415 CDE1F5<br>F415 CDE1F5<br>F419 212500<br>F410 010002<br>F410 010002<br>F420 5E<br>F420 5E<br>F422 23<br>F422 23<br>F422 71<br>F422 73<br>F422 73<br>F422 75<br>F422 75<br>F5<br>F5<br>F5<br>F5<br>F5<br>F5<br>F5<br>F5<br>F5<br>F5<br>F5<br>F5<br>F5 | RS6:<br>RS7: | JRZ<br>INX<br>MOV<br>INX<br>MOV<br>XCHG<br>CALL<br>LXI<br>DAD<br>LXI<br>MOV<br>INX<br>MOV<br>INX<br>MOV<br>INX<br>MOV<br>INX<br>MOV<br>JRZ | RS6<br>H<br>H,E<br>H,D<br>LADR<br>H,TLOCX<br>SP<br>B,NBKPT<br>E,M<br>M,C<br>H<br>D,M<br>M,C<br>H,C<br>H,E<br>D,RS8 | ;RESTORE USER PROGRAM COUNTER<br>;PRINT THE BREAKPOINT LOCATION                                  |
| F428+2802<br>F42A 7E<br>F42B 12<br>F42C 23                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | RS8:         | MOV<br>STAX<br>INX<br>DJNZ                                                                                                                 | A,M<br>D<br>H<br>RS7                                                                                               | ; SAME THING FOR OTHER<br>; BREAKPOINT                                                           |
| F42D+10F1<br>F42F+08                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |              | EXAF                                                                                                                                       |                                                                                                                    | ;NOW SAVE THE Z-80 UNIQUES                                                                       |
| F42F+08<br>F430+D9<br>F431 E5<br>F432 D5<br>F433 C5<br>F434 F5                                                                                                                                                                                                                                                                                                                                                                                                                                                              | E5           | EXX<br>PUSH<br>PUSH<br>PUSH                                                                                                                | PUSH<br>D<br>B<br>PSW                                                                                              | Н                                                                                                |
| F435+DDE5                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | ·*           | PUSHIX<br>PUSHIY                                                                                                                           |                                                                                                                    |                                                                                                  |
| F437+FDE5                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |              | LDAI                                                                                                                                       |                                                                                                                    |                                                                                                  |
| F439+ED57<br>F43B 47                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |              | MOV                                                                                                                                        | B,A                                                                                                                |                                                                                                  |
| F43C+ED5F<br>F43E 4F<br>F43F C5<br>F440 C313F1                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |              | MOV<br>PUSH<br>JMP                                                                                                                         | C,A<br>B<br>WINITA                                                                                                 | ;RETURN TO MONITOR                                                                               |

| CP/M MACRO ASSEM                                                                                                                                                                  | 2.0                                   | <b>#</b> 016                                                   | DISK MO                                                    | SS 2.2 MONITOR                                                                                                                                                                                                                                                               |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------|----------------------------------------------------------------|------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| F443 E5<br>F444 CF                                                                                                                                                                | RS9:                                  | PUSH<br>RST                                                    | H<br>1                                                     | RET BREAKPOINT ENCOUNTERED, ADJUST THE STACK<br>DO THE BREAKPOINT                                                                                                                                                                                                            |
| F446 79                                                                                                                                                                           | ĖXIT:                                 | POP<br>MOV<br>STAR                                             | B<br>A,C                                                   |                                                                                                                                                                                                                                                                              |
| F447+ED4F<br>F449 78<br>F44A+ED47                                                                                                                                                 |                                       | MOV<br>STAI                                                    | А,В                                                        |                                                                                                                                                                                                                                                                              |
| F44C+DDE1                                                                                                                                                                         |                                       | POPIX                                                          |                                                            |                                                                                                                                                                                                                                                                              |
| F44E+FDE1                                                                                                                                                                         |                                       | POPIY                                                          |                                                            |                                                                                                                                                                                                                                                                              |
| F450 F1<br>F451 C1<br>F452 D1<br>F453 E1                                                                                                                                          |                                       | POP<br>POP<br>POP<br>POP<br>EXAF                               | PSW<br>B<br>D<br>H                                         |                                                                                                                                                                                                                                                                              |
| F454+08                                                                                                                                                                           |                                       | EXX                                                            | 28                                                         |                                                                                                                                                                                                                                                                              |
| F455+D9<br>F456 D1<br>F457 C1<br>F458 F1<br>F459 E1<br>F45A F9<br>F45B 00                                                                                                         | i                                     | POP<br>POP<br>POP<br>SPHL                                      | D<br>B<br>PSW<br>H                                         |                                                                                                                                                                                                                                                                              |
| F45C 210000<br>F45F C30000                                                                                                                                                        | ENDX:                                 | DB<br>LXI<br>JMP<br>EQU                                        | 0<br>H,0<br>\$                                             | ;PLACE FOR EI                                                                                                                                                                                                                                                                |
|                                                                                                                                                                                   | ERROR                                 | HANDLER                                                        | S                                                          |                                                                                                                                                                                                                                                                              |
|                                                                                                                                                                                   | · · · · · · · · · · · · · · · · · · · | ERROR;<br>ERRORS<br>THE ERRO<br>A UNIQUI<br>INITIAL            | AN I/O A<br>(DETERMI<br>)R CONDI<br>E MESSAGI<br>IZATION ( | ERRORS ARE DETECTED: A RESTART<br>SSIGNMENT ERROR; AND CERTAIN PROGRAM<br>NED BY THE PARTICULAR ROUTINE WHERE<br>TION WAS ENCOUNTERED.) EACH CAUSES<br>E TO BE PRINTED, THEN DOES A WARM<br>OF THE MONITOR. THE I/O ERROR<br>ASSIGNMENTS TO BE RESET TO DEFAULT ASSIGNMENTS. |
| F463 320300<br>F466 216CF4<br>F469 C3B5F6                                                                                                                                         | İOER:                                 | XRA<br>STA<br>LXI<br>JMP                                       | A<br>IOBYTE<br>H,IOMSG<br>COMERR                           | ;SET IOBYTE TO DEFAULT VALUE<br>;GET ADDRESS OF I/O ERROR MSG<br>;GO PROCESS IT                                                                                                                                                                                              |
| P<br>F46C 492F4F2045<br>F473 44534B2045<br>F47E 2054AD<br>F481 2053AD<br>F484 2043AD<br>F487 2045AD<br>F487 2045AD<br>F48A 0D8A<br>F48C 3F3F3FBF<br>F490 4D4F5353201<br>F49D 0D8A | QMDG:                                 | DB<br>DB<br>DB<br>DB<br>DB<br>DB<br>DB<br>DB<br>DB<br>DB<br>DB | CR, LF+80                                                  | '+80H<br>'+80H<br>OH<br>?'+80H<br>ERS 2.2'                                                                                                                                                                                                                                   |
|                                                                                                                                                                                   | ELEI<br>8250                          | MENT. TI<br>D, AS WEI                                          | L AS TH                                                    | OR THE 8250 ASYNCHRONOUS COMMUNICATION<br>WILL INITIALIZE THE BAUD RATE OF THE<br>E WORD FORMAT. 8 DATA BITS, 1 STOP BIT,<br>ELECTED. EITHER 2 OR 3 CARRIAGE RETURNS<br>ESTABLISH THE CORRECT BAUD RATE.                                                                     |
| F49F 3E0F<br>F4A1 D324<br>F4A3 114000                                                                                                                                             | ±8250:                                | MVI<br>OUT<br>LXI                                              | A,OFH<br>SMDMCT<br>D,40H                                   | ;SET UP THE 8250<br>;SET UP TO TIME THE START BIT                                                                                                                                                                                                                            |

3E01)

AF 324B00 218000. 224900 CDA4F6

| CP/M MACRO ASSEN                                                                                                                                                                                                                                                                                                                                                                                           | 1 2.0   | #017                                                                                                                                                    | DISK MOS                                                                                                                                                                                         | SS 2.2 MONITOR                                                                                                                                                                                                                                                                                                                                                                                |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| F4A6 62<br>F4A7 6A<br>F4A8 DB26<br>F4AA A3                                                                                                                                                                                                                                                                                                                                                                 | 18250A: | ANA                                                                                                                                                     | H,D<br>L,D<br>SMDMST<br>E                                                                                                                                                                        | ;MAKE (H,L)=0<br>;WAIT FOR START BIT                                                                                                                                                                                                                                                                                                                                                          |
| F4AB+28FB<br>F4AD DB26<br>F4AF 23<br>F4B0 A3<br>F4B1 A3<br>F4B2 C2ADF4<br>F4B5 E5<br>F4B6 29<br>F4B6 29<br>F4B7 50<br>F4B8 19<br>F4B8 19<br>F4B8 29                                                                                                                                                                                                                                                        |         | JRZ<br>IN<br>INX<br>ANA<br>ANA<br>JNZ<br>PUSH<br>DAD<br>MOV<br>DAD<br>DAD<br>PUSH<br>DAD                                                                | I8250A<br>SMDMST<br>H<br>E<br>E<br>I8250B<br>H<br>H<br>E,H<br>D<br>D<br>H<br>H                                                                                                                   | ;NOW, TIME THE START BIT DURATION<br>;SAVE COUNT IN CASE OF 4 MHZ<br>;PREPARE THE 2 MHZ DIVISOR<br>;SET UP THE FUDGE FACTOR<br>;APPLY THE FUDGE FACTOR<br>;SAVE FOR LATER USE<br>;WAIT FOR 8 BIT TIMES                                                                                                                                                                                        |
| F4BC 29<br>F4BD DB20<br>F4BF 2B<br>F4CO 7D                                                                                                                                                                                                                                                                                                                                                                 | 18250C: | DAD<br>IN<br>DCX<br>MOV                                                                                                                                 | H<br>SDATA<br>H<br>A,L                                                                                                                                                                           | ;WASTE SOME TIME                                                                                                                                                                                                                                                                                                                                                                              |
| F4C1 B4<br>F4C2 C2BDF4<br>F4C5 E1<br>F4C6 3E83<br>F4C8 D323<br>F4C8 D321<br>F4CB D321<br>F4CB D321<br>F4CD 7D<br>F4CE D320<br>F4D0 3E03<br>F4D2 D323<br>F4D2 D323<br>F4D4 AF<br>F4D5 D321<br>F4D7 D325<br>F4D7 D325<br>F4D7 D325<br>F4D7 D325<br>F4D7 D325<br>F4D7 CDEEF6<br>F4D7 CDEEF6<br>F4D2 E67F<br>F4D2 E67F<br>F4E2 5D<br>F4E3 54<br>F4E4 CDEEEF4<br>F4E7 CDEEF4<br>F4EA 19<br>F4EB E5<br>F4EC+18D8 |         | ORA<br>JNZ<br>POP<br>MVI<br>OUT<br>MOV<br>OUT<br>MVI<br>OUT<br>XRA<br>OUT<br>CALL<br>ANI<br>CALL<br>CALL<br>CALL<br>CALL<br>CALL<br>DAD<br>PUSH<br>JMPR | H<br>18250C<br>H<br>A,83H<br>SLCTRL<br>A,H<br>SINTEN<br>A,L<br>SDATA<br>A,3<br>SLCTRL<br>A<br>SINTEN<br>SLSTAT<br>TTYIN<br>7FH<br>ODH<br>H<br>E,L<br>DIV2<br>DIV2<br>DIV2<br>DIV2<br>H<br>18250D | ;REGET 2 MHZ DIVISOR<br>;SET DIVISOR REGISTER ACCESS<br>;SET THE DIVISOR<br>;SET DATA REGISTER ACCESS<br>;DISABLE INTERRUPTS<br>;AND RESET ERROR FLAGS<br>;GET A CHARACTER<br>;STRIP OFF ANY PARITY BIT<br>;SEE IF IT IS A CARRIAGE RETURN<br>;SET THE STACK STRAIGHT<br>;DONE IF CARRIAGE RETURN RECEIVED<br>;ELSE, MUST BE 4 MHZ SYSTEM<br>; SO, COUNT=COUNT*5/4<br>;GO SET THE NEW DIVISOR |
| F4EE B7<br>F4EF 7C<br>F4F0 1F<br>F4F1 67<br>F4F2 7D<br>F4F3 1F<br>F4F4 6F<br>F4F5 C9                                                                                                                                                                                                                                                                                                                       | JIV2:   | ORA<br>MOV<br>RAR<br>MOV<br>RAR<br>MOV<br>RET                                                                                                           | A<br>A,H<br>H,A<br>A,L<br>L,A                                                                                                                                                                    | ;CLEAR THE CARRY BIT<br>;DO A 16-BIT RIGHT SHIFT                                                                                                                                                                                                                                                                                                                                              |

MVI ORG XRA STA LXI SHLD CALL

READ:

WRITE:

A,1 \$-1 RWFLG H,80H LUNIT EXLF SET THE READ/WRITE FLAG SAVE A BYTE HERE RESET THE READ/WRITE FLAG SAVE THE FLAG

;FORCE A READ ADDRESS COMMAND ;GET THE START, STOP ADDRESS

FIRMWARE LISTING

| CP/M MACRO ASSE                                                                                                                 | EM 2.0       | #0 <b>1</b> 8                           | DISK MO                            | SS 2.2 MONITOR                                                                                                                |
|---------------------------------------------------------------------------------------------------------------------------------|--------------|-----------------------------------------|------------------------------------|-------------------------------------------------------------------------------------------------------------------------------|
| F504 D5<br>F505 3A4B00<br>F508 B7                                                                                               | RW1:         | PUSH<br>LDA<br>ORA<br>JRNZ              | D<br>RWFLG<br>A<br>RW2             | ;SAVE THE LIMIT<br>SEE IF READ OR WRITE<br>JUMP IF READ                                                                       |
| F509+2008<br>F50B 224C00<br>F50E CDEBF6                                                                                         |              | SHLD<br>CALL<br>JMPR                    | HSTBUF<br>DWRITE<br>RW3            | SET THE WRITE SOURCE BUF<br>ELSE, DO THE WRITE                                                                                |
| F511+1803<br>F513 CDE7F6<br>F516 D1                                                                                             | RW2:<br>RW3: | CALL<br>POP<br>JRNZ                     | DREADH<br>D<br>DERROR              | ;DO THE READ<br>;JUMP IF ERROR                                                                                                |
| F517+2067<br>F519 3A4400<br>F51C 47<br>F51D DB31<br>F51F B7                                                                     |              | LDA<br>MOV<br>IN<br>ORA                 | SPT<br>B,A<br>DTRCK<br>A           | GET THE SECTORS PER TRACK<br>SAVE IT<br>SEE IF ON TRACK OO                                                                    |
| F520+200B<br>F522 061A<br>F524 3A4A00<br>F527 E610                                                                              |              | JRNZ<br>MVI<br>LDA<br>ANI<br>JRNZ       | RW4<br>B,26<br>CUNIT<br>10H<br>RW4 | ;JUMP IF NOT<br>;ELSE, SET THE SECTORS PER TRK OO                                                                             |
| F529+2002<br>F52B 0612<br>F52D E5<br>F52E 214200<br>F531 7E<br>F532 B8                                                          | RW4:         | MVI<br>PUSH<br>LXI<br>MOV<br>CMP<br>JRC | B.18                               | MINI DRIVES<br>SAVE THE DMA ADDRESS<br>SET UP MEMORY POINTER<br>GET NUMBER OF SECTORS<br>SEE IF TRACK OVERFLOW<br>JUMP IF NOT |
| F533+381B<br>F535 3A4500<br>F538 B7                                                                                             |              | LDA<br>ORA<br>JRZ                       | TWOSID<br>A<br>RW7                 | ;SEE IF DOUBLE-SIDED<br>;JUMP IF NOT                                                                                          |
| F539+280B<br>F53B 3A4300<br>F53E FEDO -                                                                                         |              | LDA<br>CPI<br>JRNZ                      | SIDE<br>ODOH<br>RW7                | ;YES, SEE IF NEXT SIDE OR TRACK NEEDED<br>;NEXT TRACK, JUMP                                                                   |
| F540+2004<br>F542 3E90                                                                                                          |              | MVI<br>JMPR                             | A,90H<br>RW8                       | ;ELSE, SET NEXT SIDE                                                                                                          |
| F544+1805<br>F546 3ED0<br>F548 2B<br>F549 34<br>F54A 23<br>F54B 324300<br>F54B 3600<br>F550 34<br>F550 34<br>F551 E1<br>F552 2B | RW7:         | MVI<br>DCX<br>INR<br>INX                | A,ODOH<br>H<br>M<br>H              | ;ELSE, UPDATE THE TRACK                                                                                                       |
| F54B 324300<br>F54E 3600<br>F550 34<br>F551 E1                                                                                  | RW8:<br>RW5: | STA<br>MVI<br>INR<br>POP                | SIDE<br>M,0<br>M<br>H              | ; AND THE SECTOR POINTER<br>;RESTORE THE DMA ADDRESS                                                                          |
| F550 34<br>F551 E1<br>F552 2B<br>F553 CD9CF3<br>F556 D5                                                                         |              | DCX<br>CALL<br>PUSH                     | H<br>HILOX<br>D<br>RW1             | SEE IF DONE<br>CONTINUE IF CONTROL RETURNED                                                                                   |
| F557+18AC                                                                                                                       |              | JMPR                                    | <b>Μ</b> Ψ                         |                                                                                                                               |
|                                                                                                                                 | ROUTI        | CONTROL                                 | INITIALIZ                          | THE 2422'S AUTO-BOOT CONTROL BIT<br>ZATION. IT THEN TRANSFERS<br>SR THE MONITOR OR THE BOOTSTRAP,                             |
| F559 DB34<br>F55B E640<br>F55D C0                                                                                               | DINIT:       | IN<br>ANI<br>RNZ                        | DCNTL<br>40H                       | ;SEE IF AUTO-BOOT WANTED<br>;NO, RETURN TO MONITOR INITIALIZATION                                                             |
| н                                                                                                                               | ROUTI        | DRIVE O                                 | O INTO LO                          | THE FIRST TWO SECTORS OF<br>OCATIONS 80H-17FH, THEN<br>AM CONTROL TO LOCATION 80H.                                            |

)

| CP/M MACRO ASSEM                                                                                                                                                  | 2.0     | #019                                                                                          | DISK MOSS 2.2 MONITOR                                                                                                                                                                                                                                                                                                                          |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|-----------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                                                                                                                                   | ;       | IT EXPE<br>TWO SEC                                                                            | CTS THE DOS LOADER TO BE ON THESE<br>TORS.                                                                                                                                                                                                                                                                                                     |
| F55E 210000<br>F561 224000<br>F564 2101D0<br>F567 224200<br>F56A 218000<br>F56D 224900<br>F570 CDE7F6                                                             |         | LXI<br>SHLD<br>LXI<br>SHLD<br>LXI<br>SHLD<br>CALL<br>JRNZ                                     | H.O ;SET UP THE DISK PARMS<br>DISKNO<br>H.ODOO1H ;SIDE O, SECTOR 1<br>SECTOR<br>H.TBUF<br>LUNIT ;FORCE A DISK DETERMINATION<br>DREADH ;GO GET A SECTOR<br>DERROR ;QUIT IF AN ERROR ENCOUNTERED                                                                                                                                                 |
| F573+200B<br>F575 3E02<br>F577 324200<br>F57A CDE7F6<br>F57D CA8000                                                                                               |         | MVI<br>STA<br>CALL<br>JZ                                                                      | A,2 ;GET SECTOR 2, ALSO<br>SECTOR<br>DREADH<br>TBUF ;GO TO THE LOADER                                                                                                                                                                                                                                                                          |
| F583 CD95F6<br>F586 3A4000<br>F589 CDA1F5<br>F58C 3A4100<br>F58F CDA1F5<br>F592 3A4200<br>F595 CDA1F5<br>F598 3A4800<br>F598 CDA1F5<br>F598 CDA1F5<br>F598 3A4700 | DERROR: | LXI<br>CALL<br>LDA<br>CALL<br>LDA<br>CALL<br>LDA<br>CALL<br>LDA<br>CALL<br>LDA<br>CALL<br>JMP | H, DERMSG ; ADDRESS OF DISK ERROR MESSAGE<br>PRTWD ; START THE MESSAGE<br>DISKNO ; DO THE UNIT ASSIGNMENT<br>DERR1<br>TRACK ; AND THE TRACK<br>DERR1<br>SECTOR ; AND THE SECTOR<br>DERR1<br>CMND ; AND THE COMMAND<br>DERR1<br>STATUS ; AND THE STATUS<br>HEX1 ; OUTPUT IT IN HEX<br>PRTWA ; CONTINUE THE MESSAGE                              |
|                                                                                                                                                                   | SET D   | ISK PARA<br>TO BE E<br>ARE: U<br>AND DOU<br>ONLY TH<br>THIS RO                                | METERS ROUTINE EXPECTS THREE PARAMETERS<br>NTERED FROM THE CONSOLE. THESE PARAMETERS<br>NIT NUMBER (0-3); SECTORS PER TRACK;<br>BLE-SIDED SWITCH (0 OR NON-0).<br>E UNIT NUMBER IS CHECKED FOR ERRORS.<br>UTINE MUST BE CALLED BEFORE USE OF EITHER<br>K READ OR WRITE ROUTINE.                                                                |
| F5A7 CD86F3<br>F5AA 7D<br>F5AB B7<br>F5AC FA09F1<br>F5AF FE04<br>F5B1 D209F1<br>F5B4 324000<br>F5B7 6B<br>F5B8 61<br>F5B9 224400<br>F5BC C9                       | PARM:   | CALL<br>MOV<br>ORA<br>JM<br>CPI<br>JNC<br>STA<br>MOV<br>SHLD<br>RET                           | EXPR3 ;GET THE THREE PARAMETERS<br>A,L ;ERROR CHECK THE UNIT ASSIGNMENT<br>A<br>QPRT<br>UISKNO ;SET THE UNIT SELECT<br>L,E ;MOVE THE SECTORS PER TRACK OVER<br>H,C ; AND THE TWO-SIDED SWITCH<br>SPT ;STORE THEM                                                                                                                               |
|                                                                                                                                                                   | ROUTI   | CASE, T<br>SET. T<br>FIRST D<br>IS DESI<br>DISK AC                                            | ALSO SETS CERTAIN DISK PARAMETERS. IN THIS<br>THE DESIRED START TRACK, SIDE, AND SECTOR ARE<br>THESE PARAMETERS NEED ONLY BE SET PRIOR TO THE<br>DISK ACCESS, OR WHEN A NON-CONTIGUOUS DISK ACCESS<br>TRED. IF THE PARAMETERS ARE NOT RESET BETWEEN<br>CCESSES, THE DATA TRANSFER WILL OCCUR TO/FROM<br>T LOGICALLY SEQUENTIAL DISK LOCATIONS. |
| F5BD CD86F3<br>F5C0 61<br>F5C1 224100<br>F5C4 7B<br>F5C5 B7<br>F5C6 3ED0<br>F5C8+2802                                                                             | ģρarm:  | CALL<br>MOV<br>SHLD<br>MOV<br>ORA<br>MVI<br>JRZ                                               | EXPR3 ;GET THE THREE PARAMETERS<br>H,C ;MOVE OVER THE START SECTOR<br>TRACK ;STORE THE TRACK AND SECTOR<br>A,E ;GET THE SIDE INDICATOR<br>A ;SEE IF SINGLE-SIDED<br>A,ODOH ;SIDE O SELECT BITS<br>QPARM1 ;JUMP IF SO                                                                                                                           |

| CP/M MACRO ASSE                                                                    | M 2.0                | #020                                              | DISK MO                                           | SS 2.2 MONITOR                                                                                                                                 |
|------------------------------------------------------------------------------------|----------------------|---------------------------------------------------|---------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------|
| F5CA 3E90<br>F5CC 324300<br>F5CF C9                                                | QPARM1:              | MVI<br>STA<br>RET                                 | A,90H<br>SIDE                                     | ELSE, SET THE SIDE 1 CONTROL BIT                                                                                                               |
|                                                                                    | HEXN                 | ROUTINE                                           |                                                   |                                                                                                                                                |
|                                                                                    | THIS R               | OUTINE A<br>UNSIGNE<br>CONSOLE                    | D NUMBER                                          | SUBTRACTS TWO HEXADECIMAL 16 BIT<br>S AND DISPLAYS THE RESULTS ON THE                                                                          |
| F5D0 CDA4F6<br>F5D3 E5<br>F5D4 19<br>F5D5 CDFBF5<br>F5D8 E1<br>F5D9 B7             | ΉEXN:                | CALL<br>PUSH<br>DAD<br>CALL<br>POP<br>ORA<br>DSBC | EXLF<br>H<br>D<br>LADRB<br>H<br>A<br>D            | GET THE TWO NUMBERS<br>SAVE IT FOR THE SUBTRACT<br>ADD THEM<br>OUTPUT THEM<br>REGET THE FIRST NUMBER<br>CLEAR THE CARRY BIT<br>DO THE SUBTRACT |
| F5DA+ED52                                                                          |                      | JMPR                                              | LADR                                              | GO OUTPUT THE RESULT                                                                                                                           |
| F5DC+1803                                                                          |                      |                                                   |                                                   |                                                                                                                                                |
|                                                                                    | ROUTI                | CURRENT                                           | P = LADR                                          | HE CONTENTS OF (H,L) ON THE<br>, EITHER AT THE START OF A NEW<br>A) OR AT THE CURRENT LOCATION (EP                                             |
| F5DE CDA9F6<br>F5E1 7C<br>F5E2 CDE6F5<br>F5E5 7D<br>F5E6 F5                        | LADRA:<br>LADR:      | CALL<br>MOV<br>CALL<br>MOV                        | CRLF<br>A,H<br>HEX1<br>A,L                        | START A NEW LINE<br>GET HIGH TWO DIGITS<br>PRINT THEM<br>GET LOW TWO DIGITS                                                                    |
| F5E6 F5<br>F5E7 OF<br>F5E8 OF<br>F5E9 OF<br>F5EA OF                                | HEX1:                | PUSH<br>RRC<br>RRC<br>RRC<br>RRC<br>RRC           | PŚW                                               | SAVE THE LOW DIGIT<br>PUT HIGH NIBBLE INTO BITS 0-3                                                                                            |
| F5EB CDEFF5<br>F5EE F1<br>F5EF CD6EF3<br>F5F2+180C                                 | HEX2:                | CALL<br>POP<br>CALL<br>JMPR                       | HEX2<br>PSW<br>CONV<br>CO                         | GO PRINT SINGLE DIGIT<br>REGET THE LOW DIGIT<br>GO INSERT ASCII ZONE<br>DO THE CHARACTER OUTPUT                                                |
|                                                                                    | ; ROUTI              | NE DASH                                           | TYPES A                                           | DASH ON THE CURRENT CONSOLE DEVICE.                                                                                                            |
| F5F4 CDE6F5<br>F5F7 0E2D                                                           | ;<br>DASH1:<br>DASH: | CALL<br>MVI<br>JMPR                               | HEX1<br>C,'-'                                     | ;FIRST, PRINT ACCUM AS TWO HEX DIGITS<br>;GET AN ASCII DASH<br>;GO TYPE IT                                                                     |
| F5F9+1805                                                                          |                      |                                                   |                                                   | ,                                                                                                                                              |
|                                                                                    | IOBYT                | E HANDLE                                          |                                                   |                                                                                                                                                |
| F5FB<br>F5FB CDDEF5                                                                | LADRB:               | ORG<br>CALL                                       | MOSS+5FI<br>LADRA                                 | BH<br>;OUTPUT (H,L) AS 4 ASCII DIGITS                                                                                                          |
| F5FE 0E20                                                                          | BLK:                 | MVI                                               | с, ч                                              | ;OUPTUT A BLANK                                                                                                                                |
| F600 3A0300<br>F603 E603<br>F605 CADEF6<br>F608 FE02                               | ċο:                  | LDA<br>ANI<br>JZ<br>CPI                           | IOBYTE<br>3<br>TTYOUT<br>2                        | ;ISOLATE CONSOLE ASGT<br>;TTY DEVICE ACTIVE                                                                                                    |
| F60A FA62F4<br>F60D C262F4                                                         |                      | JM<br>JNZ                                         | CRTOUT<br>CUSO1                                   | CRT ACTIVE<br>USER CONSOLE 1 ACTIVE                                                                                                            |
| F610 3A0300<br>F613 E6C0<br>F615 CADEF6<br>F618 FE80<br>F61A FA62F4<br>F61D CA62F4 | ἰo:                  | LDA<br>ANI<br>JZ<br>CPI<br>JM<br>JZ               | IOBYTE<br>OCOH<br>TTYOUT<br>80H<br>CRTOUT<br>LPRT | ;ISOLATE LIST ASGT<br>;TTY DEVICE ACTIVE<br>;CRT ACTIVE<br>;LINE PRINTER ACTIVE                                                                |

)

)

| F620C362F4JMPLUSE1;USER PRINTER 1 ACTIVEF6233A0300CSTS:LDAIOBYTEF626E603JZTTST;TTY ACTIVEF628F628F629CPI2F620FA62F4JNZCUST1;USER CONSOLE 1 ACTIVEF6333A0300BATST:LDAIOBYTEF633GAC6F6JZTTST;ISOLATE BATCH ASGTF638CAC6F6JZTTST;TTY ACTIVEF638F638FA62F4JMOCHF638CAC6F6CPI8F643C362F4JMPTRSTF644S0300CI:LDAIOBYTEF646SA0300CI:LDAIOBYTEF646SA0300CI:LDAIOBYTEF646SA0300CI:LDAIOBYTEF646SA0300CI:LDAIOBYTEF646SA0300CI:LDAIOBYTEF647JZTTYIN; TY DEVICE ACTIVEF648CACEF6JZTTYINF649E603FI:JNZF649CACEF6JZTTYINF653C262F4JNZCUSI1JNZCUS11; USER CONSOLE 1 ACTIVEF656SA0300RI:IDAF658CACEF6JZTTYINF659E60CJZTTYIRDRF658CACEF6JZTTYIRDRF658CACEF6JZTTYIRDRF658CACE                                                                                                                    | CP/M MACRO ASSEN                                                                  | 4 2.0 ∦021                                     | DISK MO                                 | SS 2.2 MONITOR                                                                                                |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------|------------------------------------------------|-----------------------------------------|---------------------------------------------------------------------------------------------------------------|
| F626E603ANI3;ISOLATE CONSOLE ASGTF628CAC6F6JZTTST;TTY ACTIVEF620FA62F4JMCRTST;CRT ACTIVEF630C262F4JNZCUST1;USER CONSOLE 1 ACTIVEF6333A0300BATST:LDAIOBYTEF636E60CANIOCH;ISOLATE BATCH ASGTF638CAC6F6JZTTST;TTY ACTIVEF638FE08CPI8F630FA62F4JMPTRSTF643C362F4JMPRUST2F643C362F4JMPRUST2F6463A0300CI:LDAF649E603ANIF649CACEF6JZTTYINF648CACEF6JZTTYINF656SA0300CI:LDAF656SA0300RI:LDAF656SA0300RI:LDAF656SA0300RI:LDAF659E60CANIF656GACEF6JZF656GACEF6JZF659E60CANIF659CACEF6JZF659CACEF6JZF658CACEF6JZF658CACEF6JZF659F608F659F608F659F608F659CPIF659F608F659F608F659F608F659F608F659F608F659F608                                                                                                                                                                               | F620 C362F4                                                                       | JMP                                            | LUSE1                                   | ;USER PRINTER 1 ACTIVE                                                                                        |
| F62DFA02F4JMCRTST:CRT ACTIVEF630C262F4JNZCUST1;USER CONSOLE 1 ACTIVEF6333A0300BATST:LDAIOBYTEF636E60CANIOCH;ISOLATE BATCH ASGTF638CAC6F6JZTTST;TTY ACTIVEF639F608CPI8F640CA62F4JZRUST1;USER READER 1 ACTIVEF643C362F4JMPRUST2;USER READER 2 ACTIVEF644SA0300CI:LDAIOBYTEF6463A0300CI:LDAIOBYTEF646A0300CI:LDAIOBYTEF646A0300CI:LDAIOBYTEF646A0300CI:LDAIOBYTEF646A0300CI:LDAIOBYTEF647JZTTYIN;TTY DEVICE ACTIVEF648CACEF6JZTTYINF659FA62F4JMCRTINF650FA62F4JMCRTINJNZCUSI1;USER CONSOLE 1 ACTIVEF6563A0300RI:LDAF659E60CANIOCHF659E60CANIOCHF658CACEF6JZF658CACEF6JZF658F608CPIF656F608CPIF656F608CPIF656F062F4MF656F062F4F0EINF658F060F0EINF658F060 <t< td=""><td>F626 E603<br/>F628 CAC6F6<br/>F628 FE02</td><td>ANI<br/>JZ</td><td>3<br/>TTST</td><td>;TTY ACTIVE</td></t<> | F626 E603<br>F628 CAC6F6<br>F628 FE02                                             | ANI<br>JZ                                      | 3<br>TTST                               | ;TTY ACTIVE                                                                                                   |
| F640CAO2F4JZRUSI1USER READER 1 ACTIVEF643C362F4JMPRUST2;USER READER 2 ACTIVEF6463A0300CI:LDAIOBYTEF649E603ANI3;ISOLATE CONSOLE ASGTF648CACEF6JZTTYIN;TTY DEVICE ACTIVEF648F602CPI2F650FA62F4JMCRTIN;CRT ACTIVEF653C262F4JNZCUSI1;USER CONSOLE 1 ACTIVEF6563A0300RI:LDAIOBYTEF659E60CANIOCH;ISOLATE BATCH ASGTF658CACEF6JZTTYRDR;TTY ACTIVEF655F66EF08CPI8F656F662F4JMPTEIN:PAPEE TAPE BEADER ACTIVE                                                                                                                                                                                                                                                                                                                                                                            | F62D FA62F4                                                                       | JM                                             | CRTST                                   | CRT ACTIVE                                                                                                    |
| F640CAO2F4JZRUSI1USER READER 1 ACTIVEF643C362F4JMPRUST2;USER READER 2 ACTIVEF6463A0300CI:LDAIOBYTEF649E603ANI3;ISOLATE CONSOLE ASGTF648CACEF6JZTTYIN;TTY DEVICE ACTIVEF648F602CPI2F650FA62F4JMCRTIN;CRT ACTIVEF653C262F4JNZCUSI1;USER CONSOLE 1 ACTIVEF6563A0300RI:LDAIOBYTEF659E60CANIOCH;ISOLATE BATCH ASGTF658CACEF6JZTTYRDR;TTY ACTIVEF655F66EF08CPI8F656F662F4JMPTEIN:PAPEE TAPE BEADER ACTIVE                                                                                                                                                                                                                                                                                                                                                                            | F633 3A0300<br>F636 E60C<br>F638 CAC6F6<br>F638 FE08                              | ANI<br>JZ                                      | OCH<br>TTST                             | ;ISOLATE BATCH ASGT<br>;TTY ACTIVE                                                                            |
| F649E603ANI3; ISOLATE CONSOLE ASGTF64BCACEF6JZTTYIN; TTY DEVICE ACTIVEF64EFE02CPI2F650FA62F4JMCRTIN; CRT ACTIVEF653C262F4JNZCUSI1; USER CONSOLE 1 ACTIVEF6563A0300 -RI:LDAIOBYTEF659E60CANIOCH; ISOLATE BATCH ASGTF658CACEF6JZTTYRDR; TTY ACTIVEF655FE08CPI8F660FA62F4JMPTRIN; PAPERTAPEREADERACTIVEJMPTRIN                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | FO4U CAOZF4                                                                       | JM<br>JZ                                       | PTRST<br>RUST1                          | USER READER 1 ACTIVE                                                                                          |
| F650FA62F4JMCRTIN; CRT ACTIVEF653C262F4JNZCUSI1; USER CONSOLE 1 ACTIVEF6563A0300 -RI:LDAIOBYTEF659E60CANIOCH; ISOLATE BATCH ASGTF65BCACEF6JZTTYRDR; TTY ACTIVEF65EFE08CPI8F660F662F4JMPTRINF62FF62F4JMF610                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | F649 E603<br>F64B CACEF6                                                          | ANI<br>JZ                                      | 3<br>TTYIN                              | ;ISOLATE CONSOLE ASGT<br>;TTY DEVICE ACTIVE                                                                   |
| FOOD FADZFA JM FTRIN PAPER TAPE READER ACTIVE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | F650 FA62F4                                                                       | JM                                             | CRTIN                                   | ;CRT ACTIVE<br>;USER CONSOLE 1 ACTIVE                                                                         |
| FOOD FADZFA JM FTRIN PAPER TAPE READER ACTIVE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | F656 3A0300 -<br>F659 E60C<br>F65B CACEF6<br>F65F FF08                            | ANI<br>JZ                                      | OCH<br>TTYRDR                           | ;ISOLATE BATCH ASGT<br>;TTY ACTIVE                                                                            |
| F663 CA62F4JZRUSI1USER READER 1 ACTIVEF666 C362F4JMPRUSI2USER READER 2 ACTIVE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | F660 FA62F4<br>F663 CA62F4<br>F666 C362F4                                         | JM<br>JZ                                       | PTRIN<br>RUSI1                          | PAPER TAPE READER ACTIVE<br>USER READER 1 ACTIVE<br>USER READER 2 ACTIVE                                      |
| F669 3A0300 LSTAT: LDA IOBYTE<br>F66C E6C0 ANI OCOH ;ISOLATE THE LIST DEVICE ASSIGNME<br>F66E CAD6F6 JZ TTOST<br>F671 FE80 CPI 80H<br>F673 FA62F4 JM CRTOST<br>F676 CA62F4 JZ LPRST<br>F679 C362F4 JMP LUST1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | F66E CAD6F6<br>F671 FE80                                                          | ANI<br>JZ<br>CPI<br>JM                         | OCOH<br>TTOST<br>80H<br>CRTOST<br>LPRST | ;ISOLATE THE LIST DEVICE ASSIGNMENT                                                                           |
| F67C 3A0300 PO: LDA IOBYTE<br>F67F E630 ANI 30H ;ISOLATE PUNCH ASGT<br>F681 CADEF6 JZ TTPNCH ;TTY ACTIVE<br>F684 FE20 CPI 20H                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | F67C 3A0300<br>F67F E630<br>F681 CADEF6<br>F684 FE20                              | ANI<br>JZ                                      | 30H<br>TTPNCH                           | ;ISOLATE PUNCH ASGT<br>;TTY ACTIVE                                                                            |
| F681CADEF6JZTTPNCH; ISOLATE FUNCH ASGTF681CADEF6JZTTPNCH; TTY ACTIVEF684FE20CPI20HF686FA62F4JMHSP; HIGH SPEED PUNCH ACTIVEF689CA62F4JZPUSO1; USER PUNCH 1 ACTIVEF68CC362F4JMPPUSO2; USER PUNCH 2 ACTIVE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | F686 FA62F4<br>F689 CA62F4<br>F68C C362F4                                         | JM<br>JZ                                       | HSP<br>PUS01                            | USER PUNCH 1 ACTIVE                                                                                           |
| ROUTINE CONI READS THE CONSOLE AND STRIPS OFF THE ASCID<br>PARITY BIT.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                   | ; ROUTINE CONI                                 |                                         | E CONSOLE AND STRIPS OFF THE ASCII                                                                            |
| F68F CD46F6 CONI: CALL CI ;GET THE NEXT CHARACTER<br>F692 E67F ANI 7FH ;STRIP OFF THE PARITY BIT<br>F694 C9 RTS: RET                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | F692 E67F                                                                         | ANI                                            |                                         | GET THE NEXT CHARACTER<br>STRIP OFF THE PARITY BIT                                                            |
| ROUTINE PRTWD PRINTS AN ASCII STRING ONTO THE CONSOLE.<br>THE STRING MUST BE TERMINATED BY BIT 7 SET IN THI<br>LAST CHARACTER OF THE STRING. THE STRING WILL ST<br>A NEW LINE (EP = PRTWD) OR CONTINUE ON THE SAME<br>LINE (EP = PRTWA)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                                   | THE ST<br>LAST C<br>A NEW 1                    | RING MUST<br>HARACTER (<br>LINE (EP =   | BE TERMINATED BY BIT 7 SET IN THE<br>OF THE STRING. THE STRING WILL START<br>= PRTWD) OR CONTINUE ON THE SAME |
| F695CDA9F6PRTWD:CALLCRLF; START A NEW LINEF698C5PRTWA:PUSHB; SAVE (B,C)F6994EPRTA:MOVC,M; GET NEXT CHARACTER FROM MEMORYF694CD00F6CALLCO; OUTPUT ITF69D23INXH; INCREMENT MEMORY POINTERF69E79MOVA,C; TEST FOR BIT 7 DELIMITER                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | F695 CDA9F6<br>F698 C5<br>F699 4E<br>F69A CD00F6<br>F69D 23<br>F69E 79<br>F69F 07 | PRTWA: PUSH<br>PRTA: MOV<br>CALL<br>INX<br>MOV | В,м<br>CO<br>H                          | SAVE (B,C)<br>GET NEXT CHARACTER FROM MEMORY<br>OUTPUT IT<br>INCREMENT MEMORY POINTER                         |

E-23

|     | CP/M MACRO ASSE                                                    | M 2.0                                                                | #022                                          | DISK MOS                                             | SS 2.2 MONITOR                                                                                                               |
|-----|--------------------------------------------------------------------|----------------------------------------------------------------------|-----------------------------------------------|------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------|
|     | F6A0+30F7                                                          |                                                                      | JRNC                                          | PRTA                                                 | ;NO DELIMITER, GO DO NEXT CHARACTER                                                                                          |
|     | F6A2 C1<br>F6A3 C9                                                 | PRTB:                                                                | POP<br>RET                                    | В                                                    | ;RESTORE (B,C)                                                                                                               |
|     |                                                                    | ROUTI                                                                | D,E AND                                       | READS TWO<br>H,L REGI<br>ED SEQUEN                   | D PARAMETERS, PUTS THEM INTO THE<br>ISTERS, THEN DOES A CARRIAGE RETURN,<br>NCE.                                             |
|     | F6A4 CDD9F0<br>F6A7 D1<br>F6A8 E1                                  | ÉXLF:                                                                | CALL<br>POP<br>POP                            | EXPR<br>D<br>H                                       | ;GO GET TWO PARAMETERS                                                                                                       |
|     |                                                                    | ROUTI                                                                | SEQUENC<br>IT INCL                            | E ON THE<br>UDES TWO                                 | S A CARRIAGE RETURN, LINE FEED<br>CURRENT CONSOLE TO START A NEW LINE<br>NULL CHARACTERS FOR TTY TYPE<br>HEAD MOVEMENT TIME. |
|     | F6A9 E5<br>F6AA 21C2F6<br>F6AD CD98F6<br>F6B0 E1<br>F6B1 C9        | ĊRLF:<br>CRLFA:                                                      | PUSH<br>LXI<br>CALL<br>POP<br>RET             | H<br>H,CRMSG<br>PRTWA<br>H                           | ;SAVE THE CONTENTS OF (H,L)<br>;ADDRESS OF CR,LF MESSAGE<br>; OUTPUT IT<br>;RESTORE (H,L)                                    |
| ~   | F6B2 21BBF6<br>F6B5 CD95F6<br>F6B8 C30000                          | RSTER:<br>COMERR:                                                    | LXI<br>CALL<br>JMP                            | H,RSTMSC<br>PRTWD<br>WSVEC                           | GET ADDRESS OF RESTART ERROR MSG<br>PRINT IT ON NEW LINE<br>GO TO WARM BOOT                                                  |
| al. | F6BB 525354204<br>F6C2 0D0A0080                                    | 5RSTMSG:<br>CRMSG:                                                   | DB<br>DB                                      | 'RST ER<br>CR,LF,O                                   | ','R'+80H<br>.80H                                                                                                            |
|     |                                                                    | ; I/O D                                                              | RIVERS F                                      |                                                      | 250 ASYNC COMM ELEMENT                                                                                                       |
|     | F6C6 DB25<br>F6C8 E601<br>F6CA C8<br>F6CB C6FE<br>F6CD C9          | ṫτsτ:                                                                | IN<br>ANI<br>RZ<br>ADI<br>RET                 | SLSTAT<br>1<br>OFEH                                  | GET 8250 LINE STATUS<br>SEE IF RECEIVE DATA AVAILABLE<br>RETURN IF NOT<br>FLAG THAT DATA IS AVAILABLE                        |
|     | F6CE DB25<br>F6D0 1F                                               | TTYIN:                                                               | IN<br>RAR<br>JRNC                             | SLSTAT<br>TTYIN                                      | GET 8250 LINE STATUS<br>MOVE RX DATA READY BIT INTO CARRY<br>LOOP UNTIL DATA IS IN                                           |
|     | F6D1+30FB<br>F6D3 DB20<br>F6D5 C9                                  | 1                                                                    | IN<br>RET                                     | SDATA                                                | ; READ THE DATA .                                                                                                            |
|     | F6D6 DB25<br>F6D8 E620<br>F6DA C8<br>F6DB C6BF<br>F6DD C9          | Ϋ́TOST:                                                              | IN<br>ANI<br>RZ<br>ADI<br>RET                 | SLSTAT<br>20H<br>OBFH                                | GET 8250 LINE STATUS<br>ISOLATE TX BUFFER EMPTY BIT<br>RETURN IF NOT EMPTY<br>FLAG THE EMPTY STATE                           |
|     | F6DE CDD6F6                                                        | ttyout:                                                              | CALL<br>JRZ                                   | TTOST<br>TTYOUT                                      | GET 8250 LINE STATUS<br>WAIT UNTIL ONE OF THE REGISTERS EMPTIES                                                              |
|     | F6E1+28FB<br>F6E3 79<br>F6E4 D320<br>F6E6 C9                       | 97<br>(                                                              | MOV<br>OUT<br>RET                             | A,C<br>SDATA                                         | ;MOVE THE DATA OVER<br>;OUTPUT THE DATA                                                                                      |
|     |                                                                    | , EQUAT                                                              | ES FOR A                                      | DDITIONAL                                            | CONSOLE DEVICES                                                                                                              |
|     | F462 =<br>F462 =<br>F462 =<br>F462 =<br>F462 =<br>F462 =<br>F462 = | CRTIN:<br>CRTOUT:<br>CRTST:<br>CRTOST:<br>CUSI1:<br>CUSO1:<br>CUST1: | EQU<br>EQU<br>EQU<br>EQU<br>EQU<br>EQU<br>EQU | IOER<br>IOER<br>IOER<br>IOER<br>IOER<br>IOER<br>IOER | ;UNASSIGNED CRT OUTPUT STATUS<br>;UNASSIGNED USER CONSOLE (INPUT)<br>;UNASSIGNED USER CONSOLE (OUPTUT)                       |

E-24

وط

|                                                                          | EQUAT                                                                    | TES FOR A                                       | DDITIONA                                              | L PAPER TAPE PUNCH DEVICES                                                                                                                                                                                                                                             |
|--------------------------------------------------------------------------|--------------------------------------------------------------------------|-------------------------------------------------|-------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| F6DE =<br>F462 =<br>F462 =<br>F462 =<br>F462 =                           | HSPST:                                                                   | EQU                                             | TTYOUT<br>IOER<br>IOER<br>IOER<br>IOER                | UNASSIGNED TELETYPE PUNCH<br>UNASSIGNED HIGH SPEED PUNCH<br>UNASSIGNED HIGH SPEED PUNCH STATUS<br>UNASSIGNED USER PUNCH 1<br>UNASSIGNED USER PUNCH 2                                                                                                                   |
|                                                                          | EQUAT                                                                    | TES FOR A                                       | ADDITIONA                                             | L LIST DEVICES                                                                                                                                                                                                                                                         |
| F462 =<br>F462 =<br>F462 =<br>F462 =                                     | LPRT:<br>LPRST:<br>LUSE1:<br>LUST1:                                      | EQU                                             | IOER<br>IOER<br>IOER<br>IOER                          | UNASSIGNED LINE PRINTER<br>UNASSIGNED LINE PRINTER STATUS<br>LIST DEVICE 1<br>UNASSIGNED LIST DEVICE 1 STATUS                                                                                                                                                          |
|                                                                          | EQUA                                                                     | TES FOR A                                       | DDITIONA                                              | L PAPER TAPE READER DEVICES                                                                                                                                                                                                                                            |
| F66622 = = = = = = = = = = = = = = = = =                                 | TTYRDR:<br>PTRIN:<br>PTRST:<br>RUSI1:<br>RUSI1:<br>RUSI2:<br>RUSI2:<br>; | EQU                                             | TTYIN<br>IOER<br>IOER<br>IOER<br>IOER<br>IOER<br>IOER | UNASSIGNED TELETYPE PAPER TAPE READER<br>UNASSIGNED HIGH SPEED PAPER TAPE READER<br>UNASSIGNED HS PTR STATUS<br>UNASSIGNED PAPER TAPE READER 1<br>UNASSIGNED PAPER TAPE READER 1 (STATUS)<br>UNASSIGNED PAPER TAPE READER 2<br>UNASSIGNED PAPER TAPE READER 2 (STATUS) |
|                                                                          | THE FO                                                                   | IN ALL (<br>IF THE I<br>THESE RO<br>DISK TYP    | CASES, ON<br>DISK HAS                                 | S DO THE PRIMITIVE DISK ACCESSES.<br>NE SECTOR OF DATA IS TRANSFERRED.<br>NOT BEEN PREVIOUSLY ACCESSED,<br>VILL AUTOMATICALLY DETERMINE THE<br>8 5"), SINGLE OR DOUBLE DENSITY,                                                                                        |
|                                                                          | ,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,                                  | TRACK IS                                        | S SEEKED                                              | RED DATA IS TRANSFERRED, THE DESIRED<br>OUT, THE DESIRED SECTOR AND SIDE IS<br>CTUAL DATA TRANSFER.                                                                                                                                                                    |
| T                                                                        |                                                                          | TRANSFER<br>ROUTINE<br>OPERATIO<br>SUCCESSE     | R IS ABOF<br>, THE A F<br>ON WAS SU<br>FUL. THE       | WILL BE ATTEMPTED BEFORE THE DATA<br>RTED. ON RETURN TO THE CALLING<br>REGISTER WILL CONTAIN A ZERO IF THE<br>JCCESSFUL, OR NON-ZERO IF NOT<br>E FLAG REGISTER WILL NOT NECESSARILY<br>THE A REGISTER CONTENT.                                                         |
| in                                                                       |                                                                          | THESE RO<br>AS PART                             | OF THE E                                              | ARE CP/M COMPATABLE, AND MAY BE USED BIOS.                                                                                                                                                                                                                             |
| F6E7 22400<br>F6EA 3E01<br>F6EB AF<br>F6EB AF<br>F6EC 324B0<br>F6EF 060A | DREAD:<br>DWRITE:                                                        | SHLD<br>MVI<br>ORG<br>XRA<br>STA<br>MVI<br>DUSH | HSTBUF<br>A,1<br>\$-1<br>A<br>RWFLG<br>B,10           | SAVE THE DMA ADDRESS<br>SET READ FLAG<br>SAVE A BYTE HERE<br>SET WRITE FLAG<br>SAVE IT FOR LATER USE<br>NUMBER OF RETRIES                                                                                                                                              |
| F6F1 C5<br>F6F2 CD3BF<br>F6F5 CCFDF<br>F6F8 C1<br>F6F9 C8                | AGN:<br>7<br>67<br>READ3:                                                | PUSH<br>CALL<br>CZ<br>POP<br>RZ<br>DJNZ         | B<br>SEEK<br>RDWR<br>B<br>AGN                         |                                                                                                                                                                                                                                                                        |
| F6FA+10F5<br>F6FC C9                                                     | *                                                                        | RET                                             |                                                       |                                                                                                                                                                                                                                                                        |
| F6FD 5F<br>F6FE 3A4B0                                                    | ,<br>RDWR:                                                               | MOV<br>LDA<br>ORA                               | E,A<br>RWFLG<br>A                                     | ;SAVE COMMAND                                                                                                                                                                                                                                                          |
| F701 B7<br>F702 7B                                                       |                                                                          | MOV                                             | Â,E                                                   | ; REGET THE COMMAND                                                                                                                                                                                                                                                    |

## FIRMWARE LISTING

|    | CP/M MACRO ASSE                                                                                                     | M 2.0           | #024                                                       | DISK MOS                                                      | SS 2.2 MONITOR                                                                                                                                                         |
|----|---------------------------------------------------------------------------------------------------------------------|-----------------|------------------------------------------------------------|---------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|    | F703+2810                                                                                                           |                 | JRZ                                                        | WRDAT                                                         | ;WRITE IF ZERO                                                                                                                                                         |
|    | F705 324800<br>F708 D330                                                                                            | RDAT:<br>READ1: | STA<br>OUT<br>INIR                                         | CMND<br>DCMMD                                                 | ;DISK COMMAND PORT                                                                                                                                                     |
|    | F70A+EDB2<br>F70C 15                                                                                                |                 | DCR<br>JRNZ                                                | D<br>READ1                                                    |                                                                                                                                                                        |
|    | F70D+20FB<br>F70F CD2EF7<br>F712 E69C<br>F714 C9                                                                    |                 | CALL<br>ANI<br>RET                                         | EOJ<br>9CH                                                    | ;ISOLATE READ ERROR BITS                                                                                                                                               |
| 20 | F715 F620<br>F717 324800<br>F71A D330                                                                               | WRDAT:          | ORI<br>STA<br>OUT<br>OUTIR                                 | 20H<br>CMND<br>DCMMD 😚                                        | ; ADD WRITE COMMAND<br>; DISK COMMAND PORT                                                                                                                             |
|    | F71C+EDB3<br>F71E 15                                                                                                | WIII.           | DCR<br>JRNZ                                                | D<br>WRT1                                                     | ;DO THE OUTPUT<br>;IN CASE > 256 BYTES                                                                                                                                 |
|    | F71F+20FB                                                                                                           |                 | JMPR                                                       | EOJ                                                           |                                                                                                                                                                        |
|    | F721+180B                                                                                                           |                 | JMPA                                                       | FOO                                                           | 5                                                                                                                                                                      |
|    | F723 0608<br>F725 3A4600<br>F728 B0                                                                                 | ÈOJB:<br>EOJA:  | MVI<br>LDA<br>ORA                                          | B,8<br>STPRAT<br>B                                            | BASIS OF RESTORE COMMAND<br>GET THE STEP RATE BITS<br>ADD ON THE COMMAND                                                                                               |
|    | F729 324800<br>F72C D330<br>F72E DB34<br>F730 1F                                                                    | EOJ:            | STA<br>OUT<br>IN<br>RAR                                    | CMND<br>DCMMD<br>DFLAG                                        | ;DO THE COMMAND<br>;DISK FLAG PORT                                                                                                                                     |
|    | F731+30FB<br>F733 DB30                                                                                              | 1               | JRNC                                                       | EOJ                                                           |                                                                                                                                                                        |
|    | F733 DB30<br>F735 324700<br>F738 E6FC<br>F73A C9                                                                    | EOJ1:           | IN<br>STA<br>ANI<br>RET                                    | DSTAT<br>STATUS<br>OFCH                                       | ;GET THE DISK STATUS                                                                                                                                                   |
|    | F73B CD8EF7<br>F73E C423F7<br>F741 F8<br>F742 3A4200<br>F745 D332<br>F747 DB31<br>F749 4F<br>F744 3A4100<br>F74D B9 | ŠEEK:<br>SEEK1: | CALL<br>CNZ<br>RM<br>LDA<br>OUT<br>IN<br>MOV<br>LDA<br>CMP | IDRD<br>EOJB<br>SECTOR<br>DSCTR<br>DTRCK<br>C,A<br>TRACK<br>C | INSURE HEADER HAS BEEN READ<br>RESTORE THE DRIVE IF ERROR<br>DONE IF NO DRIVE<br>SET THE SECTOR<br>DISK SECTOR PORT<br>DISK TRACK PORT<br>SAVE IT<br>GET DESIRED TRACK |
|    | F74E+280C                                                                                                           |                 | JRZ                                                        | RDWRT                                                         | ;JUMP IF NO SEEK NEEDED                                                                                                                                                |
|    | F750 D333<br>F752 061C<br>F754 CD25F7<br>F757 E698<br>F759 C0<br>F75A DB31<br>F75C B7                               | RDWRT:          | OUT<br>MVI<br>CALL<br>ANI<br>RNZ<br>IN<br>ORA              | DDATA<br>B,1CH<br>EOJA<br>98H<br>DTRCK<br>A                   | SET THE SEEK TRACK<br>BUILD THE SEEK COMMAND<br>DO THE SEEK<br>SEEK ERROR MASK<br>DONE IF SEEK ERROR<br>CHECK FOR TRACK OO                                             |
|    | F75D 214000                                                                                                         | NDWN1.          | LXI<br>JRZ                                                 | H,40H<br>RDWRTO                                               | BUILD SECTOR BYTE COUNT                                                                                                                                                |
|    | F760+2803<br>F762 3A5100<br>F765 29<br>F766 3D<br>F767 F265F7<br>F76A E5                                            | RDWRTO:         | LDA<br>DAD<br>DCR<br>JP<br>PUSH                            | IDSV+3<br>H<br>A<br>RDWRTO<br>H                               | GET SECTOR SIZE<br>DOUBLE (H,L)<br>LOOP CONTROL                                                                                                                        |
|    | F76B 0E80<br>F76D CDC3F7                                                                                            |                 | MVI<br>CALL                                                | C,80H<br>SETUP                                                | ;AUTO-WAIT BIT                                                                                                                                                         |
| 2  | F770 DB34<br>F772 E620                                                                                              |                 | IN<br>ANI                                                  | DFLAG<br>20H                                                  | ;DISK FLAG PORT<br>;SEE IF HEAD IS LOADED                                                                                                                              |

E-26

)

| CP/M MACRO ASSEM 2.0                                                                                                                                                                                             | <b>#</b> 025                                           | DISK MOS                                           | S 2.2 MONITOR                                                                                                                                                               |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------|----------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| F774 3E04                                                                                                                                                                                                        | MVI<br>JRZ                                             | A,4<br>RDWRT1                                      | ;JUMP IF NOT                                                                                                                                                                |
| F776+2801<br>F778 AF<br>F779 C688 RDWRT1:<br>F77B 2A4C00<br>F77E D1<br>F77F 43<br>F780 15<br>F781 14                                                                                                             | XRA<br>ADI<br>LHLD<br>POP<br>MOV<br>DCR<br>INR<br>JRNZ | A<br>88H<br>HSTBUF<br>D<br>B,E<br>D<br>D<br>RDWRT2 | ELSE, RESET THE HEAD LOAD FLAG<br>BUILD A READ SECTOR COMMAND<br>GET THE DMA ADDRESS<br>GET THE BYTE COUNT<br>SET UP FOR Z-80 I/O<br>SEE IF 128 BYTE SECTOR<br>;JUMP IF NOT |
| F782+2001<br>F784 14<br>F785 0E33 RDWRT2<br>F787 BF<br>F788 C9                                                                                                                                                   | INR                                                    | D<br>C,DDATA<br>A                                  | ;CLEAR THE FLAGS                                                                                                                                                            |
| F789 0658 1DRD5:<br>F78B CD25F7                                                                                                                                                                                  | MVI<br>CALL                                            | B,58H<br>EOJA                                      | ;BUILD A STEP-IN COMMAND                                                                                                                                                    |
| F78B CD25F7<br>F78E 2A4900 IDRD:<br>F791 7C<br>F792 BD<br>F793 C8<br>F794 OE80 IDRD1:<br>F796 CDC3F7<br>F796 CDC3F7<br>F799 CD33F7<br>F790 F8<br>F79D E5<br>F79E 214E00<br>F7A1 013306<br>F7A4 1601<br>F7A6 3EC4 | LHLD<br>MOV<br>CMP<br>RZ<br>MVI<br>CALL                | LUNIT<br>A,H<br>L<br>C,80H<br>SETUP                | GET THE CUNIT VALUE<br>SEE IF SAME AS LUNIT<br>RETURN IF SO<br>SET THE AUTO-WAIT BIT                                                                                        |
| F799 CD33F7<br>F79C F8<br>F79D E5<br>F79E 214E00<br>F7A1 013306<br>F7A1 013306                                                                                                                                   | CALL<br>RM<br>PUSH<br>LXI<br>LXI                       | EOJ1<br>H<br>H,IDSV<br>B,600H+I                    | INSURE A DRIVE IS THERE<br>ERROR IF NOT<br>SAVE POINTER<br>SET UP TO READ ADDRESS<br>DDATA                                                                                  |
| F7A8 CD05F7                                                                                                                                                                                                      | MVI<br>MVI<br>CALL                                     | D,1<br>A,OC4H<br>RDAT                              | ; READ ADDRESS COMMAND                                                                                                                                                      |
| F7AB E1                                                                                                                                                                                                          | POP<br>JRZ                                             | H<br>IDRD2                                         | ;RESTORE POINTER<br>;JUMP IF GOOD READ                                                                                                                                      |
| F7AC+2808<br>F7AE 3E40<br>F7B0 BE<br>F7B1 D8<br>F7B2 B6<br>F7B3 77                                                                                                                                               | MVI<br>CMP<br>RC<br>ORA<br>MOV                         | A,40H<br>M<br>M,A<br>IDRD                          | ;SEE IF DDEN IS SET<br>;TAKE THE ERROR IF SO<br>;ELSE, TRY DDEN                                                                                                             |
| F7B4+18D8                                                                                                                                                                                                        | JMPR                                                   | TDKD                                               | 10                                                                                                                                                                          |
| F7B6 DB32 1DRD2:<br>F7B8 D331<br>F7BA B7                                                                                                                                                                         | IN<br>OUT<br>ORA<br>JRZ                                | DSCTR<br>DTRCK<br>A<br>IDRD5                       | GET THE TRACK NUMBER<br>SET THE TRACK REGISTER<br>INSURE NOT ON TRACK O<br>JUMP IF NOT OKAY                                                                                 |
| F7BB+28CC<br>F7BD 7E<br>F7BE 324900<br>F7C1 AF<br>F7C2 C9                                                                                                                                                        | MOV<br>STA<br>XRA<br>RET                               | A,M<br>LÚNIT<br>A                                  | REGET SELBITS<br>UPDATE LAST USED UNIT<br>RESET ERROR FLAGS                                                                                                                 |
| F7C3 214A00 SETUP:<br>F7C6 7E<br>F7C7 B7                                                                                                                                                                         | P DRIVE I<br>LXI<br>MOV<br>ORA<br>JRNZ                 | NUMBER<br>H,CUNIT<br>A,M<br>A<br>SUO               | SEE IF DRIVE HAS BEEN ACTIVE<br>GET THE SELBITS<br>SEE IF SET UP YET<br>YES, SKIP INIT CODE                                                                                 |
| F7C8+2025                                                                                                                                                                                                        |                                                        |                                                    |                                                                                                                                                                             |
| F7CA 3A4000 ŠETIT:<br>F7CD 47<br>F7CE 04<br>F7CF AF<br>F7D0 37<br>F7D1 17 SET1:                                                                                                                                  | LDA<br>MOV<br>INR<br>XRA<br>STC<br>RAL                 | DISKNO<br>B,A<br>B<br>A                            | GET THE DESIRED DRIVE<br>SAVE IN WORK REGISTER<br>PREPARE TO CONVERT TO SELBITS<br>ZERO TO A<br>DRIVE SELECT BIT<br>SHIFT BIT INTO POSITION                                 |
|                                                                                                                                                                                                                  | DJNZ                                                   | SET1                                               | LOOP TIL BIT IS IN POSITION                                                                                                                                                 |

| E - 28 |
|--------|
|--------|

| CP/M MACRO ASSEM 2.0                                                                                                                    | <i></i> #026                                                               | DISK MOSS 2.2 MONITOR                                                                                                                                                                                                        |
|-----------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| F7D2+10FD<br>F7D4 F620<br>F7D6 77<br>F7D7 D334<br>F7D9 114600<br>F7DC 3E03<br>F7DE 12<br>F7DF CD23F7<br>F7E2 F8<br>F7E3 DB04<br>F7E5 1F | ORI<br>MOV<br>OUT<br>LXI<br>MVI<br>STAX<br>CALL<br>RM<br>IN<br>RAR<br>JRNC | 20H; ADD ON MOTOR ON BITM, A; SAVE ITDCNTL; SELECT THE DRIVED, STPRAT; SET INITIAL STEP RATEA, 3; TO SLOWEST POSSIBLED; RESTORE THE DRIVEEOJB; RESTORE THE DRIVE4; READ THE MINI TRKOO BIT4; SOLATE ITSUO; UMD IE MINI DRIVE |
| F7E6+3007<br>F7E8 3E10<br>F7EA B6<br>F7EB 77<br>F7EC 3E02<br>F7EE 12<br>F7EF DB31 SU0:<br>F7F1 B7<br>F7F2 7E                            | MVI<br>ORA<br>MOV<br>MVI<br>STAX<br>IN<br>ORA<br>MOV<br>JRNZ               | SUO ;JUMP IF MINI DRIVE<br>A,10H ;ELSE, ADD ON MAXI BIT<br>M,A<br>A,2 ;SET MAXI STEP RATE<br>D TRCK ;ELSE, SEE IF TRACK ZERO<br>A<br>A,M ;REGET THE SELBITS<br>SU1                                                           |
| F7F3+2002<br>F7F5 E6BF<br>F7F7 B1 SU1:<br>F7F8 D334<br>F7FA 3A4300<br>F7FD D304<br>F7FF C9                                              | ANI<br>ORA<br>OUT<br>LDA<br>OUT<br>RET                                     | OBFH ;INSURE DDEN IS RESET<br>C ;ADD ON AUTOWAIT BIT<br>DCNTL ;OUTPUT THE SELBITS<br>SIDE ;SET THE SIDE SELECT<br>4                                                                                                          |

## APPENDIX F

# LIMITED WARRANTY

#### LIMITED WARRANTY

California Computer Systems (CCS) warrants to the original purchaser of its products that its CCS assembled and tested products will be free from materials defects for a period of one (1) year, and be free from defects of workmanship for a period of ninety (90) days.

The responsibility of CCS hereunder, and the sole and exclusive remedy of the original purchaser for a breach of any warranty hereunder, is limited to the correction or replacement by CCS at CCS's option, at CCS's service facility, of any product or part which has been returned to CCS and in which there is a defect covered by this warranty; provided, however, that in the case of CCS assembled and tested products, CCS will correct any defect in materials and workmanship free of charge if the product is returned to CCS within ninety (90) days of original purchase from CCS; and CCS will correct defects in materials in its products and restore the product to an operational status for a labor charge of \$25.00, provided that the product is returned to CCS within one (1) year in the case of CCS assembled and tested products. All such returned products shall be shipped prepaid and insured by original purchaser to:

> Warranty Service Department California Computer Systems 250 Caribbean Drive Sunnyvale, California 94086

CCS shall have the right of final determination as to the existence and cause of a defect, and CCS shall have the sole right to decide whether the product should be repaired or replaced.

This warranty shall not apply to any product or any part thereof which has been subject to

accident, neglect, negligence, abuse or misuse;

(2) any maintenance, overhaul, installation, storage, operation, or use, which is improper; or

(3) any alteration, modification, or repair by anyone other than CCS or its authorized representative.

THIS WARRANTY IS EXPRESSLY IN LIEU OF ALL OTHER WARRANTIES EXPRESSED OR IMPLIED OR STATUTORY INCLUDING THE WARRANTIES OF DESIGN, MERCHANTABILITY, OR FITNESS OR SUITABILITY FOR USE OR INTENDED PURPOSE AND OF ALL OTHER OBLIGATIONS OR LIABILITIES OF CCS. To any extent that this warranty cannot exclude or disclaim implied warranties, such warranties are limited to the duration

....

## of this express warranty or to any shorter time permitted by law.

CCS expressly disclaims any and all liability arising from the use and/or operation of its products sold in any and all applications not specifically recommended, tested, or certified by CCS, in writing. With respect to applications not specifically recommended, tested, or certified by CCS, the original purchaser acknowledges that he has examined the products the to which this warranty attaches, and their specifications and descriptions, familiar and is with the operational characteristics thereof. The original purchaser has not relied upon the judgement or any representations of CCS as to the suitability of any CCS product and acknowledges that CCS has no knowledge of the intended use of its products. CCS EXPRESS DISCLAIMS ANY LIABILITY ARISING FROM THE USE AND/OR OPERATION CCS EXPRESSLY OF PRODUCTS, AND SHALL NOT BE LIABLE FOR ANY CONSEQUENTIAL OR ITS INCIDENTAL OR COLLATERAL DAMAGES OR INJURY TO PERSONS OR PROPERTY.

CCS's obligations under this warranty are conditioned on the original purchaser's maintenance of explicit records which will accurately reflect operating conditions and maintenance preformed on CCS's products and establish the nature of any unsatisfactory condition of CCS's products. CCS, at its request, shall be given access to such records for substantiating warranty claims. No action may be brought for breach of any express or implied warranty after one (1) year from the expiration of this express warranty's applicable warranty period. CCS assumes no liability for any events which may arise from the use of technical information on the application of its products supplied by CCS. CCS makes no warranty whatsoever in respect to accessories or parts not supplied by CCS, or to the extent that any defect is attributable to any part not supplied by CCS.

CCS neither assumes nor authorizes any person other than а duly authorized officer or representative to assume for CCS any other liability or extension or alteration of this warranty in connection with the sale or any shipment of CCS's products. Any such assumption of liability or modification of warranty must be in writing and signed by such duly authorized officer or representative to be enforceable. These warranties apply to the orginal purchaser only, and do not run to successors, assigns, or subsequent purchasers or owners; AS TO ALL PERSONS OR ENTITIES OTHER THAN THE ORIGINAL PURCHASER, CCS MAKES NO WARRANTIES WHATSOEVER, EXPRESS OR IMPLIED OR STATUTORY. The term "original purchaser" as used in this warranty shall be deemed to mean only that person to whom its product is originally sold by CCS.

Unless otherwise agreed, in writing, and except as may be necessary to comply with this warranty, CCS reserves the right to make changes in its products without any obligation to

F-4

### LIMITED WARRANTY

incorporate such changes in any product manufactured theretofore.

This warranty is limited to the terms stated herein. CCS disclaims all liability for incidental or consequential damages. Some states do not allow limitations on how long an implied warranty lasts and some do not allow the exclusion or limitation of incidental or consequential damages so the above limitations and exclusions may not apply to you. This warranty gives you specific legal rights, and you may also have other rights which vary from state to state.

F-5

# ADDENDUM TO THE 2422 OWNER'S MANUAL

. •

Kr. 2

· .

1

# SUBJECT: SILKSCREEN MISLABELING

Some of the jumper labels on the 2422 PC board's silkscreen are incorrect. The jumper labeled BOOT AUTO should be AUTO BOOT. The MON 'EN jumper should be PR EN. One of the positions for the AUTO WAIT jumper is also labeled wrong: CNTL should be STAT1. The board layout in Appendix D shows the correct jumper labeling.