# Owner's Manual

## **Model 2810**

## **Z-80 CPU**



California Computer Systems

## CCS MODEL 2810 Z-80 CPU MODULE OWNER'S MANUAL

COPYRIGHT 1980

CALIFORNIA COMPUTER SYSTEMS 250 CARIBBEAN DRIVE SUNNYVALE , CA 94086 MANUAL NO. 89000-02810

#### 2810 Z-80 CPU MANUAL ADDENDUM

On some 2810 Z-80 CPU cards, the jumper settings for the WAIT jumper have been mislabeled. The following figure shows the correct labeling:



If your board is labeled incorrectly, you may wish to change the directions in section 2.1.4 to conform to the board's labeling.

### TABLE OF CONTENTS

| CHAPTER | 1 | INTRODUCTION TO THE 2810 Z-80 CPU<br>1.1 THE CPU 1-1<br>1.2 THE ASYNCHRONOUS SERIAL I/O PORT 1-2                                                                                                                                                                                                                                                                                                                                                                                     |
|---------|---|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CHAPTER | 2 | SETUP AND INSTALLATION<br>2.1 BOARD SETUP                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|         |   | 2.1.7       PHANTOM Enable Jumper       2-4         2.1.8       NMI Enable Jumper       2-4         2.1.9       REFRESH Enable Jumper       2-5         2.1.10       2/4 MHz Toggle Switch       2-5         2.1.11       MREQ jumper       2-5         2.2       SERIAL I/O PORT SETUP       2-6         2.2.2       Peripheral Configuration       2-6         2.3       FRONT PANEL SETUP       2-7         2.3.1       ALTAIR 8800       2-7         2.3.2       IMSAI       2-7 |
| CHAPTER | 3 | THEMOSS 2.2 MONITOR3.1THE MONITOR'S MEMORY SPACE3-13.2SOFTWARE ENTRY POINTS3-23.3THE BASIC I/O ROUTINES AND THE IOBYTE3-23.4BRINGING UP THE MONITOR3-33.5MONITOR COMMANDS3-33.6ERROR MESSAGES3-53.7COMMAND DESCRIPTION3-63.7.1Assign (A)3-63.7.2Display (D)3-83.7.3End Of File (E)3-9                                                                                                                                                                                                |

i

|            | 3.7.4<br>3.7.5<br>3.7.6<br>3.7.7<br>3.7.8<br>3.7.9<br>3.7.10<br>3.7.10<br>3.7.11<br>3.7.12<br>3.7.13<br>3.7.14<br>3.7.15<br>3.7.16<br>3.7.17<br>3.7.18<br>3.7.19 | Query (Q)<br>Read (R)<br>Substitute (S)<br>Test (T)<br>Verify (V)<br>Write (W)<br>Examine (X)<br>Initialize Baud Rate (Y) | 3-10<br>3-11<br>3-11<br>3-12<br>3-12<br>3-12<br>3-12<br>3-12<br>3-12 |
|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------|
| CHAPTER 4  | THEORY OF O<br>4.1 THE CP<br>4.1.1<br>4.1.2<br>4.1.3<br>4.1.4<br>4.1.5<br>4.1.6<br>4.1.7<br>4.1.8<br>4.1.9<br>4.2 THE SE                                         |                                                                                                                           | 4-1<br>4-2<br>4-3<br>4-3<br>4-7<br>4-9<br>4-9<br>4-10                |
|            | 4.2.1<br>4.2.2                                                                                                                                                   | The CPU Interface<br>The Peripheral Interface                                                                             | 4-11                                                                 |
| APPENDIX A | A.1 THE SY<br>A.1.1<br>A.1.2<br>A.1.3<br>A.2 SERIAL                                                                                                              | The 2810 System Bus<br>The System Bus Pin Assignments<br>INTERFACE BUS                                                    | A-3<br>A-3<br>A-8<br>A-9                                             |
|            |                                                                                                                                                                  | Signal Definitions<br>RS-232-C Pin Assignments                                                                            |                                                                      |
| APPENDIX B | B.1 THE Z-<br>B.1.1<br>B.1.2<br>B.1.3                                                                                                                            | • 0                                                                                                                       | B-3<br>B-3<br>B-4                                                    |
|            | B.2.1                                                                                                                                                            | 250 ADDRESSIBLE REGISTERS<br>Peripheral Control Register                                                                  |                                                                      |

## ii

| B.2.3 | Peripheral Status Register | B-7        |
|-------|----------------------------|------------|
| B.2.4 | Line Status Register       | в-8        |
|       |                            | <b>D</b> 0 |

### APPENDIX C FIRMWARE LISTING

| APPENDIX D | PARTS LIST, BOARD LAYOUT, SCHEMATIC, SPECIFICATIONS |
|------------|-----------------------------------------------------|
|            | Parts List D-3                                      |
|            | Board Layout D-5                                    |
|            | Schematic D-7                                       |
|            | Specifications D-9                                  |

APPENDIX E LIMITED WARRANTY

#### HOW TO USE THIS MANUAL

No manual can be everything to everybody. But we have tried to design this manual so that it will be a useful reference tool for most of its users. The chapters up to "Theory of Operation" contain the information you need to configure the board to your system and to operate it with the provided firmware. "Theory of Operation" and the appendices are designed for those of you who want more information about the board, whether from curiosity or a desire to further customize it. Programming information on the Z-80 is not included in this manual; the information is simply too extensive. You will need to acquire a Z-80 programming manual.

#### CHAPTER 1

#### INTRODUCTION TO THE 2810 Z-80 CPU

California Computer Systems' 2810 Z-80 CPU provides you with a CPU, a master serial I/O port, and monitor firmware. As a result, it is the ideal foundation for an S-100 system; with the addition of RAM memory and a console device, you can have a complete system that allows considerable add-on flexibility. The 2810 Z-80 CPU is also an excellent choice for upgrading a present system. It has been carefully designed to be compatible with the major S-100 systems on the market.

The 2810 CPU and CCS's line of S-100 peripheral boards are designed to work uniquely well with each other. For example, the 2422 Multimode Floppy Disk Controller board contains ROM-resident firmware which can overlay the CPU firmware with its own, changing the monitor firmware from a paper tape-oriented firmware to a floppy-disk oriented firmware. No reprogramming of ROMs is necessary; after a minimum amount of setup, the disk controller board can be plugged in and operated with the 2810 CPU.

#### 1.1 THE CPU

2810 Z-80 CPU is an S-100 bus compatible card designed The for the Z-80 microprocessor. As such it combines the best of two the speed and large instruction set of the Z-80 worlds: processor with the versatility of the S-100 bus. The Z-80, a third generation processor, represents a real advance over the earlier 8080. Its large instruction set (80 more instructions than the 8080) and internal register configuration simplify the the programmer's task and reduce program size. The Z-80 is also designed to run at 4 MHz as well as 2 MHz. The 2810 CPU powerful processor interfaces this with the popular. S-100 8080-oriented bus. This bus is used by numerous manufacturers, allowing the user of an S-100 system a wide choice of products. To ensure compatibility with these products, the 2810 simulates as closely as possible the 8080 signals used on the S-100 bus.

Since this board will be used in a wide variety of systems and for a wide variety of applications, a number of optional features have been incorporated. These include a power-on jump for systems without front panels, address mirroring circuitry for 8080 system compatibility, and an M1 Wait State for slow memory. Moreover, bus signals for which possible bus conflicts exist are made jumper enabled.

Three diagnostic LEDs have been provided on the 2810. One indicates that the ROM is enabled and selected. The second indicates that the CPU is executing a software Halt instruction and is waiting for an interrupt. The third LED indicates that CPU has been programmed to accept interrupts. Since the CPU will remain halted while executing a Halt instruction until the system is reset or the CPU receives an interrupt, the last two LEDs can be used in combination to detect the software problem of the CPU receiving a Halt instruction before it receives an Interrupt Enable instruction.

#### 1.2 THE ASYNCHRONOUS SERIAL I/O PORT

The 2810 Z-80 CPU contains an on-board, asynchronous serial I/O port which allows you to interface to your CPU any serial I/O device which conforms to a major subset of the RS-232-C standards for asynchronous serial communications. You have several options If you are using the monitor firmware as in using this port. you are provided with driver routines for the port. These is, routines intend that the port be used to interface the CPU to some type of console device, preferably a CRT. For flexibility, the baud rate can be set through console control. Or you can, of course, use your own driver software for the port. Appendix B contains information on programming the port's Asynchronous Communications Element. The number of stop bits, the baud rate, the type of parity, and word length are all software-selectable and the handshake lines are under software control. The port's Finally, you can disable the address is jumper-selectable. serial port with an on-board jumper.

#### CHAPTER 2

#### SETUP AND INSTALLATION

The first section of this chapter deals with configuring the 2810 to meet your system's requirements. Those of you who do not plan to use the serial port and do not have a front panel can install the board in your system after having configured the board. If you do plan to use the serial port or a front panel, section 4.2 gives additional setup and installation procedures concerning the port, while section 4.3 gives information on installing this board in a front panel system.

#### 2.1 BOARD SETUP

The 2810 CPU has a number of features which are enabled or configured through on-board plug jumpers. Each of these features is discussed below, roughly in the order of the jumpers on the board, starting with the upper left corner of the board and proceeding clockwise. In addition to the plug jumpers, there is a switch to be set and an optional jumper that can be soldered in. If you are having difficulty locating or identifying any of the jumpers or the switch, the board layout in Appendix C should help.

2.1.1 Serial Port Enable and Address Select Jumpers

The SER EN jumper allows you to enable or disable the on-board serial port. If you enable the port, the SERIAL ADDRESS SELECT jumpers allow you to select the base address for the interface's registers. The address lines AO-A2 are needed to select one register out of the registers used by the serial

#### BOARD SETUP

2.1.4 M1 Wait State Select Jumper

By setting the WAIT jumper to ON, you will force the CPU into one Wait state during every M1 (op code fetch) cycle of an instruction cycle. In a Z-80, the memory access time requirements are strictest during an M1 cycle; the Memory Read and Write cycles allow an additional half a cycle to complete memory access. Thus by enabling the M1 Wait circuitry, you can use memories with access times half a clock cycle slower. In practice, this means that when the CPU is operating at 4 MHz, enabling the M1 Wait state circuitry slows the memory access requirements by approximately 110 nsecs; at 2 MHz it slows the requirements by approximately 220 nsecs. Theoretically, memories with access times slower than 400ns need a Wait state when the CPU is operating at 4 MHz. However, practice is often different than theory; you should experiment with the requirements of your system.

Most of CCS's memory boards do not need Wait states. A11 have provisions, however, for on-board Wait state generation, allowing Wait states to be inserted on an individual board basis. Thus you can slow down the processor for slow memory and allow it to run at full speed with fast. On-board Wait state generation can also be used for very slow memory: adding a Wait state by 4 this method slows access times by approximately 250 nsecs at 500 nsecs at 2 MHz. The disadvantage of on-board Wait MHz and state generation is that it adds a Wait state to every memory cycle in which the memory board is selected. You will have to experiment to discover which method, or combination of methods, is most efficient for your system. Note that the M1 Wait circuitry will also add a Wait state to Interrupt Acknowledge cycles, since the Z-80's M1 control signal is active at that time. The WAIT jumper set to ON enables the M1 Wait circuitry.

2.1.5 Power-on Jump Enable and Address Select Jumpers

If enabled by the JMP EN jumper, the power-on jump circuitry forces the CPU to jump to the address set by the JMP ADDR SEL jumpers when your system is turned on or reset. If the circuitry is disabled, the processor looks for its first instruction at memory location 0000h on power-on or reset. Should you enable the power-on jump circuitry, set the JMP ADDR SEL jumpers, JA15-JA0, to the binary value of the jump address you wish. Please note that JA15 is the high order bit; you should enter the binary address from the bottom up.

If you plan to use the ROM-resident firmware, you must force

a jump to the beginning address of the on-board ROM, F000h, on power-on or reset. To do so, set JA15-JA12 to 1, JA11-JA0 to 0, and JMP EN to ON.

#### 2.1.6 2/4 MHZ Signal Enable Jumper

In the early 8080 systems, pin 98 of the bus was assigned to the status signal sSTACK, indicating that a stack read or write was in progress. Some manufacturers of S-100 systems, noting that sSTACK is little used, have converted this line to a 2 MHz/4 MHz operation indicator, where a high indicates the processor is operating at 4 MHz. We have done so also. This is а convenient feature for those of you with front panels; the sSTACK LED will tell you at a glance at which frequency the CPU is operating. It also allows peripheral devices which can monitor this line to request Wait states only when the processor is operating at 4 MHz. The newly proposed standards for the S-100 bus, however, suggest using pin 98 for an error signal input, ERROR\*. To avoid possible bus conflicts, we have made the 2/4 MHZ line jumper-enabled/disabled.

#### 2.1.7 PHANTOM Enable Jumper

The PHANTOM line is used to overlay memory at a common address. On the the 2810 Z-80 CPU, the PHANTOM line allows an external device generating the PHANTOM signal to overlay the ROM's memory space on a byte-to-byte basis. Such a device might be one of CCS's I/O boards. The ROMs on these boards can generate the PHANTOM signal, allowing portions of the CPU's firmware to be overlaid with the I/O boards' firmware. Thus driver firware for the I/O boards can be patched onto the CPU's firmware, without the CPU's ROM being reprogrammed.

Disable the signal if you do not plan to use it.

#### 2.1.8 NMI Enable Jumper

Unlike the 8080 processor, the Z-80 processor allows two types of interrupts: a maskable interrupt (INT) and a nonmaskable interrupt (NMI). A maskable interrupt request will be accepted by the CPU depending on the state of the processor-internal Interrupt Enable flip-flop, which can be set or reset through software commands. A nonmaskable interrupt request, on the other hand, forces the CPU to do a restart at address 0066h, regardless of the state of the Interrupt Enable flip-flop. On the 2810 board, the nonmaskable interrupt control input appears on pin 12 of the bus, as required by the proposed S-100 bus standards. However, since the 8080 processor does not provide for nonmaskable interrupts, some systems may use pin 12 for another signal. To avoid bus conflicts, we have made the NMI line jumper-enabled/disabled.

#### 2.1.9 REFRESH Enable Jumper

The Z-80, unlike the 8080, is designed to work with dynamic as well as static RAM. At the end of every M1 (op code fetch) cycle, while the CPU is busy decoding the current instruction, the Z-80's refresh register puts out a refresh address on the address lines and the control signal REFRESH goes active. If you have in your system a dynamic RAM board, such as CCS's 65K dynamic RAM board, that can use the REFRESH signal for refresh control, you should enable this line. Consult your memory manual. Some 8080 systems may have the REFRESH line, pin 66, assigned to another signal. If this is true of yours, disable this line.

#### 2.1.10 2/4 MHz Toggle Switch

This toggle switch, located on the top right half of the board, allows you to select the operating frequency of the Z-80. The switch positions are marked on the board. The position of this switch should be set before you turn on your system or reset it. It should not be changed during system operation.

#### 2.1.11 MREQ jumper

Some memory boards require that the MREQ (Memory Request) control signal from the Z-80 be available on the bus at pin 65. If you have such a memory board, you can run a jumper wire from the hex pad marked 65 near the REFRESH jumper at the bottom of the board to the hex pad marked 65 near the WAIT jumper at the top of the board. Consult your memory board manuals to determine if your boards need this signal.

#### 2.2 SERIAL I/O PORT SETUP

The following instructions apply only if you are planning to use the serial port.

#### 2.2.1 I/O Cable Installation

CCS does not supply the cable assembly that plugs into J2, the serial port's connector. You will have to obtain one. The mating connector for J2 is a standard flat ribbon cable connector; the other end of the cable requires a DB-25S connector. If you assemble the cable yourself, be careful not to twist it; the pin 1 strip on the ribbon cable (usually the colored outside strip) should match pin 1 on both connectors. Plug the cable assembly into J2, matching pin 1s. (Pin 1 for J2 is labeled on the board). Push the cable connector down firmly until you can no longer see the metal pins. The DB-25S connector should be fastened to one of the slots in the back of your mainframe. Plug the DB-25P connector on your peripheral's signal cable into it.

#### 2.2.2 Peripheral Configuration

If you plan to use the I/O driver and initialization firmware provided, your peripheral should be set to expect a serial data format of 8 data bits, no parity bit, a 0 stick bit and one stop bit per word. Set your peripheral for the baud rate at which you wish to operate; the firmware will initialize the port to any standard baud rate. Consult your peripheral manual for setup instructions.

If you are not using the initialization firmware provided, you will have to configure your peripheral to match your software.

#### FRONT PANEL SETUP

2.3 FRONT PANEL SETUP

If you will be using the 2810 in a front panel system, you must connect the data cable from the front panel to the front panel data socket, J3. Specific instructions for the Altair and Imsai microcomputers follow.

#### 2.3.1 ALTAIR 8800

You must replace the molex connector on the front panel cable with a DIP plug that you supply yourself. Be careful when soldering the connections: Unlike the data lines on J3, the data lines on the Altair molex connector are not arranged sequentially.

#### 2.3.2 IMSAI

Plug the data cable connector directly into J3, matching pin 1's. Pin 1 is labeled on the board for J3. Pin 1 on the cable connector is identified by a mark or tick on the underside; it does not necessarily correspond with any numbering on top.

#### CHAPTER 3

#### THE MOSS 2.2 MONITOR

CCS's MOSS 2.2 Monitor contains powerful routines for program debugging and for controlling from a console keyboard a system using the 2810 Z-80 CPU. 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, write, and format paper tape.

Note that for the MOSS Monitor to work exactly as described below, the on-board ROM, serial I/O port, and power-on jump circuitry must be enabled, with the serial port's base address set to 20h and the jump address set to F000h.

#### 3.1 THE MONITOR'S MEMORY SPACE

The monitor is resident in the on-board ROM, the starting address of which is FOOOh. In addition, it needs some RAM space 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. The monitor also requires some low RAM as well: you should reserve locations 0000h-0003h and, if you use breakpoints, locations 0008h-000Ah.

#### 3.2 SOFTWARE ENTRY POINTS

A cold-start entry at F000h sets up the system stack and work area, initializes the serial port and register storage area, selects the on-board serial port as the console interface, and loads memory locations 0000h-0003h with a jump instruction to the warm-start routine. It also loads the following locations, called by the Z-80 restart commands, with jump vectors to a restart error message: 0008h-000Ah, 0010h-0012h, 0018h-001Ah, 0020h-0022h, 0028h-002Ah, 0030h-0032h, and 0038h-003Ah. These locations can be overwritten with restart routines.

A warm-start entry at F10Fh resets the stack pointer and the warm start jump vector located at 0000-0002h. All other conditions remain unaffected.

The breakpoint entry at F024 saves all register contents; all other conditions remain unaffected.

#### 3.3 THE BASIC I/O ROUTINES AND THE IOBYTE

You can call the monitor's basic I/O subroutines from your own programs. The jump vectors are as follows:

| Routine name                                | Address                              | Description                                                                                             |  |  |  |
|---------------------------------------------|--------------------------------------|---------------------------------------------------------------------------------------------------------|--|--|--|
| CONIN<br>CONOUT<br>CONST<br>READER<br>PUNCH | F003<br>F009<br>F012<br>F006<br>F00C | Console input<br>Console output<br>Console status<br>Paper tape reader input<br>Paper tape punch output |  |  |  |
| LIST                                        | FOOF                                 | List device output                                                                                      |  |  |  |

These routines perform the IOBYTE handling to support the IOBYTE function, as developed in the Intel MDS system and as used by CP/M. The IOBYTE function allows you to assign a physical device to one or more of four logical peripheral device categories: Console, Punch, Reader, and List. The current physical to logical device assignment is stored in the IOBYTE in location 0003h. When an I/O routine, such as CONIN, is called, it examines the contents of IOBYTE and jumps to the peripheral driver routine indicated by the physical device assignment. The contents of the IOBYTE, and hence the physical device assignments, can be changed through the Assign command.

The monitor firmware contains driver routines to support

3-2

#### THE MONITOR

only the teletype physical assignment in all four logical categories. (Please note that the physical assignment names do not have to accurately describe the actual peripheral used. The teletype assignment, for example, could be used to implement console operations with a CRT.) All other physical assignments cause a jump to the I/O Assignment Error message when one of the above routines is called. For more information, see the Assign command, 3.7.1.

With the exception of CONIN, the above basic I/O routines are CP/M compatible when used with the default teletype assignment. They 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. For a CP/M compatible console input routine, use entry point F68Fh. This routine, CONI, strips the ASCII parity bit as CP/M convention requires.

#### 3.4 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. 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 MONITOR COMMANDS

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

#### -CE1 E2 E3

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

3-3

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, the space and the comma that you can use 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 form free, 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]

#### THE MONITOR

#### 3.6 ERROR MESSAGES

The MOSS monitor detects three 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. If you are using the monitor's basic I/O routines with CP/M, an I/O assignment error will cause the error message to be printed and control returned to CP/M. See the Assign command for more detail.

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 program jump to a restart address without code. A restart error causes a warm boot of the system and the following message to be printed:

#### RST ERR

The message is followed by the monitor prompt. If you are running CP/M with the monitor enabled, a restart error will cause the error message to be printed and control returned to CP/M.

#### 3.7 COMMAND DESCRIPTION

#### 3.7.1 Assign (A)

The Assign command allows you to change the physical-to-logical device assignments and thus choose theperipherals 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 physical devices assigned to them. The possible physical-to-logical assignments are as follows:

- (C) Console Logical Device
  - (T) Teletype
    (C) CRT

  - (B) Batch Mode (input from logical reader device;
  - output to logical list device)
  - (1) User Console #1
- (R) Reader Logical Device
  - (T) Teletype
  - (P) Paper tape reader
  - (1) User reader #1
  - (2) User reader #2.
- (P) Punch Logical Device
  - (T) Teletype
  - (P) High speed paper tape punch
  - (1) User punch #1
  - (2) User punch #2
- (L) List Logical Device
  - (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 peripheral 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

3-6

#### THE MONITOR

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

EXAMPLE:

Entering

-AR-P

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

Assigning a physical device to a logical category alters the contents of the IOBYTE, stored in location 0003h. Every time an input or output routine involving a specific logical device is performed, the I/O routine examines the contents of the IOBYTE to determine the physical device assignment and jumps to the driver routine called by the physical assignment. If there is no driver routine, the I/O routine jumps to I/O assignment error routine, resulting in the I/O Assignment Error message being output and physical assignments being set to their default value, the teletype.

For all the basic I/O routines, the teletype assignment forces a jump to the on-board serial port drivers. The serial port is designed to be the console interface; it is best used for a CRT, although any console device can be used. Please note the port drivers cannot drive the paper tape reader or punch of a teletype. If you have not altered the firmware in any way, calling the Reader or Punch I/O routines results in the CPU reading from or writing to the console device when the teletype assignment is used.

None of the other physical device assignments are supported by driver routines. You can patch driver routines for different devices onto the monitor firmware by two techniques. One is to have the routines residing in a ROM device capable of generating the PHANTOM signal (section 2.1.8), so that the jump instruction to the I/O error message for a particular physical device assignment is overlaid with a jump instruction to the driver routine. CCS's S-100 peripheral boards can work in this manner; each generates the PHANTOM signal when its on-board ROM is selected. If you choose to use this method, you have the choice of programming the ROM yourself or using a CCS preprogrammed ROM. The second technique is to change the jump instruction in the ROM itself. For example, if you wished to connect a line printer to your system, you would change the jump instructions at locations F61D and F676 so that they contained the starting addresses of your driver routines and not the address of the I/O error message. This, of course, means erasing and reprogramming the ROM.

3.7.2 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 A1 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 starts with the address of the first byte in the line, followed by the data in hex and their ASCII equivalents. The contents of locations having the same last hex digit in their address are aligned vertically. Periods represent data for which there are no ASCII equivalents. As the output fills the screen, it will automatically scroll 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 command and cause the monitor prompt to appear.

#### EXAMPLE

Entering

DF450 F4BF

results in the following display:

| F453 |          | E1 08  | 3 D9 D1  | C1 F1 | E1 F9 | 00 21 | 00 00 C3             | a.YQAqay.!C                                                                                                                                                                                                         |
|------|----------|--------|----------|-------|-------|-------|----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| F460 | 00 00 AF | 32 03  | 3 00 21  | 6C F4 | C3 B5 | F6 49 | 2F 4F 20<br>OD CD 7C | /2!ltC5vI/0                                                                                                                                                                                                         |
| F470 | 45 52 D2 | CD E8  | 3 F6 B0  | 47 82 | 57 78 | C9 OÉ | OD CD 7C             | ERRMhv0G.Wx1M                                                                                                                                                                                                       |
| F480 | F6 OE OA | -C3 70 | F6 CD    | 56 F6 | E6 7F | C9 3F | 3F 3F BF             | vC vMVvf.I????                                                                                                                                                                                                      |
| F490 | 4D 4E 51 | 54 20  | 50 45    | 52 54 | 20 32 | 2E 32 | OD 8A 3E             | MOSS VERS 2.2>                                                                                                                                                                                                      |
| F4A0 | OF D3 24 | 11 40  | 00 62 00 | 6A DB | 26 Ā3 | 28 FB | DB 26 23<br>DB 20 2B |                                                                                                                                                                                                                     |
| F4BO | A3 A3 C2 | AD F   | E5 29    | 5C 19 | 19 E5 | 29 29 | DB 20 2B             | .S\$.@.bj[&#({[&#<br>##B-te)\e))[ +</td></tr><tr><td>F4CO</td><td>7D B4 C2</td><td>BD F<sup>1</sup></td><td>E1 3E</td><td>83 D3</td><td></td><td></td><td></td><td><math>}4B=ta>.S</math></td></tr></tbody></table> |

#### THE MONITOR

3.7.3 End Of File (E)

The E command informs the computer to type punch an Intel format End Of File record at the end of a just-punched paper tape file. The Intel EOF format contains both the entry address for the file and six inches null leader. The E command allows you to specify the entry address and change the length of the leader, if you wish. The general form for the command is

#### -EA L

where A is the entry address and L is the length of null leader in tenths of inches expressed in hex. For example, for a four inch leader, enter hex 28 (4"=40 tenths=28h). The default value for the length is six inches; for the address, 0000h. An entry address of 0000h will return control to the monitor after the paper tape has been read.

The Monitor expects two parameters for the E command. A carriage return after the E or first parameter will result in the error message ????. If you wish to set the length and entry address to their default values, simply enter a space or a comma twice.

If you have assigned to the logical punch category a physical punch device for which there is no driver code, using the E command will result in the error message

#### I/O ERR

and the return of the monitor prompt. The exception for this is the teletype default assignment. The firmware is designed to output the EOF record to the console device.

3.7.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 A1 and A2 are the addresses of the first and last bytes of the memory block and C is the constant in hexidecimal.

3-10

EXAMPLE

Entering

#### -F10AA 10BB 1

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

3.7.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 next address in the program. 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 B1 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 (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,B1,B2 (breakpoints set)

There are two more points regarding breakpoints that ought

#### THE MONITOR

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.7.6 Hex Number Addition (H)

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

#### -HA1 A2

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

#### AS AD

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

3.7.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.7.8 Leader (L)

The L command allows you to output hex-number nulls for a paper tape leader. As with the E command, you may specify length of the leader in tenths of inches in hex, the default value being six inches. The form for the L command is

#### -LH

where H is the length in tenths of inches expressed in hex.

If the current physical-to-logical assignment for the Punch category is the teletype, the null leader will be output to the console device unless punch driver routines have been provided for the teletype assignment.

#### 3.7.9 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 A1 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.7.10 Output (0)

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.

If you have CCS memory boards in your system, you can use this command to select a memory bank by outputting a Bank Select Byte to the Bank Select Port. (See your memory board manual.)

3.7.11 Query (Q)

The Q command displays the current physical-to-logical device assignments. Entering the command

-Q[CR]

THE MONITOR

results in the current assignments being displayed in the format

#### C-X R-X P-X L-X

where X equals the physical device code.

3.7.12 Read (R)

The read command allows you to read from an Intel format paper tape in the currently assigned paper tape reader and to add a bias to the starting address in the paper tape header. The general form for the read command is

-RB

where B is the address bias in hex.

The monitor checks for errors while reading the paper tape. If it encounters one, the program is aborted. The read routine also provides error checking of the program loaded in memory; if an error is found, the address of the byte in error is displayed, along with an 8-bit binary representation of the bit error, in which a 1 indicates a bit in error. For example, the display

#### F038 00010000

would indicate that bit 4 of the byte in memory location F038 is in error.

After the paper tape has been read, control will be returned to the monitor if the entry address in the EOF record is zero. If it is a non-zero number, control is transferred to that address.

If the current physical device assigned to the Reader logical category is the teletype, the monitor will respond to the Read commmand by reading a a program in binary typed by hand from the console unless you provide paper tape reader rountines for the teletype assignment.

#### 3.7.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 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 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.7.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 A1 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 bits in error. (See the Read command for further details). 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.7.15 Verify (V)

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

#### -VA1 A2 AD

#### THE MONITOR

where A1 and A2 are the addresses of the first and last byte in the source block and AD is the starting address of the block to be verified. Should the two blocks match, the monitor will return with the prompt. Should two corresponding bytes differ, the monitor will display the source address and its contents in hex, followed by a dash and the contents of the corresponding address of 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.7.16 Write (W)

Use the W command to punch a memory block on paper tape. Enter

#### -WA1 A2 R

where A1 and A2 are the addresses of the first and last byte of the block and R is the record length. The Intel paper tape format specifies a record length of 16 data bytes. You can change that length to any number of bytes from 1 to 255. Enter the length you want in hex. The default value is 16 data bytes. Note the monitor expects three delimiters with this command.

If you want a null leader to begin your file, you must use the L command before the W command. If you want to end your file with an EOF record or null leader, use the E or L command after the file has been punched.

Again, the monitor will output the memory block to the console device if the logical punch category is at its default value and no driver routine has been provided for the teletype punch assignment.

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

1

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 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 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 address; if you wish to alter the contents of the memory location, alter the M register. (See section B.1 for a discussion of the Z-80 registers.)

3.7.18 Initialize Baud Rate (Y)

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

and then set the baud rate of your terminal to the desired rate. Hit the carriage return key until the monitor returns with the prompt. The monitor will accept any baud rate between 2 and 56K baud.

#### 3.7.19 Zleep (Z)

The Z command is used to prevent unauthorized use of your system. Entering

### -Z[CR, space or comma]

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 divided into two main sections: the CPU and the Serial Port. In both sections, active low signals are indicated by an asterisk (\*) following the signal name. Definitions of the signals used by the CPU bus and the serial interface can be found in Appendix A.

4.1 THE CPU

This section describes the 2810's support circuitry for the Z-80. Where it is pertinent, we discuss the Z-80's operation. However, a complete description of the Z-80 is beyond the scope of this manual. Should you wish to know more about it, we suggest you consult a Z-80 technical manual.

Since the S-100 is an 8080-oriented bus, much of the circuitry in the 2810 Z-80 CPU is devoted to interfacing the Z-80 to the S-100 bus. Because of this, and because this board will be used in 8080-based systems, the following discussion of the 2810's operation will often deal with the differences between the 8080 and the Z-80.

4.1.1 The Reset Logic

The gates generating POC\*, pRESET\*, and EXT CLR\* are connected in series, so that when POC\* goes low, pRESET is pulled low, which in turn pulls EXT CLR\* low. POC\* goes low approximately 50 msecs after power-on. The delay is provided by a one-shot which emits a positive-going pulse 50 msecs after power-on. This pulse is inverted and pulls POC\* low. Both pRESET\* and EXT CLR\* can also be pulled low by external switches.

#### 4.1.2 The External Clock Circuitry

The early 8080 microprocessor required a 2 MHz, two-phase, nonoverlapping clock. Thus, by convention, there are three clocks on the S-100 bus: CLOCK, which is a 2 MHz signal; phase one,  $\Phi$ 1; and phase two,  $\Phi$ 2. The Z-80, on the other hand, can operate at either 2 or 4 MHz and requires only a one-phase clock. Thus the functions of the  $\Phi$ 1,  $\Phi$ 2, and CLOCK signals on the 2810 differ from those on an 8080 CPU. On the 2810,  $\Phi$ 1 and  $\Phi$ 2 can be either 2 MHz or 4 MHz signals. Once inverted,  $\Phi$ 2 is the processor's clock, pCLK, while  $\Phi$ 1 is available on the bus simply for those devices that need it. CLOCK remains a 2 MHz signal, regardless of processor speed, for those devices that need a clock of a constant frequency.

The clocks on the 2810 are derived from the on-board 16 MHz crystal oscillator. The 16 MHz signal is divided by 2, 4, and 8 by a synchronous 4-bit counter, U24. Thus the outputs of this counter are in-phase 8 MHz, 4 MHz, and 2 MHz signals. These signals are multiplexed by U22, a 4-to-2 line multiplexer. The select line for the multiplexer is controlled by the 2/4 MHz toggle switch. When the switch selects 2 MHz, the multiplexer's outputs are the 2 and 4 MHz signals. The 2 MHz signal is the  $\Phi$ 2 clock and is inverted and buffered to become pCLK. The 4 MHz signal is inverted and ANDed with the 2 MHz signal, creating the non-overlapping  $\Phi$ 1 clock (see figure 4-1). When 4 MHz operation is selected, the multiplexer's outputs are the 4 MHz and an 8 MHz signals, which, through the process described above, become the 4 MHz  $\Phi$ 1,  $\Phi$ 2, and pCLK signals.

4.1.3 The Address Bus and Address Mirroring

The Z-80's low-order address lines are buffered by a three state bus driver, the outputs of which are bus address lines AO-A7. They are also multiplexed with the Z-80's high-order address lines by U28 and U29, the outputs of which are the bus address lines A8-A15. The select line to the multiplexers is controlled by the address mirroring circuitry. When it is enabled through the address mirror jumper, it will pull the select line high, allowing the low-order address bits onto the high-order address bus whenever the I/O request signal from the Z-80 (IOREQ\*) is active while the M1 signal (M1\*) is inactive.

#### THEORY OF OPERATION - THE CPU

(An Interrupt Acknowledge cycle is distinguished by both signals being active.) In any other case, or if the address mirror circuitry is disabled, the select line to the multiplexer will be low, allowing only the high-order address bits onto the high-order address bus.

The signal ADD DSB\*, when active during DMA operations, places the address bus driver and multiplexers in their high impedance state, allowing an external device to control the address bus without interference from the CPU.

#### 4.1.4 The Data Out and Data In Busses

During pSYNC's active period, status bits must be available on the Data Out bus. On the 2810, this is accomplished by multiplexing the Status signals with the data lines from the Z-80. The output of the multiplexers is the Data Out bus, DOO-DO7. The signal pSYNC controls the state of the select lines. When pSYNC is active high, the status bits are multiplexed onto the Data Out bus. When pSYNC is inactive low, the data bits are multiplexed onto the Data Out bus. The Data Out bus can be placed in its high impedance state by DO DSB\* for DMA operations.

The Data In bus is buffered by an 8-bit, three-state bus driver. This driver is disabled whenever pDBIN is inactive, except during DMA operations (indicated by the active BUS ACK\*). It is also disabled under a number of other conditions. When either the ROM, the serial port, or the power-on jump circuitry is enabled, the driver is disabled, since data will be passed to the CPU on the internal bi-directional data lines. Front panel examination of memory will also disable the Data In bus while the front panel is commanding the CPU through the front panel data lines to fetch the data.

#### 4.1.5 The Control Signals

Because the S-100 is an 8080-oriented bus, the signals on its control bus are generally the functional equivalents of the control signals of the 8080 itself. Thus the 2810 Z-80 CPU must emulate the 8080's control signals if it is to be S-100 compatible. With the control inputs this causes no problem, since the 8080's control inputs have their functional equivalents in the Z-80. The control outputs of the 8080, however, are quite different from those of the Z-80. The 2810 must then generate 8080-like control outputs from the Z-80 outputs. The following section describes how each 8080 control output is emulated by the 2810.

pSYNC In an 8080 system, this signal is generated by the processor during T1 (the first clock cycle) of every machine cycle and indicates to external devices that they can read the current status of the processor on the data bus.

> The Z-80 has no equivalent signal; pSYNCH must be generated entirely through external circuitry. On the 2810 CPU, it is generated primarily by two flip-flops, one to generate pSYNC and the other to turn it off. The first flip-flop, U35b, is clocked by the rising edge of either the inverted M1\*, MREQ\*, or IOREQ\*--whichever goes first in a bus cycle. It is set by the state of active the REFRESH\* line: only when REFRESH\* is inactive high will pSYNC, the Q output of the flip-flop, be high. This prevents pSYNC from being generated during the latter part of an M1 cycle when MREQ\* goes low again with the signal REFRESH\*. So that it can be turned off, pSYNC is input to the second flip-flop, U35a. When U35a is clocked, its Q\* output clears U35b, turning off pSYNC. This flip-flop is clocked by the  $\Phi^2$  clock during cycles in which M1\* or IOREQ\* is active and by the inverted \$2 during bus cycles in which MREQ\* only is active, causing pSYNC to last approximately one clock cycle in any bus cycle, as it does when generated by an 8080. Note that during an I/O cycle, pSYNC occurs during T2, instead of T1, since IOREQ\* goes active then (see Figure 4-1). Its function remains exactly the same, however; it still marks the beginning of the bus cycle and indicates that valid status bits are on the bus.

- pWR\* PWR\* indicates that valid data is present on the data bus and thus becomes active after pSYNC. The Z-80's write control output, WR\*, serves the same function as pWR\*; it simply needs to be disqualified during the active pSYNC. Flip-flop U34b serves this purpose. The flip-flop, its D input tied high, is clocked on the falling edge of pSYNC and cleared on the rising edge. Thus its Q\* output will be low only when pSYNC is inactive. The Q\* output is ORed with WR\*. Only if both signals are low will the output of the OR gate, pWR\*, be active low. See Figure 4-1.
- pDBIN In 8080-based S-100 systems, pDBIN indicates that the data bus is conditioned to accept data from external devices. It goes active with the falling pSYNC signal and occurs during Read and Interrupt Acknowledge cycles. On the



<sup>1</sup> The Z-80 automatically inserts a Wait state in every I/O cycle



THEORY OF OPERATION - THE CPU

4-5

2810, the Z-80's Read signal, RD\*, is inverted and ORed with sINTA, producing pDBIN. Thus pDBIN will be active whenever either RD\* or sINTA is active. Note that pDBIN not disqualified by pSYNC; during a Read cycle it will is be active while pSYNC is active (see Figure 4-1). This allows a longer memory access time, yet causes no bus conflict. During the time pSYNC is active, the Data In and the internal data lines are not being used, the Bus status bits having been gated onto the Data Out bus from the status lines themselves.

- DINTE
- pINTE signal indicates the state of the The processor's internal interrupt enable flip-flop. The 8080 generates this signal itself; on the 2810 board it is generated by an external flip-flop, U14a, since the Z-80 has no equivalent signal. The state of the Z-80 internal flip-flop can be set by the EI (Enable interrupt Interrupts) and DI (Disable Interrupts) commands. In binary these commands are 1111 1011 and 1111 0011. Note that these commands are distinguished by the state of bit only. The rest of the bit pattern is the same. U32 3 monitors the data lines DO-D2 and D4-D7 for the EI/DI bit pattern. When it occurs, U32 enables flip-flop U14b, allowing it to be clocked by M1\* going inactive. When U14b is clocked, its Q output in turn clocks U14a. If D3 is high, the output of U14a, pINTE, will be set high and the Interrupt Enable LED lit. If D3 is low, pINTE will be low. U14a is cleared and pINTE made inactive low by either the active pRESET\* or sINTA. Thus the state of pINTE can be changed only by an EI or DI op code, a system reset, or an Interrupt Acknowledge. It should therefore accurately reflect the state of the processor internal interrupt flip-flop.
- pHLDA goes active in an 8080 system in response to a HOLD pHLDA request, indicated by the active pHOLD\*. In the Z-80, there are two equivalent signals, BUSRQ\* (Bus Request) and BUSAK\* (Bus Acknowledge). Thus on the 2810. BUSAK\* is simply inverted to create pHLDA.
- The signal pWAIT indicates that the processor has entered TIAWG a Wait state. The Z-80 has no equivalent signal. On the 2810 this signal is generated by the Wait state flip-flop, U34a. This flip-flop is preset every time a device requests a Wait state. This forces its Q output, pWAIT, high. This signal remains high until Preset is released and the flip-flop is clocked by the rising edge of the 8 MHz clock from U24. Please note that on the 2810, pWAIT may be active high even if the processor itself has not entered a Wait state. pWAIT goes high whenever a device requests a Wait state. The CPU, however, samples the

state of its Wait input only on the falling edge of pCLOCK during T2. A device must make its first Wait request then or the CPU does not recognize it.

### 4.1.6 The Status Bus

The status bus on the S-100 bus communicates to external devices the current state of the processor--i.e, what bus cycle it is in--and qualifies the nature of the address on the address lines. At the beginning of each instruction cycle, the 8080 puts the 8-bit status information from its internal register out on the data bus where it can be sampled by external devices. The active pSYNC indicates its stable presence on the bus. At the same time the status information is latched in the external status latch to generate the status bus signals. The meaning of the status bits are summarized in the table below.

| DATA BUS BIT          | D7   | D6  | D5 | D4  | D3   | D2 <sup>1</sup> | D1 | DO   |
|-----------------------|------|-----|----|-----|------|-----------------|----|------|
| STATUS BIT            | MEMR | INP | M1 | OUT | HLTA |                 | wo | ΙΝΤΑ |
| Instruction Fetch     | 1    | 0   | 1  | 0   | 0    | x               | 1  | 0    |
| Memory Read           | 1    | 0   | 0  | 0   | 0    | x               | 1  | 0    |
| Memory Write          | 0    | 0   | 0  | 0   | Ø    | x               | 0  | o    |
| Input Read            | 0    | 1   | 0  | 0   | 0    | x               | 1. | 0    |
| Output Write          | 0    | 0   | 0  | 1   | 0    | x               | 0  | 0    |
| Interrupt Acknowledge | 0    | 0   | 1  | 0   | 0    | x               | 1  | 1    |
| Halt Acknowledge      | 1    | о   | 0  | o   | 1    | ×               | 1  | 0    |

<sup>1</sup> In 8080 systems D2 is the STACK bit. On the 2810 sSTACK is not generated. See 2.1.6.

#### TABLE 4-1 STATUS WORD DEFINITIONS

Because the status of the Z-80 can be decoded from the control outputs themselves, the Z-80 has no internal status register. Therefore, the S-100 Status lines must be generated from the control outputs. When pSYNC is active, the status lines, with two exceptions, are gated onto the data bus by the bus multiplexers. Two of the status lines, sWO\* and sINTA, will not always be active when pSYNC is active. The WO and INTA status bits must be generated separately.

sINTA This signal indicates that the CPU has accepted an interrupt and is awaiting instruction from the interrupting device. The Z-80 indicates an Interrupt Acknowledge cycle by both M1\* and IOREQ\* being active in the same bus cycle. IOREQ\* in this case goes active almost 2 1/2 clock cycles after M1\* and is the Z-80's read strobe for this cycle. The bus signal sINTA is generated by ANDing the inverted signals M1\* and IOREQ\*. Thus sINTA will be high only when IOREQ\* is active. This is important since the 2810 uses sINTA to generate the bus Data In strobe, pDBIN, during an Interrupt Acknowledge cycle. However, sINTA generated this way does not become active until T3--too late to be gated onto the Data Out bus by pSYNC. Therefore the INTA status bit is generated by the inverted M1\* being ANDed with RD\*. Only when RD\* is inactive high will the INTA bit be high. Since an active M1\* occurs without an active RD\* only during an Interrupt Acknowledge cycle, the state of the INTA bit accurately reflects the bus cycle.

- SWO\* When active low, sWO\* indicates that the CPU is in a Write cycle. On the 2810 board, sWO\* and the status bit WO are generated by two different methods. The status signal is simply the Z-80's WR\* signal. However, WR\* goes active low during T2 of a Memory Write cycle--too late to be present on the data bus when pSYNC is active. Thus the status bit WO is generated by either MREQ\* or IOREQ\* being active while RD\* is inactive. Only during an I/O or Memory Write cycle would RD\* be inactive. The method by which the status bit WO\* is generated cannot be used to generate sWO\*, since sWO\* would then be generated during an Interrupt Acknowledge cycle.
- sHLTA sHLTA and the Z-80 HALT\* both indicate that the CPU has received a HALT instruction and is awaiting an interrupt. Thus sHLTA on the 2810 board is the inverted HALT\*. The active sHLTA lights the Halt Acknowledge LED.
- sOUT Indicating that the CPU is outputting data to an I/O device, this signal is generated when both IORQ\* and WR\* are active.
- sM1 This signal is active during the Op Code Fetch cycle of an instruction execution cycle and during an Interrupt Acknowledge cycle in both the 8080 and Z-80. Thus sM1 is generated by the inverted M1\* of the Z-80.
- sINP Indicating that the CPU is reading data from an I/O device, this signal is active when both IORQ\* and RD\* are active.
- sMEMR Active high when during a Memory Read cycle, sMEMR is active only when both MREQ\* and RD\* are active.

#### THEORY OF OPERATION - THE CPU

4.1.7 The Wait Circuitry

The WAIT\* input to the Z-80 is low when any of the following four conditions occurs: 1) the XRDY line is pulled low; 2) the pRDY line is pulled low; 3) M1\* is active when the M1 Wait states are enabled; 4) the ROM is enabled when the Z-80 is operating at 4 MHz. U21c monitors for these conditions, its output going high whenever one of them is met. This high is inverted and pulls the Preset line to the Wait flip-flop, U34a, low. The resulting low on the flip-flop's Q\* output pulls the WAIT\* input to the Z-80 low. Q\* will remain low as long as U21c continues to pull the Preset input to the flip-flop low. As soon as U21c releases the Preset line, the flip-flop will be reset when it is clocked by the rising edge of the 8 MHz clock from U24.

The 8 MHz clock is used to ensure that one and only one Wait state is generated per cycle in which the M1 or ROM Wait state circuitry is active. A Wait request from either circuit is qualified by pSYNC; only if pSYNC is active will U21c be pulled high. In most memory cycles, qualifying the signal with pSYNC ensures one Wait state per cycle. However, during an M1 cycle, pSYNC goes inactive before T2. Resetting the Wait flip-flop with the 8 MHz clock allows WAIT\* to remain active long enough for the CPU to sample it, but not so long as to generate an extra Wait state.

#### 4.1.8 The Rom Enable Circuitry

Address lines AO-A10 from the Z-80 are input directly to the ROM, since eleven address bits are necessary to select one location out of 2K. Address lines A11-A15 are input to the Address decoding ROM, U9, along with MREQ\* and PHANTOM\*. When U9 receives address bits on the high order address lines in the range of FO-F7 when PHANTOM\* is inactive and MREQ\* active, the output of U9 is pulled low. If the ROM enable jumper is set ON, this low is jumpered to the enable inputs of the ROM, enabling it and lighting the ROM LED. At the same time, the Data In bus will be disabled. If either PHANTOM\* is active or MREQ\* is inactive, U9's output will be high, disabling the ROM. 4.1.9 Power-on Jump Circuitry

The power-on jump circuitry works by placing on the data bus the unconditional jump command C3 (11000011) during the first M1 cycle after power-on or a system reset and the low byte and high byte of the jump address during the two memory read cycles that follow a jump instruction. Because the Power-on Jump circuitry, when enabled, disables the Data In bus, there is no conflict with memory.

The correct order and timing of the command and address bytes are achieved through the use of four D-type flip-flops and two 8-line-to-4-line multiplexers. The flip-flops are used as a 4-bit shift register, the Q output of one flip-flop being tied to the D input of the next. The flip-flops are triggered by the inverted RD\*. When the CPU is reset or turned on, it executes an M1 cycle, pulling the RD\* line low. This triggers the first flip-flop, the output of which simply is tied to the next. In the meantime, the A input lines to the multiplexers are tied in such a way as to generate the data byte 11000011, which is multiplexed onto the internal data bus and read by the CPU. The CPU then executes a memory read cycle as a result of receiving a jump instruction, pulling the RD\* line low again. clocks This the second flip-flop, the outputs of which change the state of the A input lines such that they reflect the address settings on the Low Byte Address jumpers. The low address byte thus can be read by the CPU. During the next memory read cycle, the third flip-flop is clocked, its output changing the state of the Select inputs on the the multiplexers, allowing the B inputs to the multiplexers onto the internal data bus. Because the B inputs reflect the settings of the High Byte Address jumpers, the CPU receives the high byte address. After having received the jump address, the CPU executes another M1 cycle to fetch the op code at the jump address. When RD\* goes low again for the M 1 cycle, the fourth flip-flop is clocked, the output of which disables the multiplexer, effectively disqualifying the power-on jump circuitry, and enables the Data In bus, allowing the CPU to read from the jump address. When the system is reset, pRESET\* clears all the flip-flops, allowing the process to begin again.

#### 4.2 THE SERIAL I/O PORT

National's 8250 Asynchronous Communications Element performs almost all the necessary functions to interface the CPU to a serial peripheral device. It takes the parallel data it receives from the CPU and converts it to serial, adds start and stop bits, and transmits it over a single wire one bit at a time. When receiving serial data from the peripheral, it does the reverse, stripping the start and stop bits from the data and converting the data to parallel for output over the eight internal data lines to the CPU. The 8250 requires a external clock, provided on the 2810 by a 1.8432 crystal oscillator. It also requires some minimal circuitry to interface it to the CPU and the peripheral.

### 4.2.1 The CPU Interface

The 8250 is selected when its chip select inputs, CSO and CS1, are high. CS1 is high when IOREQ\* is active when M1\* is inactive. (The qualifying of IOREQ\* with M1\* is necessary to distinguish a valid I/O cycle from an Interrupt Acknowledge cycle.) CSO is high when the address bits on A3-A7 match the settings of the Serial Address Select jumpers. Read/Write control is provided by pDBIN and pWR\*, which control the Data Out Strobe and Data In Strobe of the 8250 respectively, allowing the CPU to read and write to the registers selected by A0-A2. When the CPU is reading from the 8250's registers, the 8250's DDIS\* line goes active, disabling the CPU's Data In bus, since data will be transferred on the 2810's internal bi-directional data lines.

### 4.2.2 The Peripheral Interface

The Peripheral side of the interface consists of a set of line drivers and receivers which translate between the TTL signals of the 8250 and the nominal +5 to -5 volt signals required by the RS-232-C interface. The 8250's handshake lines are also used in a way which requires explanation.

The RS-232-C specifications are concerned with the communication link between a MODEM (or data communications equipment, DCE for short) and a computer terminal (or data terminal equipement, DTE for short). Thus equipment conforming to the RS-232-C specifications must take on the role of either a DCE or DTE device. The 2810's serial port is designed to be the DCE side of the interface. The problem here is that the 8250's handshake lines are defined as those of a DTE device. Thus the roles of the 8250 handshake lines must change. For example, the input into the 8250's CTS (Clear To Send) pin comes actually from the DCE-type connector's RTS (Request to Send) line. The 8250's output DTR (Data Terminal Ready) appears on the connector's DSR (Data Set Ready) line. The 8250's auxiliary output, OUT 1, is

tied to the connector's Received Line Signal Detect (RLSD), allowing RLSD to be available to signals that require the signal. The following table summarizes the connections between the 8250 and the DCE-type connector.

| 8250  | CONNECTOR |
|-------|-----------|
|       |           |
| DSR   | DTR       |
| CTS   | RTS       |
| RTS   | CTS       |
| DTR   | DSR       |
| OUT 1 | RLSD      |

### TABLE 4-3

If you have reason to consult an 8250 data sheet, please keep these role changes in mind. The serial input from the peripheral is also connected to the 8250's Ring Indicator input to support the auto-baud feature of the 2810's firmware.

# APPENDIX A

THE 2810 Z-80 CPU BUSSES

A.1 THE SYSTEM BUS

A.1.1 The S-100 Bus

The S-100 bus came into being with the Altair line of microcomputers using the 8080 microprocessor. Known then as the Altair bus, it was adopted by many other microcomputer manufacturers and became an unoffical industry standard; hence the name "standard-100" bus.

Recently the IEEE has undertaken the development of an official standard for the S-100 bus. The proposed standard differs from the unofficial standard in the definitions of several lines. The changes reflect in part the changes in the microcomputer industry. New processors have come onto the market with new capabilities: 16-bit data transfer, dynamic memory refresh, nonmaskable interrupts, etc. And as system design has become more sophisticated, there has been a move away from front panels. In the proposed standards, for example, several signals previously used for front panel functions have been eliminated and the lines themselves reserved for future use. The differences between the proposed standard and the unofficial standard present a dilemma for the manufacturer of S-100 product: Should he conform to the proposed standard or aim for current product compatability?

The 2810 board represents a compromise; we have conformed to the proposed standards where possible without sacrificing compatiblity with the major S-100 systems currently on the market. In the next section, we define the signals used by the 2810 system bus, and make note of discrepancies between our line use and those of the unofficial or the proposed standards.

A.1.2 The 2810 System Bus

The following are definitions of the signals used by the 2810 system bus. We have followed the convention of indicating active low signals with an asterisk (\*) following the signal mnemonics.

For clarity's sake, we have divided the signals on the 2810 bus into 6 categories: 1) the address and data busses, 2) the status bus, 3) processor control signals, 4) front panel control, 5) DMA control, and 6) system utilities. 1. Data and Address Lines

A0-A15 The 16-bit parallel address lines.

DIO-DI7 The 8-bit parallel data input lines.

D00-D07 The 8-bit parallel data output lines.

2. The Status Signals

The Status signals indicate the nature of the bus cycle in progress and are the functional equivalents of the outputs of the 8080's status latch. The mnemonics for the status lines begin with a lower case "s."

- sINTA The Interrupt Acknowledge signal indicates that the CPU has accepted an interrupt.
- sWO\* The Write/Output signal indicates that the CPU is in a write or output cycle.
- sHLTA The Halt Acknowledge signal indicates that the CPU is executing a HALT instruction.
- sOUT The Output signal indicates that the CPU is executing an output instruction.
- sM1 The M1 cycle signal indicates that the CPU is in the Op Code fetch portion of an instruction cycle.
- sINP The Input signal indicates that the CPU is executing an input instruction.
- sMEMR The Memory Read signal indicates that the CPU is reading from memory.

#### 3. The Processor Control Signals

The processor control signals are concerned with synchronizing the movement of data to and from the processor during any machine cycle. With the exception of NMI\*, REFRESH\*, and MREQ\*, they are the functional equivalents of the 8080 control inputs and outputs and are generally prefixed with the letter "p." Outputs

- pSYNC The Sync signal indicates the presence of status bits on the Data Out bus.
- pDBIN The Data Bus In signal gates the data on the Data In bus onto the 2810's internal data lines.
- pWR\* The Write signal indicates the presence of valid data on the Data Out bus.
- pHLDA The Hold Acknowlege signal indicates that the CPU has relinquished control of the bus in response to a Hold request.
- pWAIT The Wait signal indicates that the CPU has entered a Wait state. In the proposed standard, this signal is eliminated and the line is reserved for future use.
- pINTE The Interrupt Enable signal indicates that the CPU will respond to interrupt requests. In the proposed standard, this signal is eliminated and the line is reserved for future use.
- REFRESH\* (Optional) The Refresh signal is a control signal for dynamic memory refresh. During the time REFRESH\* is active, a dynamic memory refresh is totally transparent to the processor. This line is left undefined by the proposed standard.
- MREQ\* (Optional) The Memory Request signal from the Z-80 indicates that the address bus holds a valid address for a memory read or write. This line is left undefined by the proposed standard.

#### Inputs

- pRDY The Ready signal allows external devices to place the CPU in a Wait state.
- pINT\* The Interrupt signal allows external devices to request service from the CPU.
- pHOLD\* The Hold signal allows external devices to request control of the bus.
- NMI\* (Optional) The Nonmaskable Interrupt signal allows external devices to assert an interrupt request that

cannot be masked off by the CPU.

- pRESET\* The Reset signal, when active low, resets the CPU. It is generated usually by a front panel switch and is also asserted by POC\*.
- 4. Front Panel Control
- XRDY The External Ready signal is a ready line generally used by front panels for single-step or stop operations.
- SSW DSB\* The Sense Switch Disable signal disables the data input lines DIO-DI7 so that the input from the front panel sense switches can be strobed onto the internal bi-directional data bus. The proposed standard eliminates this signal and reserves the line for future use.
- RUN The Run signal indicates the state of the Run/Stop flip-flop on the front panel is set to Run. This proposed standard eliminates this signal and reserves the line for future use.
- SS The Single Step signal indicates a single step is being performed. The proposed standard eliminates this signal and reserves the line for future use.

5. DMA Control

- STAT DSB\* The Status Bus Disable signal allows external devices to place the status bus driver in its high impedance state.
- C/C DSB\* The Command/Control Disable signal allows external devices to place the control bus driver in its high impedance state.
- ADD DSB\* The Address Disable signal allows external devices to place the address bus driver in its high impedance state.
- DO DSB\* The Data Out Disable signal allows external devices to place the Data Out driver in its high impedance state.

6. System Utilities

- POC\* Active only during power-on, the Power-On Clear signal asserts EXT CLR\* and RESET\*.
- EXT CLR\* When active, the External Clear signal resets external devices.
- MWRT 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.
- PHANTOM (Optional) The Phantom signal is used to control memory overlay. On the 2810 board, an external device can use it to overlay the memory space occupied by the on-board ROM.
- $\phi_1$   $\phi_1$  is the phase one clock for the 8080.
- $\Phi$ 2  $\Phi$ 2 is the phase two clock for the 8080.
- CLOCK Clock is a 2 MHz signal, regardless of processor speed.
- 2\*/4 MHZ (Optional) When high, this signal indicates the processor is operating at 4 MHz. When it is low, it indicates the processor is operating at 2 MHz. The early S-100 bus used this line for the sSTACK signal; the proposed standard suggests this line be used for the signal ERROR\*.
- +8 VOLTS This is the unregulated +8 Volts from the power supply.
- +16 VOLTS This is the unregulated +16 Volts from the power supply.
- -16 VOLTS This is the unregulated -16 Volts from the power supply.

C

I

R

C

Ú

T

S

L

D

Ε

## A.1.3 The System Bus Pin Assignments





COMPONENT SI

D

Ē

#### TOP VIEW

\*Jumper-enabled signals

A.2 SERIAL INTERFACE BUS

### A.2.1 Signal Definitions

The following are the RS-232-C signals used by the asynchronous serial port.

### Inputs

- DTR Data Terminal Ready. When active, this signal indicates that the peripheral is ready to establish a communications link and receive or transmit data to/from the 8250.
- RTS Request to Send. When active, this signal indicates that the peripheral's transmit data buffer is full and is ready to transmit data.
- TxD Transmit Data. This signal is the serial data input from the peripheral to the 8250.

### Outputs

- RxD Receive Data. This signal is the serial output from the 8250 to peripheral.
- CTS Clear To Send. The active signal informs the peripheral that the 8250 is ready to send data.
- DSR Data Set Ready. This informs the peripheral that the 8250 is ready to communicate.
- RLSD Received Line Signal Detect. This signal indicates that the 8250 has detected a signal from the peripheral.

A.2.2 RS-232-C Pin Assignments

# 2810 DCE-TYPE CONNECTOR PIN ASSIGNMENTS EIA RS-232-C STANDARD



A-10

# APPENDIX B

•

THE 2810 ACCESSIBLE REGISTERS

# THE Z-80 PROGRAM ACCESSIBLE REGISTERS

### B.1 THE Z-80 PROGRAM ACCESSIBLE REGISTERS

Twenty-two of the Z-80's internal registers are accessible to the programmer. Figure B-1 shows the configuration of the accessible registers, while sections B.1.1 through B.1.3 give a short description of them.

| ACCUMULATOR<br>A  | FLAG<br>F  | MAIN SET      |
|-------------------|------------|---------------|
| ACCUMULATOR<br>A' | FLAG<br>F' | ALTERNATE SET |



SPECIAL PURPOSE REGISTERS

GENERAL PURPOSE REGISTERS



## B.1.1 Accumulator and Flag Registers

The two 8-bit accumulators hold the result of arithmetic and logical operations while their associated flag registers indicate the special results of such operations. A single exchange instruction allows the programmer to work with either pair of registers.

## B.1.2 Special Purpose Registers

Program Counter (PC)--This 16-bit register holds the memory address of the current instruction. The PC is automatically

incremented after its contents have been transferred to the address lines. A program jump overrides the incrementer and places a new value in the PC.

Stack Pointer (SP)--This 16-bit register holds the address of the current top of a stack located anywhere in external RAM memory. The PUSH and POP instructions push data from specific registers onto the stack or pop the data off the stack into specific registers.

Index Registers (IX and IY)--These two independent 16-bit registers hold a base address that is used in indexed addressing modes. This base address is used in conjunction with a displacement byte (a two's complement integer) in an indexed instruction to specify a location in memory.

Interrupt Page Address Register (I)--This register is used for interrupt response mode involving an indirect call to memory. The register stores the high order 8-bits of the indirect address; the interrupting device provides the lower 8-bits. (See your programming manual for more details.)

Memory Refresh Register (R)--This register is used as counter register for dynamic memory refresh. It contains a refresh address which is placed on the address bus during the last two clock cycles of every M1 cycle. The address is then automatically incremented. You would not normally access this register, although you can load it for testing purposes.

B.1.3 General Purpose Registers

The general purpose registers consist of a main and alternate set of six 8-bit registers. They can be used as individual 8-bit registers or as 16-bit register pairs. The main set pairs are BC, DE, and HL; the alternate set pairs are BC', DE', and HL'. A single exchange command allows the programmer to select either set. See your Z-80 programming manual for more details.

B-4

#### THE 8250 ADDRESSABLE REGISTERS

### B.2 THE 8250 ADDRESSABLE REGISTERS

There are nine accessible registers of concern in the 8250. These registers are addressed through the low-order three bits of the serial port address. The registers are addressed as follows:

| DLAB | A 2 | A 1 | AO | REGISTER                                                     |
|------|-----|-----|----|--------------------------------------------------------------|
| 0    | 0   | 0   | 0  | Receiver Buffer (read), Transmitter Holding Register (write) |
| 0    | 0   | 0   | 1  | Interrupt Enable                                             |
| x    | 0   | 1   | 1  | Line Control                                                 |
| х    | 1   | 0   | 0  | Peripheral Control                                           |
| х    | 1   | 0   | 1  | Line Status                                                  |
| х    | 1   | 1   | 0  | Peripheral Status                                            |
| 1    | 0   | 0   | 0  | Divisor Latch (least significant byte)                       |
| 1    | 0   | 0   | 1  | Divisor Latch (most significant byte)                        |

#### TABLE B-1 8250 REGISTER ADDRESSING

Note that the address lines alone are not always sufficient to select a register; the state of the Divisor Latch Bit (DLAB) of the Line Control Register determines which of the registers sharing the same address will be selected.

The contents and function of each register are summarized in Table B-2 below. In addition, six of the registers are described in more detail in the the following pages. If you consult the 8250's data sheet, you will notice discrepancies between our bit descriptions and the data sheet's descriptions for some of the bits. Such discrepancies are more apparent than real: the data sheet assumes the 8250 will be used as a DTE device and thus has named the bits accordingly; we use it as a DCE device and thus have renamed the bits. Note that since we do not use the 8250's interrupt capabilities, the first four bits of the Interrupt Enable Register should be set to 0.

|            | 1 | 0 DLAB ≃ 0                                    | 0 DLAB=0                                           | 1 DLAB=0                        | 3                           | 4                                 | 5                                           | 6                                | 0 DLAB = 1       | 1 DLAB = 1       |
|------------|---|-----------------------------------------------|----------------------------------------------------|---------------------------------|-----------------------------|-----------------------------------|---------------------------------------------|----------------------------------|------------------|------------------|
|            |   | Receiver<br>Buffer<br>Register<br>(Read Only) | Transmitter<br>Holding<br>Register<br>(Write Only) | interrupt<br>Enable<br>Register | Line<br>Control<br>Register | Peripheral<br>Control<br>Register | Line<br>Status<br>Register                  | Peripheral<br>Status<br>Register | Divisor<br>Latch | Divisor<br>Latch |
| _          |   | RBR                                           | THR                                                | IER                             | LCR                         | PCR                               | LSR                                         | PSR                              | DLL              | MSR              |
|            | 0 | Data Bit O                                    | Data Bit O                                         | Set to O                        | Word Length<br>Select Bit O | DSR                               | Data Ready                                  | Delta CTS                        | Bit O            | Bit 8            |
|            | 1 | Data Bit 1                                    | Data Bit 1                                         | Set to O                        | Word Length<br>Select Bit 1 | CTS                               | Overrun<br>Error                            | Delta DSR                        | Bit 1            | Bit 9            |
| а          | 2 | Data Bit 2                                    | Data Bit 2                                         | Set to O                        | Number of<br>Stop Bits      | RLSD                              | Parity Error                                | 0                                | Bit 2            | Bit 10           |
| BIT NUMBER | 3 | Data Bit 3                                    | Data Bit 3                                         | 0                               | Parity<br>Enable            | Set to 1                          | Framing<br>Error                            | 0                                | Bit 3            | Bit 11           |
| B          | 4 | Data Bit 4                                    | Data Bit 4                                         | 0                               | Even Parity<br>Select       | Loop                              | Break<br>Interrupt                          | RTS                              | Bit 4            | Bit 12           |
|            | 5 | Data Bit 5                                    | Data Bit 5                                         | 0                               | Stick Parity                | 0                                 | Transmitter<br>Holding<br>Register<br>Empty | DTR                              | Bit 5            | Bit 13           |
|            | 6 | Data Bit 6                                    | Data Bit 6                                         | 0                               | Set Break                   | 0                                 | Transmitter<br>Shift<br>Regi_ter<br>Empty   | 0                                | Bit 6            | Bit 14           |
|            | 7 | Data Bit 7                                    | Data Bit 7                                         | o                               | Divisor Latch<br>Access Bit | o                                 | 0                                           | 0                                | Bit 7            | Bit 15           |

REGISTER ADDRESS

### TABLE B-2 8250 REGISTER SUMMARY

### B.2.1 Peripheral Control Register

This register controls the interface with the peripheral. Bits 0 through 2 control the state of the DSR, CTS, and RLSD outputs. To set one of these signals active high, write a 1 to its bit. Bit 4, when set to 1, enables loopback testing, in which the data in the transmitter register is looped to the receiver register, without having been output. Thus data that is transmitted is immediately received. See Table B-2 for a summary of the register.

### THE 8250 ADDRESSABLE REGISTERS

### B.2.2 Line Control Register

The line control registers allows you to specify the serial data format. For ease of programming, you can examine the contents of the line control register at any time. The bit definitions and functions are summarized in Table B-3.

| BIT NO. | BIT NAME              | FUNCTION                                                                                                                                                                              | DEFINITION                                                                              |
|---------|-----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------|
| 0<br>1  | Word Length<br>Select | Bit 0         Bit 2 = Word Length           0         0         5 bits           0         1         6 bits           1         0         7 bits           1         1         8 bits |                                                                                         |
| 2       | Stop Bits Select      | Selects the number of stop bits in<br>each serial character.                                                                                                                          | 0 = 1 Stop bit<br>1 = 1 1/2 Stop bits (5-bit word)<br>2 Stop bits (6-, 7-, 8-bit words) |
| 3       | Parity Enable         | Selects whether or not a parity bit is<br>generated between the last data bit<br>and stop bit(s).                                                                                     | 0 = No Parity bit<br>1 = Parity bit                                                     |
| 4       | Even Parity Select    | Selects whether the parity bit will<br>make an even or odd number of 1s in<br>the data word.                                                                                          | 0 = Odd parity<br>1 = Even parity                                                       |
| 5       | Stick Parity          | Selects whether a 1 or a 0 will be sent in the parity bit position.                                                                                                                   | Bit 3 Bit 4 Bit 5 = Stick parity bit<br>x x 0 None<br>1 0 1 1<br>1 1 1 0                |
| 6       | Set Break             | Selects whether or not sOUT is forced to spacing (logic 0)                                                                                                                            | 0 = Break disabled<br>1 = Break (spacing enabled)                                       |
| 7       | Divisor Latch         | Determines which register of those<br>sharing the same address is selected.                                                                                                           | 0 = Receiver buffer or transmitter<br>holding register<br>1 = Divisor latches           |

#### TABLE B-3 LINE CONTROL REGISTER

### B.2.3 Peripheral Status Register

This register indicates the current state of the control lines from the peripheral device. The first two bits are set to a logic 1 whenever the state of the control line has changed since the peripheral status register was last read by the CPU. See Table B-2 for a summary of the register's contents.

### B.2.4 Line Status Register

This register provides status information to the CPU concerning the data transfer. The bit definitions and functions are summarized in Table B-4 below. Except where otherwise noted, the bits are reset when the CPU reads the line status register.

| BIT NO. | NAME                                            | DEFINITION                                                                                                                                              |
|---------|-------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0       | Data Ready (DR)                                 | Set to 1 if the Receiver Buffer is full. Reset by CPU reading buffer or writing a 0 to it.                                                              |
| 1       | Overrun Error (OE)                              | Set to 1 if the CPU did not read the data in the Receiver Buffer before the next character was transferred to it.                                       |
| 2       | Parity Error (PE)                               | Set to logic 1 when a parity error is detected.                                                                                                         |
| 3       | Framing Error (FE)                              | Set to 1 if incoming character has no valid stop bit .                                                                                                  |
| 4       | Break Interrupt (BI)                            | Set to 1 whenever the received data input is held in the<br>spacing state for longer than a full word transmission<br>time.                             |
| 5       | Transmitter Holding<br>Register Empty<br>(THRE) | Set to 1 when Transmitter Holding Register is empty,<br>having transferred its data to the Transmitter Shift<br>Register. Reset when CPU loads the THR. |
| 6       | Transmitter Shift<br>Register Empty<br>(TSRE)   | Set to 1 when Transmitter Shift Register is idle . Reset<br>upon data transfer from THR. A read-only bit.                                               |
| 7       |                                                 | Permanently set to 0                                                                                                                                    |

### TABLE B-4 LINE STATUS REGISTER

#### B.2.5 Divisor Latch Registers

,

The divisor latch registers are used to select the baud rate you wish. The programmable baud rate generator can divide the 1.8432 Mhz clock input by any divisor from 1 to (2\*\*16)-1. The output frequency of the baud rate generator is 16X the baud rate (divisor# = frequency input/ (baud rate \* 16)). The divisor is stored in the two divisor latches in a 16-bit binary format. Table B-5 shows the divisors for some common baud rates.

# THE 8250 ADDRESSABLE REGISTERS

| BAUD<br>RATE | DIVISOR<br>FOR 16x<br>CLOCK | PERCENT ERROR<br>DIFFERENCE BETWEEN<br>DESIRED AND ACTUAL |
|--------------|-----------------------------|-----------------------------------------------------------|
| 50           | 2304                        | -                                                         |
| 75           | 1536                        | · _                                                       |
| 110          | 1047                        | 0.026                                                     |
| 134.5        | 857                         | 0.058                                                     |
| 150          | 768                         | -                                                         |
| 300          | 384                         | _                                                         |
| 600          | 192                         | -                                                         |
| 1200         | 96                          | -                                                         |
| 1800         | 64                          | -                                                         |
| 2000         | . 58                        | 0.69                                                      |
| 2400         | 48                          | -                                                         |
| 3600         | 32                          | -                                                         |
| 4800         | 24                          | _                                                         |
| 7200         | 16                          | -                                                         |
| 9600         | 12                          | -                                                         |
| 19200        | 6                           | -                                                         |
| 38400        | 3                           | -                                                         |
| 56000        | 2                           | 2.86                                                      |

TABLE B-5 BAUD RATE DIVISOR

# APPENDIX C

# FIRMWARE LISTING

| CP/M MACRO ASSE                                                                                                                                            | M 2.0 #001                                                                                                                                                                                                  | MOSS 2.2 MONITOR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                                                                                                                            | ; TITLE<br>PAGE<br>MACLI                                                                                                                                                                                    | 68                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|                                                                                                                                                            | MOSS MONITO                                                                                                                                                                                                 | R (VERSION 2.2)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|                                                                                                                                                            | 20 JUNE 198<br>ALL RIGHTS                                                                                                                                                                                   | CO<br>RESERVED BY ROBERT B. MASON                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| F000<br>F000 =<br>0002 =<br>0013 =<br>000D =<br>000A =<br>000C =<br>0007 =<br>0003 =<br>0020 =<br>0021 =<br>0022 =<br>0022 =<br>0022 =<br>0022 =<br>0022 = | MOSS: ORG<br>ROM: EQU<br>WSVEC: EQU<br>NBKPTS: EQU<br>CR: EQU<br>CR: EQU<br>LF: EQU<br>FMFD: EQU<br>BELL: EQU<br>SDATA: EQU<br>SINTEN: EQU<br>SINTEN: EQU<br>SLCTRL: EQU<br>SMDMCT: EQU<br>SMDMST: EQU<br>; | OFOOOH<br>OFOOOH<br>OFOOOH<br>; ROM START ADDRESS<br>O<br>VECTOR FOR WARM RESTART<br>2<br>NUMBER OF BREAKPOINTS<br>13H<br>; ASCII DC3<br>ODH<br>ASCII CARRIAGE RETURN<br>OAH<br>ASCII LINE FEED<br>OCH<br>; ASCII FORM FEED<br>7<br>ASCII CNTRL CHAR TO RING THE BELL<br>3<br>ADDRESS OF I/O CONTROL BYTE<br>20H<br>; SERIAL DATA PORT BASE ADDRESS<br>SDATA+1<br>SERIAL INTERRUPT ENABLE REGISTER<br>SDATA+2<br>SERIAL INTERRUPT IDENTIFICATION REGIS<br>SDATA+3<br>SERIAL LINE CONTROL REGISTER<br>SDATA+4<br>SERIAL LINE STATUS REGISTER<br>SDATA+5<br>SERIAL LINE STATUS REGISTER |
| 0006 =                                                                                                                                                     | SPSV: EQU                                                                                                                                                                                                   | 6 ;STACK POINTER SAVE LOCATION                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| e<br>Port                                                                                                                                                  | REGISTER ST<br>NORMAL SYST                                                                                                                                                                                  | CORAGE DISPLACEMENTS FROM<br>TEM STACK LOCATION.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 0015 =<br>0012 =<br>0011 =<br>0010 =<br>0014 =<br>0031 =<br>0034 =<br>0034 =<br>0035 =<br>0025 =<br>0020 =                                                 | ÅLOC: EQU<br>BLOC: EQU<br>CLOC: EQU<br>ELOC: EQU<br>FLOC: EQU<br>HLOC: EQU<br>HLOC: EQU<br>PLOC: EQU<br>SLOC: EQU<br>TLOC: EQU<br>TLOC: EQU<br>TLOC: EQU<br>TLOC: EQU                                       | 15H<br>13H<br>12H<br>11H<br>10H<br>14H<br>31H<br>30H<br>34H<br>17H<br>35H<br>25H<br>20H                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 0009 =<br>0008 =<br>000A =<br>000C =<br>0008 =<br>000F =<br>000F =<br>0005 =<br>0005 =<br>0002 =<br>0003 =                                                 | ÀPLOC: EQU<br>BPLOC: EQU<br>CPLOC: EQU<br>DPLOC: EQU<br>EPLOC: EQU<br>HPLOC: EQU<br>HPLOC: EQU<br>LPLOC: EQU<br>XLOC: EQU<br>XLOC: EQU<br>YLOC: EQU<br>RLOC: EQU<br>ILOC: EQU                               | 9<br>11<br>10<br>13<br>12<br>8<br>15<br>14<br>7<br>5<br>2<br>3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| ·                                                                                                                                                          | JUMP TARGET                                                                                                                                                                                                 | S FOR BASIC INPUT/OUTPUT                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| F000 C35BF0<br>F003 C346F6<br>F006 C356F6                                                                                                                  | ;<br>CBOOT: JMP<br>CONIN: JMP<br>READER: JMP                                                                                                                                                                | INIT ;COLD START<br>CI ;CONSOLE INPUT<br>RI ;READER INPUT                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |

| CP/M MACRO ASSEN                                                                                                                                                                                                                                                                                                                                                     | M 2.0                                | #002                                                                            | MOSS 2.                                                                                                            | 2 MONITOR                                                                                                                                                                                                                  |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------|---------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| F009 C300F6<br>F00C C37CF6<br>F00F C310F6<br>F012 C323F6<br>F015 C36AF1<br>F018 C365F1<br>F018 C38AF0<br>F01E C394F6<br>F021 C394F6<br>F024 C3CFF3                                                                                                                                                                                                                   | CONCUT:<br>PUNCH:<br>LIST:<br>CONST: | JMP<br>JMP<br>JMP<br>JMP<br>JMP<br>JMP<br>JMP<br>JMP<br>JMP                     | CO<br>PO<br>LO<br>CSTS<br>IOCHK<br>IOSET<br>MEMCK<br>RTS<br>RTS<br>REST                                            | 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<br>THE                         | ONTAINS<br>EXECUTI                                                              | THE ADDR                                                                                                           | ESSES OF THE ACTION ROUTINES<br>IT TO LOOK UP THE DESIRED ADDRESS.                                                                                                                                                         |
| F027 F8F0<br>F029 09F1<br>F02B 09F1<br>F02D ACF1<br>F02T F6F4<br>F033 FDF1<br>F033 FDF5<br>F0357 09F1<br>F0357 09F1<br>F0358 09F1<br>F0358 09F1<br>F0358 09F1<br>F0357 09F5<br>F0377 09F52<br>F0450 21F55<br>F0445 09F5<br>F0445 09F5<br>F0445 09F5<br>F0445 09F5<br>F0445 09F5<br>F0445 09F5<br>F0451 80F52<br>F0451 80F52<br>F0553 82F5<br>F0557 9F5<br>F0559 82F1 | ŤΒL:                                 | 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>QPRT<br>DISP<br>EOF<br>FILL<br>GOTO<br>HENPT<br>QPRT<br>QPRT<br>QPRT<br>QPRT<br>QPRT<br>QPRT<br>QPRT<br>QP |                                                                                                                                                                                                                            |
|                                                                                                                                                                                                                                                                                                                                                                      | THE C                                | OLD INIT                                                                        | IALIZATI                                                                                                           | ON CODE                                                                                                                                                                                                                    |
| F05B F3<br>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                                 | SP,3FH<br>H,JMP*2<br>D,RSTER<br>B,16<br>D<br>H<br>INIT1                                                            | ;DISABLE INTERRUPTS<br>;USE STACK TO INITIALIZE RESTARTS<br>56 ; WITH RESTART ERROR VECTORS<br>;16 TIMES (64 BYTES)                                                                                                        |
| F069+10FC<br>F06B 3195F0<br>F06E 3E00<br>F06F                                                                                                                                                                                                                                                                                                                        |                                      | LXI<br>MVI<br>ORG                                                               | SP,FAKE<br>A,O<br>\$-1                                                                                             | -2 ;SET UP TEMPORARY STACK<br>; SKIP THE NEXT INST<br>;SAVE A BYTE HERE                                                                                                                                                    |
|                                                                                                                                                                                                                                                                                                                                                                      | MEMSI                                | FROM TH<br>FOUND.                                                               | IE BOTTOM<br>IT THEN                                                                                               | TOP OF CONTIGUOUS RAM. IT SEARCHES<br>UP UNTIL A NON-RAM LOCATION IS<br>TAKES OFF FOR MONITOR WORK SPACE<br>NS THE VALUE IN (H,L).                                                                                         |
| F06F C5<br>F070 0100F0<br>F073 21FFFF<br>F076 24<br>F077 7E<br>F078 2F<br>F078 2F<br>F079 77                                                                                                                                                                                                                                                                         | MEMSIZ:<br>MEMSZ1:                   | LXI<br>LXI                                                                      | B, ROM<br>H, -1<br>H, A, M<br>M, A                                                                                 | ;MONITOR START LOCATION<br>;START OF MEMORY ADDRESS SPACE                                                                                                                                                                  |

| CP/M MACRO ASSEM 2.0                                                                                                          | #003                                                                   | MOSS 2.2 MONITOR                                                                                                                                                           |
|-------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| F07A BE<br>F07B 2F<br>F07C 77                                                                                                 | CMP<br>CMA<br>MOV                                                      | M<br>M,A                                                                                                                                                                   |
| F07D+2004<br>F07F 7C<br>F080 B8                                                                                               | J RNZ<br>MOV<br>CMP<br>J RNZ                                           | MÉMSZ2<br>A,H ;SEE IF ON MONITOR BORDER<br>B<br>MEMSZ1                                                                                                                     |
| F081+20F3<br>F083 25 MEMSZ2:<br>F084 01DEFF<br>F087 09<br>F088 C1<br>F089 C9                                                  | 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                                                                                   |
| •                                                                                                                             | NE MEMCH                                                               | HK FINDS THE CURRENT TOP OF CONTIGUOUS MEMORY<br>THE MONITOR WORKSPACE) AND RETURNS THE VALUE.                                                                             |
| F08A E5<br>F08B CD6FF0<br>F08E 7D<br>F08F D63C                                                                                | PUSH<br>CALL<br>MOV<br>SUI<br>JRNC                                     | H<br>MEMSIZ ;GET THE RAM SIZE<br>A,L<br>60 ;TAKE OFF WORK SPACE<br>MEMCKO                                                                                                  |
| F091+3001<br>F093 25<br>F094 44 MEMCK0:<br>F095 E1<br>F096 C9                                                                 | DCR                                                                    | H<br>B,H<br>H                                                                                                                                                              |
| F097 99F0<br>F099 F9<br>F09A 1145F4<br>F09D EB<br>F09E 011D00                                                                 | DW<br>SPHL<br>LXI<br>XCHG<br>LXI                                       | FAKE+2<br>D,EXIT<br>B,ENDX-EXIT                                                                                                                                            |
| F0A1+EDB0<br>F0A3 010600<br>F0A6 D5<br>F0A7 E1<br>F0A8 2B                                                                     | LDIR<br>LXI<br>PUSH<br>POP<br>DCX<br>LDIR                              | B,3*NBKPTS<br>D<br>H<br>H                                                                                                                                                  |
| F0A9+EDB0<br>F0AB 21E8FF<br>F0AE 39<br>F0AF E5<br>F0B0 23<br>F0B1 23<br>F0B2 220600<br>F0B5 160A<br>F0B7 C5 INIT2:<br>F0B8 15 | LXI<br>DAD<br>PUSH<br>INX<br>INX<br>SHLD<br>MVI<br>PUSH<br>DCR<br>JRNZ | H,-24<br>SP<br>H<br>H ; ADJUST USER STACK LOCATION<br>H<br>SPSV ; SAVE THE STACK INITIAL VALUE<br>D,10 ; INITIALIZE REGISTER STORAGE AREA<br>B<br>D ;LOOP CONTROL<br>INIT2 |
| F0B9+20FC<br>F0BB CD94F6<br>F0BE CD9FF4<br>F0C1 CD94F6<br>F0C4 2190F4<br>F0C7 CD95F6<br>F0CA+1843                             |                                                                        | NIT CODE HERE<br>RTS<br>18250 ;INITIALIZE THE 8250<br>RTS<br>H,LOGMSG ;LOG ONTO THE SYSTEM<br>PRTWD<br>WINIT ;GO TO MONITOR EXECUTIVE                                      |
| ROU                                                                                                                           | TINE EXF<br>CHARACI<br>ON ENTI                                         | READS ONE PARAMETER. IT EXPECTS THE FIRST<br>TER OF THE PARAMETER TO BE IN THE A REGISTER<br>RY.                                                                           |
| FOCC 0601 EXF:<br>FOCE 210000                                                                                                 | MVI<br>LXI                                                             | B,1 ;SET UP FOR ONE PARAMETER<br>H,O                                                                                                                                       |

| CP/M MACRO ASSE                                                                         | M 2.0                           | #004                                                                      | MOSS 2.                                                                           | 2 MONITOR                                                                                                                                                                                                                                                                                                              |
|-----------------------------------------------------------------------------------------|---------------------------------|---------------------------------------------------------------------------|-----------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| F0D1+180C                                                                               |                                 | JMPR                                                                      | EX1                                                                               | ;FIRST CHARACTER IN A ALREADY                                                                                                                                                                                                                                                                                          |
|                                                                                         | ROUT                            | AND DEV<br>THE NUM<br>ON ENTF<br>ENTRY S<br>CURRENT<br>TAKES T<br>DISCARD | VELOPS A<br>MBER OF P<br>RY. A CA<br>SEQUENCE;<br>PARAMET<br>THE LAST<br>DED. A N | ARAMETERS FROM THE CONSOLE<br>16 BIT HEXADECIMAL FOR EACH ONE.<br>ARAMETERS WANTED IS IN THE B REG<br>RRIAGE RETURN WILL TERMINATE THE<br>A BLANK OR A COMMA WILL END THE<br>ER ENTRY. EACH PARAMETER ONLY<br>4 DIGITS TYPED IN; ANY EXCESS IS<br>ON-HEX DIGIT WILL TERMINATE THE<br>AND CAUSE A WARM BOOT OF THE MON. |
| F0D3+1079                                                                               | Ås3:                            | DJNZ                                                                      | AS2                                                                               | ;PART OF THE ASSIGN CODE                                                                                                                                                                                                                                                                                               |
| F0D5+2032                                                                               | EX3:                            | J RN Z                                                                    | QPRT                                                                              | ;NON-ZERO IS ERROR                                                                                                                                                                                                                                                                                                     |
| F0D5+2052<br>F0D7 05<br>F0D8 C8<br>F0D9 210000<br>F0DC CD7BF3<br>F0DF 4F<br>F0E0 CDB0F3 | EXPR1:<br>EXPR:<br>EXO:<br>EX1: | DCR<br>RZ<br>LXI<br>CALL<br>MOV<br>CALL<br>JRC                            | B<br>ECHO<br>CA<br>NIBBLE<br>EX2                                                  | MORE PARAMETERS?<br>NO, RETURN<br>INITIALIZE PARAMETER<br>GET NEXT NUMBER<br>SAVE CHAR FOR LATER USE<br>NOT A NUMBER, JUMP                                                                                                                                                                                             |
| F0E3+3808<br>F0E5 29<br>F0E6 29<br>F0E7 29<br>F0E8 29<br>F0E8 29<br>F0E9 B5<br>F0EA 6F  |                                 | DAD<br>DAD<br>DAD<br>DAD<br>ORA<br>MOV<br>JMPR                            | H<br>H<br>H<br>L<br>L,A<br>EXO                                                    | ;MULTIPLY BY 16<br>;ADD ON NEW DIGIT<br>;GO GET NEXT DIGIT                                                                                                                                                                                                                                                             |
| F0EB+18EF<br>F0ED E3<br>F0EE E5<br>F0EF 79<br>F0F0 CDC3F3                               | EX2:                            | XTHL<br>PUSH<br>MOV<br>CALL<br>JRNC                                       | H<br>A,C<br>P2C<br>EX3                                                            | ; OU GET NEXT DIGIT<br>; PUT UNDER RETURN ADDRESS ON STACK<br>; RESTORE RETURN ADDRESS<br>; REGET THE LAST CHARACTER<br>; TEST FOR DELIMITER<br>; JUMP IF NOT CARRIAGE RETURN                                                                                                                                          |
| F0F3+30E0<br>F0F5+1012                                                                  |                                 | DJNZ                                                                      | QPRT                                                                              | ;CARRET WITH MORE PARAM MEANS ERROR                                                                                                                                                                                                                                                                                    |
| F0F7 C9                                                                                 | ;                               | RET                                                                       |                                                                                   |                                                                                                                                                                                                                                                                                                                        |
|                                                                                         | , MALN                          | ACTION H                                                                  | ROUTINES                                                                          |                                                                                                                                                                                                                                                                                                                        |
|                                                                                         | LOGI                            | CAL ASSIC                                                                 | GNMENT OF                                                                         | PERIPHERALS                                                                                                                                                                                                                                                                                                            |
|                                                                                         | THIS F                          | PERIPHE<br>ALTERS<br>CURRENT<br>CONSOLE                                   | ERALS TO<br>IOBYTE (<br>I ASSIGNM<br>E, READER                                    | THE ASSIGNMENT OF PHYSICAL<br>THE FOUR LOGICAL DEVICE TYPES. IT<br>MEMORY LOCATION 0003) TO MATCH THE<br>IENT. 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                       | Åsgn:<br>Aso:                   | CALL<br>LXI<br>MVI<br>CMP<br>JRZ                                          | ECHO<br>H,ALT<br>D,APT-A<br>B,4<br>M<br>AS1                                       | ;GET THE LOGICAL DEVICE DESIRED<br>;START OF CONVERSION TABLE<br>LT ;DISTANCE BETWEEN LOGICAL CHOI<br>;NUMBER OF LOGICAL CHOICES<br>;IS THIS ONE IT?<br>;YES, JUMP                                                                                                                                                     |
| F104+2842<br>F106 19                                                                    |                                 | DAD<br>DJNZ                                                               | D<br>ASO                                                                          | ;NO, GO TO NEXT LOGICAL ENTRY                                                                                                                                                                                                                                                                                          |
| F107+10FA<br>F109 218CF4<br>F10C CD98F6                                                 | QPRT:<br>;                      | LXI<br>CALL                                                               | H,QMSG<br>PRTWA                                                                   | GET ADDRESS OF QUESTION MARK MSG                                                                                                                                                                                                                                                                                       |

C-6

CP/M MACRO ASSEM 2.0 #005 MOSS 2.2 MONITOR THE WARM START CODE F10F 2A0600 F112 F9 F113 210FF1 F116 E5 F117 220100 F11A 3EC3 F11C 320000 F11F CDA9F6 F122 CD78F3 F125 D641 WINIT: LHLD SPSV ; RESET THE STACK SPHL WINITA: LXI H, WINIT ; RESET RETURN AND WARM START VECTOR PUSH Η WSVEC+1 A,OC3H WSVEC SHLD MVI STA START A NEW LINE GET THE COMMAND GET RID OF ASCII ZONE CALL CRLF DECHO CALL F125 D641 SUI JRC OPRT BAD COMMAND F127+38E0 F129 FE1A 'Z'-'A'+1 CPI ; CHECK UPPER LIMIT JRNC QPRT BAD COMMAND F12B+30DC F12D 87 F12E 5F F12F 1600 F131 21271 F133 21271 F1337 7E F1338 23 F1338 66 F1338 E9 F138 E9 ADD A ;DOUBLE IT FOR TABLE OFFSET Ë,A D,O B,2 H,TBL SET UP FOR DOUBLE ADD MOV MVİ SET UP FOR TWO PARAMETERS GET ACTION ROUTINE ADDRESS MVI 2127F0 19 7E 23 66 6F LXĪ DAD D MOV A,M ;LOAD H,L INDIRECT INX MOV Ĥ H,M MOV L,A PCHL ;GO TO ACTION ROUTINE FILL ACTION ROUTINE ; , THIS ROUTINE FILLS A BLOCK OF MEMORY WITH A USER-DETERMINED CONSTANT. IT EXPECTS THREE PARAMETERS TO BE ENTERED IN THE FOLLOWING ORDER: , ì START ADDRESS FINISH ADDRESS FILL VALUE F13C CD86F3 F13F 71 F140 CD8FF3 **FILL:** EXPR3 M,C HILO GET THREE PARAMETERS PUT DOWN THE FILL VALUE INCREMENT AND CHECK THE POINTER NOT DONE YET, JUMP CALL MOV FIO: CALL JRNC FIO F143+30FA F145 D1 ;RESTORE STACK POINTER IN CASE ; STACK WAS OVERWRITTEN POP JMPR WINIT F146+18C7 SAVE THE COUNTER RESIDUE LOOP CONTROL GET THE NEW ASSIGNMENT INCREMENT POINTER D,B B,4 DECHO F148 50 ÅS1: MOV F149 0604 F14B CD78F3 F14E 23 MVI CALL AS2: INX Η F14F BE CMP М SEE IF THIS IS IT JRNZ AS3 F150+2081 F152 68 F153 2D F154 42 F155 2603 F157 05 ; SAVE THE RESIDUE TO FORM ASGT MOV L,B SAVE THE RESIDUE TO FOR ADJUST VALUE REGET THE LOGICAL RESID SET UP THE IOBYTE MASK ADJUST THIS ONE ALSO NO SHIFT NEEDED L,D B,D H,3 DCR MOV RESIDUE MVI DCR В AS5 JRZ F158+2804 F15A 29 F15B 29 AS4: DAD Η SHIFT THE MASKS INTO POSITION DAD H ÄS4 DJNZ ;NOT DONE YET, JUMP F15C+10FC F15E 3A0300 F161 B4 AS5: LDA IOBYTE

ORA

H

;MASK THE DESIRED ASSIGNMENT IN

| CP/M MACRO ASSE                                                          | M 2.0          | #006                                      | MOSS 2.2                                    | 2 MONITOR                                                                                                                                                                        |
|--------------------------------------------------------------------------|----------------|-------------------------------------------|---------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| F162 AC<br>F163 B5<br>F164 4F<br>F165 79                                 | IOSET:         | XRA<br>ORA<br>MOV<br>MOV                  | H<br>L<br>C,A<br>A,C                        | LOGICAL ASGT BITS NOW OFF<br>PUT IN NEW VALUE                                                                                                                                    |
| F166 320300<br>F169 C9                                                   |                | STA<br>RET                                | ÎĊĔYTE                                      | ;SAVE NEW ASSIGNMENTS                                                                                                                                                            |
| F16A 3A0300<br>F16D C9                                                   | IOCHK:         | LDA<br>RET                                | IOBYTE                                      |                                                                                                                                                                                  |
| F16E 4C<br>F16F 32<br>F170 31<br>F171 4C<br>F172 54                      | ÅLT:           | DB<br>DB<br>DB<br>DB<br>DB                | 'L'<br>'2'<br>'1'<br>'L'<br>'T'             | LOGICAL LIST DEVICE TABLE<br>USER DEVICE #2<br>USER DEVICE #1<br>LIST TO HIGH SPEED PRINTER                                                                                      |
| F172 56<br>F173 52<br>F175 31<br>F176 50                                 | APT:           | DB<br>DB<br>DB<br>DB<br>DB                | 'P'<br>'2'<br>'1'<br>'P'                    | LIST TO TTY<br>LOGICAL PUNCH DEVICE TABLE<br>USER DEVICE #2<br>USER DEVICE #1                                                                                                    |
| F177 54<br>F178 52<br>F179 32<br>F17 <u>9</u> 32<br>F1 <u>7</u> A 31     | ART:           | DB<br>DB<br>DB<br>DB<br>DB                | 'T'<br>'R'<br>'2'<br>'1'                    | PUNCH TO HIGH SPEED PUNCH<br>PUNCH TO TTY<br>LOGICAL READER DEVICE TABLE<br>USER DEVICE #2<br>USER DEVICE #1                                                                     |
| F17B 50<br>F17C 54                                                       |                | DB<br>DB                                  | 'P'<br>'T'                                  | READER TO HIGH SPEED READER<br>READER TO TTY                                                                                                                                     |
| F17D 43<br>F17E 31<br>F17F 42                                            | ACT:           | DB<br>DB                                  | 'Č'<br>'1'                                  | LOGICAL CONSOLE DEVICE TABLE<br>USER DEVICE #1                                                                                                                                   |
| F180 43<br>F181 54                                                       |                | DB<br>DB<br>DB                            | 'B'<br>'C'<br>'T'                           | CONSOLE TO BATCH (PRINTER OR PTR)<br>CONSOLE TO CRT<br>CONSOLE TO TTY                                                                                                            |
|                                                                          | , THE B        | OF THE<br>RESPOND<br>CHARACT              | SYSTEM.<br>TO ANYTI<br>ERS. WHI<br>IS RETUI | 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                                                                                 |
| 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         | CONTENT<br>BLOCK T                        | S IS DET<br>S DISPLA<br>TENTS OF            | IWO BLOCKS OF MEMORY AGAINST EACH<br>FFERENCE IN THE RELATIVE ADDRESS<br>ECTED, THE ADDRESS OF THE FIRST<br>YED, ALONG WITH ITS CONTENTS AND<br>THE OTHER BLOCK'S SAME RELATIVE  |
| F191 CD86F3<br>F194 OA<br>F195 C5<br>F196 46<br>F197 B8                  | COMP:<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 |                | PUSH<br>CALL<br>MOV<br>CALL<br>POP        | PSW<br>LADRB<br>A,B<br>DASH1<br>PSW         | SAVE SOURCE 2 DATA<br>WRITE THE ADDRESS<br>GET SOURCE 1 DATA<br>FORMAT<br>REGET SOURCE 2 DATA                                                                                    |

# FIRMWARE LISTING

| CP/M MACRO ASSEM 2                                    | 2.0             | #007                                                              | MOSS 2.2                                                           | MONITOR                                                                                                                                                                                                           |
|-------------------------------------------------------|-----------------|-------------------------------------------------------------------|--------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| F1A3 CDE6F5<br>F1A6 C1 CM<br>F1A7 CD9BF3<br>F1AA+18E8 | 1PB:            | POP<br>CALL                                                       | B<br>HILOXB                                                        | ;OUTPUT IT<br>;INCREMENT SOURCE 1 POINTER AND SEE IF<br>;JUMP IF NOT DONE YET                                                                                                                                     |
| 9                                                     | DISPLA          | Y ACTION                                                          | ROUTINE                                                            |                                                                                                                                                                                                                   |
|                                                       |                 | CURRENT<br>MUST SPE<br>THE DISP                                   | CONSOLE<br>CIFY THE<br>LAY IS O                                    | PLAYS A BLOCK OF MEMORY ON THE<br>DEVICE (CONSOLE DUMP). THE USER<br>START AND FINISH ADDRESSES.<br>RGANIZED TO DISPLAY UP TO 16 BYTES<br>, WITH ALL COLUMNS ALIGNED SO<br>THE SAME LAST HEX DIGIT IN ITS ADDRESS |
| F1AF CDFBF5 D3<br>F1B2 7D<br>F1B3 CDF0F1<br>F1B6 E5   | IS1:<br>IS2:    | CALL<br>CALL<br>MOV<br>CALL<br>PUSH<br>MOV<br>CALL<br>CALL<br>JRC | EXLF<br>LADRB<br>A,L<br>TRPLSP<br>H<br>A,M<br>HEX1<br>HILO<br>DIS7 | 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)<br>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?                                                                                                                                                                             |
| F1C9 7D<br>F1CA E60F<br>F1CC CDF5F1                   | IS3:<br>IS4:    | POP<br>MOV<br>ANI<br>CALL<br>MOV<br>ANI<br>MOV<br>CPI<br>JRC      | H<br>A,L<br>OFH<br>TRPL2<br>A,M<br>7FH<br>C,A<br>JIS5              | REGET LINE START ADDRESS<br>SKIP OVER TO RIGHT SPACE<br>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                                                        | 7EH<br>DIS6                                                        | ,0011 11 50                                                                                                                                                                                                       |
|                                                       |                 | 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                                                                                                          |
| F1E8+18C5<br>F1EA 93 DI<br>F1EB CDF0F1                | IS7:            | JMPR<br>SUB<br>CALL<br>JMPR                                       | DIS1<br>E<br>TRPLSP<br>DIS3                                        | ;DO THE NEXT LINE<br>;SKIP OVER TO START ASCII PRINTOUT<br>;GO PRINT THE ASCII                                                                                                                                    |
| F1F2 47<br>F1F3 87<br>F1F4 80                         | RPLSP:<br>RPL2: | ANI<br>MOV<br>ADD<br>ADD<br>MOV<br>INR                            | OFH<br>B,A<br>A<br>B<br>B,A<br>B                                   | ;ISOLATE THE LOW FOUR BITS<br>PREPARE TO SPACE OVER TO RIGHT COLUMN<br>;TRIPLE THE COUNT<br>;PUT BACK INTO B<br>;ADJUST COUNTER                                                                                   |
| F1F7 CDFEF5 T1<br>F1FA+10FB<br>F1FC C9 ;              | RPL1:           | ČALL<br>DJNZ<br>RET                                               | BLK<br>TRPL 1                                                      | ;DO THE SPACING<br>;NO, DO ANOTHER COLUMN                                                                                                                                                                         |

| CP/M MACRO ASSE                                                                                                                                   | M 2.0 #0                                                      | оов м                                                                                                  | 0SS 2.2                                        | MONITOR                                                                                                                                                                                                                                               |
|---------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------|--------------------------------------------------------------------------------------------------------|------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                                                                                                                   | ; GO TO AC                                                    | CTION RO                                                                                               | UTINE                                          |                                                                                                                                                                                                                                                       |
|                                                                                                                                                   | GOTO COM<br>IT ALL<br>AS WEL<br>THE RU                        | MMAND TR<br>LOWS THE<br>LL AS AL<br>UN, AS L                                                           | ANSFERS<br>SELECTI<br>LOWING A<br>ONG AS I     | CONTROL TO A SPECIFIED ADDRESS.<br>IVE SETTING OF UP TO TWO BREAKPOINTS<br>ANY CONSOLE INPUT TO BREAKPOINT<br>INTERRUPT 1 IS ACTIVE.                                                                                                                  |
| F1FD CDCOF3                                                                                                                                       | GOTO: CA                                                      |                                                                                                        | CHK<br>O3                                      | SEE IF OLD ADDRESS WANTED                                                                                                                                                                                                                             |
| F200+3837                                                                                                                                         |                                                               |                                                                                                        | 00                                             | ; YES, BUT SET SOME BREAKPOINTS                                                                                                                                                                                                                       |
| F202+2810<br>F204 CDCCF0<br>F207 D1<br>F208 213400<br>F20B 39<br>F20C 72<br>F20D 2B<br>F20E 73<br>F20E 73<br>F20F 79<br>F210 FE0D                 | CA<br>PC<br>LX<br>DA<br>MC<br>MC<br>MC<br>MC<br>GF<br>JF      | ALL E<br>OP D<br>XI H<br>AD S                                                                          | XF<br>, PLOC<br>, D<br>, E                     | GET NEW GOTO ADDRESS<br>PUT ADDRESS IN PC LOCATION<br>LOW BYTE<br>HIGH BYTE<br>SEE IF A CR WAS LAST ENTERED                                                                                                                                           |
| F212+2825<br>F214 0602<br>F216 213500<br>F219 39<br>F21A C5<br>F21B E5<br>F21C 0602<br>F21E CDD7F0<br>F221 D1<br>F222 E1<br>F223 7A<br>F224 B3    | GOO: MV<br>L}<br>GO1: PU<br>MV<br>CA<br>PC<br>PC<br>MO<br>OF  | VI B<br>XI H<br>USH H<br>VIL B<br>OP D<br>OP H<br>OP H<br>OP H<br>OP H<br>OP H<br>OP H<br>OP H<br>OP H | ,NBKPTS<br>1,TLOC<br>SP<br>2,2<br>CXPR1<br>1,D | POINT TO TRAP STORAGE<br>SAVE NUMBER OF BREAKPOINTS<br>SAVE STORAGE POINTER<br>SET UP TO GET A TRAP ADDRESS<br>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<br>JUMP IF SO |
| F225+280A<br>F227 73<br>F228 23<br>F229 72<br>F22A 23<br>F22B 1A<br>F22C 77<br>F22D 23<br>F22E 3ECF<br>F230 12<br>F231 79<br>F232 FE0D<br>F234 C1 | MC<br>IN<br>MC<br>IN<br>LI<br>MC<br>MC<br>S<br>GO2: MC<br>CI  | OV M<br>NX H<br>OV M<br>DAX L<br>OV M<br>NX H<br>VI A<br>TAX L<br>OV A<br>OV A<br>OV A<br>OP E         | 1,E<br>1,D<br>1,A<br>1,RST OR<br>1,C<br>2R     | SAVE THE BREAKPOINT ADDRESS<br>SAVE THE INSTRUCTION FROM THE BP ADDR<br>8 ;INSERT THE BREAKPOINT<br>REGET THE DELIMITER TO SEE<br>IF WE ARE DONE SETTING BREAKPOINTS<br>UNLOAD THE STACK FIRST                                                        |
| F235+2802                                                                                                                                         | JI                                                            | RZ G                                                                                                   | i03                                            | YES, JUMP                                                                                                                                                                                                                                             |
| F237+10E1<br>F239 CDA9F6<br>F23C E1<br>F23D 2143F4<br>F240 E5<br>F241 21CFF3<br>F244 220900<br>F247 211800<br>F24A 39<br>F24B D1<br>F24C E9       | GO3: C/<br>P(<br>L)<br>P1<br>L)<br>S1<br>L)<br>D1<br>P0<br>P0 | ALL C<br>OP H<br>XI H<br>USH H<br>XI H<br>HLD C<br>XI H                                                | CRLF<br>1<br>1,RS9<br>1,REST<br>1,24<br>5P     | ;JUMP IF NOT AT BP LIMIT<br>;GET RID OF STACK JUNK<br>;SET BREAKPOINT JUMP VECTOR ADDRESS<br>;FIND REGISTER SET ROUTINE ADDRESS<br>;ADJUST THE STACK<br>;GO TO THE DESIRED PLACE                                                                      |
|                                                                                                                                                   | GENERAL                                                       | PURPOSE                                                                                                | E INPUT/                                       | OUTPUT ROUTINES                                                                                                                                                                                                                                       |
|                                                                                                                                                   | THESE ROU                                                     | UTINES A                                                                                               | ALLOW BY                                       | TE-BY-BYTE INPUT OR OUTPUT FROM<br>OLE DEVICE, THEY ARE INVOKED BY                                                                                                                                                                                    |

C-10

; THE CURRENT CONSOLE DEVICE. THEY ARE INVOKED BY

CP/M MACRO ASSEM 2.0 #009 MOSS 2.2 MONITOR THE MONITOR "I" OR "O" COMMAND. i ;GET INPUT PORT NUMBER ;GET PORT # INTO C REGISTER ;READ VALUE INTO E REGISTER F24D CDD7F0 ÍNPT: EXPR1 CALL F250 C1 POP R INP Ε F251+ED58 BITS2 JMPR ;GO DO A BINARY PRINT OF THE VALUE F253+1851 GET THE ADDRESS AND DATA FOR OUTPUT DATA VALUE INTO E PORT INTO C F255 CDD9F0 F258 D1 F259 C1 **ÓUPT:** CALL EXPR POP D POP В DO THE OUTPUT OUTP Ε F25A+ED59 F25C C9 RET , MOVE ROUTINE , THIS ROUTINE EXPECTS THREE PARAMETERS, ENTERED IN THE 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:** CALL EXPR3 F260 7E F261 02 F262 CD9BF3 A,M B MOV1: MOV STAX HILOXB CALL JMPR MOV 1 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 TERMINATE IF A SPACE OR COMMA IS ENTERED, THE ROUTINE PROCEEDS TO THE NEXT LOCATION AND PRESENTS THE USER WITH AN OPPORTUNITY TO ALTER IT. GO GET ONE PARAMETER GET THE START ADDRESS GET THE CONTENTS OF THE ADDRESS DISPLAY IT ON CONSOLE AND A DASH GET, CHECK CHARACTER DONE IF CARRIAGE RETURN NO CHANGE TE BLANK OR F267 CDD7F0 F26A E1 F26B 7E SUBS: CALL EXPR1 POP H. A,M DASH1 SUB1: MOV F26C CDF4F5 F26F CDC0F3 F272 D8 CALL CALL PCHK RC JRZ NO CHANGE IF BLANK OR , SUB2 F273+280F F275 FE0A ;SEE IF PREVIOUS BYTE WANTED ;YES, DO IT CPI LF F277+280D F279 E5 F27A CDCCF0 F27D D1 F27E E1 F27E E1 F27F 73 F280 79 F281 FE0D F283 C8 F284 23 F285 23 F285 23 F286 2B F287 7D F288 E607 F288 CCFBF5 ĴRŽ SUB3 SAVE MEMORY POINTER GO GET REST OF NEW VALUE NEW VALUE TO E REGISTER RESTORE MEMORY POINTER PUSH H EXF CALL POP D PÕP Ĥ RESTORE MEMORY POINTER PUT DOWN NEW VALUE GET THE DELIMITER SEE IF DONE (CARRIAGE RETURN) YES, RETURN TO MONITOR NO, INCREMENT MEMORY POINTER ALLOW A FALL-THROUGH ON THE NEXT INST ADJUST (H,L) AS APPROPRIATE GET LO ADDRESS BYTE SEE IF ON A BOUNDARY CALL IF ON THE BOUNDARY GO DO THE NEXT LOCATION M,E A,C CR MOV MOV CPI RZ INX INX SUB2: Η Η SUB3: DCX Η MOV A,L ANI LADRB F28A CCFBF5 CZ JMPR SUB1

F28D+18DC

| 2 |
|---|
|   |

CP/M MACRO ASSEM 2.0 #010 MOSS 2.2 MONITOR

|                                                                                                                                   | , SEE                                 | LF ANY<br>AN EXHA                                                                      | HARD DATA<br>USTIVE TH                                                      | 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                                                 | MTEST:<br>MTEST1:                     | CALL<br>MOV<br>PUSH<br>CMA<br>MOV<br>XRA<br>CNZ                                        | EXLF<br>A,M<br>PSW<br>M,A<br>M<br>BITS                                      | READ A BYTE<br>SAVE IT<br>COMPLEMENT IT<br>WRITE IT<br>RESULT SHOULD BE ZERO<br>LOG ERROR IF NOT                                                                                                                                                                         |
| F29A F1<br>F29B 77<br>F29C CD9CF3<br>F29F+18F1                                                                                    | MTEST2:                               | POP<br>MOV<br>CALL<br>JMPR                                                             | PSW<br>M,A<br>HILOX<br>MTEST1                                               | RESTORE ORIGINAL BYTE<br>POINT TO NEXT AND SEE IF DONE<br>NO, CONTINUE                                                                                                                                                                                                   |
| F2A1 D5<br>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 |                                       | PUSH<br>MOV<br>CALL<br>MVI<br>MOV<br>RLC<br>MOV<br>MVI<br>RAL<br>MOV<br>CALL           | E,A<br>LADRB<br>B,8<br>A,E<br>E,A<br>A,'0'/2<br>C,A<br>CONOUT               | 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, OUTPUT IT                                                                 |
| F2B2+10F4<br>F2B4 D1<br>F2B5 C9                                                                                                   |                                       | DJNZ<br>POP<br>RET                                                                     | BITS1<br>D                                                                  | ;DO IT AGAIN                                                                                                                                                                                                                                                             |
|                                                                                                                                   |                                       |                                                                                        |                                                                             |                                                                                                                                                                                                                                                                          |
|                                                                                                                                   | : THE                                 | REGISTE                                                                                | RS STOREI                                                                   | MAND INSPECTS THE VALUES OF THE<br>D BY THE LAST ENCOUNTERED BREAKPOINT.<br>DDIFIED IF DESIRED.                                                                                                                                                                          |
| F2B6 23<br>F2B7 23<br>F2B8 34<br>F2B9 C8<br>F2BA F2C1F2<br>F2BD F680                                                              | : THE                                 | REGISTE<br>VALUES<br>INX<br>INX<br>INR<br>RZ<br>JP<br>ORI                              | RS STOREI<br>MAY BE MC<br>H<br>H<br>M<br>XAB<br>80H                         | D BY THE LAST ENCOUNTERED BREAKPOINT.                                                                                                                                                                                                                                    |
| F2B9 C8<br>F2BA F2C1F2<br>F2BD F680<br>F2BF+1802<br>F2C1 E67F<br>F2C3 35<br>F2C4 BE                                               | THE<br>THE<br>XAA:                    | REGISTE<br>VALUES<br>INX<br>INX<br>INR<br>RZ<br>JP                                     | RS STOREI<br>MAY BE M(<br>H<br>H<br>M<br>XAB                                | D BY THE LAST ENCOUNTERED BREAKPOINT.<br>DDIFIED IF DESIRED.<br>;SKIP OVER TO NEXT ENTRY<br>;SEE IF AT END OF TABLE<br>;COULDN'T FIND MATCH, QUIT<br>;SORT OUT BIT 7 OF TABLE                                                                                            |
| F2B9 C8<br>F2BA F2C1F2<br>F2BD F680<br>F2BF+1802<br>F2C1 E67F<br>F2C3 35                                                          | ; THE<br>; THE<br>XAA:<br>XA:<br>XAB: | REGISTE<br>VALUES<br>INX<br>INX<br>INR<br>RZ<br>JP<br>ORI<br>JMPR<br>ANI<br>DCR<br>CMP | RS STOREI<br>MAY BE MC<br>H<br>H<br>M<br>XAB<br>80H<br>XAC<br>7FH<br>M<br>M | D BY THE LAST ENCOUNTERED BREAKPOINT.<br>DDIFIED IF DESIRED.<br>;SKIP OVER TO NEXT ENTRY<br>;SEE IF AT END OF TABLE<br>;COULDN'T FIND MATCH, QUIT<br>;SORT OUT BIT 7 OF TABLE<br>;SET IT ON TEST VALUE<br>;RESET BIT 7<br>;TO BE PULLED OUT IN ROM<br>;SEE IF THIS IS IT |

| CP/M MACRO ASSE                                                                                                                | M 2.0           | #011                                                                         | MOSS 2.2                                                              | 2 MONITOR                                                                                                                                                                                 |
|--------------------------------------------------------------------------------------------------------------------------------|-----------------|------------------------------------------------------------------------------|-----------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| F2E1 07                                                                                                                        |                 | RLC<br>JRNC                                                                  | XE                                                                    | ;SEE IF 8 BIT REGISTER<br>;JUMP IF SO                                                                                                                                                     |
| F2E2+3003<br>F2E4 13<br>F2E5 7C<br>F2E6 12<br>F2E7 E1                                                                          | XE:             | INX<br>MOV<br>STAX<br>POP                                                    | D<br>A,H<br>D<br>H                                                    | ;REGISTER PAIR, DO OTHER 8 BITS<br>;RESTORE THE TABLE POINTER                                                                                                                             |
| F2E8 79<br>F2E9 FE0D                                                                                                           | XF:             | MOV<br>CPI                                                                   | A,C<br>CR                                                             | ;SEE IF IT WAS A CR                                                                                                                                                                       |
| F2EB C8<br>F2EC 213DF3<br>F2EF CDCOF3                                                                                          | XMNE:<br>XMNE1: | RZ<br>LXI<br>CALL<br>JRC                                                     | H,ACTBL<br>PCHK<br>XG                                                 | DONE IF SO<br>GET ADDRESS OF REGISTER LOOK-UP TABLE<br>FIND OUT WHAT ACTION IS WANTED<br>SHOW ALL IF CARRIAGE RETURN                                                                      |
| F2F2+380B                                                                                                                      |                 | JRZ                                                                          | XMNE1                                                                 | ; IGNORE BLANKS OR COMMAS                                                                                                                                                                 |
| F2F4+28F9<br>F2F6 FE27                                                                                                         |                 | CPI<br>JRNZ                                                                  | ,,,,<br>ХА                                                            | ;SEE IF PRIMES WANTED<br>;NO, MUST BE SINGLE REGISTER                                                                                                                                     |
| F2F8+20BE<br>F2FA 2155F3                                                                                                       |                 | LXI<br>JMPR                                                                  |                                                                       | YES, SET TABLE ADDRESS                                                                                                                                                                    |
| F2FD+18F0                                                                                                                      | ;               |                                                                              |                                                                       | ,                                                                                                                                                                                         |
| F2FF 7E<br>F300 4F<br>F301 3C<br>F302 C8<br>F303 FCA9F6<br>F306 CD09F0<br>F309 CDF7F5<br>F30C CD15F3<br>F30F CDFEF5<br>F312 23 | ΧG:             | MOV<br>MOV<br>INR<br>RZ<br>CM<br>CALL<br>CALL<br>CALL<br>CALL<br>INX<br>JMPR | A,M<br>C,A<br>A<br>CRLF<br>CONOUT<br>DASH<br>PRTVAL<br>BLK<br>H<br>XG | SEE IF AT END OF TABLE<br>DONE IF SO<br>START A NEW LINE IF BIT 7 IS SET<br>PROMPT FOR A NEW VALUE<br>GO PRINT THE VALUE<br>FORMATTER<br>POINT TO NEXT ENTRY<br>DO THE NEXT VALUE         |
| F313+18EA                                                                                                                      |                 | 0112 11                                                                      |                                                                       |                                                                                                                                                                                           |
| F315 23<br>F316 7E<br>F317 E63F<br>F319 C602<br>F318 EB<br>F31C 6F<br>F31D 2600<br>F31F 39<br>F320 EB<br>F321 7F               | PRTVAL:         | INX<br>MOV<br>ADI<br>XCHG<br>MOV<br>MVI<br>DAD<br>XCHG                       | H<br>A,M<br>3FH<br>L,A<br>H,O<br>SP                                   | POINT TO NEXT ENTRY<br>GET OFFSET AND ATTRIBUTES BYTE<br>ISOLATE THE OFFSET<br>ALLOW FOR RETURN ADDRESS<br>SWAP POINTERS<br>BUILD THE ADDRESS OF THE REG CONTENTS<br>RE-SWAP THE POINTERS |
| F322 0601                                                                                                                      |                 | MOV<br>MVI                                                                   | A,M<br>B,1                                                            | NOW FIND OUT ATTRIBUTES<br>SET UP FOR SINGLE REG VALUE                                                                                                                                    |
| F324 07<br>F325+300E                                                                                                           |                 | RLC<br>JRNC                                                                  | PV1                                                                   | ;JUMP IF SINGLE REGISTER VALUE WANTED                                                                                                                                                     |
| F327 04<br>F328 07                                                                                                             |                 | INR<br>RLC                                                                   | В                                                                     | ;SET UP FOR REGISTER PAIR                                                                                                                                                                 |
| F329+300A                                                                                                                      |                 | JRNC                                                                         | PV1                                                                   | ;JUMP IF REGISTER PAIR IS NEXT                                                                                                                                                            |
| F32B E5<br>F32C 1A<br>F32D 67<br>F32E 1B<br>F32F 1A<br>F330 6F<br>F331 7E<br>F332 E1                                           |                 | PUSH<br>LDAX<br>MOV<br>DCX<br>LDAX<br>MOV<br>MOV<br>POP<br>DJNZ              | H<br>D<br>D<br>L,A<br>A,M<br>PV2                                      | ;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                                                                                                                |

| CP/M MACRO ASSEN                                                                                                                                                                 | 1 2.0                    | #012                                                                            | MOSS 2.2                                                                                                                                           | 2 MONITOR                                                                                                                                            |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------|---------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------|
| F33A+10F9<br>F33C C9                                                                                                                                                             |                          | RET                                                                             |                                                                                                                                                    |                                                                                                                                                      |
| F333F1 4312<br>F53341 4410<br>F5334435 44611<br>F5334455 46830<br>F5334457 46830<br>F53334457 46830<br>F53334457 46830<br>F53334457 46830<br>F533553<br>F533553 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',BLOG<br>'C',CLOG<br>'E',ELOG<br>'F',FLOG<br>'F',FLOG<br>'H',HLOG<br>'L',LLOG<br>80H+'M',<br>'P',PLOG<br>'S',SLOG<br>'I',ILOG       | ALOC<br>HLOC+0C0H<br>+80H<br>+80H                                                                                                                    |
|                                                                                                                                                                                  | REST                     | OF Z-80                                                                         | REGISTER                                                                                                                                           | OFFSETS                                                                                                                                              |
| 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>F367 5887<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',BPLC<br>'C',CPLC<br>'D',DPLC<br>'E',EPLC<br>'F',FPLC<br>'L',HPLC<br>'L',LPLC<br>80H+'A'<br>'X',XLOC<br>'Y',YLOC<br>'R',RLOC<br>OFFH | DC<br>DC<br>DC<br>DC<br>DC<br>DC<br>DC<br>DC<br>L<br>HPLOC+0C0H                                                                                      |
|                                                                                                                                                                                  | GENEF                    | RAL PURPC                                                                       | SE ROUTII                                                                                                                                          | NES                                                                                                                                                  |
|                                                                                                                                                                                  | ROUTI                    | ACCUMUL                                                                         | ATOR TO 2                                                                                                                                          | THE LOW ORDER NIBBLE OF THE<br>ITS ASCII EQUIVALENT. IT<br>INTO C FOR LATER OUTPUT.                                                                  |
| F36E E60F<br>F370 C690<br>F372 27<br>F373 CE40<br>F375 27<br>F376 4F<br>F377 C9                                                                                                  | ĊONV:                    | ANI<br>ADI<br>DAA<br>ACI<br>DAA<br>MOV<br>RET                                   | 0FH<br>90H<br>40H<br>C,A                                                                                                                           | ;STRIP OFF BITS 4-7<br>;PUT ON THE ASCII ZONE<br>;PUT IN OUTPUT PASS REGISTER                                                                        |
|                                                                                                                                                                                  | ROUTI                    | INE ECHO<br>DEVICE,<br>CONSOLE                                                  | THEN EC                                                                                                                                            | BYTE FROM A HALF-DUPLEX CONSOLE<br>HOES THE CHARACTER BACK TO THE                                                                                    |
| F378 CDF7F5<br>F378 CD8FF6<br>F37E C5<br>F37F 4F<br>F380 CD09F0<br>F383 79<br>F384 C1<br>F385 C9                                                                                 | DECHO:<br>ECHO:<br>ECH1: | CALL<br>CALL<br>PUSH<br>MOV<br>CALL<br>MOV<br>POP<br>RET                        | DASH<br>CONI<br>B<br>C,A<br>CONOUT<br>A,C<br>B                                                                                                     | PRINT A DASH<br>CONSOLE READ, WRITE ROUTINE<br>SAVE (B,C)<br>PASS CHARACTER IN C REGISTER<br>OUTPUT IT<br>PUT CHARACTER BACK INTO A<br>RESTORE (B,C) |
|                                                                                                                                                                                  | ROUT                     | INE EXPRE<br>Then loai                                                          | GETS TH                                                                                                                                            | REE PARAMETERS, DOES A CR, LF AND<br>(D,E), AND (H,L) WITH THE PARAMETERS.                                                                           |
| F386 04<br>F387 CDD9F0<br>F38A C1<br>F38B D1<br>F38C C3AAF6                                                                                                                      | ÉXPR3:                   | INR<br>CALL<br>POP<br>POP<br>JMP                                                | B<br>EXPR<br>B<br>D<br>CRLFA                                                                                                                       | ;2 IS ALREADY IN THE B REGISTER<br>;GET THE PARAMETERS<br>;PUT PARAMETERS INTO REGISTERS<br>;GO DO THE CARRIAGE RETURN SEQUENCE                      |

| CP/M MACRO ASSE                                                                                                                 | M 2.0                       | #013                                                              | MOSS 2.                                                  | 2 MONITOR                                                                                                                                                                                                     |
|---------------------------------------------------------------------------------------------------------------------------------|-----------------------------|-------------------------------------------------------------------|----------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                                                                                                 | ROUTI                       | NE HILO<br>DISALLO<br>THE CAR<br>AROUND<br>THE FLA                | INCREMEN<br>WS) A WR<br>RY BIT W<br>OCCURRED<br>G BITS S | TS (H,L). IT THEN CHECKS FOR (AND<br>AP-AROUND SITUATION. IF IT OCCURS,<br>ILL BE SET ON RETURN. IF NO WRAP-<br>, (H,L) IS COMPARED TO (D,E) AND<br>ET ACCORDINGLY.                                           |
| F38F 23<br>F39F 20<br>F391 B5<br>F392 37<br>F392 C8<br>F394 7B<br>F395 7B<br>F395 7A<br>F397 90<br>F398 C9                      | ΉILO:                       | INX<br>MOV<br>ORA<br>STC<br>RZ<br>MOV<br>SUB<br>MOV<br>SBB<br>RET | H<br>A,H<br>L,E<br>L<br>A,D<br>H                         | ;INCREMENT (H,L)<br>;TEST IF ZERO<br>; IN (H,L)<br>;SET CARRY FOR (H,L)=0<br>;RETURN IF (H,L) = 0<br>;COMPARE (H,L) TO (D,E)<br>;RETURN WITH FLAGS SET                                                        |
|                                                                                                                                 | ROUTI<br>IF<br>OTH          | NE HILOX<br>EQUAL, F<br>ERWISE,                                   | ETURNS C<br>CONTROL                                      | NTS (H,L), COMPARES IT TO (D,E) AND<br>ONTROL TO THE MONITOR EXECUTIVE.<br>RETURNS TO THE CALLING ROUTINE.                                                                                                    |
| F399 D1<br>F39A C9<br>F39B O3<br>F39C CD8FF3                                                                                    | HILOD:<br>HILOXB:<br>HILOX: | POP<br>RET<br>INX<br>CALL                                         | D<br>B<br>HILO                                           | GET RID OF RETURN ADDRESS<br>RETURN TO MONITOR<br>INCREMENT (B,C)<br>INC AND CHECK (H,L)                                                                                                                      |
| F39F+38F8<br>F3A1 CD12F0<br>F3A4 B7<br>F3A5 C8<br>F3A6 CD8FF6<br>F3A9 FE13                                                      |                             | JRC<br>CALL<br>ORA<br>RZ<br>CALL<br>CPI<br>JRNZ                   | HILOD<br>CONST<br>A<br>CONI<br>CTRLS<br>HILOD            | ;DONE IF CARRY SET<br>;SEE IF CONSOLE BREAK PENDING<br>;NONE, RETURN TO CONTINUE<br>;SEE IF WAIT OR BREAK<br>;JUMP IF BREAK                                                                                   |
| F3AB+20EC<br>F3AD C38FF6                                                                                                        | ROUTI                       | THE CHA                                                           | CONI<br>E CONVER<br>THEIR EQ<br>RACTER I<br>HE ERROR.    | ;GO WAIT FOR NEXT CHARACTER<br>TS THE ASCII CHARACTERS 0-9 AND<br>UIVALENT HEXADECIMAL VALUE. IF<br>S NOT IN RANGE, THE CARRY BIT IS SET TO                                                                   |
| 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:                     |                                                                   | '0'<br>'G'-'0'<br>'9'-'0'<br>'A'-'9'<br>10               | ASCII TO HEX CONVERSION<br>DONE IF OUT OF RANGE<br>CHECK UPPER END<br>TOGGLE THE CARRY BIT<br>DONE IF OUT OF RANGE<br>+1 ;SEE IF NUMERIC<br>TOGGLE THE CARRY BIT<br>DONE IF SO                                |
|                                                                                                                                 | ROUTI                       | CHECKS<br>A DELIN<br>IF IT<br>FURTHEN<br>THE CAN                  | IT FOR A<br>MITER, A<br>IS A DELI<br>R, IF THE           | CHARACTER FROM THE CONSOLE, THEN<br>DELIMITER. IF IT IS NOT<br>NON-ZERO CONDITION IS RETURNED.<br>MITER, A ZERO CONDITION IS RETURNED.<br>DELIMITER IS A CARRIAGE RETURN,<br>S SET. A BLANK OR A COMMA RESETS |
| F3C0 CD7BF3<br>F3C3 FE20<br>F3C5 C8<br>F3C6 FE2C<br>F3C8 C8<br>F3C8 C8                                                          | РСНК:<br>Р2С:               | CALL<br>CPI<br>RZ<br>CPI<br>RZ                                    | ЕСНО<br>','                                              | GET, TEST FOR DELIMITER<br>BLANK?<br>YES, DONE<br>NO, COMMA?<br>YES, DONE                                                                                                                                     |

| CP/M MACRO ASSEM                                                                                                                             | 2.0            | #014                                                                                             | MOSS 2.2                                                                                        | MONITOR                                                                                                                                                                                              |
|----------------------------------------------------------------------------------------------------------------------------------------------|----------------|--------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| F3C9 FEOD<br>F3CB 37<br>F3CC C8<br>F3CD 3F<br>F3CE C9                                                                                        |                | CPI<br>STC<br>RZ<br>CMC<br>RET                                                                   | CR                                                                                              | NO, CARRIAGE RETURN?<br>SHOW IT IN CARRY BIT<br>DONE IF CR<br>CLEAR CARRY FOR NO DELIMITER                                                                                                           |
|                                                                                                                                              | , ROUTIN       | VE REST T<br>RESTART<br>ARE STOP<br>USE BY                                                       | TRAPS ALL<br>1 INSTRU<br>RED IN TH<br>THE GOTO                                                  | OF THE REGISTER CONTENTS WHENEVER A<br>CTION IS EXECUTED. THE TRAPPED CONTEN<br>E SYSTEM STACK AREA FOR LATER ACCESS A<br>AND THE EXAMINE REGISTERS COMMANDS.                                        |
| F3D0 D5<br>F3D1 C5<br>F3D2 F5<br>F3D3 CD6FF0<br>F3D6 EB<br>F3D7 210A00<br>F3DA 39<br>F3DB 0604<br>F3DD EB                                    | ŔEST:          | PUSH<br>PUSH<br>PUSH<br>CALL<br>XCHG<br>LXI<br>DAD<br>MVI<br>XCHG                                | H<br>D<br>PSW<br>MEMSIZ<br>H,10<br>SP<br>B,4                                                    | LER SOFTWARE AT START OF REST:<br>;SAVE ALL THE REGISTERS<br>;GET THE MONITOR'S STACK LOCATION<br>;GO UP 10 BYTES IN THE STACK<br>; TO SKIP OVER TEMP REGISTER SAVE<br>;PICK OFF THE REGISTER VALUES |
| F3DE 28<br>F3DF 72<br>F3E0 28<br>F3E1 73<br>F3E2 D1                                                                                          | RS1:           | DCX<br>MOV<br>DCX<br>MOV<br>POP<br>DJNZ                                                          | H<br>M,D<br>H<br>M,E<br>D<br>RS1                                                                | ;SAVE IN WORK AREA                                                                                                                                                                                   |
| F3E3+10F9<br>F3E5 C1<br>F3E6 OB<br>F3E7 F9<br>F3E8 212500<br>F3EB 39<br>F3EC D5<br>F3ED 1602<br>F3EF 7E                                      | RS2:           | POP<br>DCX<br>SPHL<br>LXI<br>DAD<br>PUSH<br>MVI<br>MOV                                           | SP<br>D<br>D,NBKPTS                                                                             | ;GET THE BREAKPOINT LOCATION<br>;SET THE MONITOR STACK<br>;SET UP TO RESTORE BREAKPOINTS<br>;LOOP CONTROL FOR N BREAKPOINTS                                                                          |
| F3F0 91<br>F3F1 23<br>F3F2 7E<br>F3F3 98                                                                                                     |                | MOV<br>SUB<br>INX<br>MOV<br>SBB<br>JRZ                                                           | A,M<br>C<br>H<br>A,M<br>B<br>RS5                                                                | ;SEE IF A SOFTWARE TRAP<br>;MAYBE, TRY REST OF ADDRESS<br>;FOUND ONE, JUMP TO RESET IT                                                                                                               |
| F3F7 23<br>F3F8 <b>1</b> 5                                                                                                                   | RS3:           | INX<br>INX<br>DCR<br>JRNZ                                                                        | H<br>H<br>D<br>RS2                                                                              | ;NOT FOUND, TRY NEXT ONE                                                                                                                                                                             |
| F3FC 212000<br>F3FF D1<br>F400 39<br>F401 73<br>F402 23<br>F403 72<br>F404 C5<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<br>JRZ | 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/25<br>D<br>RS6 | ; NONE FOUND<br>; STORE USER (H,L)<br>; SAVE (B,C)<br>; TYPE THE BREAK INDICATION<br>; REGET THE BREAKPOINT LOCATION<br>; SEE IF A RET BREAKPOINT                                                    |
| F40E+2809<br>F410 23<br>F411 23<br>F412 73<br>F413 23<br>F414 72                                                                             |                | INX<br>INX<br>MOV<br>INX<br>MOV                                                                  | H<br>H<br>M,E<br>H<br>M,D                                                                       | ;RESTORE USER PROGRAM COUNTER                                                                                                                                                                        |

## FIRMWARE LISTING

| CP/M MACRO ASSE                                                                                                                                                    | M 2.0        | #015                                                                                      | MOSS 2.2                                                                                                | 2 MONITOR                                                                       |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|-------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------|
| F415 EB<br>F416 CDE1F5<br>F419 212500<br>F41C 39<br>F41D 010002<br>F420 5E<br>F421 71<br>F422 23<br>F422 23<br>F424 71<br>F425 23<br>F425 23<br>F426 7B<br>F427 B2 | RS6:<br>RS7: | XCHG<br>CALL<br>DAD<br>LXI<br>MOV<br>INX<br>MOV<br>INX<br>MOV<br>INX<br>MOV<br>INX<br>MOV | LADR<br>H,TLOCX<br>SP<br>B,NBKPTS<br>E,M<br>M,C<br>H,C<br>H,C<br>H,C<br>H,C<br>H,C<br>H,C<br>H,C<br>H,C | ;RESET SYSTEM BP SAVE AREA                                                      |
| F428+2802<br>F42A 7E<br>F42B 12<br>F42C 23                                                                                                                         | RS8:         | JRZ<br>MOV<br>STAX<br>INX<br>DJNZ                                                         | RS8<br>A,M<br>D<br>H<br>RS7                                                                             | ;DO NOTHING IF ZERO<br>;SAME THING FOR OTHER<br>; BREAKPOINT                    |
| F42D+10F1                                                                                                                                                          |              | EXAF                                                                                      |                                                                                                         | ;NOW SAVE THE Z-80 UNIQUES                                                      |
| F42F+08                                                                                                                                                            |              | EXX                                                                                       |                                                                                                         |                                                                                 |
| F430+D9<br>F431 E5<br>F432 D5<br>F433 C5<br>F434 F5                                                                                                                |              | PUSH<br>PUSH<br>PUSH<br>PUSH<br>PUSHIX                                                    | H<br>D<br>B<br>PSW                                                                                      |                                                                                 |
| F435+DDE5                                                                                                                                                          |              | PUSHIY                                                                                    |                                                                                                         |                                                                                 |
| F437+FDE5                                                                                                                                                          |              | LDAI                                                                                      |                                                                                                         |                                                                                 |
| F439+ED57<br>F43B 47                                                                                                                                               |              | MOV<br>LDAR                                                                               | B,A                                                                                                     |                                                                                 |
| F43C+ED5F<br>F43E 4F<br>F43F C5<br>F440 C313F1<br>F443 E5<br>F444 CF                                                                                               | RS9:         | MOV<br>PUSH<br>JMP<br>PUSH<br>RST                                                         | C,A<br>B<br>Winita<br>H<br>1                                                                            | RETURN TO MONITOR<br>RET BREAKPOINT ENCOUNTERED, ADJUST TH<br>DO THE BREAKPOINT |
| F445 C <b>1</b><br>F446 79                                                                                                                                         | ÈXIT:        | POP<br>MOV<br>STAR                                                                        | B<br>A,C                                                                                                |                                                                                 |
| F447+ED4F<br>F449 78                                                                                                                                               |              | MOV                                                                                       | A,B                                                                                                     |                                                                                 |
| F44A+ED47                                                                                                                                                          |              | STAI                                                                                      |                                                                                                         |                                                                                 |
| F44C+DDE1                                                                                                                                                          |              | POPIX                                                                                     |                                                                                                         |                                                                                 |
| F44E+FDE1<br>F450 F1<br>F451 C1<br>F452 D1<br>F453 E1<br>F453 F1                                                                                                   |              | POPIY<br>POP<br>POP<br>POP<br>EXAF                                                        | PSW<br>B<br>D<br>H                                                                                      |                                                                                 |
| -                                                                                                                                                                  |              | EXX                                                                                       |                                                                                                         |                                                                                 |
| F455+D9<br>F456 D1<br>F457 C1<br>F458 F1<br>F459 E1<br>F45A F9<br>F45B 00                                                                                          |              | POP<br>POP<br>POP<br>SPHL<br>DB                                                           | D<br>B<br>PSW<br>H                                                                                      | ;PLACE FOR EI                                                                   |
|                                                                                                                                                                    |              |                                                                                           |                                                                                                         |                                                                                 |

| CP/M MACRO ASSEM 2.0                                               | #016                                              | MOSS 2.2 MONITOR                                                                                                                                                                                                                                                                                                                 |
|--------------------------------------------------------------------|---------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| F45C 210000<br>F45F C30000<br>F462 = ENDX:                         | LXI<br>JMP<br>EQU                                 | H,O<br>O<br>\$                                                                                                                                                                                                                                                                                                                   |
| ERROR                                                              | HANDLER                                           | RS                                                                                                                                                                                                                                                                                                                               |
|                                                                    | ERROR;<br>ERRORS<br>THE ERR<br>A UNIQU<br>INITIAL | TYPES OF ERRORS ARE DETECTED: A RESTART<br>AN I/O ASSIGNMENT ERROR; AND CERTAIN PROGRAM<br>(DETERMINED BY THE PARTICULAR ROUTINE WHERE<br>ROR CONDITION WAS ENCOUNTERED.) EACH CAUSES<br>UE MESSAGE TO BE PRINTED, THEN DOES A WARM<br>LIZATION OF THE MONITOR. THE I/O ERROR<br>THE I/O ASSIGNMENTS TO BE RESET TO DEFAULT ASSI |
| F462 AF 10ER:<br>F463 320300                                       | X RA<br>Sta                                       | A ;SET IOBYTE TO DEFAULT VALUE<br>IOBYTE                                                                                                                                                                                                                                                                                         |
| F463 320300<br>F466 216CF4<br>F469 C3B5F6<br>F46C 492F4F2045IOMSG: | LXI<br>JMP<br>DB                                  | H,IOMSG ;GET ADDRESS OF I/O ERROR MSG<br>COMERR ;GO PROCESS IT<br>'I/O ER','R'+80H                                                                                                                                                                                                                                               |
| CUF<br>HEX                                                         | RENT PAP                                          | READS TWO ASCII CHARACTERS FROM THE<br>PER TAPE READER AND ASSEMBLES THEM INTO TWO<br>L BYTES OF DATA. IT UPDATES A CHECKSUM<br>D IN REGISTER D.                                                                                                                                                                                 |
| F473 CDE8F6 BYTE:<br>F476 BO                                       | CALL<br>ORA                                       | BYT ;GET NEXT BYTE<br>B ;COMBINE THEM                                                                                                                                                                                                                                                                                            |
| F477 47<br>F478 82<br>F478 57                                      | MOV<br>ADD                                        | B,A<br>D ;UPDATE CHECKSUM                                                                                                                                                                                                                                                                                                        |
| F479 57<br>F47A 78<br>F47B C9                                      | MOV<br>MOV<br>RET                                 | D,A<br>A,B ;RESTORE BYTE                                                                                                                                                                                                                                                                                                         |
| F47C 0E0D ;<br>F47E CD7CF6<br>F481 0E0A<br>F483 C37CF6             | MVI<br>CALL<br>MVI<br>JMP                         | C,CR<br>PO<br>C,LF<br>PO ;GO PUNCH THE OUTPUT                                                                                                                                                                                                                                                                                    |
| RIX F<br>PAF                                                       | OUTINE F<br>ER TAPE                               | READS ONE CHARACTER FROM THE CURRENT<br>READER AND STRIPS OFF THE PARITY BIT.                                                                                                                                                                                                                                                    |
| F486 CD56F6 RIX:<br>F489 E67F<br>F48B C9                           | CALL<br>ANI<br>RET                                | RI<br>7FH                                                                                                                                                                                                                                                                                                                        |
| F48C 3F3F3FBF QMSG:<br>F490 4D4F535320LOGMSG:<br>F49D 0D8A         | DB<br>DB<br>DB                                    | '???','?'+80H<br>'MOSS VERS 2.2'<br>CR,LF+80H                                                                                                                                                                                                                                                                                    |
|                                                                    | MENT. I                                           | ON CODE FOR THE 8250 ASYNCHRONOUS COMMUNICATION<br>THIS CODE WILL INITIALIZE THE BAUD RATE OF THE<br>ELL AS THE WORD FORMAT. 8 DATA BITS, 1 STOP BIT<br>ITY ARE SELECTED. EITHER 2 OR 3 CARRIAGE RETURN<br>TERED TO ESTABLISH THE CORRECT BAUD RATE.                                                                             |
| F49F 3E0F 18250:<br>F4A1 D324                                      | MVI<br>OUT                                        | A,OFH ;SET UP THE 8250<br>SMDMCT                                                                                                                                                                                                                                                                                                 |
| F4A3 114000<br>F4A6 62<br>F4A7 6A                                  | LXI<br>MOV<br>MOV                                 | D,40H ;SET UP TO TIME THE START BIT<br>H,D<br>L,D ;ZEROES TO (H,L)                                                                                                                                                                                                                                                               |
| F4A8 DB26 I8250A:<br>F4AA A3                                       |                                                   | L,D ;ZEROES TO (H,L)<br>SMDMST ;WAIT FOR START BIT<br>E<br>18250A                                                                                                                                                                                                                                                                |
| F4AB+28FB<br>F4AD DB26 I8250B:<br>F4AF 23<br>F4BO A3<br>F4B1 A3    | IN<br>INX<br>ANA<br>ANA                           | SMDMST ;NOW, TIME THE START BIT DURATION<br>H<br>E<br>E                                                                                                                                                                                                                                                                          |

| CP/M MACRO ASSEM 2.0                                                                                                                                                             | #017                                                                                                                                                                                   | MOSS 2.                                                                                                                                                                                                   | 2 MONITOR                                                                                                                                                                                                                                                                                                                                                                                                             |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| F4B2 C2ADF4<br>F4B5 E5<br>F4B6 29<br>F4B7 5C<br>F4B8 19<br>F4B9 19<br>F4BA E5<br>F4BB 29<br>F4BD 29<br>F4BC 29<br>F4BC 29<br>F4BC 29<br>F4BC 29<br>F4BC 7D<br>F4C0 7D<br>F4C1 B4 | DCX<br>MOV                                                                                                                                                                             | 18250B<br>H<br>E,H<br>D<br>H<br>H<br>H<br>SDATA<br>H<br>A,L                                                                                                                                               | ;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<br>;WASTE SOME TIME                                                                                                                                                                                                                                  |
| F4C2 C2BDF4<br>F4C5 E1                                                                                                                                                           | ORA<br>JNZ<br>POP<br>OUT<br>MOV<br>OUT<br>MOV<br>OUT<br>MVI<br>OUT<br>XRA<br>OUT<br>XRA<br>OUT<br>CALL<br>ANI<br>CPI<br>POP<br>RZ<br>MOV<br>MOV<br>CALL<br>CALL<br>DAD<br>PUSH<br>JMPR | H<br>18250C<br>H<br>A,83H<br>SLCTRL<br>A,L<br>SJATA<br>A,H<br>SINTEN<br>A,H<br>SINTEN<br>A,S<br>SLCTRL<br>A<br>SINTEN<br>SLSTAT<br>TTYIN<br>7FH<br>ODH<br>H<br>E,L<br>D,H<br>DIV2<br>DIV2<br>DH<br>18250D | <pre>;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</pre> |
| F4EC+18D8<br>F4EE B7 DIV2:<br>F4EF 7C<br>F4E7 1F<br>F4F0 1F<br>F4F1 67<br>F4F2 7D<br>F4F2 7D                                                                                     | ORA<br>MOV<br>RAR<br>MOV<br>MOV                                                                                                                                                        | A<br>A,H<br>H,A<br>A,L                                                                                                                                                                                    | CLEAR THE CARRY BIT                                                                                                                                                                                                                                                                                                                                                                                                   |
| F<br>D                                                                                                                                                                           | ORMAT) ONT                                                                                                                                                                             | O THE CU<br>ENTRY P                                                                                                                                                                                       | N END OF FILE RECORD (INTEL HEX<br>RRENTLY ASSIGNED PAPER TAPE PUNCH<br>OINT ADDRESS FOR THE FILE WILL ALSO<br>IFIED.                                                                                                                                                                                                                                                                                                 |
| F4F6 CDA4F6 EOF:<br>F4F9 D5<br>F4FA CDC8F5 EOFA:<br>F4FD AF<br>F4FE 57<br>F4FF CDF6F6<br>F502 3E01<br>F504 CDFEF6<br>F507 AF<br>F508 92<br>F509 CDFEF6<br>F50C+1803              | CALL<br>PUSH<br>CALL<br>XRA<br>MOV<br>CALL<br>MVI<br>CALL<br>XRA<br>SUB<br>CALL<br>JMPR                                                                                                | EXLF<br>D<br>PSOR<br>A<br>D,A<br>PBADR<br>A,1<br>PBYTE<br>A<br>D<br>PBYTE<br>LEO                                                                                                                          | GET JUMP ADDRESS<br>SAVE THE # OF TRAILER NULLS<br>PUNCH START OF RECORD<br>ZERO OUT THE CHECKSUM<br>OUTPUT THE RECORD LENGTH AND EP<br>PUNCH RECORD TYPE = 1<br>OUTPUT THE CHECKSUM<br>GO DO THE TRAILER                                                                                                                                                                                                             |

LEADER ROUTINE "PUNCHES" SIX INCHES (OR AS SPECIFIED) OF LEADER ON THE PAPER TAPE PUNCH. NULLS ARE PUNCHED TO FORM THE LEADER (OR TRAILER). ;SEE IF SOME OTHER LENGTH WANTED ;GET THE VALUE LEADER: CALL F50E CDD7F0 EXPR1 F511 C1 F512 78 LEO: POP В Ā,B C MOV ;TEST FOR DEFAULT SELECT ;MOVE NEW VALUE IN JUST IN CASE ;GET A NULL CHARACTER ;JUMP IF NEW VALUE WANTED F513 B1 F514 41 F515 0E00 ORA Ĕ,C C,O LE1 MOV MVI JRNZ F517+2002 F519 063C DEFAULT, SET 60 NULLS MVI B,60 PUNCH F51B CDOCFO LE1: CALL KEEP GOING TIL DONE DJNZ LE1 F51E+10FB F520 C9 RET QUERY ROUTINE WILL TELL THE OPERATOR WHAT HIS CURRENT LOGICA PHYSICAL PERIPHERAL DEVICE ASSIGNMENTS ARE. NO PARAME (OTHER THAN A CARRIAGE RETURN) ARE REQUIRED ON ENTRY. ;GET THE ASSIGNMENT CONTROL BYTE ;SET UP FOR FOUR LOGICAL DEVICES ;ADDRESS OF CONVERSION TABLE F521 3A0 300 F524 0604 F526 217DF1 F529 11FBFF F52C F5 F52D CDFEF5 F530 4E F531 CD09F0 F534 CDF7F5 F537 F1 F538 F5 F539 E5 F538 23 F538 3C F53C E603 F521 3A0300 **QUERY**: LDA IOBYTE B,4 MVI Ĥ,ĂCT LXI D,ALT-APT PSW ; NEGATIVE OFFSET FOR LOGICAL TABLE LXI QUE1: PUSH ;FORMAT THE PRINT-OUT ;GET THE CURRENT LOGICAL DEVICE CODE CALL BLK C,M CONOUT MOV OUTPUT IT OUTPUT A DASH REGET THE CONTROL BYTE RESAVE IT CALL CALL DASH PSW PSW POP PUSH SAVE THE TABLE POINTER ADJUST POINTER TO CURRENT PHYSICAL DE PUSH Н QUE2: INX Н INR А ;BITS O AND 1 ARE O WHEN ON CURRENT AS ANI NOT THERE YET, TRY AGAIN JRNZ ÕUE2 F53E+20FA F540 4E F541 CD09F0 C,M CONOUT MOV ;FOUND IT, NOW PRINT IT CALL F544 E1 POP Ĥ F545 F1 POP PSW ;GO TO NEXT LOGICAL DEVICE ļĻ F546 ADJUST THE IOBYTE RAR F547 1F F548 19 RAR ; ADJUST THE TABLE POINTER DAD D DJNZ QUE1 GO DO NEXT LOGICAL DEVICE F549+10E1 F54B C9 RET :RETURN TO MONITOR READ ROUTINE READS AN INTEL HEX FORMAT PAPER TAPE FROM THE CURRENT PAPER TAPE READER. IF A NON-ZERO ADDRESS IS SPECIFIED IN THE END OF FILE RECORD, CONTROL WILL BE TRANSFERRED TO THAT ADDRESS. OTHERWISE, CONTROL WILL REVERT TO THE EXECUTIVE. GET OFFSET BIAS INTO (H,L) SAVE THE BIAS F54C CDD7F0 **ŘEAD**: EXPR1 CALL F54F E1 F550 E5 F551 CD861 F554 DE3A POP PUSH REDO: Η Η ŖIX READ A BYTE LOOK FOR START OF RECORD JUMP TO KEEP LOOKING CD86F4 CALL SBI RED1: ĴRNZ RED1 F556+20F9 F558 57 ;INITIALIZE CHECKSUM ;GET RECORD LENGTH ;JUMP IF EOF RECORD MOV D,A BYTE F559 CD73F4 CALL JRZ RED3 F55C+2823

MOSS 2.2 MONITOR

#018

CP/M MACRO ASSEM 2.0

| CP/M MACRO ASSE                                                                                                                    | M 2.0   | #019                                             | MOSS 2.2                                | 2 MONITOR                                                                                                                                                                                                                                                 |
|------------------------------------------------------------------------------------------------------------------------------------|---------|--------------------------------------------------|-----------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| F55E 5F<br>F55F CD73F4<br>F562 F5<br>F563 CD73F4<br>F566 C1<br>F567 4F<br>F568 09<br>F569 CD73F4<br>F566 C77<br>F567 77<br>F570 2F |         | CALL<br>POP                                      | BYTE<br>PSW<br>BYTE<br>B                | ELSE, ASSUME DATA RECORD<br>GET LOAD ADDRESS HIGH BYTE<br>SAVE IT<br>GET LOAD ADDRESS LOW BYTE<br>BUILD ADDRESS IN (B,C)                                                                                                                                  |
| F565 CD73F4<br>F566 C1<br>F567 4F<br>F568 09<br>F568 CD73F4<br>F56C CD73F4<br>F56F 77<br>F570 2F<br>F571 AE                        | RED2:   | MOV<br>DAD<br>CALL<br>CALL<br>MOV<br>CMA<br>XRA  | BYTE<br>BYTE<br>M,A<br>M                | ADD ON THE BIAS<br>SKIP OVER RECORD TYPE<br>GET A DATA BYTE<br>PUT IT INTO MEMORY<br>DO A QUICK CHECK<br>RESULT SHOULD BE ZERO<br>IF ERROR, PRINT ADDRESS AND DATA<br>INCREMENT MEMORY POINTER<br>RECORD LENGTH FOR LOOP CONTROL<br>DO REST OF THE RECORD |
| F572 C4A1F2<br>F575 23<br>F576 1D                                                                                                  |         | CNZ<br>INX<br>DCR<br>JRNZ                        | BITS<br>H<br>E<br>RED2                  | IF ERROR, PRINT ADDRESS AND DATA<br>INCREMENT MEMORY POINTER<br>RECORD LENGTH FOR LOOP CONTROL<br>DO REST OF THE RECORD                                                                                                                                   |
| F579 CD73F4<br>F57C C209F1                                                                                                         |         | CALL<br>JNZ<br>JMPR                              | BYTE<br>QPRT<br>REDO                    | GET THE CHECKSUM<br>ABORT IF ERROR<br>GO DO NEXT RECORD                                                                                                                                                                                                   |
| F57F+18CE<br>F581 CD73F4<br>F584 67<br>F585 CD73F4                                                                                 | RED3:   | CALL                                             | BYTE                                    |                                                                                                                                                                                                                                                           |
| F581 CD73F4<br>F584 67<br>F585 CD73F4<br>F588 6F<br>F589 B4<br>F58A D1<br>F58B C8<br>F58C E9                                       |         | MOV<br>CALL<br>MOV<br>ORA<br>POP<br>RZ<br>PCHL   | L,A<br>H<br>D                           | SEE IF IT IS ZERO<br>RESTORE THE STACK<br>RETURN TO MONITOR IF EP=0<br>ELSE, GO TO THE ENTRY POINT                                                                                                                                                        |
|                                                                                                                                    | ; WRITE | ROUTINE                                          | IS USED                                 | TO PUNCH AN INTEL HEX FORMAT<br>URRENT ASSIGNED PUNCH UNIT.                                                                                                                                                                                               |
| F58D CD86F3<br>F590 AF<br>F591 47<br>F592 B1                                                                                       | WRITE:  | CALL<br>XRA<br>MOV<br>ORA<br>JRNZ                | D.A                                     | GET 3 PARAMETERS, DO CRLF<br>SEE IF RECORD LENGTH CHANGE<br>SET HIGH BYTE TO ZERO<br>NOW SEE IF CHANGE WANTED<br>YES, JUMP AND SET IT UP                                                                                                                  |
| F593+2002<br>F595 OE10<br>F597 E5<br>F598 09<br>F599 B7                                                                            | WRI1:   | MVI                                              |                                         | NO, DEFAULT TO 16 BYTES/RECORD<br>SAVE MEMORY POINTER<br>ADD THE RECORD LENGTH<br>CLEAR THE CARRY BIT<br>SEE IF FULL RECORD REMAINS                                                                                                                       |
| F50A_FD52                                                                                                                          |         | POP<br>JRC                                       |                                         | ;RESTORE (H,L)<br>;GO DO A FULL RECORD                                                                                                                                                                                                                    |
| F59D+380A<br>F59F D5<br>F5A0 EB<br>F5A1 B7                                                                                         |         | PUSH<br>XCHG<br>ORA<br>DSBC                      | D<br>A<br>D                             | SAVE LAST BYTE ADDRESS<br>SWAP (D,E) AND (H,L)<br>RESET THE CARRY BIT<br>FIND # OF BYTE REMAINING                                                                                                                                                         |
| F5A2+ED52<br>F5A4 23<br>F5A5 E3<br>F5A6 EB<br>F5A7 C1<br>F5A8 D8<br>F5A9 C5<br>F5AA D5                                             | WRI2:   | INX<br>XTHL<br>XCHG<br>POP<br>RC<br>PUSH<br>PUSH | H<br>B<br>D                             | ADJUST TO INCLUDE LAST BYTE<br>SWAP TOP OF STACK<br>SET (D,E), (H,L) TO NORMAL<br>NEW RECORD LENGTH TO (B,C)<br>DONE IF ZERO LENGTH RECORD<br>SAVE LOOP COUNT                                                                                             |
| F5AB 50<br>F5AC 41<br>F5AD CDC8F5<br>F5B0 78<br>F5B1 CDF6F6<br>F5B4 AF                                                             |         | MOV<br>MOV<br>CALL<br>MOV<br>CALL<br>XRA         | D,B<br>B,C<br>PSOR<br>A,B<br>PBADR<br>A | ZERO THE CHECKSUM<br>MOVE LOOP CONTROL TO B<br>PUNCH START OF RECORD<br>GET RECORD LENGTH<br>PUNCH IT<br>PUNCH RECORD TYPE '0'                                                                                                                            |
| F5B5 CDFEF6<br>F5B8 7E                                                                                                             | WRI3:   | CALL<br>MOV                                      | PBYTE<br>A,M                            | ;GET NEXT DATA BYTE                                                                                                                                                                                                                                       |

.

| CP/M MACRO ASSEN                                                                             | 12.0                     | #020                                                    | MOSS 2.2                               | 2 MONITOR                                                                                                                                      |
|----------------------------------------------------------------------------------------------|--------------------------|---------------------------------------------------------|----------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------|
| F5B9 23<br>F5BA CDFEF6                                                                       |                          | INX<br>CALL<br>DJNZ                                     | H<br>PBYTE<br>WRI3                     | BUMP THE POINTER<br>PUNCH THE DATA<br>DO REST OF RECORD                                                                                        |
| F5BD+10F9<br>F5BF AF                                                                         |                          | XRA                                                     | A                                      | ;NOW, DO THE CHECKSUM                                                                                                                          |
| F5C0 92<br>F5C1 CDFEF6<br>F5C4 D1                                                            |                          | SUB<br>CALL<br>POP                                      | D<br>PBYTE<br>D                        | PUNCH IT<br>RESTORE THE REGISTERS                                                                                                              |
| F5C5 C1                                                                                      |                          | POP<br>JMPR                                             | B<br>WRI1                              | ;GO DO NEXT RECORD                                                                                                                             |
| F5C6+18CF                                                                                    | ;                        |                                                         |                                        |                                                                                                                                                |
| F5C8 CD7CF4<br>F5CB 0E3A<br>F5CD C37CF6                                                      | ÝSOR:                    | CALL<br>MVI<br>JMP                                      | PEOL<br>C,':'<br>PO                    |                                                                                                                                                |
|                                                                                              | HEXN                     | ROUTINE                                                 |                                        |                                                                                                                                                |
|                                                                                              | , THIS R                 | OUTINE A<br>UNSIGNE<br>CONSOLE                          | D NUMBERS                              | 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                       | ΉΕΧΝ:                    | 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                                                                                    | ;                        |                                                         |                                        |                                                                                                                                                |
| ·<br>·                                                                                       | ROUTI                    | CURRENT                                                 | CONSOLE<br>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<br>F5E7 OF<br>F5E8 OF<br>F5E9 OF | LADRA:<br>LADR:<br>HEX1: | CALL<br>MOV<br>CALL<br>MOV<br>PUSH<br>RRC<br>RRC<br>RRC | CRLF<br>A,H<br>HEX1<br>A,L<br>PSW      | START A NEW LINE<br>GET HIGH TWO DIGITS<br>PRINT THEM<br>GET LOW TWO DIGITS<br>SAVE THE LOW DIGIT<br>PUT HIGH NIBBLE INTO BITS 0-3             |
| F5EA OF<br>F5EB CDEFF5<br>F5EE F1<br>F5EF CD6EF3                                             | HEX2:                    | RRC<br>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                                                |
| F5F2+180C                                                                                    | ;                        |                                                         |                                        | ,                                                                                                                                              |
|                                                                                              |                          |                                                         |                                        | DASH ON THE CURRENT CONSOLE DEVICE.                                                                                                            |
| F5F4 CDE6F5<br>F5F7 0E2D                                                                     | DASH1:<br>DASH:          | CALL<br>MVI<br>JMPR                                     | HEX1<br>C,'-'<br>CO                    | ;FIRST, PRINT ACCUM AS TWO HEX DIGITS<br>;GET AN ASCII DASH<br>;GO TYPE IT                                                                     |
| F5F9+1805                                                                                    | ; IOBY                   | TE HANDL                                                | ERS                                    |                                                                                                                                                |
| F5FB                                                                                         | ;                        | ORG                                                     | MOSS+5F                                | ВН                                                                                                                                             |
| F5FB CDDEF5                                                                                  | LADRB:                   | CALL                                                    | LADRA                                  | ;OUTPUT (H,L) AS 4 ASCII DIGITS                                                                                                                |
| F5FE 0E20                                                                                    | BLK:                     | MVI                                                     | C,' '                                  | ;OUTPUT A BLANK                                                                                                                                |
|                                                                                              | ;                        |                                                         |                                        |                                                                                                                                                |

## FIRMWARE LISTING

| CP/M MACRO ASSEM 2                                                                                   | .0 #021                                          | MOSS 2.2                                                   | 2 MONITOR                                                                  |
|------------------------------------------------------------------------------------------------------|--------------------------------------------------|------------------------------------------------------------|----------------------------------------------------------------------------|
| F600 3A0300 CO<br>F603 E603<br>F605 CADEF6<br>F608 FE02                                              | 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 LO<br>F613 E6C0<br>F615 CADEF6<br>F618 FE80<br>F61A FA62F4                               | CPI<br>JM<br>JM                                  | IOBYTE<br>OCOH<br>TTYOUT<br>80H<br>CRTOUT                  | ;ISOLATE LIST ASGT<br>;TTY DEVICE ACTIVE<br>;CRT ACTIVE                    |
| F61D CA62F4<br>F620 C362F4                                                                           | JZ<br>JMP                                        | LPRT<br>LUSE1                                              | LINE PRINTER ACTIVE<br>USER PRINTER 1 ACTIVE                               |
| F626 E603<br>F628 CAC6F6                                                                             | STS: LDA<br>ANI<br>JZ<br>CPI                     | IOBYTE<br>3<br>TTST<br>2                                   | ;ISOLATE CONSOLE ASGT<br>;TTY ACTIVE                                       |
| F62B FE02<br>F62D FA62F4<br>F630 C262F4                                                              | JM<br>JNZ                                        | ČRTST<br>CUST1                                             | CRT ACTIVE<br>USER CONSOLE 1 ACTIVE                                        |
| F633 3A0300 BA<br>F636 E60C<br>F638 CAC6F6<br>F63B FE08                                              | TST: LDA<br>ANI<br>JZ<br>CPI                     | IOBYTE<br>OCH<br>TTST                                      | ;ISOLATE BATCH ASGT<br>;TTY ACTIVE                                         |
| F63D FA62F4<br>F640 CA62F4<br>F643 C362F4                                                            | JM<br>JZ<br>JMP                                  | 8<br>PTRST<br>RUST1<br>RUST2                               | PAPER TAPE READER ACTIVE<br>USER READER 1 ACTIVE<br>USER READER 2 ACTIVE   |
| F646 3A0300 ČI<br>F649 E603<br>F64B CACEF6<br>F64E FE02                                              | LDA<br>ANI<br>JZ<br>CPI                          | IOBYTE<br>3<br>TTYIN<br>2                                  | ;ISOLATE CONSOLE ASGT<br>;TTY DEVICE ACTIVE                                |
| F650 FA62F4<br>F653 C262F4                                                                           | JM<br>JNZ                                        | ČRTIN<br>CUSI1                                             | CRT ACTIVE<br>USER CONSOLE 1 ACTIVE                                        |
| F656 3A0300 RI<br>F659 E60C<br>F65B CACEF6<br>F65E FE08                                              | LDA<br>ANI<br>JZ<br>CPI                          | IOBYTE<br>OCH<br>TTYRDR<br>8                               | ISOLATE BATCH ASGT                                                         |
| F660 FA62F4<br>F663 CA62F4<br>F666 C362F4                                                            | JM<br>JZ<br>JMP                                  | PTRIN<br>RUSI1<br>RUSI2                                    | PAPER TAPE READER ACTIVE<br>JUSER READER 1 ACTIVE<br>JUSER READER 2 ACTIVE |
| F669 3A0300 LS<br>F66C E6C0<br>F66E CAD6F6<br>F671 FE80<br>F673 FA62F4<br>F676 CA62F4<br>F679 C362F4 | STAT: LDA<br>ANI<br>JZ<br>CPI<br>JM<br>JZ<br>JMP | IOBYTE<br>OCOH<br>TTOST<br>80H<br>CRTOST<br>LPRST<br>LUST1 | ;ISOLATE THE LIST DEVICE ASSIGNMENT                                        |
| F67C 3A0300 PO<br>F67F E630<br>F681 CADEF6<br>F684 FE20                                              | : LDA<br>ANI<br>JZ<br>CPI                        | IOBYTE<br>30H<br>TTPNCH<br>20H                             | ISOLATE PUNCH ASGT                                                         |
| F686 FA62F4<br>F689 CA62F4<br>F68C C362F4                                                            | JM<br>JZ<br>JMP                                  | HSP<br>PUSO1<br>PUSO2                                      | HIGH SPEED PUNCH ACTIVE<br>USER PUNCH 1 ACTIVE<br>USER PUNCH 2 ACTIVE      |
| . 9                                                                                                  | ROUTINE CONI<br>PARITY                           | READS THE BIT.                                             | E CONSOLE AND STRIPS OFF THE ASCII                                         |
| F692 E67F                                                                                            | NI: CALL<br>ANI<br>S: RET                        | CI<br>7FH                                                  | GET THE NEXT CHARACTER<br>STRIP OFF THE PARITY BIT                         |

|                                                                                   |                           |                                                  |                                    | $\sim$                                                                                                                                              |
|-----------------------------------------------------------------------------------|---------------------------|--------------------------------------------------|------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|
| CP/M MACRO ASSEM                                                                  | 2.0                       | #022                                             | MOSS 2.2                           | MONITOR                                                                                                                                             |
|                                                                                   | ROUTIN                    | THE STRI<br>LAST CHA<br>A NEW LI                 | NG MUST                            | N ASCII STRING ONTO THE CONSOLE.<br>BE TERMINATED BY BIT 7 SET IN THE<br>F THE STRING. THE STRING WILL START<br>PRTWD) OR CONTINUE ON THE SAME<br>) |
| F695 CDA9F6<br>F698 C5<br>F699 4E<br>F69A CD00F6<br>F69D 23<br>F69E 79<br>F69F 07 | PRTWD:<br>PRTWA:<br>PRTA: | CALL<br>PUSH<br>MOV<br>CALL<br>INX<br>MOV<br>RLC | B<br>C,M<br>CO<br>H<br>A,C         | START A NEW LINE<br>SAVE (B,C)<br>GET NEXT CHARACTER FROM MEMORY<br>OUTPUT IT<br>INCREMENT MEMORY POINTER<br>TEST FOR BIT 7 DELIMITER               |
| F6A0+30F7<br>F6A2 C1<br>F6A3 C9                                                   | PRTB:                     | JRNC<br>POP<br>RET                               | PRTA<br>B                          | ;NO DELIMITER, GO DO NEXT CHARACTER<br>;RESTORE (B,C)                                                                                               |
| FORS C9                                                                           | :                         |                                                  |                                    |                                                                                                                                                     |
|                                                                                   | ROUTI                     | NE EXLF H<br>D,E AND<br>LINE FEH                 | READS TWO<br>H,L REGI<br>ED SEQUEN | PARAMETERS, PUTS THEM INTO THE<br>STERS, THEN DOES A CARRIAGE RETURN,<br>CE.                                                                        |
| F6A4 CDD9F0<br>F6A7 D1<br>F6A8 E1                                                 | ÉXLF:                     | CALL<br>POP<br>POP                               | EXPR<br>D<br>H                     | ;GO GET TWO PARAMETERS                                                                                                                              |
|                                                                                   | ROUTII                    | IT INCLU                                         | JDES TRHE                          | A CARRIAGE RETURN, LINE FEED<br>CURRENT CONSOLE TO START A NEW LINE<br>CE 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,RSTMSG<br>PRTWD<br>WSVEC         | ;GET ADDRESS OF RESTART ERROR MSG<br>;PRINT IT ON NEW LINE<br>;GO TO WARM BOOT                                                                      |
| F6BB 5253542045<br>F6C2 0D0A0080                                                  | RSTMSG:<br>CRMSG:         | DB<br>DB                                         | 'RST ER'<br>CR,LF,O,               | ,'R'+80H<br>80H                                                                                                                                     |
|                                                                                   | ; I/O D                   | RIVERS FO                                        | OR THE 82                          | 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                                                              | † TYIN:                   | 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                                                 |                           | IN<br>RET                                        | SDATA                              | ; READ THE DATA                                                                                                                                     |
| F6D6 DB25<br>F6D8 E620<br>F6DA C8<br>F6DB C6BF<br>F6DD C9                         | TTOST:                    | 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 DB25<br>F6E0 E620                                                            | ττνουτ:                   | IN<br>ANI<br>JRZ                                 | SLSTAT<br>20H<br>TTYOUT            | GET 8250 LINE STATUS<br>ISOLATE THRE BIT<br>WAIT UNTIL ONE OF THE REGISTERS EMPTI                                                                   |

## FIRMWARE LISTING

| CP/M MACRO ASSEM                                                                                 | 12.0 #0                                                         | 023 1                             | MOSS 2.2                                              | MONITOR                                                                                                                                                                                                                                                                 |
|--------------------------------------------------------------------------------------------------|-----------------------------------------------------------------|-----------------------------------|-------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| F6E2+28FA<br>F6E4 79<br>F6E5 D320<br>F6E7 C9                                                     | O                                                               | OV<br>UT<br>ET                    | A,C<br>SDATA                                          | ;MOVE THE DATA OVER<br>;OUTPUT THE DATA                                                                                                                                                                                                                                 |
|                                                                                                  | EQUATES                                                         | FOR AD                            | DITIONAL                                              | CONSOLE DEVICES                                                                                                                                                                                                                                                         |
| F462 =<br>F462 =<br>F462 =<br>F462 =<br>F462 =<br>F462 =<br>F462 =<br>F462 =                     | CRTOUT: EC<br>CRTST: EC<br>CRTOST: EC<br>CUSI1: EC<br>CUSO1: EC |                                   | 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 (OUTPUT)                                                                                                                                                                  |
|                                                                                                  | EQUATE                                                          | S FOR A                           | DDITIONA                                              | L PAPER TAPE PUNCH DEVICES                                                                                                                                                                                                                                              |
| F6DE =<br>F462 =<br>F462 =<br>F462 =<br>F462 =<br>F462 =                                         | HSP: EC<br>HSPST: EC<br>PUSO1: EC                               | QU<br>QU<br>QU                    | 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                                                                                                                    |
|                                                                                                  | , EQUATE                                                        | S FOR A                           | DDITIONA                                              | L LIST DEVICES                                                                                                                                                                                                                                                          |
| F462 =<br>F462 =<br>F462 =<br>F462 =                                                             | LPRST: EC                                                       | QU<br>QU                          | IOER                                                  | ;UNASSIGNED LINE PRINTER<br>;UNASSIGNED PRINTER STATUS<br>;LIST DEVICE 1<br>;LIST DEVICE 1 STATUS                                                                                                                                                                       |
|                                                                                                  | EQUATE                                                          | S FOR A                           | DDITIONA                                              | L PAPER TAPE READER DEVICES                                                                                                                                                                                                                                             |
| F6CE =<br>F462 =<br>F462 =<br>F462 =<br>F462 =<br>F462 =<br>F462 =                               | PTRST: EC<br>RUSI1: EC<br>RUST1: EC<br>RUSI2: EC                | QU<br>QU<br>QU<br>QU<br>QU        | TTYIN<br>IOER<br>IOER<br>IOER<br>IOER<br>IOER<br>IOER | ;UNASSIGNED TELETYPE PAPER TAPE READER<br>;UNASSIGNED HIGH SPEED PAPER TAPE READ<br>;UNASSIGNED HS PTR STATUS<br>;UNASSIGNED PAPER TAPE READER 1<br>;UNASSIGNED PAPER TAPE READER 1 (STATU<br>;UNASSIGNED PAPER TAPE READER 2<br>;UNASSIGNED PAPER TAPE READER 2 (STATU |
| F6E8 CDF0F6<br>F6EB 07<br>F6EC 07<br>F6ED 07<br>F6EE 07<br>F6EF 47<br>F6F0 CD86F4<br>F6F3 C3B0F3 | RI<br>RI<br>RI<br>RI<br>RIBBLE: C                               | LC<br>LC<br>LC<br>LC<br>OV<br>ALL | RIBBLE<br>B,A<br>RIX<br>NIBBLE                        | READ AND CONVERT ONE CHARACTER<br>SHIFT INTO HIGH NIBBLE<br>SAVE IN B TEMPORARILY<br>READ A CHARACTER<br>GO CONVERT TO HEX DIGIT                                                                                                                                        |
|                                                                                                  | PADR RO<br>IT IS<br>FORMA                                       | UTINE P<br>USED T<br>T RECOR      | UNCHES (<br>O PUT TH<br>D.                            | H,L) AS FOUR ASCII CHARACTERS.<br>HE ADDRESS INTO AN INTEL HEX                                                                                                                                                                                                          |
| F6F6 CDFEF6<br>F6F9 7C<br>F6FA CDFEF6<br>F6FD 7D                                                 | PADR: M<br>C                                                    |                                   | PBYTE<br>A,H<br>PBYTE<br>A,L                          |                                                                                                                                                                                                                                                                         |
|                                                                                                  | PBYTE R<br>THE C                                                | OUTINE                            | PUNCHES<br>PUNCH DE                                   | (A) AS TWO ASCII CHARACTERS ON<br>EVICE.                                                                                                                                                                                                                                |
| F6FE F5<br>F6FF 0F<br>F700 0F<br>F701 0F<br>F702 0F                                              | R<br>R<br>R                                                     | USH<br>RC<br>RC<br>RC<br>RC<br>RC | PSW                                                   | ;SAVE THE BYTE<br>;DO HIGH NIBBLE FIRST                                                                                                                                                                                                                                 |
| F703 CD6EF3<br>F706 CD0CF0                                                                       | С                                                               | ALL                               | CONV<br>PUNCH                                         | ;CONVERT TO ASCII<br>;PUNCH IT                                                                                                                                                                                                                                          |

| CP/M MACRO ASSEM 2.0                                                                         | <i>#</i> 024                                            | MOSS 2.2 MONITOR                                                                                                                 |
|----------------------------------------------------------------------------------------------|---------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------|
| F709 F1<br>F70A F5<br>F70B CD6EF3<br>F70E CD0CF0<br>F711 F1<br>F712 82<br>F713 57<br>F714 C9 | POP<br>PUSH<br>CALL<br>CALL<br>POP<br>ADD<br>MOV<br>RET | PSW ;GET LOW NIBBLE<br>PSW ;RESAVE FOR CHECKSUM<br>CONV ;CONVERT TO ASCII<br>PUNCH ;PUNCH IT<br>PSW<br>D ;UPDATE CHECKSUM<br>D,A |
| F715 '                                                                                       | END                                                     |                                                                                                                                  |

# APPENDIX D

# PARTS LIST, BOARD LAYOUT, SCHEMATIC, SPECIFICATIONS

| QTY<br>               | REF NO.                                        | DESCRIPTION                                                                   | CCS PART NO.*                                                                                         |
|-----------------------|------------------------------------------------|-------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------|
| Capad                 | citors                                         |                                                                               |                                                                                                       |
| 2<br>12               | C1,3<br>C2,7,12,13<br>15,C17-23                | 27pf. Mica<br>.1uf 50v Monolythic                                             | 42215 <b>-</b> 52705<br>42034 <b>-</b> 21046                                                          |
| 1<br>6<br>1<br>1      | C4<br>C5,6,8–11<br>C14<br>C16                  | 56pf 500v Mica<br>4.7uf 35v Dip Tantalum<br>.47uf 50v Monolythic<br>33pf Mica | 42215-55605<br>42804-54756<br>42034-24746<br>42215-53305                                              |
| Integrated Circuits   |                                                |                                                                               |                                                                                                       |
| 1<br>2<br>1<br>1<br>2 | U1<br>U13,39<br>U2,3<br>U4<br>U5<br>U6,7<br>U8 | 7404<br>74LS04<br>75150<br>75154<br>8250<br>74LS136<br>2716, 2048 X 8 EPROM   | 30200-07404<br>30000-00004<br>30300-00150<br>30300-00154<br>31200-08250<br>30000-00136<br>31900-02716 |

| ł                  | 01               | 7404                  | 50200-07404          |
|--------------------|------------------|-----------------------|----------------------|
| 2                  | U13,39           | 74LSO4                | 30000 <b>-</b> 00004 |
| 2<br>2             | U2,3             | 75150                 | 30300-00150          |
| 1                  | U4               | 75154                 | 30300-00154          |
| 1                  | Ū5               | 8250                  | 31200-08250          |
| 2                  | ŪĞ,7             | 74LS136               | 30000-00136          |
| 1                  | U8               | 2716, 2048 X 8 EPROM  | 31900-02716          |
| 1                  | U9               | 5623, 256 X 4 ROM     | 30900-05623          |
| 1                  | U 10             | Z-80                  | 31200-38804          |
| 2                  | U11,18,26        | 74LS08                | 30000-00008          |
| 2                  |                  | 74LS00                | 30000-00000          |
| 2                  | U12,27           |                       |                      |
| 3<br>2<br>3<br>· 1 | U14,34,35        | 74LS74                | 30000-00074          |
| · 1                | U15              | 74LS175               | 30000-00175          |
| 3                  | U16,17,25        | 74LS02                | 30000-00002          |
| 1                  | U19              | 78L12, +12V Regulator | 32000-17812          |
| 1                  | U20              | 79L12, -12V Regulator | 32000-17912          |
| 1                  | U21              | 74LS10                | 30000-00010          |
| 7                  | U22,28,29,33,42, | 74LS257               | 30000 <b>-</b> 00257 |
|                    | 43,45            |                       |                      |
| 1                  | U24              | 74LS161               | 30000-00161          |
| 6                  | U30,31,37,40,41, | 74LS367               | 30000-00367          |
|                    | 44               |                       |                      |
| 1                  | U32              | 74LS30                | 30000-00030          |
| 1                  | U36              | 74LS20                | 30000-00020          |
| 1                  | U38              | 74LS32                | 30000-00032          |
| 1                  | U46              | 7805, +5V Regulator   | 32000-07805          |
| 2                  | U47,49           | 75453                 | 30300-00453          |
| 1                  | U48              | 555                   | 30900-00555          |
| -                  |                  |                       |                      |
| <b>.</b> .         | 1                |                       |                      |

Resistors

| 2 | R1,2 | 470 1/4W 5%     | 40002-04715 |
|---|------|-----------------|-------------|
| 1 | R3   | 680 ohm 1/4W 5% | 40002-06815 |
| 1 | R4   | 1.5K 1/4W 5%    | 40002-01525 |

 $\ensuremath{^{\star}}$  Use CCS part number when ordering spare parts or replacements.

| CONTIN<br>QTY                                                   | NUED<br>REF NO.                                             | DESCRIPTION                                                                                                                                                                                                                                                                                                                                              | CCS PART NO.                                                                                                                                                                                                                  |
|-----------------------------------------------------------------|-------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3<br>2<br>1<br>1<br>4<br>5                                      | R5-7<br>R8,R15<br>R9<br>R10<br>R11-14<br>Z1-5               | lM 1/4W 5%<br>2.7K 1/4W 5%<br>1.2K 1/4W 5%<br>22 ohm 1/4W 5%<br>220 ohm 1/4W 5%<br>2.7K X 7 SIP Network                                                                                                                                                                                                                                                  | 40002-01055<br>40002-02725<br>40002-01225<br>40002-02205<br>40002-02215<br>40930-72726                                                                                                                                        |
| IC So                                                           | ckets                                                       |                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                               |
| 20                                                              | XU1,6,7,11-14,16-<br>18,21,25-27,<br>32,34-36,38,39         | 14-Pin Low Profile                                                                                                                                                                                                                                                                                                                                       | 58102-00140                                                                                                                                                                                                                   |
| 5<br>18                                                         | XU2,3,47-49<br>XU4,9,15,22,24,<br>28-31,33,37,<br>40-45, J3 | 8-Pin Low Profile<br>16-Pin Low Profile                                                                                                                                                                                                                                                                                                                  | 58102-00080<br>58102-00160                                                                                                                                                                                                    |
| 1<br>2                                                          | XU8<br>XU5,10                                               | 24-Pin Low Profile<br>40-Pin Low Profile                                                                                                                                                                                                                                                                                                                 | 58102-00240<br>58102-00400                                                                                                                                                                                                    |
| Misce                                                           | llaneous                                                    |                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                               |
| 3<br>1<br>1<br>30<br>30<br>1<br>1<br>1<br>1<br>2<br>1<br>2<br>2 | CR1-3<br>J2<br>Q1<br>S1<br>W1-30<br>W1-30<br>Y1<br>Y2<br>   | LED, Rectangular Red<br>Header, 2 x 13 Right Angle<br>Transistor, PN2907<br>Switch, Toggle<br>Header, 1 x 3 Straight<br>Berg Jumper Plugs<br>Crystal, 1.8432 MHz<br>Crystal, 16.000 MHz<br>Heatsink<br>Nut, Hex Kep 6-32<br>Screw, 6-32 x 5/16"<br>Tape, Foam Two-sided<br>PC Board, 2810 CPU, rev A<br>Extractor, PCB nonlocking<br>Extractor Roll Pins | 37400-00001<br>56005-02013<br>36100-02907<br>27391-12000<br>56004-01003<br>56200-00001<br>48132-84321<br>48231-60003<br>60022-00001<br>73006-32001<br>71006-32051<br>60003-00001<br>02810-00002<br>60010-00001<br>60010-00000 |



POWER-ON JUMP ENABLE

#### 2810 Z-80 CPU 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: .650 amps at +8 volts .030 amps at +16 volts .025 amps at -16 volts Power Dissipation: 6.2 watts

#### ENVIRONMENTAL REQUIREMENTS

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

# COMMENT SHEET

## 2810 Z-80 CPU MANUAL 89000-02810A

Any comments, criticisms, or suggestions you have will be appreciated.

Name: Company: Address: Position:

Publications • California Computer Systems 250 Caribbean Dr. • Sunnyvale, CA 94086

### APPENDIX E

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

(1) 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 to which this warranty attaches, and their specifications and familiar with operational descriptions. and is the 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 EXPRESSLY DISCLAIMS ANY LIABILITY ARISING FROM THE USE AND/OR OPERATION OF ITS PRODUCTS, AND SHALL NOT BE LIABLE FOR ANY CONSEQUENTIAL OR 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 conditions accurately reflect operating 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 CCS. CCS makes no warranty whatsoever in respect to by 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 a

E-2

#### LIMITED WARRANTY

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

