

Martin Eberhard 13 August 2014

# Revision History

| Rev  | Date      | Author      | Notes                                                                    |
|------|-----------|-------------|--------------------------------------------------------------------------|
| 1.00 | 15SEP2013 | M. Eberhard | Created                                                                  |
| 1.01 | 25MAR2014 | M. Eberhard | Fixed alternate platter load bug                                         |
| 1.02 | 26MAR2014 | M. Eberhard | Platter number in signon, jump to XENTER when done, so message completes |
| 1.03 | 05JUN2014 | M. Eberhard | Use sense switch All to select platter.<br>Don't allow selecting unit.   |
| 2.00 | 13AUG2014 | M. Eberhard | Turnkey Module compatibility: copy code<br>to RAM before running.        |
|      |           |             |                                                                          |

## INTRODUCTION

HDBL is a 256-byte PROM program that loads the boot file from either platter of an 88-HDSK hard disk, and executes the successfully loaded code. Progress and error messages are printed on a "standard" 6850based Altair Terminal port, such as port A of an 88-2SIO, the serial port on a Turnkey Module, or the serial port of an 88-UIO.

## CONTENTS

| 1.  | INSTALLATION                       | 3 |
|-----|------------------------------------|---|
| 2.  | SYSTEM REQUIREMENTS                | 3 |
| 3.  | SELECTING THE BOOT PLATTER         | 3 |
| 4.  | OPERATING PROCEDURES               | 4 |
| 5.  | ERROR INDICATIONS                  | 5 |
| 6.  | 8800b TURNKEY MODULE COMPATIBILITY | 5 |
| API | PENDIX A - DISK STRUCTURE          | 6 |
| API | PENDIX B - SOURCE CODE LISTING     | б |

## 1. INSTALLATION

The HDBL PROM must be installed at address 176000 octal. It is inserted in slot E of an 88-PMC memory card (with its base address at 174000 octal), or in slot L1 of a Turnkey Module.

## 2. SYSTEM REQUIREMENTS

The standard build of HDBL requires at least 48K of RAM in the Altair, because its stack and relocated code is located in the 256-byte page that begins at address BF00h.

The 88-HDSK controller must be installed at the I/O standard addresses, 280 octal through 287 octal (A0h through A7h).

HDBL expects a Motorola 6850 ACIA-type device as its Terminal. This can be one of the following devices: an 88-2SIO (port A), an 8800b Turnkey Module, or an 88-UIO. This I/O device must be addressed at address 020 and 021 octal (10h and 11h).

## 3. SELECTING THE BOOT PLATTER

MITS's software only boots from the removable cartridge of the disk drive. HDBL allows you to boot also from the fixed platter. You can select from which platter to boot using Sense Switch 3<sup>1</sup> (labeled A11 on an Altair front panel). If this switch is down (0), then HDBL will boot from the removable cartridge. If this switch is up (1), then HDBL will load from the fixed platter.

<sup>&</sup>lt;sup>1</sup> This particular switch was chosen to minimize collisions with the normal use of sense switches <Al1:A8>. 0000 through 0110 select the input device for MBL and for the various checksum loaders on tape (and values above 0110 will generate an error). So if you have the sense switches (which may be inaccessible on an 8800b Turnkey board) set for loading from e.g. cassette, then the machine will still boot from the removable cartridge when booting via HDBL.

#### 4. OPERATING PROCEDURES

- 5.1 Start the Computer
  - 1. Power on or Reset the Altair.
  - 2. If you have TURMON or UBMON, then start this program, if the autostart did not do so already.
  - 3. If you do not have TURMON or UBMON or equivalent:
    - a. STOP and RESET the Altair.
    - b. EXAMINE address 176000 octal
- 5.1 START THE HARD DISK
  - 1. Power on the disk controller
  - 2. Power on the disk drive
  - 3. When the SAFE light comes on, press the RUN switch on the disk drive, and wait for the READY light to come on.
- 5.3 INITIATING THE LOAD
  - 1. Select the boot platter by setting Sense Switch 3
    - a. Set Switch 3 down to boot from the removable cartridge
    - b. Set Switch 3 up to boot from the fixed platter
  - 2. Start HDBL
    - a. If you are using TURMON, type "J176000".
    - b. If you are using UBMON, type "L"
    - c. If you are starting with a front panel, press the RUN switch.
- 5.4 COMPLETING THE LOAD
  - 1. HDBL will immediately announce its revision number.
  - 2. HDBL will announce "LOADING FROM {0 or 1}", where 0 is the removable cartridge, and 1 is the fixed platter. This message is printed after HDBL has successfully loaded the Pack Descriptor Page from the hard disk. The Pack Descriptor page (track 0, side 0, sector 0) informs HDBL the starting load sector number, and the total number of sectors to load.
  - 3. Loading will continue until the specified number of sectors has been loaded, or until an error occurs. HDBL does not retry on errors.

## 5. ERROR INDICATIONS

The Interrupt Enable light remains off if loading is proceeding properly. If an error occurs, the Interrupt Enable light comes on and an error message is printed on the Console. The 88-HDSK error code is stored in address 0000, and then the Altair will hang in an infinite loop. (You can reset the Altair, and then examine this location.)

The 88-HDSK error code is an 8-bit value, with each bit indicating a different error when set. These bits are interpreted as follows:

| Bit | Meaning                      |  |  |  |  |  |  |  |  |
|-----|------------------------------|--|--|--|--|--|--|--|--|
| 0   | Drive not ready              |  |  |  |  |  |  |  |  |
| 1   | Illegal sector requested     |  |  |  |  |  |  |  |  |
| 2   | CRC error in sector data     |  |  |  |  |  |  |  |  |
| 3   | CRC error in sector header   |  |  |  |  |  |  |  |  |
| 4   | Wrong sector detected        |  |  |  |  |  |  |  |  |
| 5   | Wrong cylinder detected      |  |  |  |  |  |  |  |  |
| 6   | Wrong head detected          |  |  |  |  |  |  |  |  |
| 7   | Write protect (not an error) |  |  |  |  |  |  |  |  |

See the 88-HDSK documentation for further details.

#### 6. 8800b TURNKEY MODULE COMPATIBILITY

The 8800b Turnkey Modules (except for Rev 0 Turnkey Modules that do not have the 88-SYS-CLG mods) disable PROM and enable RAM whenever software inputs from the Sense Switch port. (Some versions of this board will disable the PROMs when any IN instruction is executed!)

This means that any PROM that reads the Sense switches will not work with the Turnkey Module - and any PROM that ever uses the IN instruction will fail with some Turnkey Modules.

Starting with version 2.00, HDBL will work with all Turnkey Modules, because it relocates its own code to RAM before ever reading the Sense Switches. Code is relocated to the same page of memory that HDBL uses for its stack, starting at address BF00h in the standard build. (This requires at least 48K of RAM in the Altair.)

13 August 2014 88 HDBL PROM vers. 2.00

## APPENDIX A - DISK STRUCTURE

There are 24 256-byte sectors per track, and these are numbered 0 through 23 on each track. Each platter has 2 sides, numbered 0 and 1. Data on each platter is organized as a sequence of Disk Pages, where each Page is one sector. Pages are numbered sequentially starting at 0 (on track 0, side 0), through the 24 sectors on track 0, side 0, and then on to track 0, side 1, where sector 0 is page 24. Page 47 is the first sector on track 1, side 0, and page numbering continues this way through all the tracks.

Page 0 (which is track 0, side 0, sector 0) is the Pack Descriptor Page, containing various information about the particular disk platter. Bytes 40-43 of this Page are the "Opsys Pointers." Bytes 40 & 41 are the page number of the starting boot page, Bytes 42 & 43 are the number of pages to load during boot. HDBL assumes that the boot file is to be loaded into memory starting at address 0000.

## APPENDIX B - SOURCE CODE LISTING

The following pages list the source code for HDBL. This code was assembled using Digital Research's ASM assembler. As such, all values are in hexadecimal, rather than in octal as is normal for MITS software.

> 13 August 2014 88 HDBL PROM vers. 2.00

HDBL.PRN

\_\_\_\_\_ Hard Disk Boot Loader (HDBL) By Martin Eberhard HDBL is a 256-byte PROM program that loads the boot file from an 88-HDSK hard disk, and executes the successfully loaded code. Progress and error messages are printed on a "standard" 6850-based Altair Terminal port at address 10H and 11h, such as port A of an 88-2SIO, the serial port on a Turnkey Module, or the serial port of an 88-UIO. The standard 88-HDSK system uses a Pertec D3422 disk drive, which contains 2 platters - one is in a removable cartridge, the other is a fixed platter. However, The 88-HDSK controller can actually support up to 4 platters, supporting the Pertec D3462 disk drive, which has one removable platter, and 3 fixed platters. Altair software normally boots only from the removable cartridge of a D3422 disk drive. HDBL allows you to boot also from the fixed platter. You can select from which platter to boot using Sense Switch 3 (A11 on the front panel). 0 (down) selects the removable cartridge, 1 (up) selects the fixed platter. This switch was chosen to minimize collisions with the normal use of sense switches <A11:A8>. 0000 through 0110 select the input device for MBL and for the various checksum loaders on tape (and values above 0110 will generate an error). So if you have the sense switches (which may be inaccessible on an 8800b Turnkey board) set forloading from e.g. cassette, then the machine will still boot from the removable cartridge when booting via HDBL. There are 24 256-byte sectors per track, and these are numbered 0 through 23 on each track. Each platter has 2 sides, numbered 0 and 1. Data on each platter is organized as a sequence of Disk Pages, where each Page is one sector. Pages are numbered sequentially starting at 0 (on track 0, side 0), through the 24 sectors on track 0, side 0, and then on to track 0, side 1, where sector 0 is page 24. Page the first sector on track 1, side 0, and page numbering Page 47 is continues this way through all the tracks. Page 0 (which is track 0, side 0, sector 0) is the Pack Descriptor Page, containing various information about the particular disk platter. Bytes 40-43 of this Page are the "Opsys Pointers." Bytes 40 & 41 are the Page number of the starting boot Page, Bytes 42 & 43 are the number of Pages to load during boot. HDBL assumes that the boot file is to be loaded into memory starting at address 0000, and executed there. During loading, the INTE (Interrupt Enabled) LED on the front panel will be off. Any error during loading will cause the INTE LED to light and a "LOAD ERR" message to be printed on the Terminal. The error code is stored in memory at address 0. HDBL will then hwng in a loop until Reset. Because HDBL may be running stand-alone, the Terminal port gets initialized during HDBL initialization. But if control came from UBMON (with an "L" command) or from TURMON (with a "J 176000" command) then the Terminal port's ACIA will still Page 1

|                  | HDBL.PRN<br>; be transmitting the last two character-echos of the command<br>; when HDBL begins. HDBL will stall 6.5 uS (one character time<br>; above 1800 baud) before initializing the Terminal port, so<br>; that the ACIA will have time to finish transmitting this last<br>; characters before it gets reset.                                                                                                                                                                                                                                                               |  |  |  |  |  |  |  |
|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|
|                  | , Newer Turnkey Modules (and older ones with the 88-SYS-CLG<br>; modification) will disable the PROMs when an IN instruction<br>; reads port FFh (the Sense Switches). Some of these boards<br>; will disable the PROM when *any* IN instruction is<br>; executed. For this reason, HDBL copies itself to RAM, and<br>; runs from there, before executing any IN instructions.                                                                                                                                                                                                     |  |  |  |  |  |  |  |
|                  | , This code is written to assemble with ASM by Digital Research                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |  |  |
|                  | Revision History<br>1.00 15SEP2013 M.Eberhard<br>Created<br>1.01 25MAR2014 M.Eberhard<br>Fixed bug with loading from alternate platters, code<br>squeeze, improve comments<br>1.02 26MAR2014 M.Eberhard<br>Further compression. Print platter number in signon msg.<br>Jump to XENTER instead of XMON on error, so ACIA reset<br>doesn't hose the last chr of error code.<br>1.03 05JUN2013 M.Eberhard<br>Use sense switch All to select boot platter. Eliminate<br>selection of boot drive.<br>2.00 15AUG2014 M.Eberhard<br>Copy code to RAM before execution, for Turnkey Module |  |  |  |  |  |  |  |
|                  | (Remember to update the Version String below)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |  |  |  |
| 0000 =<br>FFFF = | ;=====================================                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |  |  |
|                  | ; PROM address and Entry point for HDBL. UBMON assumes FC00h.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |  |  |  |
| FC00 =           | HDBL equ OFCOOh ;Beginning of HDBL PROM                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |  |  |  |  |
|                  | ; RAM address for moved code. Exactly one of these<br>; should be used.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |  |  |  |  |
| BF00 =           | RAMPAG equ 0BF00h ;beginning of RAM page (48K system)<br>;RAMPAG equ 0F700h ;beginning of RAM page (62K system)<br>;RAMPAG equ 0FB00h ;beginning of RAM page (63K system)<br>;(e.g. Turnkey Module's RAM)                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |  |  |  |  |
| 3D00 =           | ROF equ HDBL-RAMPAG ;RAM relocation offset                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |  |  |  |  |
|                  | ; Sense Switch assignment for selecting the boot platter & unit                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |  |  |
| 00FF =<br>0008 = | SSWTCH equ OFFh ;Sense Switch address<br>PSWTCH equ 008h ;mask for platter Switches<br>;Code assumes 008h (bit 3)                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |  |  |  |
|                  | ; Terminal port equates - same for 88-2SIO port 0, Turnkey<br>; Module, and 88-UIO (all based on the Motorola 6850 ACIA)<br>; Note: transmitting with 2 stop bits is also compatible with a<br>; receiver that is programmed for 1 stop bit.<br>Page 2                                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |  |  |

HDBL.PRN

| 0010 =<br>0010 =<br>0011 =<br>0011 =                                                   | ACCTRL<br>ACSTAT<br>ACTXD<br>ACRXD                                                   | EQU<br>EQU<br>EQU<br>EQU                                    | 10h<br>10h<br>11h<br>11h                                    | ;ACIA Control output port<br>;ACIA Status input port<br>;ACIA TX Data register<br>;ACIA RX Data register                                                                                                                                  |
|----------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------|-------------------------------------------------------------|-------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0003 =<br>0001 =<br>0002 =<br>0011 =                                                   | ACRSET<br>ACRDF<br>ACTDE<br>ACINIT                                                   | EQU<br>EQU<br>EQU<br>EQU                                    | 0000001<br>0000000<br>0000001<br>0001000                    | 1b ;Master reset<br>1b ;RX Data register full<br>0b ;TX Data register empty<br>1b ;/16, 8-bit, No Parity, 2Stops                                                                                                                          |
|                                                                                        | ; 88-HDS                                                                             | SK ports                                                    | (The in                                                     | terface board is actually an 88-4PIO.)                                                                                                                                                                                                    |
| 00A0 =<br>00A1 =<br>00A2 =<br>00A3 =                                                   | CREADY<br>CSTAT<br>ACSTA<br>ACMD                                                     | equ<br>equ<br>equ<br>equ                                    | 0A0h<br>0A1h<br>0A2h<br>0A3h                                | ;IN: Ctlr ready for command (bit7)<br>;IN: error flags, reset CREADY<br>;IN: Command Ack (bit 7)<br>;IN: reset Command Ack                                                                                                                |
| 00A4 =<br>00A5 =<br>00A6 =<br>00A7 =                                                   | CDSTA<br>CDATA<br>ADSTA<br>ADATA                                                     | equ<br>equ<br>equ<br>equ                                    | 0A4h<br>0A5h<br>0A6h<br>0A7h                                | ;IN: data/stat availablr at CDATA<br>;IN: Disk data or status from Ctlr<br>;IN: ADATA Port Available (bit 7)<br>;OUT: Command low byte                                                                                                    |
|                                                                                        | ; 88-HDS                                                                             | SK ACMD:                                                    | ADATA Cor                                                   | nmands                                                                                                                                                                                                                                    |
| 0000 =                                                                                 | CSEEK                                                                                | equ                                                         | 00h                                                         | ;Bits 15:12 = 0000b<br>;Bits 11:10 = Unit #<br>;Bits 9:0 = Cylinder #                                                                                                                                                                     |
| 0030 =                                                                                 | CRDSEC                                                                               | equ                                                         | 30h                                                         | ;Bits 15:12 = 0011b<br>;Bits 11:10 = Unit #<br>;Bits 9:8 = Buffer #<br>;Bit 7:6 = Platter #<br>;Bits 5 = Side #<br>;Bits 4:0 = Sector #                                                                                                   |
| 0020 =<br>00C0 =<br>000C =                                                             | CSIDE<br>CFPLTR<br>CUNIT                                                             | equ<br>equ<br>equ                                           | 020h<br>0C0h<br>00Ch                                        | ;Side select for CRDSEC<br>;platter mask for CRDSEC<br>;Unit mask for CSEEK & CRDSEC                                                                                                                                                      |
| 0050 =                                                                                 | CRDBUF                                                                               | equ                                                         | 50h                                                         | ;Bits 15:12 = 0101b<br>;Bits 11:10 = not used<br>;Bits 9:8 = buffer #<br>;Bits 7:0 = # bytes to transfer<br>;(00 means 256)                                                                                                               |
|                                                                                        | ; 88-HDS                                                                             | бк сятат                                                    | error b                                                     | its                                                                                                                                                                                                                                       |
| 0001 =<br>0002 =<br>0004 =<br>0008 =<br>0010 =<br>0020 =<br>0040 =<br>0080 =<br>007F = | ERDNR<br>ERBADS<br>ERSCRC<br>ERHCRC<br>ERSWRG<br>ERCWRG<br>ERHWRG<br>WPROT<br>ERMASK | equ<br>equ<br>equ<br>equ<br>equ<br>equ<br>equ<br>equ<br>equ | 01h<br>02h<br>04h<br>08h<br>10h<br>20h<br>40h<br>80h<br>7Fh | ;drive not ready<br>;illegal sector<br>;CRC error during sector read<br>;CRC error during header read<br>;header has wrong sector<br>;header has wrong cylinder<br>;header has wrong head<br>;Write Protect<br>;all the actual error bits |
|                                                                                        | ; 88-HDS                                                                             | SK Consta                                                   | ants                                                        |                                                                                                                                                                                                                                           |
| 0028 =<br>0018 =<br>0000 =                                                             | OSOFF<br>HDSPT<br>DBUFR                                                              | equ<br>equ<br>equ                                           | 40<br>24<br>0                                               | ;Page 0 offset to opsys pointers<br>;Sectors per track<br>;Default controller buffer: 0-3<br>Page 3                                                                                                                                       |

## HDBL.PRN ;Code gets longer if <>0

|                                                      |                                              | ; ASCII                                                   | charact                                            | ers                                                          |                                                                                              |
|------------------------------------------------------|----------------------------------------------|-----------------------------------------------------------|----------------------------------------------------|--------------------------------------------------------------|----------------------------------------------------------------------------------------------|
| 000d<br>000a                                         | =                                            | CR<br>LF                                                  | equ<br>equ                                         | 0Dh<br>0Ah                                                   |                                                                                              |
| FC00                                                 |                                              | ;======<br>; Start                                        | of HDBL<br>org                                     | PROM<br>HDBL                                                 |                                                                                              |
| FC00                                                 | F3                                           | ,                                                         | di                                                 |                                                              | ;front panel INTE light off                                                                  |
|                                                      |                                              | ; Copy (<br>; This (<br>; faster; bytes                   | code to I<br>vill allo<br>r to comp<br>in RAM      | RAM. This will provide the state of the state of the stack.) | rovide 6.5 mS of delay.<br>s running at 1700 baud or<br>on. (This also leaves 18             |
| FC01<br>FC04                                         | 2100C0<br>16FC                               | ,                                                         | lxi<br>mvi                                         | h,RAMPAG+100h<br>d,(HDBL/256)                                | ;last RAM address+1<br>;PROM code page                                                       |
| FC06<br>FC07<br>FC08<br>FC09<br>FC0A<br>FC0B<br>FC0D | 2B<br>5D<br>1A<br>77<br>7D<br>D612<br>C206FC | COPLUP:                                                   | dcx<br>mov<br>ldax<br>mov<br>sui<br>jnz            | h<br>e,1<br>d<br>m,a<br>a,1<br>RAMCOD and OFFh<br>COPLUP     | ;(5+1)<br>;(4+1)<br>;(7+1)<br>;(7+1)<br>;(4+1)<br>;(7+2)ends with a=0<br>;(10+3)             |
|                                                      |                                              | ;54 cyc                                                   | les per p                                          | pass X (256-18) /                                            | /2 = 6.426  mS                                                                               |
|                                                      |                                              | ;<br>: Set u                                              | o svstem                                           | stack immediate                                              | ly below RAM code image                                                                      |
| FC10                                                 | F9                                           | ;                                                         | sphl                                               |                                                              |                                                                                              |
|                                                      |                                              | ;;<br>;go to                                              | loaded co                                          | ode (with a=0)                                               |                                                                                              |
| FC11                                                 | Е9                                           | ;                                                         | pchl                                               |                                                              |                                                                                              |
|                                                      |                                              | ;======<br>; All o<br>; On En<br>; a =                    | f the fo<br>try:<br>0                              | llowing code gets                                            | s copied to RAM and run there.                                                               |
| FC12<br>FC13                                         | 67<br>6F                                     | RAMCOD:                                                   | mo∨<br>mo∨                                         | h,a<br>1,a                                                   | ;set load initial page<br>;hl=0                                                              |
|                                                      |                                              | Initia<br>(Actua<br>On En<br>a =<br>hl =<br>On Ex<br>hl = | alize 88<br>ally por<br>try:<br>0<br>0<br>it:<br>0 | -HDSK interface k<br>ts 0 and 1 of an                        | board<br>88-4PIO)                                                                            |
| FC14<br>FC16<br>FC18<br>FC1A                         | D3A0<br>D3A2<br>D3A4<br>D3A6                 | ,                                                         | out<br>out<br>out<br>out                           | 0A0h<br>0A2h<br>0A4h<br>0A6h                                 | ;Select port OAh DDR<br>;Select port OBh DDR<br>;Select port 1Ah DDR<br>;Select port 1Bh DDR |

|                                                  | HDBL.PRN                                                                                                       |                                                                                                                      |                                                                                                                                                                                        |  |  |  |  |
|--------------------------------------------------|----------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| FC1C D3A1<br>FC1E D3A5                           | out<br>out                                                                                                     | 0A1h<br>0A5h                                                                                                         | ;Port OAh is an input port<br>;Port 1Ah is an input port                                                                                                                               |  |  |  |  |
| FC20 2F<br>FC21 D3A3<br>FC23 D3A7                | cma<br>out<br>out                                                                                              | 0A3h<br>0A7h                                                                                                         | ;Port OBh is an output port<br>;Port 1Bh is an output port                                                                                                                             |  |  |  |  |
| FC25 3E2C<br>FC27 D3A0<br>FC29 D3A4<br>EC28 D3A6 | mvi<br>out<br>out                                                                                              | a,2Ch<br>0A0h<br>0A4h<br>0a6b                                                                                        | ;set up input port handshakes                                                                                                                                                          |  |  |  |  |
| FC2D 3E24<br>FC2F D3A2                           | mvi<br>out                                                                                                     | a,24h<br>0A2h                                                                                                        | ;set up port OBh handshakes                                                                                                                                                            |  |  |  |  |
| FC31 DBA1                                        | in                                                                                                             | CSTAT                                                                                                                | ;clear Controller Ready bit                                                                                                                                                            |  |  |  |  |
|                                                  | ; Reset and ini<br>; On Entry & Ex<br>; hl = 0                                                                 | tialize the Term <sup>.</sup><br>it:                                                                                 | inal port ACIA                                                                                                                                                                         |  |  |  |  |
| FC33 3E03<br>FC35 D310<br>FC37 3E11<br>FC39 D310 | ,<br>mvi<br>out<br>mvi<br>out                                                                                  | A,ACRSET<br>ACCTRL<br>A,ACINIT<br>ACCTRL                                                                             |                                                                                                                                                                                        |  |  |  |  |
|                                                  | ;<br>Print HDBL ve<br>; On Entry & Ex<br>; hl = 0                                                              | rsion message<br>it:                                                                                                 |                                                                                                                                                                                        |  |  |  |  |
| FC3B CDE5BF<br>FC3E 0D0A484442                   | , call<br>db                                                                                                   | PRINTF-ROF<br>CR,LF,'HDBL 2.0                                                                                        | ;print the following string<br>','O'+80h                                                                                                                                               |  |  |  |  |
|                                                  | ; Read the Pack<br>; to get the Op<br>; Bytes 41:40<br>; Bytes 43:42<br>; On Entry:<br>; hl = 0                | Descriptor Page<br>sys Pointers:<br>= Initial Disk F<br>= Disk Page cour                                             | (Disk Page 0)<br>Page number<br>nt (Byte 43=MSB=0)                                                                                                                                     |  |  |  |  |
| FC49 062B<br>FC4B CD82BF                         | ;<br>mvi<br>call                                                                                               | b,0SOFF+3<br>GETPAG-ROF                                                                                              | ;byte count to end of pointers<br>;Seek, read page hl into buffer<br>;set up to read b buffer bytes                                                                                    |  |  |  |  |
| FC4E E5<br>FC4F EB                               | push<br>xchg                                                                                                   | h                                                                                                                    | ;execution address on stack<br>;load address into de                                                                                                                                   |  |  |  |  |
|                                                  | ; Read from the<br>; we get to the<br>; C & HL. Note:<br>; the controlle<br>; byte every 2.<br>; page count, s | controller buffe<br>opsys pointers.<br>no testing any b<br>r can keep up. (1<br>5 uS.) This only<br>ince the high by | er and discard everything until<br>Load the opsys pointers into<br>nandshake here - just assume<br>The controller can send a data<br>reads the low byte of the<br>te must be 0 anyway. |  |  |  |  |
| FC50 DBA5                                        | PTRLUP: in                                                                                                     | CDATA                                                                                                                | ;read byte from controller                                                                                                                                                             |  |  |  |  |
| FC52 6C<br>FC53 61<br>FC54 4F                    | mo∨<br>mo∨<br>mo∨                                                                                              | l,h<br>h,c<br>c,a                                                                                                    | ;shift everybody over<br>;and put it away                                                                                                                                              |  |  |  |  |

|                                      | HDBL.PRN                                                      |                                                                                                                                                                                          |                                                                            |                                                                               |                                                                                                  |  |  |  |
|--------------------------------------|---------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------|-------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------|--|--|--|
| FC55<br>FC56                         | 05<br>C250BF                                                  |                                                                                                                                                                                          | dcr<br>jnz                                                                 | b<br>PTRLUP-ROF                                                               |                                                                                                  |  |  |  |
|                                      | ; Announce 'LOADING FROM <platter>' on the Terminal</platter> |                                                                                                                                                                                          |                                                                            |                                                                               |                                                                                                  |  |  |  |
| FC59<br>FC5C                         | CDDCBF<br>494E472046                                          | 5                                                                                                                                                                                        | call<br>db                                                                 | LOADPF-ROF<br>'ING FROM',' '+8                                                | ;CR,LF,'LOAD', then string<br>30h                                                                |  |  |  |
| FC65                                 | DBFF                                                          |                                                                                                                                                                                          | in                                                                         | SSWTCH                                                                        | ; read platter switch                                                                            |  |  |  |
| FC67<br>FC69<br>FC6A<br>FC6B         | E608<br>0f<br>0f<br>0f                                        |                                                                                                                                                                                          | ani<br>rrc<br>rrc<br>rrc                                                   | PSWTCH                                                                        | ; (disables proms in furnkey bu)<br>;mask off all others                                         |  |  |  |
| FC6C<br>FC6E                         | C630<br>CDF3BF                                                |                                                                                                                                                                                          | adi<br>call                                                                | '0'<br>PRINTA-ROF                                                             | ;make it ASCII<br>;and print it                                                                  |  |  |  |
|                                      |                                                               | Read c Pages from disk, starting at Page hl, into<br>memory starting at the address on the stack<br>On Entry:<br>b = 0<br>c = page count<br>de = LDADDR<br>hl = initial Disk page number |                                                                            |                                                                               |                                                                                                  |  |  |  |
| FC71                                 | CD82BF                                                        | PAGELP:                                                                                                                                                                                  | call                                                                       | GETPAG-ROF                                                                    | ;Seek, read page hl into buffer<br>;set up to read b buffer bytes<br>;b=0 here always.           |  |  |  |
|                                      |                                                               | ; Load 2<br>; Note:<br>; contro<br>; every                                                                                                                                               | 256 bytes<br>no test<br>oller car<br>2.5 uS.)                              | s of buffer data<br>ing any handshake<br>n keep up. (The c<br>)               | into memory at de (b=0 here)<br>e here - just assume the<br>controller can send a data byte      |  |  |  |
| FC74<br>FC76<br>FC77<br>FC78<br>FC79 | DBA5<br>12<br>13<br>05<br>C274BF                              | BYTELP:                                                                                                                                                                                  | in<br>stax<br>inx<br>dcr<br>inz                                            | CDATA<br>d<br>d<br>b<br>BYTELP-ROF                                            | ;get a data byte<br>;write it to RAM<br>;next address<br>;bump byte counter<br>:until done (b=0) |  |  |  |
|                                      |                                                               | ; Next [                                                                                                                                                                                 | J<br>Disk Page                                                             | 2                                                                             |                                                                                                  |  |  |  |
| FC7C<br>FC7D<br>FC7E                 | 23<br>OD<br>C271BF                                            |                                                                                                                                                                                          | inx<br>dcr<br>jnz                                                          | h<br>C<br>PAGELP-ROF                                                          | ;Next Disk Page<br>;bump Disk Page count                                                         |  |  |  |
|                                      |                                                               | ;                                                                                                                                                                                        | ecute loa                                                                  | aded code, at the                                                             | e address on the stack                                                                           |  |  |  |
| FC81                                 | С9                                                            | ;                                                                                                                                                                                        | ret                                                                        |                                                                               |                                                                                                  |  |  |  |
|                                      |                                                               | ;===Subi<br>; Seek a<br>; On Ent<br>; D=nu<br>; On Ex<br>; a,f<br>; Cont                                                                                                                 | routine==<br>and read<br>try:<br>umber of<br>it:<br>lags tras<br>troller h | disk Page hl int<br>bytes to transfe<br>shed, all others<br>nas specified sec | to 88-HDSK buffer 0<br>er (0 means 256)<br>preserved<br>ctor data in its buffer                  |  |  |  |
| FC82<br>FC83<br>FC84                 | E5<br>D5<br>C5                                                | GETPAG:                                                                                                                                                                                  | push<br>push<br>push                                                       | h<br>d<br>b<br>Page 6                                                         | ;Save requested Page<br>;Save regs<br>;save byte count                                           |  |  |  |

HDBL.PRN

|                                   | Compu<br>h<br>This<br>usual<br>so th<br>divis<br>if th<br>alway<br>requi | ute cyli<br>= hl /<br>= hl MC<br>is fast<br>lly put<br>nis will<br>sion of<br>ne boot<br>/s miss<br>ire a fu | nder and sectorX2<br>(2*HDSPT) (Quotic<br>D (2*HDSPT) (Rema<br>only if the cyli<br>the boot image st<br>be faster and sh<br>previous HDBL rev<br>image is above cy<br>the next sector a<br>ll disk rev (25 m | 2 from Disk Page number in hl<br>ent=cylinder)<br>ainder=sectorx2)<br>inder number is low. MITS<br>tarting at cylinder 0, side 1,<br>norter than the 'fast'<br>7. This will become slower<br>7 linder 20 or so. But we will<br>anyway, so each sector will<br>mS), plenty of time |
|-----------------------------------|--------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| FC85 01D0FI<br>FC88 50<br>FC89 58 | ;                                                                        | lxi<br>mov<br>mov                                                                                            | b,-2*HDSPT<br>d,b<br>e,b                                                                                                                                                                                     | ;de=FFFF=-1<br>;since loop goes 1 extra                                                                                                                                                                                                                                           |
| FC8A 13<br>FC8B 09<br>FC8C DA8ABI | DIV1:                                                                    | inx<br>dad<br>jc                                                                                             | d<br>b<br>DIV1-ROF                                                                                                                                                                                           | ;compute quotient=cylinder<br>;hl gets remainder                                                                                                                                                                                                                                  |
| FC8F 7D<br>FC90 91                |                                                                          | mo∨<br>sub                                                                                                   | a,l<br>c                                                                                                                                                                                                     | ;fix remainder, since<br>;loop went 1 extra                                                                                                                                                                                                                                       |
| FC91 EB                           |                                                                          | xchg                                                                                                         |                                                                                                                                                                                                              | ;cylinder number to hl                                                                                                                                                                                                                                                            |
|                                   | ;;<br>; Compu<br>; If se<br>; bit,<br>; hl=<br>; a =                     | ute Sect<br>ectorX2<br>and red<br>= Quotie<br>= Remain                                                       | or & Side<br>> sectors/track 1<br>luce sector number<br>nt (cylinder)<br>der (sectorX2, et                                                                                                                   | then set CSIDE<br>r by sectors/track<br>ither for head 0 or 1)                                                                                                                                                                                                                    |
| FC92 FE18<br>FC94 DA99BI          | ,                                                                        | cpi<br>jc                                                                                                    | HDSPT<br>SIDEOK-ROF                                                                                                                                                                                          | ;past end of side 0?<br>;N: sector number is good                                                                                                                                                                                                                                 |
| FC97 C608                         |                                                                          | adi                                                                                                          | CSIDE-HDSPT                                                                                                                                                                                                  | ;Compute sector mod HDSPT,<br>;and set side 1 bit                                                                                                                                                                                                                                 |
| FC99 47                           | SIDEOK:                                                                  | mov                                                                                                          | b,a                                                                                                                                                                                                          | ;save sector # with side                                                                                                                                                                                                                                                          |
|                                   | ; Seek<br>; b<br>; h]<br>;<br>if CSE                                     | Cylinde<br>= secto<br>l = cyli<br>EEK+DBUF<br>mov<br>ori<br>mov                                              | r<br>nder number, with st<br>nder number<9:0><br>R<br>a,h<br>CSEEK+DBUFR<br>h,a                                                                                                                              | ide bit set correctly<br>;these are actually 00<br>;h<1:0>=cylinder<9:8><br>;combine with SEEK cmd                                                                                                                                                                                |
| FC9A CDB9BI                       | end i r                                                                  | call                                                                                                         | HDCMD-ROF                                                                                                                                                                                                    | ;hl=SEEK command with cyl #<br>;HCMD gets unit # from switches                                                                                                                                                                                                                    |
|                                   | Get p<br>side<br>b<7<br>b<7<br>b<2<br>ser                                | olatter<br>and sec<br>7:6> = 0<br>0<5> = s<br>1:0> = s<br>1:0> = s<br>1:e Swit                               | from sense switch<br>tor already in b<br>ide<br>ector number<br>ch <a11> = platte</a11>                                                                                                                      | n, and combine with                                                                                                                                                                                                                                                               |

Page 7

HDBL.PRN FC9D 2630 ;read command, high byte mvi h,CRDSEC+DBUFR FC9F DBFF ;read platter switches in SSWTCH FCA1 E608 PSWTCH ;mask off all others ani FCA3 07 rlc ;Shift to CFPLTR position FCA4 07 rlc ;..which are bits 7:6 FCA5 07 rlc FCA6 B0 ora b ;combine w/ sect & side \_\_\_\_\_ Read Sector from current track into controller's buffer 0 a < 7:6 > = plattera < 5 > = sidea < 4:0 > = sector number . \_ \_ \_ \_ \_ \_ \_\_\_\_\_ FCA7 CDBABF call HDCMDA-ROF ; low command byte is in a \_\_\_\_\_ Issue CRDBUF command to kick off read of 256 bytes from the controller's buffer Note: this assumes the controller is ready. (and it is, because HDCMD left it that way.) FCAA DBA5 in CDATA ;reset CDA in CDSTA FCAC DBA3 in ACMD ;clear CMDACK in ACSTA FCAE C1 FCAF 78 ;b=requested byte count b pop mov a,b FCB0 D3A7 out ADATA :..to controller FCB2 3E50 a, CRDBUF+DBUFR ; issue Read Buffer command mvi :..to controller FCB4 D3A3 out ACMD FCB6 D1 d pop ;(10)(10) 10 us total from 'out' FCB7 E1 pop h The 8x300 is ready to transmit data in 8 uS. This code takes 30 cycles (including the 'ret'), or 15 uS min to get around to reading the data - so there is no need to wait on CDSTA if FALSE ;Wait for data port to be ready DATAWT: in CDSTA rlc :msb=CDA DATAWT-ROF jnc endif Controller is ready to transfer 256 bytes of data from its buffer ------FCB8 C9 ;(10)done with GETPAG ret \_\_\_\_\_ Issue a disk command, and then wait for the controller to complete it Note: this just assumes the controller is ready, which is OK since the last command was either a seek (where HDCMD waited for the controller to become ready) or it was a CRDBUF, which ended with all bytes transferred - and the controller becomes ready very soon (1.5 uS) after the last byte is transferred. Page 8

|                                                    |                              | · On Ent                                                      | try at U                                                                                                                                                                            | HDBL.PRN                        |                                                                       |  |  |  |
|----------------------------------------------------|------------------------------|---------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------|-----------------------------------------------------------------------|--|--|--|
|                                                    |                              | ; hl = complete command<br>; On Entry at HDCMDA:              |                                                                                                                                                                                     |                                 |                                                                       |  |  |  |
|                                                    |                              | ; a=low byte of command<br>; h=high byte of command           |                                                                                                                                                                                     |                                 |                                                                       |  |  |  |
|                                                    |                              | ; On Ex-<br>; a,f<br>; The<br>; Any<br>; mess                 | <pre>xit: flags trashed, all others preserved. e command is completed and the controller is ready. y errors will terminate the load, and print an error ssage on the Terminal</pre> |                                 |                                                                       |  |  |  |
| FCB9                                               | 7D                           | ;=======<br>HDCMD:                                            | mov                                                                                                                                                                                 | a,1                             | ;low byte of command                                                  |  |  |  |
| FCBA                                               | D3A7                         | HDCMDA:                                                       | out                                                                                                                                                                                 | ADATA                           | ;to data port                                                         |  |  |  |
| FCBC<br>FCBE                                       | DBA1<br>DBA3                 |                                                               | in<br>in                                                                                                                                                                            | CSTAT<br>ACMD                   | ;reset CRDY flag just in case<br>;clear CMDACK in ACSTA               |  |  |  |
| FCC0<br>FCC1                                       | 7C<br>D3A3                   |                                                               | mov<br>out                                                                                                                                                                          | a,h<br>ACMD                     | ;command high byte<br>;issue command                                  |  |  |  |
| FCC3<br>FCC5<br>FCC6                               | DBAO<br>07<br>D2C3BF         | HDWAIT:                                                       | in<br>rlc<br>jnc                                                                                                                                                                    | CREADY<br>HDWAIT-ROF            | ;Is the controller done?<br>;look at msb=CRDY<br>;N: keep waiting     |  |  |  |
| FCC9<br>FCCB<br>FCCD                               | DBA1<br>E67F<br>C8           |                                                               | in<br>ani<br>rz                                                                                                                                                                     | CSTAT<br>ERMASK                 | ;reset CRDY flag<br>;and get A=error code<br>;No errors: happy return |  |  |  |
|                                                    |                              | ;                                                             | Fall int                                                                                                                                                                            | to error exit                   |                                                                       |  |  |  |
|                                                    |                              | ;===Error Exit====================================            |                                                                                                                                                                                     |                                 |                                                                       |  |  |  |
| FCCE<br>FCD1<br>FCD4                               | 320000<br>CDDCBF<br>204552D2 | ,                                                             | sta<br>call<br>db                                                                                                                                                                   | 0<br>LOADPF-ROF<br>'ER','R'+80h | ;save a=error flags<br>;CR,LF,'LOAD', then string                     |  |  |  |
| FCD8<br>FCD9                                       | fb<br>C3D9BF                 | FOREVR:                                                       | ei<br>jmp                                                                                                                                                                           | FOREVR-ROF                      | ;INTE is error indicator light<br>;N: die here, INTE light lit        |  |  |  |
|                                                    |                              | <pre>;===Subroutine====================================</pre> |                                                                                                                                                                                     |                                 |                                                                       |  |  |  |
| FCDC<br>FCDF                                       | CDE5BF<br>0D0A4C4F4          | ;======<br>LOADPF:                                            | call<br>db                                                                                                                                                                          | PRINTF-ROF<br>CR.LF.'LOA'.'D'+  |                                                                       |  |  |  |
|                                                    |                              | ;fall in                                                      | ito PRIN                                                                                                                                                                            | ,-, <u>-</u> , J                |                                                                       |  |  |  |
| ;===Subroutine==================================== |                              |                                                               |                                                                                                                                                                                     |                                 | rminal                                                                |  |  |  |

|                      |                        | ; The<br>; The<br>; The<br>; 1as<br>; On Ex<br>; Tra | e string<br>e string<br>e actual<br>st string<br>it:<br>ashes a | HDBL.PRN<br>address is the '<br>is terminated by<br>return address f<br>g character.<br>and flags, all ot | 'return address" on the stack.<br>y bit 7 set in its last chr.<br>is the next address after the<br>ther registers preserved. |
|----------------------|------------------------|------------------------------------------------------|-----------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------|
| FCE5                 | Е3                     | PRINTF:                                              | xth1                                                            |                                                                                                           | ;get string address, save hl                                                                                                 |
| FCE6<br>FCE7<br>FCE9 | 7e<br>e67f<br>cdf3bf   | PRNTLP:                                              | mov<br>ani<br>call                                              | a,m<br>7Fh<br>PRINTA-ROF                                                                                  | ;get string character<br>;strip end-of-string mark<br>;and print it                                                          |
| FCEC<br>FCED<br>FCEE | BE<br>23<br>CAE6BF     |                                                      | cmp<br>inx<br>jz                                                | m<br>h<br>PRNTLP-ROF                                                                                      | ;end of string?<br>;point to next chr<br>;No difference: keep going                                                          |
| FCF1<br>FCF2         | E3<br>C9               |                                                      | xthl<br>ret                                                     |                                                                                                           | ;restore hl, put return address<br>;onto stack, and go there                                                                 |
|                      |                        | ;===Sub<br>Print<br>On En<br>a=cl<br>On Ex<br>al     | routine=<br>a the To<br>try:<br>hr to pr<br>it:<br>l registo    | erminal<br>int<br>ers preserved.                                                                          | =                                                                                                                            |
| FCF3                 | F5                     | ,======<br>PRINTA:                                   | push                                                            | psw                                                                                                       | ;save chr to print                                                                                                           |
| FCF4<br>FCF6<br>FCF8 | DB10<br>E602<br>CAF4BF | PALOOP:                                              | in<br>ani<br>jz                                                 | ACSTAT<br>ACTDE<br>PALOOP-ROF                                                                             | ;Wait for TX to be ready                                                                                                     |
| FCFB<br>FCFC<br>FCFE | F1<br>D311<br>C9       |                                                      | pop<br>out<br>ret                                               | psw<br>ACTXD                                                                                              | ;and send chr                                                                                                                |
| FCFF                 |                        |                                                      | end                                                             |                                                                                                           |                                                                                                                              |