# University of St Andrews



Full metadata for this thesis is available in St Andrews Research Repository at: <u>http://research-repository.st-andrews.ac.uk/</u>

This thesis is protected by original copyright

## APPLICATIONS OF MICROPROCESSOR TO INTERFACING TECHNOLOGY (SCSI)

## **Elizabeth Ann McKinnon**



1011

<sup>a</sup>s a té

The Als

## Declaration for the Degree of M.Sc.

I, Elizabeth Ann McKinnon hereby certify that this thesis has been composed by myself, that it is a record of my own work, and that it has not been accepted in partial or complete fulfilment of any other degree or professional qualification.

Signed:

Date: 4.10.88

## ABSTRACT

A study of the S-100 interface and the Small Computer System Interface (SCSI) was carried out. An interface board was built to communicate between the S-100 interface and a hard disk drive supporting SCSI. Two methods of communication were investigated. The first interface board used only standard TTL logic and the second interface board used TTL logic and a VLSI SCSI controller (NCR53C80).

## ACKNOWLEDGEMENTS

I would like to acknowledge the support and guidance given to me by Dr Reg C G Killean throughout this project.

I would like to thank Professor Wilson Sibbett and the University of St Andrews for giving me the opportunity to undertake a Master of Science degree.

I would also like to thank the everyone in the department who gave me access to the computers and printers necessary to compile and print this thesis.

## CONTENTS

- 1 CHAPTER 1:S-100 BUS ARCHITECTURE
- 2 Power Supply
- 3 Address Bus
- 3 Data Bus
- 3 Clock And Control Signals

## 6 CHAPTER 2:CROMEMCO SINGLE CARD COMPUTER

- 7 Power Supply
- 8 Clocks
- 8 Z80A CPU
- 11 System Reset
- 12 SCC Memory
- 13 SCC Input/Output Ports
- 19 SCC Interrupts
- 19 SCC Timers
- 20 UART Configuration

#### 25 CHAPTER 3: THE SMALL COMPUTER SYSTEM INTERFACE (SCSI)

- 27 Hardware
- 29 SCSI Bus Phases
- 36 SCSI Bus Conditions
- 37 SCSI Commands

## 42 CHAPTER 4:ADVANTAGES OF SMALL COMPUTER SYSTEM INTERFACE42 Advantages For Hard Disks

## 44 CHAPTER 5:TTL LOGIC INTERFACE BOARD

- 44 Input/Output Buffers
- 46 Input/Output Buffer Enabling
- 47 General Components
- 47 Selecting The Input/Output Buffers
- 50 Control Signals
- 51 Bus Phases
- 55 Software

#### 59 CHAPTER 6:INTELLIGENT INTERFACE BOARD

- 59 Input/Output
- 62 Input/Output Selection
- 63 General Components
- 64 Selecting The Input/Output
- 65 Control Signals
- 66 NCR53C80 Internal Registers
- 70 Bus Phases
- 76 Software

## 79 CHAPTER 7: USES OF THE SCSI SYSTEM

79 Example Functions

## A1 APPENDIX A:TTL LOGIC INTERFACE BOARD SOFTWARE A2 MAIN.Z80

A12 EQU.Z80

A13 MSG.Z80

A14 VDU.Z80

A17 SCSI.Z80

## B1 APPENDIX B:INTELLIGENT INTERFACE BOARD SOFTWARE B2 NCR.Z80

## C1 APPENDIX C:BUS PHASE SEQUENCES

## D1 APPENDIX D:COMPARISON OF PERFORMANCE OF TTL BOARD AND NCR 53C80 BOARD

## CHAPTER 1

## S-100 BUS ARCHITECTURE

The industry standard S-100 bus was originally designed at Stanford University for use with the Intel 8080 microprocessor. As a result, the bus signal definitions closely follow those of the 8080 system. The S-100 bus physically consists of 100 parallel lines (50 on each side of the connector), either etched onto a printed circuit board or, in its origination, hard wired. The printed circuit board with the S-100 edge connectors on it is referred to as a "motherboard". Table 1.1 shows the S-100 bus signals.

## Table 1.1 : S-100 Bus Signals

| 1<br>2<br>3<br>4<br>5<br>6<br>7<br>8<br>9<br>10<br>11<br>12<br>13<br>14<br>15<br>16<br>17<br>18 | +8V<br>+18V<br>XRDY<br>VI0<br>VI1<br>VI2<br>VI3<br>VI4<br>VI5<br>VI6<br>VI7<br>NMI<br>DMA3<br>A18<br>A16<br>A17<br>SDSB | 26<br>27<br>28<br>29<br>30<br>31<br>32<br>33<br>34<br>35<br>36<br>37<br>38<br>39<br>40<br>41<br>42<br>43 | pHLDA<br>A5<br>A4<br>A3<br>A15<br>A12<br>A9<br>DO1/DATA1<br>DO0/DATA0<br>A10<br>DO4/DATA4<br>DO5/DATA5<br>DO6/DATA6<br>DI2/DATA10<br>DI3/DATA11<br>DI7/DATA15<br>A11 | 51<br>52<br>53<br>54<br>55<br>56<br>57<br>58<br>59<br>60<br>61<br>62<br>63<br>64<br>65<br>66<br>67<br>68 | +8V<br>-18V<br>DMA0<br>DMA1<br>DMA2<br>sXTRQ<br>A19<br>SIXTN<br>A20<br>A21<br>A22<br>A23<br>MREQ<br>RFSH | 76<br>77<br>78<br>79<br>80<br>81<br>82<br>83<br>84<br>85<br>86<br>87<br>88<br>89<br>90<br>91<br>92<br>93 | pSYNC<br>pWR<br>pDBIN<br>A0<br>A1<br>A2<br>A6<br>A7<br>A8<br>A13<br>A14<br>A11<br>DO2/DATA2<br>DO3/DATA3<br>DO7/DATA7<br>DI4/DATA12<br>DI5/DATA13<br>DI6/DATA14<br>D11/DATA0 |
|-------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 16<br>17                                                                                        | A16                                                                                                                     | 41<br>42                                                                                                 | DI2/DATA10                                                                                                                                                           | 66<br>67                                                                                                 | RFSH                                                                                                     | 91<br>92                                                                                                 | DI4/DATA12<br>DI5/DATA13                                                                                                                                                     |
| 18<br>19<br>20<br>21<br>22<br>23<br>24                                                          | CDSB<br>ADSB<br>DODSB                                                                                                   | 43<br>44<br>45<br>46<br>47<br>48<br>49                                                                   | DI7/DATA15<br>sM1<br>sOUT<br>sINP<br>sMEMR<br>sHLTA<br>CLOCK                                                                                                         | 68<br>69<br>70<br>71<br>72<br>73<br>74                                                                   | MWRT<br><br>pRDY<br>pINT<br>pHOLD                                                                        | 93<br>94<br>95<br>96<br>97<br>98<br>99                                                                   | DI6/DATA14<br>DI1/DATA9<br>DI0/DATA8<br>sINTA<br>sWO<br>ERROR<br>POC                                                                                                         |
| 25                                                                                              | ф<br>                                                                                                                   | 50                                                                                                       | GND                                                                                                                                                                  | 75                                                                                                       | PRESET                                                                                                   | 100                                                                                                      | GND                                                                                                                                                                          |

The signals in Table 1.1 which have a bar across them, (ie. SIGNAL), are negative logic and are asserted/active when they are 0V or deasserted/inactive when they are +5V. Signals with no bar, (ie. SIGNAL), are positive logic and are asserted/active when they are +5V or deasserted/inactive when they are 0V.

The S-100 bus allows interaction between a device operating as a bus master and a device operating as a bus slave. Briefly, the bus master, (whether temporary or permanent), initiates all bus cycles, the result of which may be to transfer data to and from the addressed bus slave. The bus slave monitors all bus cycles and, if addressed, will input or output data as required.

Signals not implemented on the S-100 bus using the Cromemco Single Card Computer (SCC) are:

| SIXTN and sXTRQ | These signals control 16 bit data transfer. |  |
|-----------------|---------------------------------------------|--|
| Sixin and Sxing | These signals control to on data transfer.  |  |

- DMA0-DMA3 These signal are Direct Memory Access control signals which arbitrate between simultaneous requests, by temporary bus masters, for control of the bus.
  - VI0-VI7 These are the eight Vectored Interrupt lines, which control the eight levels of interrupt request priority.
  - ERROR This signal is used to indicate an error during the current bus cycle. On the Cromemco SCC S-100 bus this is used to indicate speed of operation. See Table 2.1 and chapter 2.2.

A brief description of the SCC implemented S-100 bus signals follows, they are also discussed fully in subsequent chapters. The signals present on the S-100 bus can be grouped into categories:

Power supply lines Address bus Data bus Clock and control signals

## **1.1 POWER SUPPLY**

Unregulated DC power supply voltages (+8 Volts, +18 Volts, -18 Volts and Ground) are supplied from a central power supply and must be regulated on each individual board.

This method of supply has certain advantages over a single, centrally regulated supply. Firstly, every card is individually protected from voltage overload, secondly, any heat produced by voltage regulation is thermally distributed through a larger area and finally, the expansion of a computer system by the addition of cards is made easier, as voltage drop through loading of the power supply is no longer critical.

One disadvantage is that there is a danger of short circuiting the supply lines, (pins 1, 2, 51 and 52), together if a card is inadvertently moved while the voltage is on.

## **1.2 ADDRESS BUS**

The S-100 bus address lines are used to select specific memory locations or specific input/output devices. There are two types of addressing, standard addressing using A0-A15 and extended addressing using A0-A23. The Cromemco Single Card Computer uses standard addressing.

|            | Memory Locations         | Input/Output Devices |
|------------|--------------------------|----------------------|
| Standard   | Up to 65,536 bytes       | Up to 256 Devices    |
| Addressing | (64 Kbytes) Using A0-A15 | Using A0-A7          |
| Extended   | Up to 16,777,216 bytes   | Up to 65,536 Devices |
| Addressing | (16 MBytes) Using A0-A23 | Using A0-A15         |

## **1.3 DATA BUS**

There are 16 lines used for data transfer on the S-100 bus. These can be two unidirectional, 8 bit, data buses (DO0-DO7 and DI0-DI7) or one bidirectional, 16 bit, data bus (DATA0-DATA15). The Cromemco Single Card Computer board uses the two, 8 bit bus type.

## **1.4 CLOCK AND CONTROL SIGNALS**

## **CLOCK SIGNALS**

There are two clock signals present on the S-100 bus system:

- $\phi$ , (4MHz) This is the system clock, which is generated by the permanent master, and controls the timing for all the bus cycles.
- CLOCK, (2MHz) The CLOCK line is not synchronous with any other bus signal and can be used by counters, timers etc.

## CONTROL SIGNALS

The status signals identify the current bus cycle:

| <b>s</b> MEMR | Memory read           |
|---------------|-----------------------|
| sM1           | Op-code fetch         |
| sINP          | Input                 |
| SOUT          | Output                |
| sWO           | Write cycle           |
| sINTA         | Interrupt acknowledge |
| sHLTA         | Halt acknowledge      |

The control output signals determine the movement and timing of data during bus cycles:

| pSYNC | Start of new bus cycle                       |
|-------|----------------------------------------------|
| pDBIN | Gate data onto data bus                      |
| pWR   | Write from data bus                          |
| pHLDA | Data and address bus in high impedance state |

The following signals are used primarily with the Z80A microprocessor:

| pINT and NMI | Interrupt lines used to request servicing from the permanent bus master.                                                                           |
|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------|
| pHOLD        | This signal is used to request control of the bus from a permanent bus master.                                                                     |
| MREQ         | This is a control signal which indicates that the address bus holds<br>a valid address for a memory read/write operation.                          |
| RFSH         | This is a control signal which indicates that the lower seven bits<br>of the address bus can be used as a refresh address for dynamic<br>memories. |

The following signals are primarily used on systems which also have front panel control (allowing the operator to interrupt, single step, perform read/write operations etc. on the bus master):

XRDY and pRDY These signals allow bus slaves to synchronise with bus masters and request operations of the permanent master.

MWRT This is a control signal used to indicate a memory write operation.

There are four lines which are used to tri-state the bus drivers, for example, during DMA operations:

| SDSB  | Status disable   |
|-------|------------------|
| CDSB  | Control disable  |
| ADSB  | Address disable  |
| DODSB | Data out disable |

System reset signals:

pRESET This is the reset signal for all bus masters.

POC Power-On-Clear, this is only asserted when the power is switched on and it also asserts pRESET.

## **CROMEMCO SINGLE CARD COMPUTER**

The Cromemco Single Card Computer (SCC) is a Zilog Z80A based S-100 interface board and can be used as a self contained development system. It allows parallel and serial input/output and provides on board sockets for eight kilobytes of user programmable EPROM memory. Figure 2.1 shows the Single Card Computer block diagram. Table 2.1, which is a subset of Table 1.1, shows S-100 bus connections of the Single Card Computer.

| 1                | +8V   | 26 | pHLDA         | 51 | +8V    | 76  | pSYNC |
|------------------|-------|----|---------------|----|--------|-----|-------|
| 2                | +18V  | 27 |               | 52 | -18V   | 77  | pWR   |
| 3                | XRDY  | 28 |               | 53 |        | 78  | pDBIN |
| 2<br>3<br>4<br>5 |       | 29 | A5            | 54 |        | 79  | A0    |
| 5                |       | 30 | A4            | 55 |        | 80  | A1    |
| 6                |       | 31 | A3            | 56 |        | 81  | A2    |
| 7                |       | 32 | A15           | 57 |        | 82  | A6    |
| 8                |       | 33 | A12           | 58 |        | 83  | A7    |
| 9                |       | 34 | A9            | 59 |        | 84  | A8    |
| 10               |       | 35 | DO1           | 60 |        | 85  | A13   |
| 11               |       | 36 | DO0           | 61 |        | 86  | A14   |
| 12               | NMI   | 37 | A10           | 62 |        | 87  | A11   |
| 13               | '     | 38 | DO4           | 63 |        | 88  | DO2   |
| 14               |       | 39 | DO5           | 64 |        | 89  | DO3   |
| 15               |       | 40 | DO6           | 65 | MREQ   | 90  | DO7   |
| 16               |       | 41 | DI2           | 66 | RFSH   | 91  | DI4   |
| 17               |       | 42 | DI3           | 67 |        | 92  | DI5   |
| 18               | SDSB  | 43 | DI7           | 68 | MWRT   | 93  | DI6   |
| 19               | CDSB  | 44 | sM1           | 69 |        | 94  | DI1   |
| 20               |       | 45 | sOUT          | 70 |        | 95  | DI0   |
| 21               |       | 46 | sINP          | 71 |        | 96  | sINTA |
| 22               | ADSB  | 47 | <b>s</b> MEMR | 72 | pRDY   | 97  | sWO   |
| 23               | DODSB | 48 | sHLTA         | 73 | PINT   | 98  | 4MHz  |
| 24               | φ     | 49 | CLOCK         | 74 | PHOLD  | 99  | POC   |
| 25               |       | 50 | GND           | 75 | PRESET | 100 | GND   |

## Table 2.1 : SCC S-100 Bus Signals

As mentioned in Chapter 1, the S-100 bus signals were designed for use with the Intel 8080 microprocessor. There is a substantial difference between the 8080 and Z80A control lines, but the SCC board is designed to interpret the important S-100 "8080-like" bus functions.



## Figure 2.1 : Single Card Computer Block Diagram

The SCC can be grouped into eight parts:

Power supply Clocks Z80A Central Processing Unit System reset Memory Input/output ports Interrupts Timers

## 2.1 POWER SUPPLY

The SCC board requires three unregulated voltages:

+8VDC @ 1.75A +18VDC @ 100mA -18VDC @ 50mA

These voltages are regulated on the SCC board to +5VDC, +12VDC and -5VDC respectively. The +5VDC provides power to the TTL logic and the 5501 UART. The +12VDC and -5VDC voltages provide power to the UART.

## 2.2 CLOCKS

There is an 8MHz crystal on the SCC board which is used to control the internal SCC timing functions. This frequency is then halved to provide the 4MHz to the Z80A CPU clock input, and to the S-100  $\phi$  bus line. Other SCC devices use the complement of the 4MHz signal as a reference. The 4MHz frequency is halved again to supply a 2MHz signal to the S-100 CLOCK bus line, and to both of the 5501 UART clock inputs ( $\phi_1$  and  $\phi_2$ ).

The S-100 bus 4MHz line (pin 98) is a Cromemco Z80A system function. This signal is used to show whether the system is running at 4MHz (logic 1) or 2MHz (logic 0). This line is pulled high on the SCC board.

## 2.3 Z80A CPU

The Z80A Central Processing Unit allows direct addressing of up to 64 Kilobytes of memory, 256 input ports and 256 output ports. The Z80A instruction set contains 158 instructions, including the 78 instructions of the 8080A.

## **Z80A REGISTERS**

The Z80A contains eighteen 8 bit registers, four 16 bit registers and two interrupt status flip-flops. These can be divided into groups as shown in the following tables.

#### Main 8 Bit Register Set

Alternate 8 Bit Register Set

| D (General)E (General)D (General)E (General)H (General)L (General)H' (General)L' (General) | A (Accumulator)<br>B (General)<br>D (General)<br>H (General) | F (Flag)<br>C (General)<br>E (General)<br>L (General) | A' (Accumulator)<br>B' (General)<br>D' (General)<br>H' (General) | F' (Flag)<br>C' (General)<br>E' (General)<br>L' (General) |  |
|--------------------------------------------------------------------------------------------|--------------------------------------------------------------|-------------------------------------------------------|------------------------------------------------------------------|-----------------------------------------------------------|--|
|--------------------------------------------------------------------------------------------|--------------------------------------------------------------|-------------------------------------------------------|------------------------------------------------------------------|-----------------------------------------------------------|--|

- A, A' The accumulator holds the results of logical and arithmetic operations.
  - F,F' The flag register indicates the conditions of the last operation (eg. if the result was zero).
- B,B',C,C',D,D', These remaining general purpose registers can either be used as E,E',H,H',L,L' twelve 8 bit registers, or as six 16 bit register pairs (BC, DE etc.).

### Special Purpose 16 Bit Registers

| IX (Index Register) | IY (Index Register)  |
|---------------------|----------------------|
| SP (Stack Pointer)  | PC (Program Counter) |

- IX, IY The index registers are used to hold the base address when using indexed addressing mode.
  - SP The stack pointer register holds the address of the current top of the stack. The stack is a temporary data storage area.
  - PC The program counter is the register which holds the address of the instruction which is being fetched from memory. After the contents of the counter are transferred to the address bus, the program counter is automatically incremented. If the instruction being executed causes a program jump, the new address is written over the address in the counter register.

## Special Purpose 8 Bit Registers

| I (Interrupt | R (Refresh |  |
|--------------|------------|--|
| Register)    | Register)  |  |

- I The interrupt register is used when the Z80A CPU is operated in a mode which will respond to an interrupt with an indirect call to any memory location. Servicing interrupt requests in this way means that the time taken to access the interrupt routine can be minimised, as the routine can be stored anywhere in memory.
- R The refresh register is used to generate the memory refresh address when dynamic memories are being used in the system.

#### Interrupt Status Flip-Flops

#### Interrupt Mode Flip-Flops

| IFF1 | IFF2 | IMFa | IMFb |
|------|------|------|------|
|------|------|------|------|

IFF1, IFF2 The interrupt status flip-flops and the interrupt mode flip-flops are the registers which help to ascertain the current interrupt mode of the Z80A CPU, (Mode 0, Mode 1 or Mode 2).

## **Z80A ADDRESS BUS AND DATA BUS**

The Z80A has a 16 bit, (tri-state output), address bus and an 8 bit, (tri-state input/output), data bus. The lines of these buses can be in three different states, logic 1, logic 0 or in a high impedance state. When the buses of the Z80A CPU are in the high impedance state they appear to be disconnected from the other devices which utilise the bus. This allows the other logic circuitry to use the bus without any confusion of the signals.

The S-100 address bus, A0-A15, is driven from the Z80A address bus, A0-A15. The two buses are connected together, via two tri-state drivers. The S-100 address bus drivers can be put into a high impedance state during direct memory access operations by asserting the S-100 bus signal ADSB. The Z80A address bus controls the SCC memory and input/output ports, as described in Chapters 2.6 and 2.7.

The S-100 data out bus, DO0-DO7, is driven from the Z80A data bus, D0-D7, via a tri-state driver. Similarly, the Z80A data bus receives data from the S-100 data in bus, DI0-DI7, via a tri-state buffer. The data output driver can be disabled (ie. tri-stated) during direct memory access operations by asserting the S-100 bus signal DODSB.

## **Z80A CONTROL INPUT SIGNALS**

NMI (non-maskable interrupt) is a buffered version of the S-100 bus NMI signal. Similarly, BUSRQ (bus request) is the buffered version of S-100 bus signal  $\overline{p}HOLD$ . The Z80A WAIT (wait) input is used to indicate to the CPU that the addressed memory or input/output devices are not ready for a data transfer. The CPU stays in the wait state as long as this signal is asserted. INT (interrupt request) is generated by input/output devices. The CPU will service the interrupt at the end of the current instruction if the internal software controlled interrupt enable flip-flop (IFF) is enabled. RESET is used to initialise the CPU, (see Z80A Reset section for more information).

## **Z80A CONTROL OUTPUT SIGNALS**

The Z80A control output lines are logically combined to generate S-100 bus control signals. S-100 signals sM1, pHLDA and sHLTA are the logical inversion of MI (machine cycle one), BUSAK (bus acknowledge) and HALT (halt state) respectively. S-100 MREQ is a buffered version of the Z80A MREQ (memory request) signal. Similarly, S-100 RFSH is the buffered version of Z80A signal RFSH (refresh). S-100 pSYNC which signals the beginning of a new machine cycle is clocked high by a falling edge of either MREQ or IORQ and is clocked back low by the next rising edge of phi. The remaining S-100 control lines are derived from the Z80A outputs as shown:

> sINP = IORQ + RD sOUT = IORQ + WR  $\overline{sWO} = sOUT + (RFSH \cdot RD \cdot MREQ)$  sMEMR = MREQ + RD  $sINTA = (External Priority) \cdot (MI + IORQ)$  pDBIN = RD + sINTA $\overline{pWR} = WR(Delayed)$

 $\overline{pWR}$  is delayed so sOUT has time to stabilise before the pWR low pulse is used as a data strobe. All of these lines can be disabled during DMA by asserting S-100 bus lines  $\overline{SDSB}$  and  $\overline{CDSB}$ .

## **Z80A RESET**

The Z80A CPU is reset when the RESET input is asserted (0V) for at least three clock cycles (600nS). This resets the interrupt enable flip-flop, clears the program counter and registers I and R and sets the interrupt status flip-flops to Mode 0. During the reset time the address bus and the data bus go into a high impedance state and all control output signals go to the inactive state. When the Z80A is reset the program counter is set to 0000H, and program execution is started from memory location 0000H.

## 2.4 SYSTEM RESET

On power up the SCC circuitry automatically asserts the S-100 POC (Power-On-Clear) line, this also asserts the S-100  $\overline{p}$ RESET line. This resets the Z80A, by asserting RESET, and puts the SCC into a known state with the on board memory enabled. The same resetting of the SCC and Z80A occurs when the S-100  $\overline{p}$ RESET signal is asserted by an external source. Any other device can use the S-100  $\overline{p}$ RESET bus line to reset to a known state.

## 2.5 SCC MEMORY

The SCC has space for 8 kilobytes of 2716 EPROM memory (in sockets ROM0, ROM1, ROM2 and ROM3) and 1 kilobyte of 4045 static RAM. The memory address map is shown in the following table.

## SCC Memory Map

| ROM0 (2K)       | 0000H - 07FFH |
|-----------------|---------------|
| ROM1 (2K)       | 8000H - 0FFFH |
| ROM2 (2K)       | 1000H - 17FFH |
| ROM3 (2K)       | 1800H - 1FFFH |
| RAM             | 2000H - 23FFH |
| External Memory | 2400H - FFFFH |

Additional memory can be installed in the SCC controlled system by plugging ROM or RAM boards into the S-100 bus.

ROM0 contains the assembled SCSI INTERFACE program (see Appendices A and B) which is automatically entered when the SCC is powered up or when the S-100  $\overline{pRESET}$  line is pulled low, causing the Z80A to reset the program counter to 0000H and start program execution.

## MEMORY SELECTION

The memory select signals are controlled by a standard 4 line to 10 line (BCD to DECIMAL) decoder chip as shown by the table below.

#### **INPUTS OUTPUTS** B D σ T 4 DEVICE A C 2 3 A11 A12 SELECTED A13 0 0 0 0 0 1 1 1 1 ROM0 0 0 0 1 1 1 0 1 1 ROM1 ROM<sub>2</sub> 0 1 0 0 1 1 0 1 1 1 1 0 0 1 1 1 0 1 ROM3

## **ROM Memory Select Logic**

## **RAM Memory Select Logic**

|          | INP      | UTS      |   |   | 0 | UTPU | ГS |   | ]  |                    |
|----------|----------|----------|---|---|---|------|----|---|----|--------------------|
| A<br>A11 | B<br>A12 | C<br>A13 | D | σ | T | 2    | 3  | 4 | EN | DEVICE<br>SELECTED |
| 0        | 0        | 1        | 0 | 1 | 1 | 1    | 1  | 0 | 0  | RAM                |

In both of the above memory select logic tables, decoder inputs A, B and C are A11, A12 and A13 respectively. Decoder input D is used as an active low enable signal. D is low when the SCC memory disable option is inactive, MI or MREQ is active (logic 0), IORQ is not active (logic 1), A14 and A15 are low.

In the RAM select logic table, EN is the logical OR of A10 and the decoder output 4.

ROM0-ROM3 are selected with the appropriate address on A11-A13 and decoder input D active (logic 0). The SCC RAM is selected with the appropriate address on A10-A13 and decoder input D active (logic 0).

## 2.6 SCC INPUT/OUTPUT PORTS

The SCC has three 8 bit parallel input/output ports, with separate input data lines and output data lines, on connectors J1, J2 and J3 (addressed at 0AH, 0BH and 04H respectively). Port 04H is an integral part of the 5501 UART and ports 0AH and 0BH are driven from the Z80A data bus via latches. The parallel input/output ports are not used in this project and are only mentioned briefly. The serial input/output port found on connector J4, addressed at 00H-02H, is used to connect a VDU terminal to the SCC. The VDU terminal is used to input data into the SCC and display the output from the SCC.

Data is received from and transmitted to the terminal, (via connector J4), from the Z80A (register A). The parallel CPU data is converted to the serial terminal data, and vice versa, by the 5501 Universal Asynchronous Receiver Transmitter (UART). The UART also supplies the serial status data and the serial control data.

The SCC TTL signals (0V or 5V) are converted to the terminal RS232 ( $\pm 12V$ ) signals, and from RS232 to TTL, by the interface on the SCC. See figure 2.2 which shows the serial signal paths of the SCC and the terminal connection.





The input/output select logic, for the ports and the UART, is controlled by a Cromemco custom PROM as shown by the tables below. The inputs to the PROM are, from the address bus, A0-A3 and, from the Z80A CPU, WR. The CS input is low when A4-A7 are low, IORQ is active, and MI is inactive.

There are eight output lines from the PROM, Y1-Y8. Y1 and Y2 are used as an active high strobe for 0BH and 0AH respectively. Y3 is an active low enable for the 5501 UART. Y4-Y7 select a 5501 UART function by driving its A0-A3 address lines as shown in the table below.

| D7 | D6 | D5     | D4 | D3           | D2     | D1 | D0 |
|----|----|--------|----|--------------|--------|----|----|
|    |    | DATA I |    | OM TER<br>Γ> | RMINAL |    |    |

When an IN A,(01H) instruction is executed, an assembled data byte (D0 - D7) is read into the Z80A (register A), from the the UART receiver data port (ie. the terminal). The Z80A knows when there is valid data available by testing the serial status port, bit RDA.

All bits are used in relation to this project.

## **Transmitter Data Port**

| D7 | D6 | D5   | D4 | D3      | D2   | D1 | D0 |
|----|----|------|----|---------|------|----|----|
|    |    | DATA |    | ΤΟ TERM | INAL |    |    |

Data is written from the Z80A (register A) into the transmitter data port (D0 - D7) when the Z80A executes an OUT (01H), A. The Z80A is programmed to recognise when to send the data byte, by testing the serial status port, bit TBE.

All bits are used in relation to this project.

## **Command Register Port**

| D7          | D6          | D5  | D4  | D3  | D2  | D1  | D0  |
|-------------|-------------|-----|-----|-----|-----|-----|-----|
| NOT<br>USED | NOT<br>USED | TB5 | HBD | INE | RS7 | BRK | RES |

The UART is configured when an OUT (02H), A instruction is executed (register A containing the data). Only four of the command register port bits have any effect on the serial port - HBD, INE, BRK and RES.

- HBD (D4) High Baud. Setting this bit to logic 1 multiplies the UART clock frequency by eight, which causes the serial port baud rate to multiply by eight (eg. 1200 baud becomes 9600 baud).
- INE (D3) INTA Enable. When this bit is reset to logic 0 the UART ignores the INTA (interrupt acknowledge) cycles. The UART will recognise the INTA cycles and service the interrupt when this bit is set to logic 1.
- BRK (D1) Break. When this is reset to logic 0 the serial transmitter operates normally however, when set to logic 1 the serial transmitter output is latched in the low (spacing) state.
- RES (D0) UART Reset. When this bit is set to logic 1 the serial status port bit, RDA, is reset to logic 0 and the serial receiver goes into the search for a new character mode (not affecting the contents of the receiver data port). Also, the serial status register port, bit TBE, is set to logic 1 and the serial transmitter output goes high (marking). Once this happens RES will reset to logic 0 and the UART will be ready to perform serial input/output operations.

Only bits D4 (HBD) and D0 (RES) are used in relation to this project.

#### Interrupt Address Port

| D7 | D6 | D5             | D4 | D3             | D2 | D1 | D0 |
|----|----|----------------|----|----------------|----|----|----|
| 1  | 1  | L <sub>2</sub> | L  | L <sub>o</sub> | 1  | 1  | 1  |

When the UART interrupt address port is read by execution of an IN A,(03H) instruction, the Z80A (register A) contains the coding of the source of the interrupt request (eg. if the contents are 07EH then is RDA requesting service).

This port is not implemented in relation to this project.

#### **Interrupt Mask Port**

| D7         | D6         | D5  | D4  | D3         | D2  | D1         | D0         |
|------------|------------|-----|-----|------------|-----|------------|------------|
| TIMER<br>5 | TIMER<br>4 | TBE | RDA | TIMER<br>3 | INT | TIMER<br>2 | TIMER<br>1 |

The UART interrupt mask port is configured an OUT (03H), A instruction is executed by the Z80A (register A containing the data).

When the bit is reset to logic 0, the source cannot issue an interrupt request. When the bit is set to logic 1 the source can issue an interrupt request. TBE (D5) and RDA (D4) cannot be disabled in this way.

This port is not implemented in relation to this project.

## 2.7 SCC INTERRUPTS

The SCC has ten interrupt sources which can be grouped as follows:

| S-100 Interrupts | NMI is connected directly to the Z80A NMI input and is the only interrupt which cannot be software disabled. pINT is channelled into the Z80A INT input and is only enabled after the Z80A executes an EI instruction.                                          |
|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| UART Interrupts  | TIMER1-TIMER5, INT, RDA and TBE are all channelled into the Z80A INT input. For any of these interrupts to be enabled the correct interrupt mask port code must be present in addition to the interrupts being enabled by execution of the Z80A EI instruction. |

The interrupts are not utilised in relation to this project.

## 2.8 SCC TIMERS

The UART contains five timers, TIMER1-TIMER5, which can be enabled and disabled by the UART interrupt mask port. There is a port assigned to each of the timers (05H - 09H) which can be loaded with a delay count (maximum value of 0FFH). This delay count is then decremented either every 64 micro-seconds (if command register port HBD is reset) or every 8 micro-seconds (if HBD is set).

If the interrupts are disabled when the delay count reaches zero the UART serial status port, bit IPG, is set to logic 1. The Z80A can determine the timer which is requesting service and reset IPG to logic 0 by reading the UART interrupt address port. This method does not enter an INTA cycle as only the SCC input ports are being used, not the Z80A INT input. If the interrupts are enabled and UART command register port, bit INE, is set to logic 1 when the delay count reaches zero, the Z80A is interrupted. The Z80A will then execute the timer unique RST instruction in response to the Z80A INTA cycle.

If the interrupts are enabled and UART command register port, bit INE, is reset to logic 0 when the delay count reaches zero, the Z80A is interrupted. The Z80A will initiate an interrupt service routine which will read the interrupt address port to identify the source.

The timers are not utilised in relation to this project.

## **2.9 UART CONFIGURATION**

Before the serial input/output port is used the UART must be configured by writing into register A and issuing an OUT (02H), A instruction. The correct baud rate must also be set by writing into register A and issuing an OUT (00H), A instruction.

The following shows the part of the main program which is used to configure the UART. Refer to the UART ports descriptions for full details on the ports mentioned in the description of the program.

## **BAUD RATE TABLE**

This shows the table of bytes for the different baud rates. When the program is assembled and written into the EPROM, the binary number are stored as hex bytes in consecutive locations with a label (baudrs).

| db | 10010000b                        | ; 2400 / 19,200                                                                               |
|----|----------------------------------|-----------------------------------------------------------------------------------------------|
| db | 1100000b                         | ;9600/76,800                                                                                  |
| db | 10100000b                        | ; 4800 / 38,400                                                                               |
| db | 10010000b                        | ; 2400 / 19,200                                                                               |
| db | 10001000b                        | ; 1200 / 9,600                                                                                |
| db | 10000100b                        | ; 300/2,400                                                                                   |
| db | 10000010b                        | ; 150/1,200                                                                                   |
| db | 0000001b                         | ; 110/880                                                                                     |
|    | db<br>db<br>db<br>db<br>db<br>db | db 11000000b<br>db 10100000b<br>db 10010000b<br>db 10001000b<br>db 10000100b<br>db 100000100b |

The terminal can be operating at any one of a number of baud rates, as shown by the table above. The UART command register port, bit HBD determines which range of baud rates are valid. When HBD is set to 0, the range is 110 baud to 9600 baud. When HBD is set to 1, the range is 880 baud to 76,800 baud. The first value in the table, 2400/19,200, is the normal setting for the terminal, if this is not correct, the other values will be tried.

When the boards are powered up, the user must press the carriage return key (ASCII value - 0DH) several times to allow the baud rate of the terminal and the baud rate of the SCC to be matched. The program does this as shown below.

## **PROGRAM LISTING**

## Main Program

| Line 1  |       | ld   | hl,baudrs |
|---------|-------|------|-----------|
| Line 2  |       | ld   | c,00H     |
| Line 3  |       | ld   | a,11h     |
| Line 4  | baud1 | out  | (02H),a   |
| Line 5  |       | outi |           |
| Line 6  |       | call | gbyte     |
| Line 7  |       | call | gbyte     |
| Line 8  |       | and  | 7fh       |
| Line 9  |       | ср   | Odh       |
| Line 10 |       | ld   | a,1       |
| Line 11 |       | jr   | nz,baud1  |

Gbyte Subroutine

| Line S1 | gbyte | in  | a,(00H) |
|---------|-------|-----|---------|
| Line S2 | •••   | bit | 6,a     |
| Line S3 |       | jr  | z,gbyte |
| Line S4 |       | in  | a,(01H) |
| Line S5 |       | ret |         |

## **PROGRAM DESCRIPTION**

Line 1 to Line 3 sets up the contents of the HL, C and A registers.

Register pair HL is pointing to the first baud rate in the table.

Register C contains the address of the UART baud rate port.

Register A contains reset bit and high baud for sending to the UART command register port.

Line 4 outputs the contents of register A, (00010001 in binary notation), to the UART command register port (02H). This configures and resets the UART. Note that this line has a label (baud1). If the correct baud rate is not found the first time, the program will jump back to here and reset the UART. The program will continue looping round to Line 4 until the correct baud rate is found. The UART command register will contain the following.

| D7          | D6          | D5  | D4  | D3  | D2  | D1  | D0  |
|-------------|-------------|-----|-----|-----|-----|-----|-----|
| NOT<br>USED | NOT<br>USED | TB5 | HBD | INE | RS7 | BRK | RES |
| 0           | 0           | 0   | 1   | 0   | 0   | 0   | 1   |

Four of these bits have an effect on the serial input/output port: HBD, INE, BRK and RES.

HBD=1, serial port baud rate to multiplies by eight (eg. 2400 baud becomes 19,200 baud).

INE=0, interrupt acknowledge (INTA) cycles ignored by UART.

BRK=0, serial transmitter operates normally.

RES=1, reset UART.

Line 5 outputs the contents of the memory location addressed by HL (first baud rate), to the address contained in register C, (UART baud rate port) and then increments HL. HL is then pointing to the next baud rate in the table. For the first baud rate in the table, the UART baud rate port contains the following.

| D7           | D6              | D5              | D4              | D3             | D2            | D1            | D0          |
|--------------|-----------------|-----------------|-----------------|----------------|---------------|---------------|-------------|
| STOP<br>BITS | 9600/<br>76,800 | 4800/<br>38,400 | 2400/<br>19,200 | 1200/<br>9,600 | 300/<br>2,400 | 150/<br>1,200 | 110/<br>880 |
| 1            | 0               | 0               | 1               | 0              | 0             | 0             | 0           |

This sets the baud rate port to a baud rate of 19,200, (HBD=1 UART command register port), with 1 stop bits. For subsequent baud rates, HBD=0 in the UART command register port, therefore the lower values are active.

Lines 6 and 7 call the gbyte subroutine. This subroutine is called twice to stop any phase match error. The first call of the gbyte subroutine is being ignored in this description as explained above. The second call of the gbyte subroutine performs a read from the terminal, via the SCC serial port, using the carriage return characters which the user is sending to determine the baud rate setting of the terminal.

Line S1 of the gbyte subroutine inputs a data byte from the UART serial status port, (00H), into register A. Note that this line has a label (gbyte). This label is not only used for the call instruction from the main program, it is also used by the subroutine itself.

Line S2 tests bit 6 of register A, UART serial status port bit RDA. A logic 0 in this bit, (no data byte available), sets the zero flag. A logic 1 in this bit, (data byte available), does not set the zero flag. The UART serial status port is shown below.

| D7  | D6  | D5  | D4  | D3  | D2  | D1  | D0  |
|-----|-----|-----|-----|-----|-----|-----|-----|
| TBE | RDA | IPG | TBE | RDA | SRV | ORE | FME |
| Х   | 0/1 | Х   | X   | X   | X   | Х   | X   |

Line S3 causes the program to jump back to Line S1 if there is no data byte available. The program will continue looping in this manner until there is a data byte available.

When there is a data byte available, Line S4 reads it from the receiver data port, (address 01H), and stores it in register A. Line S5 returns to the main program, (Line 8).

Line 8 performs a logical AND between register A and 7FH, this masks off bit D7 of the receiver data port because only bits D0 to D6 are valid.

Line 9 compares the contents of register A, (receiver data port), with 0DH, (carriage return character). If the data byte in register A is 0DH the zero flag is set, otherwise the zero flag is not set. The setting of the zero flag signifies that the baud rate of the terminal and the baud rate of the SCC are matched.

Line 10 loads register A with 1, (00000001 in binary notation), which is used to reset the UART command register port if a 0DH is not recognised, (incorrect baud rate).

Line 11 tests the zero flag and depending on its value, either continues with the program or jumps back to Line 4. If the baud rates match, the zero flag will be set and the main program will continue. If the baud rates do not match, the zero flag will not be set and there will be a jump back to Line 4, (reset UART command register port), where the next value in baud rate table will be tried. The program continues in this manner until the baud rate of the terminal and the baud rate of the SCC are matched.

## CHAPTER 3

## THE SMALL COMPUTER SYSTEM INTERFACE (SCSI)

In this chapter SCSI is discussed with reference to the RODIME RO652 hard disk drive which was used in this project. SCSI supports both block and character transfer, the RO652 uses the block method. For more detailed information on SCSI, the American National Standards Institute document X3T9 should be referred to.

The theory of bus structure is based on a system originally developed in the 1960's and 1970's for use in mainframe computers. This concept was improved on and was introduced as the Shugart Associated Standard Interface (SASI). SASI was then offered to the American National Standards Institute (ANSI) as the basis for a new industry standard. The Small Computer System Interface (SCSI) was the name chosen by ANSI and the X3T9 specification was issued in the early 1980's.

The SCSI interface is an eight bit, eight port intelligent bus. RO652 bus transfers are asynchronous and follow a defined REQ/ACK handshake protocol. The input/output bus structure enables intelligent peripherals to communicate with multiple hosts over a single bus and allows these peripherals to be used by one or more host computers attached to the same bus. Communication on the SCSI bus uses the initiator/target framework, where the initiator is the device which requests that an operation be performed by another device and the target is the device which performs an operation when requested to do so by an initiator. Up to eight SCSI devices can be supported in any combination on the bus. There are three principal SCSI system configurations: single initiator/single target (figure 3.1); single initiator/multi target (figure 3.2) and multi initiator/multi target (figure 3.3). The main advantage of the SCSI bus system is that several tasks can be interleaved at the same time (figure 3.4).





SCSI can also operate in a synchronous data transfer mode, which is faster than the asynchronous mode, due to reduced handshaking. Synchronous data bus transfers can only be used if previously agreed by both the initiator and the target, using a Synchronous Data Transfer Request command.

HOST

OMPUTER

DEVICE

SCSI





Arbitration allows a number of peripheral devices to be attached to the bus and makes it possible for one SCSI device to gain control of the bus and assume the role of an initiator or a target. To gain control of the bus, a device waits for a bus free state and asserts its own SCSI ID. After waiting for at least an arbitration delay the SCSI device examines the data bus, if there is a higher SCSI ID present the device has lost control, if no higher SCSI ID is present the device has won control of the bus. Figure 3.5 and figure 3.6 show the sequence of bus phases for arbitrating and non-arbitrating devices.

Figures 3.5-3.6 : SCSI Bus Phases





## **3.1 HARDWARE**

SCSI devices are daisy chained together using a 50 way cable. The RO652 hard disk drive uses the single ended driver alternative, which gives a maximum cable length of six metres. The differential pair driver alternative has a maximum cable length of 25 metres and is normally used where the SCSI device has to be some distance from the host. Both ends of the bus cable must be terminated correctly, with 220 ohms to +5V and 330 ohms to ground,

on all of the signal lines. Figure 3.7 shows an example of correct signal termination. Single ended drivers and differential pair drivers cannot be used on the same bus. All signals on the SCSI bus are active low and use open collector drivers. SCSI bus signals use negative logic, this means that a false/deasserted signal on the SCSI bus is +5 volts and a true/asserted signal is 0 volts.

Figure 3.7 : SCSI Bus Termination



The SCSI interface is a bidirectional bus interface which transfers data asynchronously. The fifty way SCSI bus consists of eighteen signal lines: nine control signals used to co-ordinate data transfer between the host system and the disk drive and nine data bus signals used as an eight-bit bidirectional data bus with parity. The following table shows the SCSI single ended option pin numbers and names for the RO652.

## SCSI BUS SIGNALS

| 1  | GND | 27 | GND | 2  | DBO     | 28 | NC  |
|----|-----|----|-----|----|---------|----|-----|
| 3  | GND | 29 | GND | 4  | DBI     | 30 | NC  |
| 5  | GND | 31 | GND | 6  | DB2     | 32 | ATN |
| 7  | GND | 33 | GND | 8  | DB3     | 34 | NC  |
| 9  | GND | 35 | GND | 10 | DB4     | 36 | BSY |
| 11 | GND | 37 | GND | 12 | DB5     | 38 | ACK |
| 13 | GND | 39 | GND | 14 | DB6     | 40 | RST |
| 15 | GND | 41 | GND | 16 | DB7     | 42 | MSG |
| 17 | GND | 43 | GND | 18 | DBP     | 44 | SEL |
| 19 | GND | 45 | GND | 20 | NC      | 46 | C/D |
| 21 | GND | 47 | GND | 22 | NC      | 48 | REQ |
| 23 | GND | 49 | GND | 24 | NC      | 50 | I/0 |
| 25 | NC  |    |     | 26 | TERMPWR |    |     |

TERMPWR

Terminator power is a +4.0VDC - +5.25VDC signal which is provided on the SCSI bus by the RO652. GND GROUND NC No Connection

DB0-DB7, DBP These nine lines, data bit 0-data bit 7, and a data parity bit form the data bus. Data bit 7 is the most significant bit and has the highest priority during an arbitration phase. Data bit 0 is the least significant bit and has the lowest priority during an arbitration phase. Parity is odd in the SCSI system and can either be enabled on all devices connected to the SCSI bus or disabled on all devices. The RO652 does not support parity.

## **Control Lines**

- ATN Attention indicates to the target that the initiator has a message to send.
- BSY Busy indicates that the bus is in use.
- ACK Acknowledge is used with REQ to indicate an acknowledgement of a bus transfer handshake.
- RST Reset is used to clear all activity on the bus.
- MSG Message indicates that the bus is in a message phase.
- SEL Select is used during device-selection phase.
- C/D Control/Data indicates whether control or data information is on the data bus. When this signal is true control information is on the bus.
- **REQ** Request is used with ACK to request a bus transfer handshake.
- I/O Input/Output indicates direction of the data flow on data bus, with respect to the initiator. When this signal is true, data is being inputted to the initiator.

## **3.2 SCSI BUS PHASES**

The SCSI bus can be in one of eight phases:

Bus Free Phase Arbitration Phase Selection Phase Reselection Phase Command Phase Data Exchange Phase Status Phase Message Phase

Phases 5, 6, 7 and 8 are collectively known as the Information Transfer Phase.

The following table shows which of the SCSI bus signals the initiator or the target is permitted to source during the specific phase. The SCSI bus signal RST may be sourced by both initiator and target during any phase. No attempt is made here to show if the source is driving the SCSI bus signal asserted, negated, or is passive. All SCSI device drivers that are not active sources are in the passive state.

#### Signal Sources

| Bus Phase                                                                                       | BSY                                                               | SEL                                                           | C/D,I/O<br>MSG,REQ                                             | ACK,ATN                                                                       | DB(7-0,P)                                                                            |  |
|-------------------------------------------------------------------------------------------------|-------------------------------------------------------------------|---------------------------------------------------------------|----------------------------------------------------------------|-------------------------------------------------------------------------------|--------------------------------------------------------------------------------------|--|
| Bus Free<br>Arbitration<br>Selection<br>Reselection<br>Command<br>Data In<br>Data Out<br>Status | None<br>All<br>I+T<br>I+T<br>Target<br>Target<br>Target<br>Target | None<br>Winner<br>Initiator<br>Target<br>None<br>None<br>None | None<br>None<br>Target<br>Target<br>Target<br>Target<br>Target | None<br>None<br>Initiator<br>Initiator<br>Initiator<br>Initiator<br>Initiator | None<br>SCSI ID<br>Initiator<br>Target<br>Initiator<br>Target<br>Initiator<br>Target |  |
| Message In<br>Message Out                                                                       | Target<br>Target                                                  | None<br>None                                                  | Target<br>Target                                               | Initiator<br>Initiator                                                        | Target<br>Initiator                                                                  |  |

- All The signal is driven by all SCSI devices that are actively arbitrating.
- SCSI ID A unique data bit, the SCSI ID, is driven by each SCSI device that is actively arbitrating; the other 7 data bits are deasserted (ie. not driven) by that device. DBP may be undriven or driven true but can never be driven false during this phase.
  - I+T The signal is driven by the initiator, the target or both as specified in the Selection and Reselection Phases.
- Initiator If the signal is driven, it is only driven by the active initiator.
  - None The signal is deasserted; that is not be driven by any SCSI device. The bias circuitry of the bus terminators pulls the signal to a false state.
- Winner The signal is driven by the SCSI device that wins arbitration.
- Target If the signal is driven, it is driven only by the active target.

The following descriptions of the phases should be read in conjunction with appendix C.

### **BUS FREE PHASE**

The Bus Free Phase is used to indicate that no device is using the bus. It is caused by BSY and SEL being false, for at least a bus settle delay (400 nanoseconds), and all connected devices releasing control of the bus within a bus clear delay (800 nanoseconds).

### **ARBITRATION PHASE**

The Arbitration Phase is only used in multiple host configurations and is not implemented in relation to this project. The Arbitration Phase is used to avoid bus conflicts. During arbitration, devices try to gain control of the bus by asserting a unique SCSI ID onto one bit of the data bus and releasing the other seven data bits. The device asserting DB7 has the highest priority and the device asserting DB0 has the lowest priority. To arbitrate for control of the bus, the device has to:

Test for a Bus Free Phase, ie. BSY and SEL false for at least a bus settle delay.

After detection of a Bus Free Phase, the device waits for at least a bus free delay.

The device then asserts BSY and its own SCSI ID.

The device then waits for an arbitration delay and examines the SCSI bus. If there is a higher priority SCSI ID bit on the data bus then the device has lost arbitration and has to release BSY and its SCSI ID from the data bus, then wait for the next Bus Free Phase. If there is no higher SCSI ID bit on the data bus the device has won arbitration and asserts SEL to claim the bus and enters the Selection Phase.

### SELECTION PHASE

For single initiator systems the Selection Phase is entered after the Bus Free Phase. During this phase:

The initiator selects the SCSI target to communicate with by asserting its own address and the address of the target onto the bus.

After a delay the initiator asserts SEL.

The target will then assert BSY.

Then the initiator releases SEL.

BSY remains asserted until the next Bus Free Phase, when the target will release it.

### **RESELECTION PHASE**

The Reselection Phase allows the target to reconnect to an initiator to continue an operation that was previously started by the initiator, but was suspended by the target, i.e. the target disconnected by allowing a Bus Free Phase to occur before the operation was finished. Reselection can only be used in systems that have an Arbitration Phase implemented. The Reselection Phase is not supported by the RO652 and is not used in this project.

### INFORMATION TRANSFER PHASE

There are four information phases, as shown below. Note that the Data Phase is subdivided into a Data In Phase and a Data Out Phase, and that the Message Phase is subdivided into a Message In Phase and a Message Out Phase.

Command Phase Status Phase Data Phase: Message Phase:

Data In Phase Data Out Phase Message In Phase Message Out Phase The SCSI bus signals MSG, C/D and I/O are used to distinguish between the different Information Transfer Phases as shown in the table below. These three signals are all driven by the target device, which therefore controls the SCSI bus and all phase changes. The Target can also cause a Bus Free Phase by releasing MSG, C/D, I/O and BSY.

| MSG    | C/D | I/O | Phase Name  | Direction Of Transfer |  |
|--------|-----|-----|-------------|-----------------------|--|
| 0      | 0   | 0   | Data Out    | Initiator -> Target   |  |
|        | Ō   | 1   | Data In     | Target -> Initiator   |  |
| 0<br>0 | 1   | 0   | Command     | Initiator -> Target   |  |
| 0      | 1   | 1   | Status      | Target -> Initiator   |  |
| 1      | 0   | 0   | Reserved    | Ŭ                     |  |
| 1      | 0   | 1   | Reserved    |                       |  |
| 1      | 1   | 0   | Message Out | Initiator -> Target   |  |
| 1      | 1   | 1   | Message In  | Target -> Initiator   |  |

Once the Information Transfer Phase is complete the bus returns to the Bus Free Phase.

# **Command Phase**

This phase follows the Selection Phase and allows the target to obtain the command information from the initiator.

The Command Phase is entered when BSY and C/D are asserted and MSG, I/O, SEL and ATN are deasserted.

The target waits for a bus settle delay and asserts REQ to request the first byte of the Command Descriptor Block (See Chapter 3.4).

The initiator places the first byte on the bus and asserts ACK.

The Target reads the byte, then releases REQ.

The initiator will then release ACK.

The first byte is now transferred and the target will continue to request additional bytes until the complete Command Descriptor Block has been transferred and the Command Phase has ended.

## **Data Phase**

This phase allows the exchange of data between the target and the initiator.

### **Data In Phase**

The Data In Phase allows data to be transferred from the initiator to the target. The Data In Phase is entered when BSY is asserted and MSG, C/D and I/O are deasserted.

The target asserts REQ to request the first data byte.

The initiator places the first data byte on the bus and asserts ACK.

The Target reads the byte, then releases REQ.

The initiator will then release ACK.

The first data byte is now transferred and the target will continue to request additional data bytes until the last data byte has been transferred.

### **Data Out Phase**

The Data Out Phase allows data to be transferred to the initiator from the target. The Data Out Phase is entered when BSY and I/O are asserted and  $\overline{MSG}$  and  $\overline{C}/D$  are deasserted.

The target asserts REQ and the initiator reads the first data byte from the target.

The initiator asserts ACK.

The Target releases the data bus and REQ.

The initiator will then release ACK.

The first data byte is now transferred and the target will continue to request that the initiator reads the data until the last data byte has been transferred.

### **Status Phase**

The Status Phase allows the target to request that the initiator reads its Status information. (Chapter 3.4)

The Status Phase is entered when command execution is complete or an error that cannot be recovered from occurs. BSY, C/D and I/O are asserted and SEL and MSG are deasserted.

The target puts the Status Byte on the bus and asserts REQ.

The initiator reads the byte and asserts ACK.

This causes the target to release REQ.

The initiator will then release ACK.

### **Message Phase**

This phase allows the transfer of a Message information. The first byte transferred can be a single Message Byte (Chapter 3.4) or the first byte of a multiple-byte message.

#### Message In Phase

The Message In Phase allows a Message Byte to be read from the target by the initiator. The Message In Phase signals the end of an operation and is entered when BSY, MSG, C/D and I/O are are asserted.

The target puts the Message Byte on the bus and asserts REQ.

- 36 -

The initiator reads the byte and asserts ACK.

This causes the target to release REQ.

The initiator will then release ACK.

The Message In Phase terminates when MSG is deasserted.

### **Message Out Phase**

The Message Out Phase is not supported by the RO652 and is not used in this project.

### **3.3 SCSI BUS CONDITIONS**

The SCSI bus has two asynchronous conditions, the Attention Condition and the Reset Condition. These cause the SCSI device to perform certain actions and can alter the phase sequence.

### ATTENTION CONDITION

The Attention Condition allows an initiator to inform a target that the initiator has a message ready, (eg. parity error, whereby the target will send the byte again). The target may get this message by performing a Message Out Phase. The initiator creates the Attention Condition by asserting ATN during the Arbitration Phase or Bus Free Phase. This condition is not supported by the R0652 and is not used in this project.

### **RESET CONDITION**

The Reset Condition is used to immediately clear all SCSI devices from the bus. When the RST signal is received by the SCSI device, the device removes all signals that it is currently asserting from the SCSI bus and clears any current commands. A Bus Free Phase always follows a Reset Condition.

### **3.4 SCSI COMMANDS**

The RO652 hard disk drive which was used in this project is always a target. To execute commands the initiator sends a command, using the appropriate Command Descriptor Block, to the target via the host adaptor. The target performs the command and reports its status, (Message Byte and Status Byte), to the initiator.

# **OPERATION CODES**

The first byte of the Command Descriptor Block contains the Operation Code of the SCSI command. The Operation Code has two parts as shown below, firstly the Group Code and secondly the Command Code. The Group Code is a three bit code, therefore there are eight command groups. The Command Code is a five bit code, therefore there are thirty-two commands within each group. This gives a total of 256 available command operation codes.

#### **Operation Code Command Descriptor Block**

| Bit    | 7          | 6 | 5 | 4 | 3  | 2       | 1   | 0 |
|--------|------------|---|---|---|----|---------|-----|---|
| Byte 0 | Group Code |   |   |   | Co | mmand C | ode |   |

Group Code

| 6 Byte Commands                 |
|---------------------------------|
| 10 Byte Commands                |
| Reserved                        |
| Reserved                        |
| Reserved                        |
| 12 Byte Commands                |
| Vendor Unique                   |
| Vendor Unique (6 Byte Commands) |
|                                 |

Of the eight possible command groups, only group 0, group 1 and group 7 are supported by the RO652. Only the Command Codes implemented by the RO652 are discussed. See ANSI specification X3T9 and common command set book for full description of all of the commands available.

### **Command Codes**

|         | Hexadecimal<br>Operation Code                                  | Command Name                                                                                                                                           |
|---------|----------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|
| Group 0 | 00<br>03<br>04<br>07<br>08<br>0A<br>0B<br>12<br>15<br>1A<br>1D | Test Unit Ready<br>Request Sense<br>Format Unit<br>Reassign Blocks<br>Read<br>Write<br>Seek<br>Inquiry<br>Mode Select<br>Mode Sense<br>Send Diagnostic |
| Group 1 | 25<br>28<br>2A<br>2F<br>37<br>3C<br>3B                         | Read Capacity<br>Read Extended<br>Write Extended<br>Verify<br>Read Defect Data<br>Read Data Buffer<br>Write Data Buffer                                |
| Group 7 | E0<br>E1<br>E2<br>E8<br>EA                                     | Maintenance Seek<br>Format Maintenance Tracks<br>Certify<br>Fast Read<br>Fast Write                                                                    |

# COMMAND DESCRIPTOR BLOCKS FORMAT

The number of bytes contained by the Command Descriptor Block (CDB) is dependent on the group of the command. Group 0 and Group 7 commands have a 6 byte CDB and Group 1 commands have 10 byte CDB. The Command Descriptor Block has an Operation Code as the first byte, as shown above, followed by a Logical Unit Number (LUN), command parameters (if any) and a Control Byte. If there is an invalid parameter in the CDB, the target will stop executing the command without altering the medium. Regardless of command completion, the target will return a status byte and a message byte to the initiator. The RO652 only supports Status Byte 02H (Check Condition) and Message Byte 00H (command complete), see ANSI spec for full description of other status and message bytes. Tables 3.1 and 3.2 show the typical command descriptor blocks for 6 and 10 byte commands. Tables 3.3 and 3.4 show the status and message byte command descriptor blocks.

| Bit    | 7     | 6                                   | 5         | 4                                          | 3         | 2          | 1  | 0 |  |  |
|--------|-------|-------------------------------------|-----------|--------------------------------------------|-----------|------------|----|---|--|--|
| Byte 0 |       | Operation Code                      |           |                                            |           |            |    |   |  |  |
| Byte 1 | Logic | al Unit N                           | lumber    | Logical Block Address MSB<br>(if required) |           |            |    |   |  |  |
| Byte 2 |       | Logical Block Address (if required) |           |                                            |           |            |    |   |  |  |
| Byte 3 |       | L                                   | ogical Bl | ock Addr                                   | ess LSB ( | if require | d) |   |  |  |
| Byte 4 |       | Transfer Length (if required)       |           |                                            |           |            |    |   |  |  |
| Byte 5 |       | Control Byte                        |           |                                            |           |            |    |   |  |  |

Table 3.1 : Typical 6 Byte Command Descriptor Block (Group 0 and Group 7)

Table 3.2 : Typical 10 Byte Command Descriptor Block (Group 1)

| Bit    | 7     | 6                                       | 5          | 4         | 3       | 2           | 1  | 0      |  |  |  |
|--------|-------|-----------------------------------------|------------|-----------|---------|-------------|----|--------|--|--|--|
| Byte 0 |       | Operation Code                          |            |           |         |             |    |        |  |  |  |
| Byte 1 | Logic | al Unit N                               | umber      |           | Res     | erved       |    | RelAdr |  |  |  |
| Byte 2 |       | Logical Block Address MSB (if required) |            |           |         |             |    |        |  |  |  |
| Byte 3 |       | Logical Block Address (if required)     |            |           |         |             |    |        |  |  |  |
| Byte 4 |       | Logical Block Address (if required)     |            |           |         |             |    |        |  |  |  |
| Byte 5 |       | L                                       | ogical Blo | ock Addre | ess LSB | (if require | d) |        |  |  |  |
| Byte 6 |       | Reserved                                |            |           |         |             |    |        |  |  |  |
| Byte 7 |       | Transfer Length MSB (if required)       |            |           |         |             |    |        |  |  |  |
| Byte 8 |       | Transfer Length LSB (if required)       |            |           |         |             |    |        |  |  |  |
| Byte 9 |       | Control Byte                            |            |           |         |             |    |        |  |  |  |

Logical Unit Number

The LUN addresses one of eight devices attached to the target.

Logical Block Address

The logical block address on logical units begins with block 0 and is contigous up to the last logical block on the unit. The logical block concept implies that the initiator and target have previously established the number of data bytes per logical block. This can be done using the Read Capacity command or the Mode Sense command. Group 0 and Group 7 Command Descriptor Blocks have a 21-bit logical block address. Group 1 Command Descriptor Blocks have a 32-bit logical block address.

| Relative Address (Rel<br>Adr) | The relative address of Group 1 Command Descriptor Blocks is<br>set to one to indicate that the logical block address is a two's<br>complement displacement. This negative/positive displacement is<br>added to the logical block address last accessed on the unit to<br>form the logical block address for that command. This is only<br>used when linking commands and is not supported by the RO652. |
|-------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Transfer Length               | The transfer length specifies the amount of data to be transferred, usually the number of blocks.                                                                                                                                                                                                                                                                                                        |
|                               |                                                                                                                                                                                                                                                                                                                                                                                                          |

Control Byte The control byte is the very last byte of every Command Descriptor Block. A typical Control Byte is shown below. For the R0652 Hard disk drive, all bits of the Control Byte are set to zero.

#### **Control Byte**

| Bit | 7      | 6      | 5 | 4    | 3    | 2 | 1    | 0    |
|-----|--------|--------|---|------|------|---|------|------|
|     | Vendor | Unique |   | Rese | rved |   | Flag | Link |

- Link Bit If the Link Bit is set to one the initiator wants an automatic link to the next command when the current command is successfully completed. This is not implemented in the RO652.
- Flag Bit If the Link Bit is set to zero, then the Flag Bit is set to zero. If the Link Bit is set to one and the command is successfully completed, the target sends a linked command complete message (if Flag Bit=0) or a linked command complete message with flag (if Flag Bit=1). This bit is typically used to cause an interrupt in the initiator between linked commands.

# STATUS

The status returned on completion of a command contains a Status Byte and a Message Byte.

Only the status supported by the RO652 is discussed here.

#### Table 3.3 : Status Byte

| Bit    | 7 | 6 | 5 | 4 | 3 | 2 | 1   | 0 |
|--------|---|---|---|---|---|---|-----|---|
| Byte 0 | 0 | 0 | 0 | 0 | 0 | 0 | ERR | 0 |

ERR=0 no error occurred during command execution. ERR=1 error occurred during command execution. Most error conditions cannot be explained with a single status code and a Request Sense Command should be issued when ERR=1 to determine nature of the error.

Table 3.4 : Message Byte

| Bit    | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|--------|---|---|---|---|---|---|---|---|
| Byte 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

00H Command Complete is the only message supported by the RO652. This message is sent from a target to an initiator to indicate that the execution of a command has terminated and that a valid status has been sent to the initiator. This does not indicate correct or incorrect execution of the command. After this message is sent a Bus Free Phase is entered.

### **CHAPTER 4**

# ADVANTAGES OF SMALL COMPUTER SYSTEM INTERFACE (SCSI)

Before the SCSI bus standard emerged there were many different types of devices, most with different interfaces, which would typically be connected to a computer system. For example, a Winchester disk drive would have an ST506 interface, a tape streamer would have a QIC36 interface and a printer would have an RS232 interface. Therefore, it was necessary to have a different hardware controller for each of these devices. Although each of these were already industry standard interfaces, the introduction of SCSI as the new industry standard meant that the Winchester disk drive, the tape streamer and the printer would all have the same interface and could be controlled by the same hardware.

SCSI has a common command set, which allows the loading to be taken off the host system CPU as more tasks are performed by the SCSI controller. For example, Copy is a function of the common command set which allows transfer of data from one device in the system to another without host CPU monitoring. The common command set supports present and future peripherals, so new software drivers do not need to be written for upgraded devices. This makes system design independent of advances in device capacity and performance. Although the same SCSI hardware is able to control printers, hard disk drives, floppy disk drives etc. a different software driver is needed for each of them. The software has to take into account whether the connected device is a block device (eg. a hard disk drive) or a character device (eg. a printer).

SCSI also supports arbitration between connected devices, allowing several tasks from different devices to be interleaved on the bus at the same time as shown in Chapter 3.

# 4.1 ADVANTAGES FOR HARD DISKS

SCSI supersedes the ST506 interface as the new industry standard for hard disk drives and is supported by most major device manufacturers. The SCSI common command set ensures

compatibility between similar devices from different manufacturers. Previously, a separate input/output driver was needed for each hard disk drive type as they were manufactured with different numbers of heads, cylinders and sectors. SCSI overcomes this by viewing any hard disk drive, regardless of manufacturer, as a string of random logical blocks. As a result, the only difference between drive types is the maximum logical block number which can be addressed. The logical block number is converted to the physical block number by the disk drive alone and a single input/output driver can be developed to run any SCSI disk drive directly. Device specific problems, such as bad blocks on the hard disk media are handled entirely within the hard disk thus reducing the host system CPU involvement as the hard disk appears to be error free media to the operating system.

With current computers tending to be 16 bit and 32 bit microprocessor based, rather than 8 bit microprocessor based, they need more disk storage capacity. There are three methods of increasing hard disk capacity:

Increase the available recording area by adding disks.

The ST506 is limited to 8 heads maximum. SCSI does not have this limitation as it sees only logical blocks when communicating with a hard disk drive and lets the hard disk electronics convert it into physical blocks.

Increase track density.

To increase the track density on an ST506 interface a closed loop servo system (feedback) is needed to drive the read/write heads. This is due to the type of data coding that the ST506 uses. SCSI uses a different type of data coding, which will give a 50% increase in disk capacity, without the need for a closed loop servo system driving the read/write heads.

Increase Flux Changes per Inch (FCI).

ST506 is limited to a maximum transfer rate of 5 Mbits/s. SCSI has a much higher maximum synchronous transfer rate of 32 Mbits/s.

#### **CHAPTER 5**

### TTL LOGIC INTERFACE BOARD

This board translates between the SCSI bus and the S-100 bus by using 74 series TTL logic gates. The Single Card Computer can be said to be the host and this interface board the host adapter. Figures 5.1 and 5.2 which show the circuit diagram and parts list for the board, Appendix A which contains the software listings and Appendix C which shows the bus phase sequences, should be referred to while reading the explanations in this chapter. The connections on the left hand side of the circuit diagram go to the S-100 bus, ie. to the Single Card Computer (SCC). The connections on the right hand side of the circuit diagram go to the SCC is the initiator and the RO652 hard disk drive, the target. The circuit can be grouped into three functional parts<sup>-</sup>

Input/Output Buffers Input/Output Buffer Enabling General Components

# **5.1 INPUT/OUTPUT BUFFERS**

The following are the input/output buffers:

IC1 - 74LS240 octal inverting buffer IC2 - 74LS373 D-type latch IC3 - 74LS240 octal inverting buffer IC9 - 74LS240 octal inverting buffer IC11 - 74LS373 D-type latch IC12 - 74LS38 2-input NAND

### IC1, IC3 AND IC9

IC1, IC3 and IC9 are 74LS240 octal buffer chips, with three-state outputs. The output is the logical inversion of the input and can be in a logic 1 state, a logic 0 state or a high impedance state. When the buffer is in the high impedance state its output appears to be disconnected from the bus. There are two enable inputs (1G and 2G) on the 74LS240, on pins 1 and 19. One enable is used to control four of the buffers and the other enable is used to control the

other four buffers. In the circuit these are connected together, to give one enable control input for all eight buffers. The truth table below shows the enable logic of the 74LS240, with G being the common enable input, A being the buffer input and Y being the buffer output.

| G | Α | Y |
|---|---|---|
| 0 | 0 | 1 |
| 0 | 1 | 0 |
| 1 | X | Z |

0-Logic 0 (0 Volts), 1-Logic 1 (+5 Volts), X-irrelevant, Z-high impedance (disconnected)

### **IC2 AND IC11**

IC2 and IC11 are 74LS373 octal D-type latches, with three-state outputs. There are two controlling inputs on the 74LS373, enable (G) and output control (OC). When the OC input is logic 1 the chip goes into its high impedance state. This state does not occur in the circuit as the OC input is connected to 0 volts. The truth table below shows the enable logic of the 74LS373 with G being the enable input, D being the latch input and Q being the latch output.

| G   | D   | Q   |
|-----|-----|-----|
| 1 1 | 1 0 | 1 0 |
| 0   | x   | Qo  |

0-Logic 0 (0 Volts), 1-Logic 1 (+5 Volts), X-irrelevant, Qo-previous Q

### **IC12**

IC12 is a 74LS38 two-input NAND chip with open collector outputs. In open collector circuits the final "pull up" resistor is missing and must be provided by the user. The missing final resistor allows the user to connect more than one open collector output together through the same "pull up" resistor. By doing this the outputs of the gates which are connected through the same "pull up" resistor are OR-ed together.

## **5.2 INPUT/OUTPUT BUFFER ENABLING**

The following are all part of the buffer enable circuitry:

IC4 - 74LS11 three-input AND IC5 - 74LS00 two-input NAND IC6 - 74LS04 inverter IC7 - 74LS244 octal buffer IC8 - 74LS08 two-input AND IC10 - 74LS682 8-bit magnitude comparator SW1 - 8 way single pole/single throw switch

### IC4, IC5, IC6 AND IC8

IC4, IC5, IC6 and IC8 function as standard logic gates, as shown in the circuit diagram.

### IC7

IC7 the 74LS244 non-inverting octal buffer with three-state outputs is used to buffer A0. A0 has to be buffered so there is only one TTL load on the S100 bus line.

### IC10 AND SW1

IC10 the 74LS682 8-bit magnitude comparator with totem pole output is used to decode the base address on A7 through A1. A7 through A1 are on the P inputs and the Q inputs are connected to SW1 which is an 8 way single pole/single throw switch. SW1 is set for a base address of 20H. The 74LS682 has two control outputs, P=Q and P>Q. Only the P=Q output is used in this circuit. The truth table below shows the decode logic of the 74LS682 with P and Q being the address inputs, and P=Q being the decoder output.

| P,Q                                | P=Q |
|------------------------------------|-----|
| P=Q                                | 0   |
| P>Q<br>P <o< td=""><td>1</td></o<> | 1   |
| P <q< td=""><td>1</td></q<>        | 1   |

0-Logic 0 (0 Volts), 1-Logic 1 (+5 Volts)

The following are all general components:

IC13 - 7805 voltage regulator RN1 - 220/330 ohm resistor network RN2 - 220/330 ohm resistor network C1-C12 - 0.01 micro-farad capacitors

### **IC13**

IC13 is a 7805 voltage regulator which regulates the +8 volts on the S100 bus (pin 51) to a +5 volts supply for the interface board.

### RN1 AND RN2

RN1 and RN2 are 2200hm/3300hm resistor networks used to terminate the SCSI bus lines in the correct manner, for single ended drivers. With 220 ohms to +5 volts and 330 ohms to 0 volts.

# C1-C12

C1 through C12 are 0.01 micro-farad capacitors which are placed between 0 volts and +5 volts next to the IC packages. These are de-coupling capacitors which are used to smooth out any spikes appearing on the voltage rails.

### **5.4 SELECTING THE INPUT/OUTPUT BUFFERS**

Data/Command/Status and Message byte transfers are controlled by writing to and reading from interface board address 20H. Direction/Information type (ie. data byte, command byte, status byte or message byte) are controlled by reading from and writing to interface board address 21H. The address which is written to/read from controls the buffer selection/disconnection.

A

R

D

D

S

D

S

datap (data port)=20H, statp (status port)=21H, contp (control port)=21H A=Asserted, R=Deasserted, S=Selected, D=Disconnected

A

R

R

# IC1

write contp

IC1 is selected when there is a 0V signal on the enable input (pin 1 and pin 19). NAND gate 1C outputs a 0V signal to IC1 when the following conditions are satisfied:

(1) Address lines A7-A0 hold address 20H
 (2) sINP and pDBIN are asserted

A read from the interface board, address 20H, causes sINP and pDBIN to be asserted which selects IC1. During a read from the interface board sOUT and  $\overline{pWR}$  are deasserted and I/O is asserted which disconnects the other buffers. This allows the transfer of data from the RO652 to the SCC data in bus.

# IC2

IC2 is selected when there is a +5V signal on the enable input (pin 11). AND gate 2C outputs a +5V signal to IC2 when the following conditions are satisfied:

(1) Address lines A7-A0 hold address 20H (2) sOUT and  $\overline{pWR}$  are asserted

A write to the interface board, address 20H, causes sOUT and  $\overline{pWR}$  to be asserted, and I/O to be deasserted which selects IC2 and IC3. During a write to the interface board sINP and pDBIN are deasserted which disconnects the other buffers. This allows the transfer of data from the SCC data out bus to the RO652.

IC3 is selected when there is a 0V signal on the enable input (pin 1 and pin 19). INVERTER gate 1E outputs a 0V signal to IC3 when I/O from the SCSI bus is inactive.

A write to the interface board, address 20H or address 21H, causes sOUT and  $\overline{pWR}$  to be asserted, and I/O to be deasserted which selects IC3. During a write to the interface board sINP and pDBIN are deasserted which disconnects the other buffers. This allows the transfer of data and control information from the SCC data out bus to the RO652.

### IC9

IC9 is selected when there is a 0V signal on the enable input (pin 1 and pin 19). NAND gate 3C outputs a 0V signal to IC9 when the following conditions are satisfied:

(1) Address lines A7-A0 hold address 21H
 (2) sINP and pDBIN are asserted

A read from the interface board, address 21H, causes sINP and pDBIN to be asserted which selects IC9. During a read from the interface board sOUT and  $\overline{pWR}$  are deasserted and I/O is asserted which disconnects the other buffers. This allows transfer of status information from the RO652 to the SCC data in bus.

### IC11

IC11 is selected when there is a +5V signal on the enable input (pin 11). AND gate 4C outputs a +5V signal to IC11 when the following conditions are satisfied:

(1) Address lines A7-A0 hold address 21H (2) sOUT and  $\overline{pWR}$  are asserted

A write to the interface board, address 21H, causes sOUT and  $\overline{pWR}$  to be asserted, and I/O to be deasserted which selects IC11 and IC3. During a write to the interface board sINP and pDBIN are deasserted which disconnects the other buffers. This allows the transfer of control information from the SCC data out bus to the RO652.

# **5.5 CONTROL SIGNALS**

Certain SCC and SCSI signals are used to control the transfer of data, commands, status and message signals between the data buses. The SCC control signals are used to select/disconnect the buffers during different phases. The SCSI control lines are the lines used to control what is being transferred on the data bus.

# SCC CONTROL SIGNALS

| sINP<br>(output from SCC)  | This signal is connected to the input/output buffer enabling circuitry. sINP is asserted $(+5V)$ during a data input to the SCC, deasserted $(0V)$ at all other times.                                                                                                                    |
|----------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| pDBIN<br>(output from SCC) | This signal is connected to the input/output buffer enabling circuitry. pDBIN is asserted $(+5V)$ when data is latched onto onto data bus, deasserted $(0V)$ at all other times.                                                                                                          |
| sOUT<br>(output from SCC)  | This signal is connected to the input/output buffer enabling circuitry. sOUT is asserted $(+5V)$ during a data output from the SCC, deasserted $(0V)$ at all other times.                                                                                                                 |
| pWR<br>(output from SCC)   | This signal is connected to the input/output buffer enabling circuitry. $\overline{pWR}$ is asserted (0V) during a data write from the SCC, deasserted (+5V) at all other times.                                                                                                          |
| A0<br>(output from SCC)    | This signal is connected to the input/output buffer enabling circuitry. When A0 is asserted $(+5V)$ transfer is between the RO652 control bus and the SCC data in or data out bus. When A0 is deasserted (0V) transfer is between the RO652 data bus and the SCC data in or data out bus. |

# SCSI CONTROL SIGNALS

| ACK<br>(output from SCC) | This signal is connected, via IC11, from the SCC data out line DO0 to the RO652 control bus. $\overline{ACK}$ is asserted (0V) to acknowledge a request (REQ) from the RO652 hard disk drive. $\overline{ACK}$ is deasserted (+5V) at other times. |
|--------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| RST<br>(output from SCC) | This signal is connected, via IC11, from the SCC data out line DO1 to the RO652 control bus. RST is asserted $(0V)$ to clear all bus activity. RST is deasserted $(+5V)$ at other times.                                                           |
| SEL<br>(output from SCC) | This signal is connected, via IC11, from the SCC data out line DO2 to the RO652 control bus. SEL is asserted $(0V)$ during selection of the RO652 hard disk drive. SEL is deasserted (+5V) at other times.                                         |
| BSY<br>(input to SCC)    | This signal is connected, via IC9, from the RO652 control bus to the SCC data in line DI0. BSY is asserted (0V) when the SCSI bus                                                                                                                  |

is busy. BSY is deasserted (+5V) at other times.

| MSG<br>(input to SCC) | This signal is connected, via IC9, from the RO652 control bus to the SCC data in line DI1. MSG is asserted $(0V)$ when the SCSI bus is in a message phase. MSG is deasserted $(+5V)$ at other times.                                                                                              |
|-----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| C/D<br>(input to SCC) | This signal is connected, via IC9, from the RO652 control bus to the SCC data in line DI2. $C/D$ is asserted (0V) when control information is on the SCSI bus. $C/D$ is deasserted (+5V) when data information is on the SCSI bus.                                                                |
| REQ<br>(input to SCC) | This signal is connected, via IC9, from the RO652 control bus to the SCC data in line DI3. REQ is asserted $(0V)$ when the RO652 is requesting something from the SCC. REQ is deasserted (+5V) at other times.                                                                                    |
| I/O<br>(input to SCC) | This signal is connected, via IC9, from the RO652 control bus to the SCC data in line DI4. I/O is asserted (0V) when the direction of transfer on the SCSI bus is from the RO652 to the SCC. I/O is deasserted (+5V) when the direction of transfer on the SCSI bus is from the SCC to the RO652. |

### **5.6 BUS PHASES**

This section shows the relevant circuitry active during each of the phases with reference to the subroutines in the SCSI.Z80 software (Appendix A.5).

# SELECTION PHASE

During the Selection Phase the RO652 hard disk drive is selected by the SCC. The SELECT subroutine of SCSI.Z80 controls the selection of the RO652 hard disk as follows.

The address of the RO652 hard disk drive is written from the SCC to the RO652 data port, IC2 and IC3 selected.

SEL is asserted by writing to the RO652 control port, IC3 and IC11 selected.

The RO652 status port is read until BSY is asserted, IC9 selected.

SEL is deasserted by writing to the RO652 control port, IC3 and IC11 selected.

This completes the Selection Phase.

### DATA IN PHASE

During the Data In Phase data is sent from the RO652 hard disk drive to the VDU, via the SCC. The SCSIRD subroutine of SCSI.Z80 controls the transfer of a data byte as follows.

The RO652 status port is read, IC9 selected, until REQ and BSY are asserted and MSG, C/D and I/O are deasserted.

The RO652 data port is read, IC1 selected, to transfer the data byte into the SCC.

The SCC then outputs the data byte, which was read from the drive, to the VDU.

ACK is asserted by writing to the RO652 control port, IC3 and IC11 selected. (SCC has read the data byte).

The RO652 status port is read, IC9 selected, until REQ is false.

ACK is deasserted by writing to the RO652 control port, IC3 and IC11 selected.

The data byte transfer is complete.

### DATA OUT PHASE

During the Data Out Phase data is sent from the VDU, via the SCC, to the RO652 hard disk drive. The SCSIWR subroutine of SCSI.Z80 controls the transfer of a data byte as follows.

The data byte, to be written to the RO652, is read from the VDU into the SCC.

The RO652 status port is read, IC9 selected, until REQ, BSY, I/O are asserted and MSG and C/D are deasserted.

The SCC writes the data byte to the RO652 data port, IC2 and IC3 selected, to transfer the data byte into the RO652.

ACK is asserted by writing to the RO652 control port, IC3 and IC11 selected. (SCC has written the data byte).

The RO652 status port is read, IC9 selected, until REQ is false.

ACK is deasserted by writing to the RO652 control port, IC3 and IC11 selected.

The data byte transfer is complete.

### **COMMAND PHASE**

During the Command Phase data is sent from the VDU, via the SCC, to the RO652 hard disk drive. The SEND subroutine of SCSI.Z80 controls the transfer of a command byte as follows.

The data byte, to be written to the RO652, is read from the VDU into the SCC.

The RO652 status port is read, IC9 selected, until REQ, BSY and C/D are asserted and MSG and I/O are deasserted.

The SCC writes the command byte to the RO652 data port, IC2 and IC3 selected, to transfer the data byte into the RO652.

ACK is asserted by writing to the RO652 control port, IC3 and IC11 selected. (SCC has read the data byte).

The RO652 status port is read, IC9 selected, until REQ is false.

ACK is deasserted by writing to the RO652 control port, IC3 and IC11 selected.

The command byte transfer is complete.

### STATUS PHASE

During the Status Phase status information is sent from the RO652 hard disk drive to the VDU, via the SCC. The STATUS subroutine of SCSI.Z80 controls the transfer of a status byte as follows.

The RO652 status port is read, IC9 selected, until REQ, C/D, I/O and BSY are asserted and MSG is deasserted.

The RO652 data port is read, IC1 selected, to transfer the status byte into the SCC.

The SCC then outputs the status byte, which was read from the drive, to the VDU.

ACK is asserted by writing to the RO652 control port, IC3 and IC11 selected. (SCC has read the data byte).

The RO652 status port is read, IC9 selected, until REQ is false.

ACK is deasserted by writing to the RO652 control port, IC3 and IC11 selected.

The status byte transfer is complete.

### MESSAGE IN PHASE

During the Message In Phase message information is sent from the RO652 hard disk drive to the VDU, via the SCC. The MESSAGE subroutine of SCSI.Z80 controls the transfer of a message byte as follows.

The RO652 status port is read, IC9 selected, until REQ, C/D, I/O, BSY and MSG are asserted.

The RO652 data port is read, IC1 selected, to transfer the message byte into the SCC.

The SCC then outputs the message byte, which was read from the drive, to the VDU.

ACK is asserted by writing to the RO652 control port, IC3 and IC11 selected. (SCC has read the data byte).

The RO652 status port is read, IC9 selected, until REQ is false.

ACK is deasserted by writing to the RO652 control port, IC3 and IC11 selected.

The message byte transfer is complete.

### **5.7 SOFTWARE**

The listings of the programs are in Appendix A. There are five programs which control the TTL logic interface board:

| MAIN.Z80 |
|----------|
| EQU.Z80  |
| MSG.Z80  |
| VDU.Z80  |
| SCSI.Z80 |

MAIN.Z80 is the main program, the other four are programs which are included into the assembled firmware.

### MAIN.Z80

This is the main program which controls VDU, SCC and RO652 input/output, by utilising the subroutines, equates etc. contained in the other programs.

## EQU.Z80

This file contains:

Equates for the VDU control VDU ASCII equates SCSI equates SCSI status bits equates SCSI control bits equates SCC RAM storage size

# **MSG.Z80**

This file has the messages which are sent to the VDU during program operation.

# **VDU.Z80**

In this file are the subroutines which control VDU input/output. (Baud rate selection and reading from and writing to the VDU screen.)

# SCSI.Z80

As shown in Chapter 5.6, this is file which has the subroutines used to control the RO652 hard disk drive phases.

Figure 5.1



DKG. No. E is 74.6240 OCTAL BUFFER (INVERTED 3-5TATE OUTPUTS) 74.6373 OCTAL D-TYPE LATCHEG (3-5TATE OUTPUTS) 74.6373 OCTAL D-TYPE LATCHEG (3-5TATE OUTPUTS) 74.6300 OCTAL EUFFER (INVERTED 3-9TATE OUTPUTS) 74.6300 OUAD 2-INDUT POSITIVE -AND GATES 74.6304 HEX INVERTER 2007 74.6304 HEX INVERTER 2017 74.6304 OCTAL EUFFER (INVIRTED 3-9TATE OUTPUTS) 74.6323 OCTAL EUFFER (INVIRTED 3-9TATE OUTPUTS) 74.6324 OCTAL EUFTRED 3-9TATE OUTPUTS) 74.6324 OUTPUT POSITIVE -AND BUFFERS (OPEN-COLLECTOR OUTPUTS) 74.6324 OUTPUT POSITIVE -AND EUFFERS (OPEN-COLLECTOR OUTPUTS) APPROVED ð CHECKED SHEET TRACED DRAWING No. B WAY SINGLE POLE-SINGLE THROW DUAL-IN-LINE SWITCH DRAWN 2201/3301 x 6 (RESIGTOR TERMINATION PACK) SIOO→ SCOI INTERFACE ONOIF 25 V (DECOUPLING CAPACITORS) TTL LOGIC BOARD TITLE CC NOT SCUE DESCRIPTION APPO DATE 15/ 01 Nid 8 PARTS LIST DESCRIPTION ICI (20 PIN) IC2 (20 PIN) IC2 (20 PIN) IC3 (14 PIN) IC3 (14 PIN) IC5 (14 PIN) IC5 (14 PIN) IC5 (14 PIN) IC7 (20 PIN) IC7 (20 PIN) IC1 (14 PIN) IC1 ( SWI (16 PIN) PART CI-C12 RN2 īzď PART OF 15 553- 94 ISSE ö U

Figure 5.2

### **CHAPTER 6**

### INTELLIGENT INTERFACE BOARD

This board translates between the SCSI bus and the S-100 bus using TTL logic and a NCR5380 SCSI interface chip. As in Chapter 5, the Single Card Computer is said to be the host (initiator) and the RO652 hard disk drive the target. Appendix B, containing the software used to control transfers, Appendix C which shows the bus phase sequences and Figures 6.1 and 6.2 which show the circuit diagram and the parts list, should be referred to while reading this chapter. The connections on the left hand side of the circuit diagram go to the S-100 bus, ie. to the Single Card Computer (SCC). The connections on the right hand side of the circuit diagram go to the SCSI bus ie. the RO652 hard disk drive. The circuit can be grouped into three functional parts:

Input/Output Input/Output Selection General Components

### 6.1 INPUT/OUTPUT

The following are the input/output ICs

IC1 - 74LS244 octal buffer IC2 - 74LS244 octal buffer IC5 - NCR53C80 SCSI interface chip

### **IC1 AND IC2**

IC1 and IC2 are 74LS244 non-inverting octal buffer chips, with three state outputs. As before, the output can be in a logic 1 state, a logic 0 state or a high impedance state. There are two enable inputs (1G and 2G) on the 74LS244, on pins 1 and 19. One enable is used to control four of the buffers and the other enable is used to control the other four buffers. These two inputs are connected together, to give one enable control input for all eight buffers. The truth table below shows the enable logic of the 74LS244, with G being the common enable input, A being the buffer input and Y being the buffer output.

| G | Α | Y |
|---|---|---|
| 0 | 0 | 0 |
| 0 | 1 | 1 |
| 1 | X | Z |

0-Logic 0 (0 Volts), 1-Logic 1 (+5 Volts), X-irrelevant, Z-high impedance (disconnected)

### IC5

IC5 is a VLSI chip, the NCR53C80. This is a CMOS SCSI interface chip designed to support the ANSI specification for Small Computer Systems Interfaces, X3T9.2. In this project the chip is operated in the initiator mode but it can also be operated in the target mode. The chip is controlled by reading from and writing to several internal registers, Chapter 6.6 discusses these registers. The NCR53C80 can be grouped into seven functional parts:

SCSI Bus Signals DMA Control Signals Data Bus Signals Reset Conditions Interrupts Mode of Operation Internal Register Signals

### **SCSI Bus Signals**

| DB0-DB7 | RST | MSG |
|---------|-----|-----|
| DBP     | ATN | C/D |
| BSY     | ACK | I/O |
| SEL     | REQ |     |

These eighteen signals are identical to those shown in Chapter 3. SCSI bus signal ATN is not used in this project because the message out phase is not supported.

### **DMA Control Signals**

EOP DRQ READY DACK The NCR53C80 is not used in a DMA mode in relation to this project. Input signals EOP and DACK are held at +5V, deasserted state (ie. not active). Output signals READY and DRQ are not used.

Data Bus Signals

| D0-D7 | Data Bus (D0-D7) is the bidirectional, tri-state bus connected to |
|-------|-------------------------------------------------------------------|
|       | the host computer.                                                |

#### **Reset Conditions**

There are three possible reset conditions within the NCR53C80:

| Hardware Reset    | Input signal RESET is used to clear all internal registers, it does not reset the SCSI bus.                                                                                                                                                   |
|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SCSI RST Received | This performs a chip reset, clearing all internal registers except<br>port, 1 bit 7 which is the assert RST bit. RST is used to clear all<br>SCSI bus activity.                                                                               |
| SCSI RST Issued   | If the host sets the assert RST bit (bit 7, port 1) all internal registers are cleared apart from port 1, bit 7. RST will be active, clearing all SCSI bus activity, until port 1, bit 7 is deasserted or the NCR53C80 RESET input is active. |

### Interrupts

Output signal IRQ is not used in relation to this project. IRQ is used to inform the host of an error or an event completion.

### Mode of Operation

The NCR53C80 supports four modes of operation: programmed I/O transfers; normal DMA mode; block DMA mode and pseudo DMA mode. Programmed I/O is used in this project, this uses the REQ/ACK handshake method of controlling data transfers.

Signals CS, IOR, IOW and A0-A2 are used to address all internal registers. CS enables a read or a write of one of the eight internal registers selected. All data transfers between the SCC and the RO652 are controlled by these registers. See Chapter 6.6 for explanation of the registers used in this project.

### **6.2 INPUT/OUTPUT SELECTION**

The following are all part of the input/output select circuitry:

IC4 - 74LS08 2-input AND IC6 - 74LS04 inverter IC7 - 74LS10 3-input NAND IC3 - 74LS682 8-bit magnitude comparator SW1 - 8 way single pole/single throw switch

### IC4, IC6 AND IC7

IC4, IC6 and IC7 function as standard logic gates, as shown in the circuit diagram.

### IC3 AND SW1

IC3 the 74LS682 8-bit magnitude comparator with totem pole output is used to decode the base address on A7 through A3. A7 through A3 are on the P inputs and the Q inputs are connected to SW1 which is an 8 way single pole/single throw switch. SW1 is set for a base address of 20H. The 74LS682 has two control outputs, P=Q and P>Q. Only the P=Q output is used in this circuit. The truth table below shows the decode logic of the 74LS682 with P and Q being the address inputs, and P=Q being the decoder output.

| P,Q                         | P=Q |
|-----------------------------|-----|
| P=O                         | 0   |
| P>Q                         | 1   |
| P <q< td=""><td>1</td></q<> | 1   |

0-Logic 0 (0 Volts), 1-Logic 1 (+5 Volts)

### **6.3 GENERAL COMPONENTS**

The following are all general components:

IC8 - 7805 voltage regulator RN1 - 220/330 ohm resistor network RN2 - 220/330 ohm resistor network R1,R2 - 1K ohm resistors C1-C7 - 0.01 micro-farad capacitors

IC8

IC8 is a 7805 voltage regulator which regulates the +8 volts on the S100 bus (pin 51) to a +5 volts supply for the interface board.

### RN1 AND RN2

RN1 and RN2 are 2200hm/3300hm resistor networks used to terminate the SCSI bus lines in the correct manner, for single ended drivers. With 220 ohms to +5 volts and 330 ohms to 0 volts.

### R1 AND R2

R1 and R2 are 1K ohm resistors used as pull-up resistors on the NCR53C80 inputs EOP and DACK, preventing them from being asserted.

### C1-C7

C1 through C7 are 0.01 micro-farad capacitors which are placed between 0 volts and +5 volts next to the IC packages. These are de-coupling capacitors which are used to smooth out any spikes appearing on the voltage rails.

# 6.4 SELECTING THE INPUT/OUTPUT

Data/Command/Status and Message byte transfers are controlled by writing to and reading from the interface board, base address 20H. The direction of the information on the data bus controls the buffer selection/disconnection.

The following tables shows the chips that are selected and disconnected with each read/write function.

|                                                                                                     |                                 |                            | sOUT                       | pWR                        | DEVICE(S) SELECTED         |                                 |                                 |
|-----------------------------------------------------------------------------------------------------|---------------------------------|----------------------------|----------------------------|----------------------------|----------------------------|---------------------------------|---------------------------------|
| FUNCTION                                                                                            | sINP                            | pDBIN                      |                            |                            | IC1                        | IC2                             | IC5                             |
| read datap<br>write datap<br>write icmdp<br>write modep<br>write tcmdp<br>read stat1p<br>read prstp | A<br>R<br>R<br>R<br>R<br>A<br>A | A<br>R<br>R<br>R<br>A<br>A | R<br>A<br>A<br>A<br>R<br>R | R<br>A<br>A<br>A<br>R<br>R | D<br>S<br>S<br>S<br>D<br>D | S<br>D<br>D<br>D<br>D<br>S<br>S | S<br>S<br>S<br>S<br>S<br>S<br>S |

datap (data register)=20H, icmdp (initiator command register)=21H, modep (mode register=22H), tcmdp (target command register)=23H, stat1p (bus status register)=24H, prstp (reset parity/interrupt register)=27H A=Asserted, R=Deasserted, S=Selected, D=Disconnected

# IC1

IC1 is selected when there is a 0V signal on the enable input (pin 1 and pin 19). NAND gate 2B outputs a 0V signal to IC1 when the following conditions are satisfied:

(1) Address lines A7-A3 hold base address 20H (2) sOUT and  $\overline{pWR}$  are asserted

A write to the interface board, base address 20H, causes sOUT and  $\overline{pWR}$  to be asserted which selects IC1. This allows the transfer of information from the SCC data out bus to the NCR53C80 (IC5). During a write to the interface board sINP and pDBIN are deasserted which disconnects IC2.

IC2 is selected when there is a 0V signal on the enable input (pin 1 and pin 19). NAND gate 1B outputs a 0V signal to IC2 when the following conditions are satisfied:

Address lines A7-A3 hold base address 20H
 sINP and pDBIN are asserted

A read from the interface board, base address 20H, causes sINP and pDBIN to be asserted which selects IC2. This allows the transfer of information from the NCR53C80 (IC5) to the SCC data in bus. During a read from the interface board sOUT and  $\overline{pWR}$  are deasserted which disconnects IC1.

### IC5

IC5 is selected when there is a 0V signal on the CS input (pin 19). AND gate 3C outputs a 0V signal to IC5 when the output of 1B or 2B is 0V. This happens when there is a read or a write to base address 20H. When there is a read from base address 20H, IOR is asserted (0V) and when there is a write to base address 20H, IOW is asserted (0V). This allows transfers to take place between the RO652 and the SCC.

# **6.5 CONTROL SIGNALS**

Certain SCC control signals are used to control the NCR53C80. The control signals are used to select/disconnect IC1 and IC2, enable or disable the NCR53C80 and set up the correct conditions on the NCR53C80 for communication between the SCC and the RO652. The NCR53C80 control signals are used to address the eight internal registers which control data transfers between the SCC and the RO652.

# SCC CONTROL SIGNALS

sINP (output from SCC) This signal is connected to the input/output buffer enabling circuitry. sINP is asserted (+5V) during a data input to the SCC, deasserted (0V) at all other times.

| pDBIN             | This signal is connected to the input/output buffer enabling      |
|-------------------|-------------------------------------------------------------------|
| (output from SCC) | circuitry. pDBIN is asserted (+5V) when data is latched onto onto |
| · · ·             | data bus, deasserted (OV) at all other times.                     |
|                   | 5% (A. 5 1971) (S. 1986) (S. 1986)                                |

sOUT This signal is connected to the input/output buffer enabling (output from SCC) circuitry. sOUT is asserted (+5V) during a data output from the SCC, deasserted (0V) at all other times.

 $\overline{pWR}$  This signal is connected to the input/output buffer enabling (output from SCC) This signal is asserted (0V) during a data write from the SCC, deasserted (+5V) at all other times.

A0-A2 A0 through A2 are connected to the NCR53C80 A0-A2 input. (output from SCC) These are used to control the NCR53C80 internal register selection.

pRESET<br/>(output from SCC)This signal is connected to the NCR53C80 RESET input. When<br/>pRESET is asserted (0V) the NCR53C80 clears all its internal<br/>registers. This does not force the SCSI bus signal RST low and<br/>therefore, it does not reset the SCSI bus.

### NCR53C80 CONTROL SIGNALS

- CS This signal comes from the input/output selection circuitry. When CS is asserted (0V), a read/write of the internal register addressed by A0-A2 can take place.
- IOR This signal comes from the input/output selection circuitry. When IOR is asserted (0V), a read of the internal register selected by CS, A0-A2 takes place.
- IOW This signal comes from the input/output selection circuitry. When IOW is asserted (0V), a write to the internal register selected by CS, A0-A2 takes place.
- A0-A2 These signals come directly from the SCC. The address selects a specific register.

### 6.6 NCR53C80 INTERNAL REGISTERS

The table below shows a summary of the NCR53C80 internal register selection.

| CS | IOR | IOW | A2 | A1 | A0 | REGISTER SELECTED           | USED |
|----|-----|-----|----|----|----|-----------------------------|------|
| R  | R   | Α   | R  | R  | R  | Output Data                 | YES  |
| R  | A   | R   | R  | R  | R  | Current SCSI Data           | YES  |
| R  | R   | A   | R  | R  | A  | Initiator Command           | YES  |
| R  | A   | R   | R  | R  | A  | Initiator Command           | NO   |
| R  | R   | A   | R  | A  | R  | Mode                        | YES  |
| R  | A   | R   | R  | A  | R  | Mode                        | NO   |
| R  | R   | A   | R  | A  | A  | Target Command              | YES  |
| R  | A   | R   | R  | A  | A  | Target Command              | NO   |
| R  | R   | Α   | Α  | R  | R  | Select Enable               | NO   |
| R  | Α   | R   | A  | R  | R  | Current SCSI Bus Status     | YES  |
| R  | R   | Α   | Α  | R  | A  | Start DMA send              | NO   |
| R  | Α   | R   | A  | R  | A  | Bus and Status              | NO   |
| R  | R   | Α   | Α  | A  | R  | Start DMA Target Receive    | NO   |
| R  | A   | R   | Α  | A  | R  | Input Data                  | NO   |
| R  | R   | Α   | Α  | Α  | A  | Start DMA Initiator Receive | NO   |
| R  | Α   | R   | Α  | Α  | Α  | Reset Parity/Interrupts     | YES  |

A-asserted, R-deasserted

Only the registers used in relation to this project are discussed. See the NCR53C80 Design

Manual for descriptions of unused registers.

## Output Data Register/Current Scsi Data Register

Address 0 - The Output Data Register and Current SCSI Data Register are referred to in the phase explanations (Chapter 6.7) as the data register.

Write datap - This register is used to send data to the SCSI bus and to assert SCSI ID bits during selection phase.

| 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|-----|-----|-----|-----|-----|-----|-----|-----|
| DB7 | DB6 | DB5 | DB4 | DB3 | DB2 | DB1 | DBO |

DB0-DB7 are as the SCSI bus signals of the same name.

Read datap - This register allows the host to read the active SCSI data bus.

| 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|-----|-----|-----|-----|-----|-----|-----|-----|
| DB7 | DB6 | DB5 | DB4 | DB3 | DB2 | DBI | DBO |

DB0-DB7 are as the SCSI bus signals of the same name.

#### **Initiator Command Register**

Address 1 - The Initiator Command Register.

Write icmdp - This register is used to assert some SCSI bus signals.

| 7             | 6  | 5  | 4             | 3             | 2             | 1             | 0               |
|---------------|----|----|---------------|---------------|---------------|---------------|-----------------|
| Assert<br>RST | TM | DE | Assert<br>ACK | Assert<br>BSY | Assert<br>SEL | Assert<br>ATN | Assert<br>D BUS |

Assert SIGNAL/D BUS

sert Reading these bits shows the status of the signal/data bus. If the bit is one (1) then the signal/data bus is active. When a one is written to any of these bytes the signal/data bus is asserted.

- TM Test Mode. When a one is written to this bit the NCR53C80 output drivers are disabled.
- DE Differential Enable. When a one is written to this bit the external differential pair driver option is enabled.

Only bits 7 (assert RST), 4 (assert ACK), 2 (assert SEL) and 0 (assert DATA BUS) are used in relation to this project.

#### **Mode Register**

Address 2 - The Mode Register.

Write modep - This register controls the operational mode of the chip.

| 7             | 6 | 5               | 4 | 3                 | 2               | 1           | 0   |
|---------------|---|-----------------|---|-------------------|-----------------|-------------|-----|
| B Mode<br>DMA |   | Enable<br>P Chk |   | Enable<br>EOP Int | Monitor<br>Busy | DMA<br>Mode | Arb |

B Mode DMA Block Mode DMA. This controls the characteristics of DMA handshakes. Set to 0 during selection phase.

Target Mode Sets up NCR53C80 as an initiator or a target. This bit is set to 0 (NCR53C80 is an initiator) during the selection phase.

| Enable P Chk   | Enable Parity Checking. This bit is set to 0 (ignore parity) during the selection phase.       |
|----------------|------------------------------------------------------------------------------------------------|
| Enable P Int   | Enable Parity Interrupt. This bit is set to 0 (interrupt disabled) during the selection phase. |
| Enable EOP Int | Enable EOP interrupt. This bit is set to 0 (interrupt disabled) during the selection phase.    |
| Monitor Busy   | This bit is set to 0 (no interrupt when BSY lost) during the selection phase.                  |
| DMA Mode       | This bit is set to 0 (no DMA) during the selection phase.                                      |
| Arb            | Arbitrate. This bit is set to 0 (no arbitration) during the selection phase.                   |

#### **Target Command Register**

Address 3 - The Target Command Register.

Write tcmdp - This register mode register allows the host to control the SCSI bus Information Transfer Phase and assertion of REQ.

| 7   | 6 | 5 | 4 | 3             | 2             | 1             | 0             |
|-----|---|---|---|---------------|---------------|---------------|---------------|
| LBS | х | x | x | Assert<br>REQ | Assert<br>MSG | Assert<br>C/D | Assert<br>I/O |

LBS Last Byte Sent. This is used by the NCR53C80 to indicate, during DMA, when the last byte has been sent to the SCSI bus.

Assert SIGNAL Assert REQ has no meaning when operating as an initiator. When a one is written to any of these bytes the signal is asserted.

#### **Current Scsi Bus Status Register**

Address 4 - The Current SCSI Bus Status Register.

Read stat1p - This register is used to monitor seven SCSI bus control signals and the data parity bit.

| 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|-----|-----|-----|-----|-----|-----|-----|-----|
| RST | BSY | REQ | MSG | C/D | I/O | SEL | DBP |

#### Start Dma Send Register/Bus And Status Register

Address 5 - This register is not used in this project.

#### Input Data Register/Start Dma Target Receive Register

Address 6 - This register is not used in this project.

#### **Reset Parity/Interrupts Register**

Address 7 - Reset Parity/Interrupts Register.

**Read prstp** - This register is reset when it is read. The three bits reset when this register is read are: parity error bit (bit 5); interrupt request bit (bit 4) and busy error bit (bit 2) in the Bus and Status Register.

#### **6.7 BUS PHASES**

This section shows the relevant circuitry active during each of the phases with reference to the subroutines in the NCR.Z80 software (Appendix B).

Here is the sequence of events leading to the phase explanations.

The SCSI bus is reset by asserting, then releasing, RST in the NCR53C80 (IC5) initiator command register.

Class byte and command byte requested, via VDU.

The Selection Phase is entered.

After selecting the hard disk drive, the Command Phase is entered.

After sending the command to the drive the status of the bus is checked by reading the RO652 control port, via the NCR53C80 current SCSI bus status register.

If BSY is deasserted, command execution is complete and the program starts again. If BSY is asserted, command execution is incomplete and REQ is tested. If REQ is deasserted the status of the bus is checked again. If REQ is asserted, all bits except C/D, I/O and MSG are masked out from the current SCSI bus status register.

These bits are used to determine what phase the bus is in and what subroutine is entered.

| MSG | C/D | I/O | Phase          | Subroutine Entered |  |
|-----|-----|-----|----------------|--------------------|--|
| R   | R   | Α   | Data In Phase  | DATAIN             |  |
| R   | R   | R   | Data Out Phase | SCSIWR             |  |
| R   | Α   | Α   | Status Phase   | STATUS             |  |
| A   | Α   | Α   | Message Phase  | MESSAGE            |  |

A=asserted, R=deasserted

#### SELECTION PHASE

During the Selection Phase the RO652 hard disk drive is selected by the SCC, via the NCR53C80 (IC5). The SELECT subroutine of NCR.Z80 controls the selection of the RO652 hard disk as follows.

The SCC sets up IC5 as an initiator with no interrupts and sets the initiator command register, IC1 and IC5 selected.

The SCC resets the IC5 parity/interrupts register, IC2 and IC5 selected.

The address of the RO652 hard disk drive is written from the SCC to the IC5 (RO652 data port), IC1 and IC5 selected.

Information is sent to the IC5 target command register to release C/D and I/O, (data being transferred into RO652), IC1 and IC5 selected.

SEL is asserted by writing to the IC5 initiator command register (RO652 control port), IC1 and IC5 selected.

The RO652 status port, via the IC5 bus status register, is read until BSY is asserted, IC2 and IC5 selected.

SEL is deasserted by writing to the IC5 initiator command register (RO652 control port), IC1 and IC5 selected.

This completes the Selection Phase.

#### **DATA IN PHASE**

During the Data In Phase data is sent from the RO652 hard disk drive, via the NCR53C80 (IC5) and the SCC, to the VDU. The DATAIN subroutine of NCR.Z80 controls the transfer of a data byte as follows.

The RO652 data port is read, via the NCR53C80 data register, to transfer the data byte into the SCC, IC2 and IC5 selected.

The SCC then outputs the data byte, which was read from the drive, to the VDU.

ACK is asserted by writing to the IC5 initiator command register (RO652 control port), IC1 and IC5 selected.

The RO652 status port, via the IC5 bus status register, is read until REQ is deasserted, IC2 and IC5 selected.

ACK is then deasserted by writing to the IC5 initiator command register (RO652 control port), IC1 and IC5 selected.

The data byte transfer is complete.

#### DATA OUT PHASE

During the Data Out Phase data is sent from the VDU, via the SCC and the NCR53C80 (IC5), to the RO652 hard disk drive. The SCSIWR subroutine of NCR.Z80 controls the transfer of a data byte as follows.

The data byte, to be written to the RO652, is read from the VDU into the SCC.

Information is sent to the IC5 target command register to release C/D and I/O, (data being transferred into RO652), IC1 and IC5 selected.

The data byte is written to the RO652 by writing to the IC5 data register, IC1 and IC5 selected.

ACK is asserted by writing to the IC5 initiator command register (RO652 control port), IC1 and IC5 selected.

The RO652 status port, via the IC5 bus status register, is read until REQ is deasserted, IC2 and IC5 selected.

ACK is then deasserted by writing to the IC5 initiator command register (RO652 control port), IC1 and IC5 selected.

The data byte transfer is complete.

#### **COMMAND PHASE**

During the Command Phase a command byte is sent from the VDU, via the SCC and the NCR53C80 (IC5), to the RO652 hard disk drive. The SEND6 subroutine of NCR.Z80 controls the transfer of a command byte as follows.

The command byte, to be written to the RO652, is read from the VDU into the SCC.

Information is sent to the IC5 target command register to assert C/D and release I/O, (command being transferred into RO652), IC1 and IC5 selected.

The RO652 status port, via the IC5 bus status register, is read until REQ is asserted, IC2 and IC5 selected.

The command byte is written to the RO652 by writing to the IC5 data register, IC1 and IC5 selected.

ACK is asserted by writing to the IC5 initiator command register (RO652 control port), IC1 and IC5 selected.

The RO652 status port, via the IC5 bus status register, is read until REQ is deasserted, IC2 and IC5 selected.

ACK is then deasserted by writing to the IC5 initiator command register (RO652 control port), IC1 and IC5 selected.

The command byte transfer is complete.

#### STATUS PHASE

During the Status Phase status information is sent from the RO652 hard disk drive, via the NCR53C80 (IC5) and the SCC, to the VDU. The STATUS subroutine of NCR.Z80 controls the transfer of a data byte as follows.

The RO652 data port is read, via the NCR53C80 data register, to transfer the status byte into the SCC, IC2 and IC5 selected.

The SCC then outputs the status byte, which was read from the drive, to the VDU.

ACK is asserted by writing to the IC5 initiator command register (RO652 control port), IC1 and IC5 selected.

The RO652 status port, via the IC5 bus status register, is read until REQ is deasserted, IC2 and IC5 selected.

ACK is then deasserted by writing to the IC5 initiator command register (RO652 control port), IC1 and IC5 selected.

The status byte transfer is complete.

#### **MESSAGE IN PHASE**

During the Message In Phase message information is sent from the RO652 hard disk drive, via the NCR53C80 (IC5) and the SCC, to the VDU. The MESSAGE subroutine of NCR.Z80 controls the transfer of a data byte as follows.

The RO652 data port is read, via the NCR53C80 data register, to transfer the message byte into the SCC, IC2 and IC5 selected.

The SCC then outputs the message byte, which was read from the drive, to the VDU.

ACK is asserted by writing to the IC5 initiator command register (RO652 control port), IC1 and IC5 selected.

The RO652 status port, via the IC5 bus status register, is read until REQ is deasserted, IC2 and IC5 selected.

ACK is then deasserted by writing to the IC5 initiator command register (RO652 control port), IC1 and IC5 selected.

The message byte transfer is complete.

### **6.8 SOFTWARE**

NCR.Z80 controls VDU, SCC and RO652 input/output. The program contains:

Equates for VDU control, VDU ASCII characters, NCR53C80 SCSI, NCR53C80 SCSI status/control, SCC RAM storage size.

Messages which are sent to the VDU during operation.

Subroutines which control VDU input/output, baud rate selection and reading from and writing to the VDU.

Subroutines controlling the RO652 hard disk drive phases.

Figure 6.1







#### **CHAPTER 7**

#### USES OF THE SCSI SYSTEM

The SCSI system, as described in this thesis, can be used to exercise any peripheral device eg. printers, hard disk drives, tape streamers etc. which support the Small Computer System Interface (SCSI). It is a very useful tool for service engineers, because it can communicate directly with a wide range of peripheral devices and is manufacturer independent. It can be used to determine whether a peripheral or a host computer is the cause of failure in a non-working computer system.

The SCSI system can be used to exercise a hard disk drive, for example, by seeking, writing and reading from specified tracks. The SCSI system can also be used to change the format parameters of a hard disk drive (sectors per track, bytes per sector, interleave etc.) and then low level format the drive using these new parameters.

Custom software can be written for the SCSI system and programmed into the SCC resident EPROM. This software can be used to exercise any SCSI device, with or without user input. Some uses of such software are:

Quality Control. Manufacturers can use the SCSI system as part of a "quality control" system to test their SCSI peripherals before they are sent out to customers.

Goods In. OEMs can use the SCSI system as part of a "goods in" test to check out incoming SCSI peripherals before they are used as part of computer systems.

#### 7.1 EXAMPLE FUNCTIONS

The following examples are functions which cannot normally be carried out from a standard operating system. All have been carried out using the SCSI system, which consists of the following:

S-100 bus system (motherboard and power supply) VDU Cromemco Single Card Computer (SCC) Intelligent SCSI adapter card (See Chapter 6) RO652 hard disk drive

#### **EXAMPLE 1 : EXAMINE DRIVE FORMAT PARAMETERS**

When the SCSI system is powered up the prompt for the Class of command appears on the VDU. The class (0) and the command (1A) of the Mode Sense op-code are entered, then the page code for the drive format parameters (03). The allocate length is then prompted for, this specifies the number of bytes that has been allocated for the returned data. The allocate length is set to the maximum value (FF), as the drive will terminate the command when all data has been transferred. When this command is issued, the hard disk drive will respond by returning the bytes shown. Then the status byte and message byte are returned, indicating command completion. The following shows the sequence of entries, with user responses in bold type.

SCSI Tester V 01.02 July 1986 Class: 0 Command: 1A

Page Code: 03 Allocate length: FF

18 00 00 00 03 13 01 32 01 32 00 06 00 06 00 22 02 00 00 02 00 00 00 00 80

Status: 00 Message: 00

The 25 bytes returned by the mode sense command are split into two different parts as shown below, the far left column shows the returned value:

Mode sense header (4 bytes) Format parameters page (21 bytes)

Mode Sense Header (4 bytes)

|    | Bit    | 7 | 6   | 5 | 4        | 3         | 2  | 1 | 0 |
|----|--------|---|-----|---|----------|-----------|----|---|---|
| 18 | Byte 0 |   |     |   | Sense Da | ta Length | l, |   |   |
| 00 | Byte 1 |   | 00H |   |          |           |    |   |   |
| 00 | Byte 2 |   | 00H |   |          |           |    |   |   |
| 00 | Byte 3 |   |     |   | 00       | )H        |    |   |   |

Sense Data Length This is the number of bytes, in hexadecimal, returned from the drive during the data in phase. The sense data length does not include itself.

|    | Bit     | 7   | 6                         | 5   | 4          | 3         | 2   | 1   | 0 |  |
|----|---------|-----|---------------------------|-----|------------|-----------|-----|-----|---|--|
| 03 | Byte 0  | SDP | 0                         | 0   | 0          | 0         | 0   | 1   | 1 |  |
| 13 | Byte 1  |     | Page Length (0013H)       |     |            |           |     |     |   |  |
| 01 | Byte 2  |     |                           | Т   | racks per  | Zone MS   | SB  |     |   |  |
| 32 | Byte 3  |     |                           | Г   | racks per  | Zone LS   | SB  |     |   |  |
| 01 | Byte 4  |     |                           | Alt | Sectors p  | er Zone 1 | MSB | 596 |   |  |
| 32 | Byte 5  |     |                           | Alt | Sectors p  | ber Zone  | LSB |     |   |  |
| 00 | Byte 6  |     |                           | Alt | Tracks p   | er Zone M | MSB |     |   |  |
| 06 | Byte 7  |     | Alt Tracks per Zone LSB   |     |            |           |     |     |   |  |
| 00 | Byte 8  |     | Alt Tracks per Volume MSB |     |            |           |     |     |   |  |
| 06 | Byte 9  |     | Alt Tracks per Volume LSB |     |            |           |     |     |   |  |
| 00 | Byte 10 |     | 00H                       |     |            |           |     |     |   |  |
| 22 | Byte 11 |     |                           |     | Sectors    | per Track | [   |     |   |  |
| 02 | Byte 12 |     |                           | В   | ytes per S | Sector MS | SB  |     |   |  |
| 00 | Byte 13 |     |                           | В   | ytes per   | Sector LS | SB  |     |   |  |
| 00 | Byte 14 |     |                           |     | 0          | OH        |     |     |   |  |
| 02 | Byte 15 |     |                           |     | Inter      | leave     |     |     |   |  |
| 00 | Byte 16 |     |                           |     | 00         | OH        |     |     |   |  |
| 00 | Byte 17 |     |                           |     | 00         | )H        |     |     |   |  |
| 00 | Byte 18 |     | 00H                       |     |            |           |     |     |   |  |
| 00 | Byte 19 |     | 00H                       |     |            |           |     |     |   |  |
| 80 | Byte 20 |     |                           |     | 80         | H         |     |     |   |  |

#### 21 Byte Format Parameters Page

SDP The SDP bit allows the user to Set Default Parameters. If this bit is set the user implements the factory defined default parameters for this page.

The bytes returned translate as follows:

The Page Length is 13H, 19 decimal.

The number of Tracks per Zone is 132H, 306 decimal.

The number of Alternate Sectors per Zone is 132H, 306 decimal.

The number of Alternate Tracks per Zone is 6.

The number of Alternate Tracks per Volume is 6.

The number of Sectors per Track is 22H, 34 decimal.

The number of Bytes per Sector is 200H, 512 decimal.

The Interleave is 2.

#### **EXAMPLE 2 : LOW-LEVEL FORMAT**

When the SCSI system is powered up the prompt for the Class of command appears on the VDU. The class (0) and the command (04) of the Format op-code are entered, then the format control code (00). The interleave is then prompted for, which is set to 03. When this command is issued, the hard disk drive will execute a low-level format. Then the status byte and message byte are returned, indicating command completion. The following shows the sequence of entries, with user responses in bold type.

SCSI Tester V 01.02 July 1986 Class: 0 Command: 04

Format Control: 00 Interleave: 03

Status: 00 Message: 00

With the format control code set to 00, the drive is formatted using both Primary Defect List (P-LIST) which was written on the drive during manufacture and Growing Defect List (G-LIST) which the user writes to the drive.

The Interleave has been changed from 02, as shown in the previous example to be 03. If the drive format parameters are re-examined after the format is complete, byte 15 of the format parameters page will be 03.

#### REFERENCES

Draft Proposed American National Standard for Information Systems - Small Computer System Interface (SCSI) X3T9.2 Revision 17

American National Standard Common Command Set (CCS) of the Small Computer System Interface (SCSI) X3T9.2 Revision 4

RODIME 650 Series User Maunual (Product Number: USM 00090)

CROMEMCO Single Card Computer (SCC) Instruction Manual

ZILOG Z80A CPU Data Sheets

The S-100 Bus Handbook, Dave Bursky 1980

TEXAS INTRUMENTS TTL Data Book for Design Engineers Volume 1

NCR53C80 SCSI Interface Chip Design Manual

Programming the Z80, Rodnay Zaks 1980

# APPENDIX A

# TTL LOGIC INTERFACE BOARD SOFTWARE

- A.1 MAIN.Z80
- A.2 EQU.Z80
- A.3 MSG.Z80
- A.4 VDU.Z80
- A.5 SCSI.Z80

# A.1 MAIN.Z80

; Development program SCSI device tester

\*include scsiequ.z80 \*include scsimsg.z80 \*include scsivdu.z80 \*include scsiscsi.z80

; Main Program start

| start | ld<br>out<br>ld<br>ld<br>ld<br>call<br>jp                                         | a,rst<br>contp,a<br>a,00h<br>contp,a<br>hl,stack<br>sp,hl<br>getbaud<br>prog                                                     | ; reset drive<br>; set up stack pointer register<br>; set the baud rate                                                                                              |
|-------|-----------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| prog  | ld<br>ld<br>call<br>ld<br>call<br>ld<br>ld<br>cp<br>jr                            | hl,stack<br>sp,hl<br>hl,banner1<br>outst<br>b,2<br>inhex<br>hl,inhexs + 1<br>a,(hl)<br>null<br>nz,cmderr                         | ; set up stack pointer register<br>; output Class request to VDU<br>; one byte only<br>; hl -> second byte<br>; test only one byte                                   |
|       | dec<br>ld<br>push<br>ld<br>call<br>ld<br>call<br>ld<br>ld<br>ld<br>ld<br>cp<br>jr | hl<br>a,(hl)<br>af<br>hl,msgcmd<br>outst<br>b,3<br>inhex<br>hl,inhexs<br>a,(hl)<br>Ofh<br>e,a<br>hl<br>a,(hl)<br>null<br>z,cmdok | ; get the byte<br>; save Class<br>; ask for command hex bytes<br>; possibly two bytes<br>; hl -> first byte<br>; get first byte<br>; keep it in e<br>; only one byte |
|       | and<br>ld<br>ld<br>cp<br>jr<br>ld<br>add<br>ld<br>inc<br>ld<br>cp<br>jr           | Ofh<br>d,a<br>a,e<br>1<br>nz,cmderr<br>a,10h<br>a,d<br>e,a<br>hl<br>a,(hl)<br>null<br>nz,cmderr                                  | ; save second byte<br>; get back first byte<br>; check the value is one<br>; form command<br>; keep it in e<br>; only two bytes allowed                              |
| cmdok | pop<br>cp<br>jr<br>cp<br>jp                                                       | af<br>'0'<br>z,class0<br>'1'<br>z,class1                                                                                         | ; restore Class<br>; test valid Class                                                                                                                                |

|        | ср   | '7'       |
|--------|------|-----------|
|        | jp   | z,class7  |
| cmderr | ld   | hl,msgwcl |
|        | call | outst     |
|        | jr   | prog      |

; command error exit

## ; Class-0 commands

class0

| ld<br>ld<br>ld | a,e<br>hl,buff<br>(hl),a  | ; hl -> command buffer<br>; byte-0 |
|----------------|---------------------------|------------------------------------|
| inc<br>cp      | hl<br>OOh                 | ; test drive ready                 |
| jr<br>cp       | z,null5<br>01h            | ; recalibrate                      |
| jr<br>cp       | z,null5<br>03h            | ; request sense                    |
| jr<br>cp       | z,sens5<br>04h            | ; format unit                      |
| jr<br>cp       | z,form5<br>07h            | ; reassign blocks                  |
| jp<br>cp<br>in | z,reas5<br>08h<br>z,read5 | ; read                             |
| jp<br>cp<br>jp | 0ah<br>z,writ5            | ; write                            |
| cp<br>jp       | 0bh<br>z,seek5            | ; seek                             |
| cp<br>jp       | 12h<br>z,inqy5            | ; inquiry                          |
| cp<br>jp       | 15h<br>z,msel5            | ; mode select                      |
| cp<br>jp       | lah<br>z,msen5            | ; mode sense                       |
| cp<br>jp<br>jp | ldh<br>z,diag5<br>prog    | ; send diagnostics                 |
|                |                           |                                    |

; Send a null byte into command buffer and increment pointer

zero ld (hl),null inc hl ret

; Get a hex byte and convert to binary byte

| gethex2 | call<br>ld | outst<br>b,3 | ; maximum of two bytes |
|---------|------------|--------------|------------------------|
|         | call       | inhex        |                        |
|         | call       | binary       |                        |
|         | ret        |              |                        |

; Byte-1 followed by 5 null bytes ; used by cmd000 and cmd001

| null5  | ld                 | b,5                       |                             |
|--------|--------------------|---------------------------|-----------------------------|
| null5a | call<br>djnz<br>jp | zero<br>null5a<br>cl0send | ; byte-1 to byte-5 are null |

; Byte-1 followed by 3 nulls, allocation length (18), 1 null ; used by cmd003

| sens5<br>sens5a | ld<br>call        | b,3<br>zero              | ; byte-1 to byte-3 are null         |
|-----------------|-------------------|--------------------------|-------------------------------------|
|                 | djnz<br>ld<br>inc | sens5a<br>(hl),12h<br>hl | ; allocation length                 |
|                 | ld<br>call        | (hl),null<br>select      |                                     |
|                 | ld<br>call        | hl,buff<br>send6         |                                     |
|                 | ld<br>call        | hl,msgsens<br>outst      | ; sense byte banner                 |
|                 | call<br>call      | scsird<br>status         | ; read data bytes and output to VDU |
|                 | call              | message                  |                                     |
|                 | JP                | prog                     |                                     |

; Byte-0 followed by format control code, 2 null bytes, interleave, 1 ; null byte used by cmd004

| form5  | push | hl        | ; save pointer                |
|--------|------|-----------|-------------------------------|
|        | ld   | hl,msgfmc | ; format control requested    |
|        | call | gethex2   |                               |
|        | pop  | hl        | ; restore pointer             |
|        | ld   | (hl),a    | ; byte-1                      |
|        | inc  | hl        |                               |
|        | ld   | b,2       |                               |
| form5a | call | zero      | ; byte-2 and byte-3 are null  |
|        | djnz | form5a    |                               |
|        | push | hl        | ; save pointer                |
|        | ld   | hl,msgfmi | ; format interleave requested |
|        | call | gethex2   |                               |
|        | pop  | hl        | ; restore pointer             |
|        | ld   | (hl),a    | ; byte-4                      |
|        | inc  | hl        |                               |
|        | ld   | (hl),null | ; byte-5 null                 |
|        | call | select    |                               |
|        | ld   | hl,buff   |                               |
|        | call | send6     |                               |
|        | call | scsiwr    |                               |
|        | call | status    |                               |
|        | call | message   |                               |
|        | jp   | prog      |                               |
|        |      |           |                               |

; Byte-1 followed by 5 null bytes ; used by cmd007

| reas5  | ld   | b,5     |                             |
|--------|------|---------|-----------------------------|
| reas5a | call | zero    | ; byte-1 to byte-5 are null |
|        | djnz | reas5a  |                             |
|        | call | select  |                             |
|        | ld   | hl,buff |                             |
|        | call | send6   |                             |
|        | call | scsiwr  |                             |
|        | call | status  |                             |
|        | call | message |                             |
|        | jp   | prog    |                             |

; Byte-0 followed by track address and one null byte

; used by cmd008

| read5 | call | setup5  |
|-------|------|---------|
|       | call | select  |
|       | ld   | hl,buff |
|       | call | send6   |
|       | call | scsird  |
|       | call | status  |
|       | call | message |
|       | jp   | prog    |

; Byte-0 followed by track address and one null byte
; requests write byte value once only
; used by cmd00a

| writ5 | call | setup5  |
|-------|------|---------|
|       | call | select  |
|       | ld   | hl,buff |
|       | call | send6   |
|       | call | scsiwb  |
|       | call | status  |
|       | call | message |
|       | jp   | prog    |
|       |      |         |

; Byte-0 followed by track address and one null byte ; used by cmd00b

| seek5 | call | setup5  |
|-------|------|---------|
|       | jp   | clOsend |

; setup5 - provides byte-1 to byte-5 for read5, writ5 and seek5 ; setup5a byte-4 and byte5 for frd5 and fwr5

| setup5  | push<br>ld | hl<br>hl,msgtckh      | ; save pointer<br>; high track address requested                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|---------|------------|-----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|         | call       | gethex2               | , mgn duck uddress requested                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|         | pop        | hl                    | ; restore pointer                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|         | Îd 🗍       | (hl),a                | ; byte-1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|         | inc        | hl                    | 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|         | push       | hl                    | ; save pointer                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|         | ld<br>call | hl,msgtckm<br>gethex2 | ; middle track address requested                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|         | pop        | ĥl                    | ; restore pointer                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|         | ld         | (hl),a                | ; byte-2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|         | inc        | hl                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|         | push       | hl                    | ; save pointer                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|         | ld<br>call | hl,msgtckl<br>gethex2 | ; low track address requested                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|         |            | hl                    | ; restore pointer                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|         | pop<br>ld  | (hl),a                | ; byte-3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|         | inc        | hl                    | , 0910-5                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| setup5a | push       | hl                    | ; save pointer                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| •       | Îd         | hl,msgbcnt            | ; block count                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|         | call       | gethex2               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|         | pop        | hl                    | ; restore pointer                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|         | Îd Î       | (hl),a                | ; byte-4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|         | inc        | hl                    | Constant Constant - Constant Const |
|         | ld         | (hl),null             | ; byte-5 null                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|         | ret        |                       | 1872                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |

; Byte-0 followed by 3 null bytes, allocation length, 1 null byte ; used by cmd012

| inqy5  | ld   | b,3        |                               |
|--------|------|------------|-------------------------------|
| inqy5a | call | zero       | ; bytes 1 to 3 are null       |
|        | djnz | inqy5a     |                               |
|        | push | hl         | ; save pointer                |
|        | ld   | hl,msgalen | ; allocation length requested |
|        | call | gethex2    |                               |
|        | pop  | hl         | ; restore pointer             |
|        | ld   | (hl),a     | ; byte-4 is allocation length |
|        | inc  | hl         |                               |
|        | ld   | (hl),null  | ; byte-5 null                 |
|        | call | select     |                               |
|        | ld   | hl,buff    |                               |
|        | call | send6      |                               |
|        | call | scsird     |                               |
|        | call | status     |                               |
|        | call | message    |                               |
|        | jp   | prog       |                               |

; Byte-0 followed by 3 null bytes, parameter list length, 1 null byte ; used by cmd015

| msel5<br>msel5a | ld<br>call | b,3<br>zero           | ; bytes 1 to 3 are null           |
|-----------------|------------|-----------------------|-----------------------------------|
| mseisa          | djnz       | msel5a                | , bytes i to 5 are num            |
|                 | push       | hl                    | ; save pointer                    |
|                 | ld<br>call | hl,msgplst<br>gethex2 | ; allocation length requested     |
|                 | pop        | hl                    | ; restore pointer                 |
|                 | Îd Î       | (hl),a                | ; byte-4 is parameter list length |
|                 | inc        | hl                    |                                   |
|                 | ld         | (hl),null             | ; byte-5 null                     |
|                 | call       | select                |                                   |
|                 | ld         | hl,buff               |                                   |
|                 | call       | send6                 |                                   |
|                 | call       | scsiwr                |                                   |
|                 | call       | status                |                                   |
|                 | call       | message               |                                   |
|                 | jp         | prog                  |                                   |

; Byte-0 followed by null, page code, null, allocation length, null ; used by cmd01a

| msen5 | call<br>push<br>ld<br>call | zero<br>hl<br>hl,msgpcod<br>gethex2 | ; byte-1<br>; save pointer<br>; page code requested |
|-------|----------------------------|-------------------------------------|-----------------------------------------------------|
|       | pop                        | ĥl                                  | ; restore pointer                                   |
|       | ld<br>inc                  | (hl),a<br>hl                        | ; byte-2 is page code                               |
|       | call                       | zero                                | ; byte-3 is null                                    |
|       | push                       | hl                                  | ; save pointer                                      |
|       | ld<br>call                 | hl,msgalen<br>gethex2               | ; allocation length requested                       |
|       | pop                        | ĥl                                  | ; restore pointer                                   |
|       | Îd Î                       | (hl),a                              | ; byte-4 is allocation length                       |
|       | inc                        | hl                                  |                                                     |
|       | ld                         | (hl),null                           | ; byte-5 null                                       |
|       | call                       | select                              |                                                     |
|       | ld                         | hl,buff                             |                                                     |

- A6 -

| call | send6   |
|------|---------|
| call | scsird  |
| call | status  |
| call | message |
| jp   | prog    |

; Byte-1 followed by 04h followed by 4 null bytes ; cmd01d

| diag5  | ld<br>inc          | (hl),04h<br>hl            | ; byte-1                    |
|--------|--------------------|---------------------------|-----------------------------|
|        | ld                 | b,4                       |                             |
| diag5a | call<br>djnz<br>jp | zero<br>diag5a<br>cl0send | ; byte-2 to byte-5 are null |

## ; Class-1 commands

| class1 | ld<br>add<br>ld<br>ld<br>inc | a,e<br>20h<br>hl,buff<br>(hl),a<br>hl | ; add class-1 for byte-0<br>; hl -> command buffer<br>; byte-0 |
|--------|------------------------------|---------------------------------------|----------------------------------------------------------------|
|        | call                         | zero                                  | ; byte-1                                                       |
|        | cp                           | 25h                                   | ; read capacity                                                |
|        | jp                           | z,capy9                               |                                                                |
|        | cp                           | 28h                                   | ; read extended                                                |
|        | jp                           | z,rdex9                               |                                                                |
|        | cp                           | 2ah                                   | ; write extended                                               |
|        | jp                           | z,wrex9                               |                                                                |
|        | cp                           | 2fh                                   | ; verify                                                       |
|        | jp                           | z,verf9                               |                                                                |
|        | cp                           | 37h                                   | ; read defect data                                             |
|        | jp                           | z,deft9                               | 1 1 . 1 . 00                                                   |
|        | cp                           | 3ch                                   | ; read data buffer                                             |
|        | jp                           | z,rddb9                               | · 1 · 1 · CC                                                   |
|        | cp                           | 3bh                                   | ; write data buffer                                            |
|        | cp<br>jp<br>jp               | z,wrdb9                               |                                                                |
|        | JP                           | prog                                  |                                                                |

; Byte-0 and byte-1 followed by 4 byte logical block address, 2 null bytes
; PMI byte and null byte
; used by cmd105

| capy9 | push<br>ld<br>call | hl<br>hl,msglba1<br>gethex2 | ; save pointer            |
|-------|--------------------|-----------------------------|---------------------------|
|       | pop                | hl                          | ; restore pointer         |
|       | ld<br>inc          | (hl),a<br>hl                | ; byte-2 is LBA high byte |
|       | push               | hl                          | ; save pointer            |
|       | Îd                 | hl,msglba2                  |                           |
|       | call               | gethex2                     |                           |
|       | pop                | hl                          | ; restore pointer         |
|       | Îd 🗌               | (hl),a                      | ; byte-3 is LBA byte 2    |
|       | inc                | hl                          |                           |
|       | push               | hl                          | ; save pointer            |
|       | Îd                 | hl,msglba3                  |                           |
|       | call               | gethex2                     |                           |
|       | pop                | hl                          | ; restore pointer         |
|       | ĺď                 | (hl),a                      | ; byte-4 is LBA byte 3    |
|       |                    |                             |                           |

| inc<br>push | hl<br>hl   | ; save pointer           |
|-------------|------------|--------------------------|
| Îd          | hl,msglba4 | , sure pointer           |
| call        | gethex2    | ar                       |
| pop         | hl         | ; restore pointer        |
| ld          | (hl),a     | ; byte-5 is LBA low byte |
| inc         | hl         |                          |
| call        | zero       | ; byte-6 null            |
| call        | zero       | ; byte-7 null            |
| push        | hl         | ; save pointer           |
| ld          | hl,msgpmi  |                          |
| call        | gethex2    |                          |
| pop         | hl         | ; restore pointer        |
| ld          | (hl),a     | ; byte-8 is PMI          |
| inc         | hl         |                          |
| ld          | (hl),null  | ; byte-9                 |
| call        | select     |                          |
| ld          | hl,buff    |                          |
| call        | send10     |                          |
| call        | scsird     |                          |
| call        | status     |                          |
| call        | message    |                          |
| jp          | prog       |                          |
|             |            |                          |

; Byte-0 and byte-1 followed by 2 nulls,3 byte logical block address,
; 1 null, 2 byte block count and null byte
; used by cmd108, cmd10a and cmd10f

# rdex9 wrex9 verf9

| call | zero       | ; byte-2                             |
|------|------------|--------------------------------------|
| push | hl         | ; save pointer                       |
| Îd   | hl,msglba1 |                                      |
| call | gethex2    |                                      |
| pop  | hl         | ; restore pointer                    |
| ld   | (hl),a     | ; byte-3 is LBA high byte            |
| inc  | hl         | , 0, 10 0 10 2011 mgn 0, 10          |
| push |            | ; save pointer                       |
| ld   | hl,msglba2 | , suve pointer                       |
| call | gethex2    |                                      |
|      | hl         | : restore pointer                    |
| pop  |            | ; restore pointer                    |
| ld   | (hl),a     | ; byte-4 is LBA byte 2               |
| inc  | hl         |                                      |
| push |            | ; save pointer                       |
| ld   | hl,msglba3 |                                      |
| call | gethex2    | 51                                   |
| pop  | hl         | ; restore pointer                    |
| ld   | (hl),a     | ; byte-5 is LBA low byte             |
| inc  | hl         |                                      |
| call | zero       | ; byte-6 null                        |
| push | hl         | ; save pointer                       |
| ld   | hl,msgbcnt |                                      |
| call | gethex2    |                                      |
| pop  | hl         | ; restore pointer                    |
| Îd Î | (hl),a     | ; byte-7 is block count MSB          |
| inc  | hl         |                                      |
| push | hl         | ; save pointer                       |
| ĺd   | hl,msgbct2 | ,                                    |
| call | gethex2    |                                      |
| pop  | hl         | ; restore pointer                    |
| ld   | (hl),a     | ; byte-8 is block count LSB          |
| inc  | hl         | , of the one of the of the count Lob |
| me   |            |                                      |

|        | ld       | (hl),null | ; byte-9 |
|--------|----------|-----------|----------|
|        | call     | select    |          |
|        | ld       | hl,buff   |          |
|        | call     | send10    |          |
|        | call     | scsird    |          |
|        | ld       | hl,buff   |          |
|        | ld       | a,2ah     |          |
|        | ср       | (hl)      |          |
|        | cp<br>jr | nz,rdex9a |          |
|        | call     | scsiwb    |          |
| rdex9a | call     | status    |          |
|        | call     | message   |          |
|        | jp       | prog      |          |

; Byte-0 and byte-1 followed by P/G/CODE byte, 4 nulls,
; 2 byte allocation length and null byte
; used by cmd117

| deft9  | push<br>ld<br>call                                                                                                           | hl<br>hl,msgdeft                                                                                                                                                      | ; save pointer                                                                                                                                 |
|--------|------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------|
|        | pop<br>ld<br>inc<br>ld                                                                                                       | gethex2<br>hl<br>(hl),a<br>hl<br>b,4                                                                                                                                  | ; restore pointer<br>; byte-2 is P/G/Code                                                                                                      |
| deft9a | call<br>djnz                                                                                                                 | zero<br>deft9a                                                                                                                                                        | ; bytes 3 to 6 are null                                                                                                                        |
|        | push<br>ld                                                                                                                   | hl<br>hl,msgalen                                                                                                                                                      | ; save pointer                                                                                                                                 |
|        | call<br>pop<br>ld<br>inc<br>push<br>ld<br>call<br>pop<br>ld<br>inc<br>ld<br>call<br>ld<br>call<br>call<br>call<br>call<br>jp | gethex2<br>hl<br>(hl),a<br>hl<br>hl<br>hl,msgaln2<br>gethex2<br>hl<br>(hl),a<br>hl<br>(hl),null<br>select<br>hl,buff<br>send10<br>scsird<br>status<br>message<br>prog | ; restore pointer<br>; byte-7 is MSB allocation length<br>; save pointer<br>; restore pointer<br>; byte-8 is LSB allocation length<br>; byte-9 |

; Byte-0 and byte-1 followed by 6 nulls,
; 2 byte allocation length and null byte
; used by cmd117 and cmd11c

| rddb9  |                    |                             |                                   |
|--------|--------------------|-----------------------------|-----------------------------------|
| wrdb9  | ld                 | b,6                         |                                   |
| rddb9a | call<br>djnz       | zero<br>rddb9a              | ; bytes 3 to 6 are null           |
|        | push<br>ld<br>call | hl<br>hl,msgalen<br>gethex2 | ; save pointer                    |
|        | pop                | ĥl                          | ; restore pointer                 |
|        | pop<br>ld          | (hl),a                      | ; byte-7 is MSB allocation length |
|        | inc                | hl                          |                                   |

|        | push<br>ld<br>call<br>pop<br>ld<br>inc<br>ld<br>call<br>ld<br>call<br>call<br>ld<br>ld<br>ld<br>ld | hl<br>hl,msgaln2<br>gethex2<br>hl<br>(hl),a<br>hl<br>(hl),null<br>select<br>hl,buff<br>send10<br>scsird<br>hl,buff<br>a,3bh |
|--------|----------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------|
| rddb9b | ld<br>cp<br>jr<br>call<br>call<br>call<br>jp                                                       | a,3bh<br>(hl)<br>nz,rddb9b<br>scsiwb<br>status<br>message<br>prog                                                           |

; save pointer

; restore pointer ; byte-8 is LSB allocation length

; byte-9

# ; Class-7 commands

class7

| ld             | a,e      |                             |
|----------------|----------|-----------------------------|
| add            | 0e0h     | ; add class-7 for byte-0    |
| ld             | hl,buff  | ; hl -> command buffer      |
| ld             | (hl),a   | ; byte-0 to command buffer  |
| inc            | hl       |                             |
| ср             | 0e0h     | ; maintenance seek          |
| ср<br>jp       | z,mseek5 |                             |
| ср             | 0e1h     | ; format maintenance tracks |
| ср<br>jp       | z,mform5 |                             |
|                | 0e2h     | ; certify                   |
| cp<br>jp       | z,cert5  |                             |
| cp             | 0e8h     | ; fast read                 |
| jp             | z,frd5   |                             |
| cp             | Oeah     | ; fast write                |
| jp             | z,fwr5   |                             |
| cp<br>jp<br>jp | prog     |                             |
|                |          |                             |

; Byte-0 followed by 1 null, 2 byte cylinder number, 1 byte head number
; and null byte
; used by cmd700

| mseek5 | call<br>push<br>ld<br>call | zero<br>hl<br>hl,msgcylh<br>gethex2   | ; byte-1<br>; save pointer            |
|--------|----------------------------|---------------------------------------|---------------------------------------|
|        | pop                        | hl                                    | ; restore pointer                     |
|        | ld<br>inc                  | (hl),a<br>hl                          | ; byte-2 is cylinder number high byte |
|        | push<br>ld                 | hl<br>hl,msgcyll                      | ; save pointer                        |
|        | call                       | gethex2                               |                                       |
|        | pop                        | ĥl                                    | ; restore pointer                     |
|        | ld                         | (hl),a                                | ; byte-3 is cylinder number low byte  |
|        | inc                        | hl                                    |                                       |
|        | push                       | hl                                    | ; save pointer                        |
|        |                            |                                       |                                       |
|        |                            |                                       | restore pointer                       |
|        | ld                         | (hl),a                                | ; byte-4 is head number               |
|        | Îd<br>call<br>pop          | hl,msghead<br>gethex2<br>hl<br>(hl),a | ; restore pointer                     |

| inc | hl        |
|-----|-----------|
| ld  | (hl),null |
| jr  | cl7send   |

; byte-5 null

; Set pattern of bytes ; used by cmd701

| mform5 | ld<br>inc       | (hl),00000000b<br>hl            | ; byte-1      |
|--------|-----------------|---------------------------------|---------------|
|        | ld<br>inc       | (hl),01010010b<br>hl            | ; byte-2      |
|        | ld              | (hl),01001111b<br>hl            | ; byte-3      |
|        | inc<br>ld       | (hl),0000000b                   | ; byte-4      |
|        | inc<br>ld<br>jr | hl<br>(hl),00000000b<br>cl7send | ; byte-5 null |

; Byte-0 followed by 2 null bytes, pass count, 2 null bytes ; used by cmd702

cert5

| call      | zero       | ; byte-1                      |
|-----------|------------|-------------------------------|
| call      | zero       | ; byte-2 is null              |
| push      | hl         | ; save pointer                |
| Îd        | hl,msgpcnt | ; allocation length requested |
| call      | gethex2    |                               |
| pop       | hl         | ; restore pointer             |
| pop<br>ld | (hl),a     | ; byte-3 is pass count        |
| inc       | hl         |                               |
| call      | zero       | ; byte-4 null                 |
| ld        | (hl),null  | ; byte-5 null                 |
| jr        | cl7send    |                               |

; Byte-0 followed by 3 null bytes, block count, 1 null byte ; used by cmd708 and cmd70a

#### frd5

| fwr5  | ld           | b,3                |                         |
|-------|--------------|--------------------|-------------------------|
| fwr5a | call<br>djnz | zero<br>fwr5a      | ; bytes 1 to 3 are null |
|       | call<br>jr   | setup5a<br>cl7send |                         |

; Class-7 send control bytes

cl0send cl7send

| nd | call | select  |
|----|------|---------|
|    | ld   | hl,buff |
|    | call | send6   |
|    | call | status  |
|    | call | message |
|    | jp   | prog    |
|    | end  | start   |

; end of file

## A.2 EQU.Z80

; Development program SCSI device tester

; General equates

| ; VDU equates  |            |               |  |
|----------------|------------|---------------|--|
|                | equ        | 00h           |  |
| vdubaud        | equ        | 00h           |  |
| vdudata        | equ        | 01h           |  |
| vducmd         | equ        | 02h           |  |
| rda            | equ        | 6             |  |
| tbe            | equ        | 7             |  |
| ; ASCII ec     | mates      |               |  |
| null           | equ        | 00h           |  |
| cr             | equ        | Odh           |  |
| lf             | equ        | Oah           |  |
|                |            |               |  |
| ; SCSI equ     |            | 20h           |  |
| datap<br>contp | equ<br>equ | 2011<br>21h   |  |
| statp          | equ        | 21h<br>21h    |  |
| statp          | cqu        | 2111          |  |
| ; Status bit   | t positio  | ons           |  |
| bsy            | equ        | 0             |  |
| msg            | equ        | 1             |  |
| cd             | equ        | 2             |  |
| req            | equ        | 2<br>3<br>4   |  |
| io             | equ        | 4             |  |
| ; Control v    | alues      |               |  |
| ack            | equ        | 1             |  |
| rst            | equ        | 2             |  |
| sel            | equ        | 4             |  |
| : Storage a    | llocatio   | on in SCC RAM |  |
| ; 2000h to     | 23ffh      |               |  |
| stack          | equ        | 2100h         |  |
| inhexs         | equ        | 2200h         |  |
| buff           | equ        | 2220h         |  |
| L CC1          | 1.5        | 22401         |  |

equ

2240h

; VDU status register ; VDU baud rate register ; VDU data register ; VDU command register ; RDA bit

; TBE bit

; end of file

buff1

; reserved for stack ; ASCII bytes and trap for last byte ; working buffer

; working buffer

# A.3 MSG.Z80

; Development program SCSI device tester

| banner1 | db | cr,lf,lf,'SCSI Tester V 00.02 June 1986',cr,lf |
|---------|----|------------------------------------------------|
|         | db | 'Class: ',null                                 |
| crlf    | db | cr,lf,null                                     |
| msgalen | db | cr, lf, 'Allocate length 1: ', null            |
| msgaln2 | db | cr,lf,'Allocate length 2: ',null               |
| msgbcnt | db | cr,lf,'Block Count 1: ',null                   |
| msgbct2 | db | cr,lf,'Block Count 2: ',null                   |
| msgcmd  | db | cr,lf,'Command: ',null                         |
| msgcylh | db | cr,lf,'Cylinder 1: ',null                      |
| msgcyll | db | cr,lf,'Cylinder 2: ',null                      |
| msgdeft | db | cr,lf,'P/G/Code: ',null                        |
| msgfmc  | db | cr,lf,'Format Control: ',null                  |
| msgfmi  | db | cr,lf,'Interleave: ',null                      |
| msghead | db | cr,lf,'Head: ',null                            |
| msghexe | db | cr,lf,'? HEX ?',cr,lf,lf,null                  |
| msglba1 | db | cr,lf,'LBA 1: ',null                           |
| msglba2 | db | cr,lf,'LBA 2: ',null                           |
| msglba3 | db | cr,lf,'LBA 3: ',null                           |
| msglba4 | db | cr,lf,'LBA 4: ',null                           |
| msgmsg  | db | ' Message: ',null                              |
| msgnot  | db | cr,lf,'????',null                              |
| msgpcnt | db | cr,lf,'Pass Count: ',null                      |
| msgpcod | db | cr, lf, 'Page Code: ', null                    |
| msgpmi  | db | cr,lf,'PMI: ',null                             |
| msgplst | db | cr, lf, 'Parameter List Length: ', null        |
| msgsens | db | cr,lf,'Report:',cr,lf,null                     |
| msgspac | db | '',null                                        |
| msgstat | db | cr,lf,'Status: ',null                          |
| msgtckh | db | cr,lf,'Address 1: ',null                       |
| msgtckm | db | cr,lf,'Address 2: ',null                       |
| msgtckl | db | cr,lf,'Address 3: ',null                       |
| msgwcl  | db | cr,lf,'INVALID',null                           |
| 9.2781  |    |                                                |

; end of file

; wait for a digit available

### A.4 VDU.Z80

; Development program SCSI device tester

; VDU I/0 routines

; Output a null terminated string

; hl -> string

; preserves all registers

| outst  | push     | af        | ; save registers                                |
|--------|----------|-----------|-------------------------------------------------|
|        | push     | hl        | hander and a second second to the second second |
| outst1 | call     | tbemp     |                                                 |
|        | ld       | a,(hl)    | ; get the byte                                  |
|        | ср       | null      |                                                 |
|        | cp<br>jr | z,outst2  | ; a null, so all done                           |
|        | out      | vdudata,a |                                                 |
|        | inc      | hl        | ; point to next byte                            |
|        | jr       | outst1    |                                                 |
| outst2 | pop      | hl        | ; restore registers                             |
|        | pop      | af        |                                                 |
|        | ret      |           |                                                 |
|        |          |           |                                                 |

; Wait for transmitter bufer to empty

; preserves all registers

| tbemp  | push             | af                 |                |
|--------|------------------|--------------------|----------------|
| tbemp1 | in<br>bit        | a,vdustat<br>tbe,a | ; wait for TBE |
|        | jr<br>pop<br>ret | z,tbemp1<br>af     |                |
|        |                  |                    |                |

## ; Wait for read data available and read byte into a

; preserves all registers except af

gbyte

in a,vdustat bit rda,a jr z,gbyte in a,vdudata ret

; Output a null terminated byte to VDU followed by a space

; (a) = byte

; preserves all registers

| byteout | push<br>and<br>rrca<br>rrca<br>rrca                                         | af<br>OfOh                                                                       | ; output hex byte to VDU  |
|---------|-----------------------------------------------------------------------------|----------------------------------------------------------------------------------|---------------------------|
| byteou1 | rrca<br>cp<br>jr<br>add<br>add<br>call<br>out<br>call<br>pop<br>push<br>and | Oah<br>c,byteou1<br>a,7<br>3Oh<br>tbemp<br>vdudata,a<br>tbemp<br>af<br>af<br>Ofh | ; test for hex adjustment |

|         | cp<br>jr<br>add | 0ah<br>c,byteou2<br>a,7 | ; test for hex adjustment |
|---------|-----------------|-------------------------|---------------------------|
| byteou2 | add             | 30h                     |                           |
| 0910002 | out             | vdudata,a               |                           |
|         | call            | tbemp                   |                           |
|         | ld              | a,''                    | ; output a space          |
|         | out             | vdudata,a               |                           |
|         | pop             | af                      |                           |
|         | ret             |                         |                           |

; Convert one/two hex values (high/low) to binary
; high hex is stored in inhexs
; (a) = binary byte
; preserves all registers except af

| binary push hl                |                   |
|-------------------------------|-------------------|
| ld $hl,inhexs + 1$            |                   |
| ld a,(hl) ; if null only      | y one byte input  |
| cp null                       |                   |
| cp null<br>jp nz,binary1      |                   |
| dec hl                        |                   |
| ld a,(hl) ; get byte          |                   |
| and Ofh                       |                   |
| ld e,a ; save hex va          | alue in e         |
| jr binary2                    |                   |
| binary1 dec hl ; form both r  | nibbles           |
| rld                           |                   |
| ld a,(hl)                     |                   |
| ld e,a ; save hex va          | alue in e         |
| binary2 ld a,e ; get byte and | nd return it in a |
| pop hl                        |                   |
| ret                           |                   |

; Input a hex string of numbers up to inhexm long terminated with cr
; input is stored in inhexs
; on input b = maximum number of hex digits required
; preserves all registers

| inhexm<br>inhex | equ<br>push<br>push<br>push<br>ld<br>cp<br>jr<br>ld | 0ah<br>af<br>bc<br>hl<br>a,inhexm -2<br>b<br>c,inhexe<br>hl,inhexs | ; save registers        |
|-----------------|-----------------------------------------------------|--------------------------------------------------------------------|-------------------------|
|                 | ld                                                  | b,inhexm                                                           | ; load count            |
| inhex0          | ld                                                  | (hl),null                                                          | ; nulls to storage area |
|                 | inc<br>djnz                                         | hl<br>inhex0                                                       |                         |
|                 | ld                                                  | hl,inhexs                                                          | ; get back pointer      |
|                 | ld                                                  | b,inhexm                                                           | ; load count            |
| inhex1          | call                                                | gbyte                                                              | ; get a byte from VDU   |
|                 | and                                                 | 7fh                                                                | ; strip parity bit      |
|                 | cp<br>jr                                            | cr                                                                 | ; is number finished    |
|                 | jr                                                  | z,inhex2                                                           |                         |
|                 | ld                                                  | (hl),a                                                             |                         |
|                 | call                                                | outst                                                              | ; echo to VDU           |
|                 | cp                                                  | '0'                                                                |                         |
|                 | jr<br>cp                                            | c,inhexe<br>'9'+1                                                  | ; abandon if not hex    |
|                 | Cp                                                  | 7 71                                                               |                         |

| inhex4      | jr<br>cp<br>jr<br>sub<br>cp<br>jr<br>cp              | c,inhex3<br>'a'<br>c,inhex4<br>a,20h<br>'A'<br>c,inhexe<br>'F'+1 | ; abandon if not hex                                                          |
|-------------|------------------------------------------------------|------------------------------------------------------------------|-------------------------------------------------------------------------------|
| inhex3      | jr<br>sub<br>ld<br>inc                               | nc,inhexe<br>a,7<br>(hl),a<br>hl                                 | ; abandon if not hex<br>; adjust byte<br>; store digit<br>; increment pointer |
| inhex2      | djnz<br>jr<br>ld<br>sub                              | inhex1<br>inhexe<br>a,inhexm<br>b                                | ; number too long                                                             |
|             | ld<br>cp<br>jr<br>pop                                | b,a<br>null<br>z,inhexe<br>hl                                    | ; b = no of hex digits<br>; abandon as no input                               |
| inhexe      | pop<br>pop<br>ret<br>ld<br>call                      | bc<br>af<br>hl,msghexe<br>outst                                  | ; point to error message                                                      |
| ; Baud rate | jp<br>selecti                                        | prog<br>on routine                                               |                                                                               |
| baudrs      | db<br>db<br>db<br>db<br>db<br>db<br>db<br>db         | 10010000b<br>11000000b<br>10100000b<br>10010000b<br>10001000     | ; 9600<br>; 4800<br>; 2400<br>; 1200<br>; 300<br>; 150<br>; 110               |
| getbaud     | ld<br>ld<br>ld                                       | hl,baudrs<br>c,vdubaud<br>a,11h                                  | ; hl -> baud rate table<br>; c = baud port<br>; reset bit and high baud       |
| baud1       | outi<br>call<br>call<br>and<br>cp<br>ld<br>jr<br>ret | vducmd,a<br>gbyte<br>gbyte<br>7fh<br>0dh<br>a,1<br>nz,baud1      | ; reset<br>; recognise a cr?<br>; reset bit only                              |

; end of file

## A.5 SCSI.Z80

; Development program SCSI device tester

; SCSI Subroutines

; Read status byte from drive and output to VDU ; preserves all registers

| status   | push<br>push                         | af<br>hl                                            |                           |
|----------|--------------------------------------|-----------------------------------------------------|---------------------------|
| status0  | in                                   | a,statp<br>Ofdh                                     | ; test for status byte    |
|          | cp<br>jr<br>ld<br>call               | nz,status0<br>hl,msgstat<br>outst                   | ; hl -> banner            |
|          | in                                   | a,datap                                             | ; read drive status byte  |
|          | call<br>ld                           | byteout<br>a,ack                                    | ; acknowledge drive       |
| status 1 | out<br>in<br>bit                     | contp,a<br>a,statp                                  | ; wait for request false  |
|          | jr<br>ld<br>out<br>pop<br>pop<br>ret | req,a<br>nz,status1<br>a,00h<br>contp,a<br>hl<br>af | ; reset acknowledge false |

# ; Read message byte from drive and output to VDU ; preserves all registers

| message | push<br>push           | af<br>hl                         |                          |
|---------|------------------------|----------------------------------|--------------------------|
| messag0 | în                     | a,statp<br>Offh                  | ; test for status byte   |
|         | cp<br>jr<br>ld<br>call | nz,messag0<br>hl,msgmsg<br>outst | ; hl -> banner           |
|         | in<br>call             | a,datap<br>byteout               | ; read drive status byte |
|         | ld<br>out              | a,ack<br>contp,a                 | ; acknowledge drive      |
| messag1 | in<br>bit              | a,statp<br>req,a<br>nz,messag1   | ; wait for request false |
|         | jr<br>ld<br>out        | a,00h<br>contp,a                 | ; put acknowledge false  |
|         | pop<br>pop<br>ret      | hl<br>af                         |                          |

# ; Read data bytes from drive and output to VDU ; preserves all registers

| scsird  | push | af         |                       |
|---------|------|------------|-----------------------|
| scsird0 | in   | a,statp    | ; test for request    |
|         | bit  | req,a      |                       |
|         | jr   | z,scsird0  |                       |
|         | cp   | 0f9h       | ; is it read in data? |
|         | jr   | nz,scsird2 | ; return as all done  |
|         | in   | a,datap    | ; read data byte      |

| scsird1<br>scsird2 | call<br>ld<br>out<br>in<br>bit<br>jr<br>ld<br>out<br>jr<br>pop<br>ret | byteout<br>a,ack<br>contp,a<br>a,statp<br>req,a<br>nz,scsird1<br>a,00h<br>contp,a<br>scsird0<br>af | ; acknowledge drive<br>; wait for request false<br>; put acknowledge false<br>; look for next data in byte |
|--------------------|-----------------------------------------------------------------------|----------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------|
|                    |                                                                       | to drive from VDU                                                                                  |                                                                                                            |
| ; preserves        | s an reg                                                              | ISIEIS                                                                                             |                                                                                                            |
| scsiwrb            | db                                                                    | cr,lf,'B: ',null                                                                                   |                                                                                                            |
| scsiwr             | push                                                                  | af                                                                                                 |                                                                                                            |
|                    | push                                                                  | hl                                                                                                 |                                                                                                            |
| scsiwr0            | īn                                                                    | a,statp                                                                                            | ; test for request                                                                                         |
|                    | bit                                                                   | req,a                                                                                              |                                                                                                            |
|                    | jr                                                                    | z,scsiwr0                                                                                          |                                                                                                            |
|                    | cp                                                                    | 0e9h                                                                                               | ; is it requesting data?                                                                                   |
|                    | Jr                                                                    | nz,scsiwr2                                                                                         | ; return as all done                                                                                       |
|                    | ld                                                                    | hl,scsiwrb                                                                                         |                                                                                                            |
|                    | call                                                                  | outst                                                                                              |                                                                                                            |
|                    | ld                                                                    | hl,inhexs                                                                                          |                                                                                                            |
|                    | call<br>call                                                          | inhex                                                                                              |                                                                                                            |
|                    |                                                                       | binary<br>datap                                                                                    | ; write data byte                                                                                          |
| 6                  | out<br>ld                                                             | datap,a<br>a,ack                                                                                   | ; acknowledge drive                                                                                        |
|                    | out                                                                   |                                                                                                    | , acknowledge unve                                                                                         |
| scsiwr1            | in                                                                    | contp,a<br>a,statp                                                                                 | ; wait for request false                                                                                   |
| SCSIWII            | bit                                                                   | req,a                                                                                              | , wait for request faise                                                                                   |
|                    | jr                                                                    | nz,scsiwr1                                                                                         |                                                                                                            |
|                    | ld                                                                    | a,00h                                                                                              | ; put acknowledge false                                                                                    |
|                    | out                                                                   | contp,a                                                                                            | , put ucknow reage raise                                                                                   |
|                    | jr                                                                    | scsiwr0                                                                                            | ; look for next data in byte                                                                               |
| scsiwr2            | pop                                                                   | hl                                                                                                 | ,                                                                                                          |
| 0001112            | pop                                                                   | af                                                                                                 |                                                                                                            |
|                    | ret                                                                   |                                                                                                    |                                                                                                            |
|                    | 0.000                                                                 |                                                                                                    |                                                                                                            |

; Write block of bytes to drive from VDU ; preserves all registers

| scsiwb  | push<br>push<br>ld<br>call<br>ld  | af<br>hl<br>hl,scsiwrb<br>outst<br>hl,inhexs –             | ; ask for byte                                                                                                      |
|---------|-----------------------------------|------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------|
| scsiwb0 | call<br>call<br>ld<br>in<br>bit   | inhex<br>binary<br>h,a<br>a,statp<br>req,a                 | ; save the byte<br>; test for request                                                                               |
|         | jr<br>cp<br>jr<br>ld<br>out<br>ld | z,scsiwb0<br>0e9h<br>nz,scsiwb2<br>a,h<br>datap,a<br>a,ack | ; is it requesting data?<br>; return as all done<br>; get the byte back<br>; write data byte<br>; acknowledge drive |
| scsiwb1 | out<br>in                         | contp,a<br>a,statp                                         | ; wait for request false                                                                                            |

| scsiwb2                    | bit<br>jr<br>ld<br>out<br>jr<br>pop<br>pop<br>ret | req,a<br>nz,scsiwb1<br>a,00h<br>contp,a<br>scsiwb0<br>h1<br>af | ; put acknowledge false<br>; look for next data in byte       |
|----------------------------|---------------------------------------------------|----------------------------------------------------------------|---------------------------------------------------------------|
| ; Select dr<br>; preserves |                                                   | isters                                                         |                                                               |
| select                     | push<br>ld<br>out<br>ld<br>out                    | af<br>a,00000001b<br>datap,a<br>a,sel<br>contp,a               | ; select drive                                                |
| select1                    | in<br>bit<br>jr<br>ld                             | a,statp<br>bsy,a<br>z,select1<br>a,00h                         | ; wait for bsy true                                           |
|                            | out<br>pop<br>ret                                 | contp,a<br>af                                                  | ; reset select false                                          |
|                            | fer cont                                          | ontrol bytes to drive<br>aining the six bytes<br>isters        |                                                               |
| send6                      | push<br>push<br>push<br>ld<br>ld                  | af<br>bc<br>hl<br>c,datap<br>b,6                               |                                                               |
| send10                     | jr<br>push<br>push<br>push<br>Id<br>Id            | send6a<br>af<br>bc<br>hl<br>c,datap<br>b,10                    |                                                               |
| send6a                     | in<br>cp<br>jr<br>outi<br>ld                      | a,statp<br>Oedh<br>nz,send6a<br>a,ack                          | ; wait for request<br>; send byte<br>; acknowledge byte ready |
| send6b                     | out<br>in<br>cp                                   | contp,a<br>a,statp<br>0e5h                                     | ; wait for drive to read byte                                 |
|                            | jr<br>ld<br>out<br>cp<br>jr<br>ld                 | nz,send6b<br>a,0<br>contp,a<br>b<br>nz,send6a<br>hl,crlf       | ; set acknowledge false                                       |
|                            | call<br>pop<br>pop<br>pop<br>ret                  | outst<br>hl<br>bc<br>af                                        | ; cr/lf to tidy display                                       |

; end of file

ų,

## INTELLIGENT INTERFACE BOARD SOFTWARE

B.1 NCR.Z80

; Development program SCSI device tester

#### ; \*\*\*\*\*\*\*\*Equates\*\*\*\*\*\*\*

; VDU equates

| vdustat | equ | 00h | ; VDU status register    |
|---------|-----|-----|--------------------------|
| vdubaud | equ | 00h | ; VDU baud rate register |
| vdudata | equ | 01h | ; VDU data register      |
| vducmd  | equ | 02h | ; VDU command register   |
| rda     | equ | 6   | ; RDA bit                |
| tbe     | equ | 7   | ; TBE bit                |

#### ; ASCII equates

| null | equ | 00h |
|------|-----|-----|
| cr   | equ | Odh |
| lf   | equ | 0ah |

#### ; NCR53C80 SCSI equates

| base   | equ | 20h        | ; Base port                    |
|--------|-----|------------|--------------------------------|
| datap  | equ | base $+ 0$ | ; data port                    |
| icmdp  | equ | base $+ 1$ | ; initiator command port       |
| modep  | equ | base $+2$  | ; mode port                    |
| tcmdp  | equ | base $+3$  | ; target command port          |
| stat1p | equ | base $+ 4$ | ; bus status port              |
| prstp  | equ | base $+7$  | ; reset parity/interrupts port |

; Initiator Command Register commands - icmdp

| rst   | equ | 1000000b  | ; reset SCSI bus               |
|-------|-----|-----------|--------------------------------|
| sel   | equ | 00000101b | ; select device                |
| ack   | equ | 00010001b | ; acknowledge device from host |
| ackin | equ | 00010000b | ; acknowledge device to host   |

### ; Storage allocation in SCC RAM ; 2000h to 23ffh

| stack   | equ | 2100h | ; reserved for stack                          |
|---------|-----|-------|-----------------------------------------------|
| inhexs  | equ | 2200h | ; ASCII bytes and trap for last byte          |
| buff    | equ | 2220h | ; working buffer                              |
| buff1   | equ | 2240h | ; working buffer                              |
| scsiwrf | equ | 2260h | ; zero for single byte, otherwise block write |

#### ; \*\*\*\*\*\*\* Main Program Start\*\*\*\*\*\*\*

| start | ld       | hl,stack           | ; set up stack pointer register |
|-------|----------|--------------------|---------------------------------|
|       | ld<br>ld | sp,hl<br>hl,baudrs | ; hl -> baud rate table         |
|       | ld       | c,vdubaud          | ; $c = baud port$               |
|       | ld       | a,11h              | ; reset bit and high baud       |
| baud1 | out      | vducmd,a           | ; reset                         |
|       | outi     |                    |                                 |
|       | call     | gbyte              |                                 |
|       | call     | gbyte              |                                 |
|       | and      | 7fh                |                                 |
|       | cp<br>ld | Odh                | ; recognise a cr?               |
|       |          | a,1                | ; reset bit only                |
|       | jr       | nz,baud1           |                                 |

| start1         | ld     | a,rst                                                                                        | ; reset SCSI               |
|----------------|--------|----------------------------------------------------------------------------------------------|----------------------------|
|                | out    | icmdp,a                                                                                      |                            |
|                | ld     | b,null                                                                                       |                            |
| waitrst        | djnz   | waitrst                                                                                      | ; wait a moment            |
|                | ld     | a,null                                                                                       |                            |
|                | out    | icmdp,a                                                                                      | ; finish SCSI reset        |
|                | jp     | prog                                                                                         | ,                          |
|                | JP     | P-08                                                                                         |                            |
| · *******      | Baud r | ate selection routine                                                                        | values******               |
|                |        |                                                                                              |                            |
| baudrs         | db     | 10010000b                                                                                    |                            |
|                | db     | 11000000b                                                                                    | ; 9600                     |
|                | db     | 10100000b                                                                                    | ; 4800                     |
|                | db     | 10010000b                                                                                    | ; 2400                     |
|                | db     | 10001000b                                                                                    | ; 1200                     |
|                | db     | 10000100b                                                                                    | ; 300                      |
|                | db     | 10000010b                                                                                    | ; 150                      |
|                | db     | 00000001b                                                                                    | ; 110                      |
|                |        |                                                                                              |                            |
| · *******<br>· | *Messa | ges to VDU******                                                                             | *                          |
| hommon1        | 46     | an 16 16 'SCOL Tasta                                                                         | - V 01 02 July 1086' or lf |
| banner1        | db     |                                                                                              | r V 01.02 July 1986',cr,lf |
| 10             | db     | 'Class: ',null                                                                               |                            |
| crlf           | db     | cr,lf,null                                                                                   | .1 .1 .7                   |
| msgalen        | db     | cr,lf,'Allocate leng                                                                         | th 1: ',null               |
| msgaln2        | db     | cr,lf,'Allocate leng                                                                         |                            |
| msgbcnt        | db     | cr,lf,'Block Count                                                                           | 1: ',null                  |
| msgbct2        | db     | cr,lf,'Block Count                                                                           |                            |
| msgcmd         | db     | cr,lf,'Command: ',null                                                                       |                            |
| msgcylh        | db     | cr,lf,'Cylinder 1: ',null                                                                    |                            |
| msgcyll        | db     | cr,lf,'Cylinder 2: ',null                                                                    |                            |
| msgdeft        | db     | cr,lf,'P/G/Code: ',null                                                                      |                            |
| msgfmc         | db     | cr,lf,'Format Control: ',null                                                                |                            |
| msgfmi         | db     | cr,lf,'Interleave: ',null                                                                    |                            |
| msghead        | db     | cr,lf,'Head: ',null                                                                          |                            |
| msghexe        | db     | cr lf.'? HEX ?' cr l                                                                         | f,lf,null                  |
| msglba1        | db     | cr.lf,'LBA 1: '.null                                                                         |                            |
| msglba2        | db     | cr.lf,'LBA 2: '.null                                                                         |                            |
| msglba3        | db     | cr,lf,'LBA 1: ',null<br>cr,lf,'LBA 2: ',null<br>cr,lf,'LBA 3: ',null<br>cr,lf,'LBA 4: ',null |                            |
| msglba4        | db     | cr.lf,'LBA 4: '.null                                                                         |                            |
| msgmsg         | db     | ' Message: ',null                                                                            |                            |
| msgnot         | db     | cr,lf,'????',null                                                                            |                            |
| msgpcnt        | db     | cr,lf,'Pass Count: '                                                                         | null                       |
| msgpcod        | db     | cr,lf,'Page Code: ',                                                                         | null                       |
| msgpmi         | db     | cr,lf,'PMI: ',null                                                                           | nun                        |
|                | db     | cr,lf,'Parameter Lis                                                                         | t Length: ' null           |
| msgplst        | db     |                                                                                              | a Longui, inun             |
| msgspac        |        | ' ',null                                                                                     |                            |
| msgstat        | db     | cr, lf, 'Status: ', null                                                                     |                            |
| msgtckh        | db     | or 16' Address 1: ,I                                                                         | 1011                       |
| msgtckm        | db     | cr,lf,'Address 1: ',r<br>cr,lf,'Address 2: ',r<br>cr,lf,'Address 3: ',r                      | 1011                       |
| msgtckl        | db     | cr, II, Address 3: ',I                                                                       | 11                         |
| msgwcl         | db     | cr,lf,'INVALID',ni                                                                           | .111                       |
|                |        |                                                                                              |                            |

; \*\*\*\*\*\*\*VDU I/0 Routines\*\*\*\*\*\*\*
; Output a null terminated string
; hl -> string
; preserves all registers

| push | af                                                               | ; save registers                                                                                                         |
|------|------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------|
| push | hl                                                               |                                                                                                                          |
| call | tbemp                                                            |                                                                                                                          |
| ld   | a,(hl)                                                           | ; get the byte                                                                                                           |
| ср   | null                                                             |                                                                                                                          |
| jr   | z,outst2                                                         | ; a null, so all done                                                                                                    |
| out  | vdudata,a                                                        |                                                                                                                          |
| inc  | hl                                                               | ; point to next byte                                                                                                     |
| jr   | outst1                                                           |                                                                                                                          |
| pop  | hl                                                               | ; restore registers                                                                                                      |
| pop  | af                                                               |                                                                                                                          |
| ret  |                                                                  |                                                                                                                          |
|      | push<br>call<br>ld<br>cp<br>jr<br>out<br>inc<br>jr<br>pop<br>pop | push hl<br>call tbemp<br>ld a,(hl)<br>cp null<br>jr z,outst2<br>out vdudata,a<br>inc hl<br>jr outst1<br>pop hl<br>pop af |

; Wait for transmitter bufer to empty

; preserves all registers

tbemp tbemp1 push af in a,vdustat bit tbe,a jr z,tbemp1 pop af ret

; wait for TBE

; Wait for read data available and read byte into a

a,vdustat

; preserves all registers except af

| g | by | yt | e |
|---|----|----|---|
|   |    |    |   |

; wait for a digit available

bit rda,a jr z,gbyte in a,vdudata ret

; Output a hexadecimal byte to VDU followed by a space

; (a) = binary value of byte

in

; preserves all registers

| byteout | push<br>and<br>rrca | af<br>OfOh       | ; output hex byte to VDU<br>; mask for upper hex value<br>; shift down |
|---------|---------------------|------------------|------------------------------------------------------------------------|
|         | rrca                |                  | , shirt down                                                           |
|         | rrca                |                  |                                                                        |
|         | call                | byteou0          | ; convert and output to VDU                                            |
|         | pop                 | af               | ; get the binary value back                                            |
|         | push                | af               |                                                                        |
|         | and                 | Ofh              | ; mask for lower hex value                                             |
|         | call<br>call        | byteou0<br>tbemp | ; convert and output to VDU                                            |
|         | ld                  | a,' '            | ; output a space                                                       |
|         | out                 | vdudata,a        |                                                                        |
|         | pop                 | af               |                                                                        |
|         | ret                 |                  |                                                                        |
| byteou0 | cp                  | Oah              | ; test for hex adjustment                                              |
|         | cp<br>jr            | c,byteou1        |                                                                        |
|         | add                 | a,7              |                                                                        |
| byteou1 | add                 | 30h              | ; convert to ASCII                                                     |
|         | call                | tbemp            |                                                                        |
|         | out                 | vdudata,a        |                                                                        |
|         | ret                 |                  |                                                                        |

1

; Get a hex byte and convert to binary byte

| gethex2 | call<br>ld<br>call<br>call | outst<br>b,3<br>inhex<br>binary | ; maximum of two bytes |
|---------|----------------------------|---------------------------------|------------------------|
|         | ret                        |                                 |                        |

; Convert one/two hex values (high/low) to binary ; high hex is stored in inhexs

; (a) = binary byte ; preserves all registers except af

| binary  | push<br>ld<br>ld<br>cp<br>jp<br>dec | hl<br>hl,inhexs + 1<br>a,(hl)<br>null<br>nz,binary1<br>hl | ; if null only one byte input         |
|---------|-------------------------------------|-----------------------------------------------------------|---------------------------------------|
|         | ld<br>and<br>pop<br>ret             | a,(hl)<br>Ofh<br>hl                                       | ; get byte                            |
| binary1 | dec<br>rld<br>ld<br>pop<br>ret      | hl<br>a,(hl)<br>hl                                        | ; form both nibbles into binary value |

; Input a hex string of numbers up to inhexm long terminated with cr
; input is stored in inhexs
; on input b = maximum number of hex digits required

; preserves all registers

| inhexm | equ  | Oah          |                                    |
|--------|------|--------------|------------------------------------|
| inhex  | push | af           | ; save registers                   |
|        | push | bc           |                                    |
|        | push | hl           |                                    |
|        | Îd   | a, inhexm -2 |                                    |
|        | cp   | b            |                                    |
|        | jr   | c,inhexe     |                                    |
|        | ld   | hl, inhexs   |                                    |
|        | ld   | b,inhexm     | ; load count                       |
| inhex0 | ld   | (hl),null    | ; nulls to storage area            |
|        | inc  | hl           | WAADERTOOD THE INTERNET D'ARCOUNTS |
|        | djnz | inhex0       |                                    |
|        | ld   | hl,inhexs    | ; get back pointer                 |
|        | ld   | b,inhexm     | ; load count                       |
| inhex1 | call | gbyte        | ; get a byte from VDU              |
|        | and  | 7fh          | ; strip parity bit                 |
|        | cp   | cr           | ; is number finished               |
|        | jr   | z,inhex2     |                                    |
|        | ld   | (hl),a       |                                    |
|        | call | outst        | ; echo to VDU                      |
|        | ср   | '0'          |                                    |
|        | jr   | c,inhexe     | ; abandon if not hex               |
|        | cp   | '9'+1        |                                    |
|        | jr   | c,inhex3     |                                    |
|        | ср   | 'a'          |                                    |
|        | jr   | c,inhex4     |                                    |
|        | sub  | a,20h        |                                    |
| inhex4 | ср   | 'A'          |                                    |

| p 'F'+1<br>nc,inhexuub a,7<br>d (hl),a<br>nc hl<br>jnz inhex1<br>inhexe | e ; abandon if not hex<br>; adjust byte<br>; store digit<br>; increment pointer           |
|-------------------------------------------------------------------------|-------------------------------------------------------------------------------------------|
| ub a,7<br>1 (hl),a<br>nc hl<br>jnz inhex1                               | ; store digit                                                                             |
| l (hl),a<br>nc hl<br>jnz inhex1                                         | ; store digit                                                                             |
| nc hl<br>jnz inhex1                                                     |                                                                                           |
|                                                                         |                                                                                           |
|                                                                         |                                                                                           |
| micac                                                                   | ; number too long                                                                         |
| a,inhexm                                                                |                                                                                           |
| ub b                                                                    |                                                                                           |
| i b,a                                                                   | ; $b = no of hex digits$                                                                  |
| p null                                                                  |                                                                                           |
| z,inhexe                                                                | ; abandon as no input                                                                     |
|                                                                         |                                                                                           |
| · · · · · · · · · · · · · · · · · · ·                                   |                                                                                           |
| -                                                                       |                                                                                           |
| et                                                                      |                                                                                           |
| i hl,msghe                                                              | exe ; point to error message                                                              |
| all outst                                                               |                                                                                           |
| o prog                                                                  |                                                                                           |
|                                                                         | l b,a<br>p null<br>c z,inhexe<br>op hl<br>op bc<br>op af<br>et<br>l hl,msghe<br>all outst |

; \*\*\*\*\*\* Main Program Continues\*\*\*\*\*\*

prog

| ld       | hl,stack      | ; set up stack pointer register |
|----------|---------------|---------------------------------|
| ld       | sp,hl         |                                 |
| ld       | hl,banner1    | ; output Class request to VDU   |
| call     | outst         |                                 |
| ld       | b,2           | ; one byte only                 |
| call     | inhex         |                                 |
| ld       | hl,inhexs + 1 | ; hl -> second byte             |
| ld       | a,(hl)        | ; test only one byte            |
| cp       | null          |                                 |
| jr       | nz,cmderr     |                                 |
| dec      | hl            |                                 |
| ld       | a,(hl)        | ; get the byte                  |
| push     | af            | ; save Class                    |
| ld       | hl,msgcmd     |                                 |
| call     |               | ; ask for command hex bytes     |
| ld       | b,3           | ; possibly two bytes            |
| call     |               | h h S first huts                |
| ld<br>ld | hl,inhexs     | ; hl -> first byte              |
| and      | a,(hl)<br>Ofh | ; get first byte                |
| ld       |               | ; keep it in e                  |
| inc      | e,a<br>hl     | , keep it in e                  |
| ld       | a,(hl)        |                                 |
| ср       | null          |                                 |
| jr       | z,cmdok       | ; only one byte                 |
| and      | Ofh           | , only one ofte                 |
| ld       | d,a           | ; save second byte              |
| ld       | a,e           | ; get back first byte           |
| ср       | 1             | ; check the value is one        |
| jr       | nz,cmderr     |                                 |
| ĺd       | a,10h         |                                 |
| add      | a,d           | ; form command                  |
| ld       | e,a           | ; keep it in e                  |
| inc      | hl            |                                 |
| ld       | a,(hl)        |                                 |
| ср       | null          |                                 |
| jr       | nz,cmderr     | ; only two bytes allowed        |
| pop      | af            | ; restore Class                 |
| cp       | '0'           | ; test valid Class              |
|          |               |                                 |

cmdok

jr z,class0 '1' ср z,class1 '7' jp cp z,class7 jp cmderr ; command error exit ld hl,msgwcl call outst prog jp ; \*\*\*\*\*\*\*Class-0 Commands\*\*\*\*\*\*\* ld a,e ld hl,buff ; hl -> command buffer ld (hl),a ; byte-0 inc hl 00h ; test drive ready ср jp z.null5 01h ; recalibrate cp z,null5 jp 03h ср ; request sense z,sens5 jp cp 04h ; format unit jp z,form5 07h ; reassign blocks cp z,reas5 jp 08h ; read ср z,read5 jp Oah ; write cp z,writ5 jp ; seek 0bh cp z,seek5 jp 12h ; inquiry cp jp z,inqy5 ; mode select cp 15h z,msel5 jp ; mode sense cp 1ah z,msen5 jp 1dh ; send diagnostics ср jp z,diag5 jp prog

; Class-0 and Class-7 send control bytes

#### cl0send

class0

| cl7send | call | select  |
|---------|------|---------|
|         | ld   | hl,buff |
|         | call | send6   |
|         | jp   | phaser  |

; Class-1 send control bytes

cl1send

| call | select  |
|------|---------|
| ld   | hl,buff |
| call | send10  |
| jp   | phaser  |

; Send a null byte into command buffer and increment pointer

| zero | ld  | (hl),null |
|------|-----|-----------|
|      | inc | hl        |
|      | ret |           |

; Byte-1 followed by 5 null bytes ; used by cmd000 and cmd001

| null5  | ld                 | b,5                       |                             |
|--------|--------------------|---------------------------|-----------------------------|
| null5a | call<br>djnz<br>jp | zero<br>null5a<br>cl0send | ; byte-1 to byte-5 are null |

; Byte-1 followed by 3 nulls, allocation length (18), 1 null ; used by cmd003

| sens5  | ld   | b,3       |                             |
|--------|------|-----------|-----------------------------|
| sens5a | call | zero      | ; byte-1 to byte-3 are null |
|        | djnz | sens5a    |                             |
|        | lď   | (hl),12h  | ; allocation length         |
|        | inc  | hl        |                             |
|        | ld   | (hl),null |                             |
|        | jp   | clOsend   |                             |

; Byte-0 followed by format control code, 2 null bytes, interleave, 1 ; null byte used by cmd004

| push<br>ld<br>call<br>pop | hl,msgfmc<br>gethex2                                                      | ; save pointer<br>; format control requested                                                                                                                            |
|---------------------------|---------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                           | gethex2                                                                   |                                                                                                                                                                         |
| non                       |                                                                           |                                                                                                                                                                         |
| pop                       | hl                                                                        | ; restore pointer                                                                                                                                                       |
| ld                        | (hl),a                                                                    | ; byte-1                                                                                                                                                                |
| inc                       | hl                                                                        |                                                                                                                                                                         |
| ld                        | b,2                                                                       |                                                                                                                                                                         |
| call                      | zero                                                                      | ; byte-2 and byte-3 are null                                                                                                                                            |
| djnz                      | form5a                                                                    |                                                                                                                                                                         |
|                           | hl                                                                        | ; save pointer                                                                                                                                                          |
| Îd                        | hl,msgfmi                                                                 | ; format interleave requested                                                                                                                                           |
| call                      |                                                                           | -                                                                                                                                                                       |
| pop                       | hl                                                                        | ; restore pointer                                                                                                                                                       |
| Îd Î                      | (hl),a                                                                    | ; byte-4                                                                                                                                                                |
| inc                       | hl                                                                        |                                                                                                                                                                         |
| ld                        | (hl),null                                                                 | ; byte-5 null                                                                                                                                                           |
| ld                        |                                                                           |                                                                                                                                                                         |
| ld                        |                                                                           | ; single byte write to drive                                                                                                                                            |
|                           | clOsend                                                                   |                                                                                                                                                                         |
|                           | inc<br>ld<br>call<br>djnz<br>push<br>ld<br>call<br>pop<br>ld<br>inc<br>ld | inc hl<br>ld b,2<br>call zero<br>djnz form5a<br>push hl<br>ld hl,msgfmi<br>call gethex2<br>pop hl<br>ld (hl),a<br>inc hl<br>ld (hl),null<br>ld a,null<br>ld (scsiwrf),a |

; Byte-1 followed by 5 null bytes ; used by cmd007

| reas5  | ld   | b,5         |                                                                           |
|--------|------|-------------|---------------------------------------------------------------------------|
| reas5a | call | zero        | ; byte-1 to byte-5 are null                                               |
|        | djnz | reas5a      | N (F)                                                                     |
|        | ld   | a,null      |                                                                           |
|        | ld   | (scsiwrf),a | ; single byte write to drive                                              |
|        | jp   | clOsend     | navna presizer stantin en sekan tel a frema den national Schernich, under |

; Byte-0 followed by track address and one null byte ; used by cmd008

| read5 | call | setup5  |
|-------|------|---------|
|       | jp   | clOsend |

; setup5 - provides byte-1 to byte-5 for read5, writ5 and seek5 ; setup5a byte-4 and byte5 for frd5 and fwr5

| setup5  | push<br>ld<br>call | hl<br>hl,msgtckh<br>gethex2 | ; save pointer<br>; high track address requested |
|---------|--------------------|-----------------------------|--------------------------------------------------|
|         | pop                | hl                          | ; restore pointer                                |
|         | Îd Î               | (hl),a                      | ; byte-1                                         |
|         | inc                | hl                          | 20                                               |
|         | push               |                             | ; save pointer                                   |
|         | ld<br>call         | hl,msgtckm<br>gethex2       | ; middle track address requested                 |
|         | pop                | hl -                        | ; restore pointer                                |
|         | ld                 | (hl),a                      | ; byte-2                                         |
|         | inc                | hl                          |                                                  |
|         | push               | hl                          | ; save pointer                                   |
|         | ld<br>call         | hl,msgtckl<br>gethex2       | ; low track address requested                    |
|         | pop                | hl                          | ; restore pointer                                |
|         | Îd Î               | (hl),a                      | ; byte-3                                         |
|         | inc                | hl                          | a polici car                                     |
| setup5a | push               | hl                          | ; save pointer                                   |
|         | ld<br>call         | hl,msgbcnt<br>gethex2       | ; block count                                    |
|         | pop                | ĥl                          | ; restore pointer                                |
|         | Îd Î               | (hl),a                      | ; byte-4                                         |
|         | inc                | hl                          |                                                  |
|         | ld<br>ret          | (hl),null                   | ; byte-5 null                                    |

; Byte-0 followed by track address and one null byte

; requests write byte value once only

; used by cmd00a

| writ5 | call     | setup5              |                             |
|-------|----------|---------------------|-----------------------------|
|       | ld<br>ld | a,-1<br>(scsiwrf),a | ; multi-byte write to drive |
|       | jp       | clOsend             | •                           |

; Byte-0 followed by track address and one null byte ; used by cmd00b

seek5 call setup5 jp cl0send

; Byte-0 followed by 3 null bytes, allocation length, 1 null byte ; used by cmd012

| inqy5  | ld        | b,3        |                               |
|--------|-----------|------------|-------------------------------|
| inqy5a | call      | zero       | ; bytes 1 to 3 are null       |
|        | djnz      | inqy5a     |                               |
|        | push      | hl         | ; save pointer                |
|        | Īd        | hl,msgalen | ; allocation length requested |
|        | call      | gethex2    |                               |
|        | pop       | hl         | ; restore pointer             |
|        | pop<br>ld | (hl),a     | ; byte-4 is allocation length |
|        | inc       | hl         |                               |
|        | ld        | (hl),null  | ; byte-5 null                 |
|        | jp        | clOsend    |                               |

; Byte-0 followed by 3 null bytes, parameter list length, 1 null byte ; used by cmd015

| msel5  | ld        | b,3         |                                   |
|--------|-----------|-------------|-----------------------------------|
| msel5a | call      | zero        | ; bytes 1 to 3 are null           |
|        | djnz      | msel5a      |                                   |
|        | push      | hl          | ; save pointer                    |
|        | ld        | hl,msgplst  | ; allocation length requested     |
|        | call      | gethex2     |                                   |
|        | pop<br>ld | hl          | ; restore pointer                 |
|        | ld        | (hl),a      | ; byte-4 is parameter list length |
|        | inc       | hl          |                                   |
|        | ld        | (hl),null   | ; byte-5 null                     |
|        | ld        | a,null      |                                   |
|        | ld        | (scsiwrf),a | ; single byte write to drive      |
|        | jp        | cl0send-    |                                   |

; Byte-0 followed by null, page code, null, allocation length, null ; used by cmd01a

| msen5 | call       | zero                  | ; byte-1                              |
|-------|------------|-----------------------|---------------------------------------|
|       | push       | hl                    | ; save pointer                        |
|       | Îd<br>call | hl,msgpcod<br>gethex2 | ; page code requested                 |
|       | pop        | hl                    | ; restore pointer                     |
|       | id '       | (hl),a                | ; byte-2 is page code                 |
|       | inc        | hl                    |                                       |
|       | call       | zero                  | ; byte-3 is null                      |
|       | push       | hl                    | ; save pointer                        |
|       | Îd<br>call | hl,msgalen<br>gethex2 | ; allocation length requested         |
|       | рор        | hl                    | ; restore pointer                     |
|       | ld         | (hl),a                | ; byte-4 is allocation length         |
|       | inc        | hl                    | •                                     |
|       | ld         | (hl),null             | ; byte-5 null                         |
|       | jp         | clOsend               | A MARTINE CONTRACTOR AND A CONTRACTOR |

; Byte-1 followed by 04h followed by 4 null bytes ; cmd01d

| diag5  | ld<br>inc          | (hl),04h<br>hl            | ; byte-1                    |
|--------|--------------------|---------------------------|-----------------------------|
|        | ld                 | b.4                       |                             |
| diag5a | call<br>djnz<br>jp | zero<br>diag5a<br>cl0send | ; byte-2 to byte-5 are null |

; \*\*\*\*\*\*\*Class-1 Commands\*\*\*\*\*\*\*

class1

| ld<br>add<br>ld      | a,e<br>20h<br>hl,buff        | ; add class-1 for byte-0<br>; hl -> command buffer |
|----------------------|------------------------------|----------------------------------------------------|
| ld<br>inc            | (hl),a<br>hl                 | ; byte-0                                           |
| call                 | zero                         | ; byte-1                                           |
| ср                   | 25h                          | ; read capacity                                    |
| cp<br>jp<br>cp<br>jp | z,capy9<br>28h<br>z,rdex9    | ; read extended                                    |
| ср                   | 2, idex y<br>2ah<br>z, wrex9 | ; write extended                                   |
| jp<br>cp             | 2,wicky<br>2fh               | ; verify                                           |

| jp             | z,verf9 |                     |
|----------------|---------|---------------------|
| ср             | 37h     | ; read defect data  |
| jp             | z,deft9 |                     |
| cp<br>jp       | 3ch     | ; read data buffer  |
| jp             | z,rddb9 |                     |
| ср             | 3bh     | ; write data buffer |
| cp<br>jp<br>jp | z,wrdb9 |                     |
| jp             | prog    |                     |

; Byte-0 and byte-1 followed by 4 byte logical block address, 2 null bytes
; PMI byte and null byte
; used by cmd105

| capy9 | push<br>ld<br>call | hl<br>hl,msglba1<br>gethex2 | ; save pointer              |
|-------|--------------------|-----------------------------|-----------------------------|
|       | pop                | hl                          | ; restore pointer           |
|       | ld                 | (hl),a                      | ; byte-2 is LBA high byte   |
|       | inc                | hl                          | , oj to 2 is 2211 mgn oj to |
|       | push               | hl                          | ; save pointer              |
|       | ld                 | hl,msglba2                  | , sure pointer              |
|       | call               | gethex2                     |                             |
|       | pop                | hl                          | ; restore pointer           |
|       | ld                 | (hl),a                      | ; byte-3 is LBA byte 2      |
|       | inc                | hl                          | , byte 5 is Ebit byte 2     |
|       | push               | hl                          | ; save pointer              |
|       | ld                 | hl,msglba3                  | , save pointer              |
|       | call               | gethex2                     |                             |
|       |                    | hl                          | ; restore pointer           |
|       | pop<br>ld          | (hl),a                      | ; byte-4 is LBA byte 3      |
|       | inc                | hl                          | , byte 4 is EBIT byte 5     |
|       | push               | hl                          | ; save pointer              |
|       | ld                 | hl,msglba4                  | , save pointer              |
|       | call               | gethex2                     |                             |
|       |                    | hl                          | ; restore pointer           |
|       | pop<br>ld          | (hl),a                      | ; byte-5 is LBA low byte    |
|       | inc                | hl                          | , byte-5 is EBA low byte    |
|       | call               |                             | ; byte-6 null               |
|       | call               | zero                        | ; byte-7 null               |
|       |                    | zero                        |                             |
|       | push               | hl<br>hl magnini            | ; save pointer              |
|       | ld                 | hl,msgpmi                   |                             |
|       | call               | gethex2                     | · matana maintan            |
|       | pop                | hl (hl) a                   | ; restore pointer           |
|       | ld                 | (hl),a                      | ; byte-8 is PMI             |
|       | inc                | hl                          | · hute 0                    |
|       | ld                 | (hl),null                   | ; byte-9                    |
|       | jp                 | cl1send                     |                             |

; Byte-0 and byte-1 followed by 2 nulls,3 byte logical block address,
; 1 null, 2 byte block count and null byte
; used by cmd108, cmd10a and cmd10f

| rdex9<br>wrex9 |           |            |                           |
|----------------|-----------|------------|---------------------------|
| verf9          | call      | zero       | ; byte-2                  |
|                | push      | hl         | ; save pointer            |
|                | Îd        | hl,msglba1 | _                         |
|                | call      | gethex2    | 4                         |
|                | pop       | hl         | ; restore pointer         |
|                | pop<br>ld | (hl),a     | ; byte-3 is LBA high byte |
|                | inc       | hl         |                           |
|                | push      | hl         | ; save pointer            |
|                |           |            |                           |

| ld   | hl,msglba2  |                             |
|------|-------------|-----------------------------|
| call | gethex2     |                             |
| pop  | hl          | ; restore pointer           |
| ld   | (hl),a      | ; byte-4 is LBA byte 2      |
| inc  | hl          |                             |
| push | hl          | ; save pointer              |
| Îd   | hl,msglba3  |                             |
| call | gethex2     |                             |
| pop  | hl          | ; restore pointer           |
| ld   | (hl),a      | ; byte-5 is LBA low byte    |
| inc  | hl          | , eye e te Ebir tow eye     |
| call | zero        | ; byte-6 null               |
| push | hl          | ; save pointer              |
| ld   | hl,msgbcnt  | , save pointer              |
| call |             |                             |
|      | gethex2     | · mastara maintan           |
| pop  | hl          | ; restore pointer           |
| ld   | (hl),a      | ; byte-7 is block count MSB |
| inc  | hl          |                             |
| push | hl          | ; save pointer              |
| ld   | hl,msgbct2  |                             |
| call | gethex2     |                             |
| pop  | hl          | ; restore pointer           |
| Îd 🗍 | (hl),a      | ; byte-8 is block count LSB |
| inc  | hl          |                             |
| ld   | (hl),null   | ; byte-9                    |
| ld   | a,-1        | ••                          |
| ld   | (scsiwrf),a | ; multi-byte write to drive |
| jp   | cl1send     | , man of to mite to arre    |
| JP   | erroena     |                             |

; Byte-0 and byte-1 followed by P/G/CODE byte, 4 nulls,
; 2 byte allocation length and null byte
; used by cmd117

| deft9  | push<br>ld               | hl<br>hl,msgdeft              | ; save pointer                                         |
|--------|--------------------------|-------------------------------|--------------------------------------------------------|
|        | call<br>pop<br>ld<br>inc | gethex2<br>hl<br>(hl),a<br>hl | ; restore pointer<br>; byte-2 is P/G/Code              |
| deft9a | ld<br>call<br>djnz       | b,4<br>zero<br>deft9a         | ; bytes 3 to 6 are null                                |
|        | push<br>Id<br>call       | hl<br>hl,msgalen<br>gethex2   | ; save pointer                                         |
|        | pop<br>ld                | hl<br>(hl),a                  | ; restore pointer<br>; byte-7 is MSB allocation length |
|        | inc<br>push<br>ld        | hl<br>hl<br>hl,msgaln2        | ; save pointer                                         |
|        | call<br>pop<br>ld        | gethex2<br>hl<br>(hl),a       | ; restore pointer<br>; byte-8 is LSB allocation length |
|        | inc<br>Id<br>jp          | hl<br>(hl),null<br>cl1send    | ; byte-9                                               |

; Byte-0 and byte-1 followed by 6 nulls,
; 2 byte allocation length and null byte
; used by cmd11b and cmd11c

#### - B13 -

rddb9 wrdb9 rddb9a

class7

| ld   | b,6         |                                   |
|------|-------------|-----------------------------------|
| call | zero        | ; bytes 3 to 6 are null           |
| djnz | rddb9a      | 1. No. 31                         |
| push | hl          | ; save pointer                    |
| ld   | hl,msgalen  |                                   |
| call | gethex2     | •                                 |
| pop  | hl          | ; restore pointer                 |
| ld   | (hl),a      | ; byte-7 is MSB allocation length |
| inc  | hl          |                                   |
| push | hl          | ; save pointer                    |
| ld   | hl,msgaln2  |                                   |
| call | gethex2     |                                   |
| pop  | hl          | ; restore pointer                 |
| ld   | (hl),a      | ; byte-8 is LSB allocation length |
| inc  | hl          |                                   |
| ld   | (hl),null   | ; byte-9                          |
| ld   | a,null      |                                   |
| ld   | (scsiwrf),a | ; single byte write to drive      |
| jp   | cl1send     |                                   |

; \*\*\*\*\*\*\*Class-7 Commands\*\*\*\*\*\*\*

| ld             | a,e      |                             |
|----------------|----------|-----------------------------|
| add            | 0e0h     | ; add class-7 for byte-0    |
| ld             | hl,buff  | ; hl -> command buffer      |
| ld             | (hl),a   | ; byte-0 to command buffer  |
| inc            | hl       | The second second second    |
| CD             | 0e0h     | ; maintenance seek          |
| cp<br>jp       | z,mseek5 | hote Abailt                 |
|                | 0e1h     | ; format maintenance tracks |
| ср<br>jp       | z,mform5 |                             |
| cp             | 0e2h     | ; certify                   |
| jp             | z,cert5  |                             |
| cp             | 0e8h     | ; fast read                 |
| jp             | z,frd5   | ,                           |
|                | Oeah     | ; fast write                |
| in             | z,fwr5   | ,                           |
| cp<br>jp<br>jp | prog     |                             |
| JP             | 1.00     |                             |

; Byte-0 followed by 1 null, 2 byte cylinder number, 1 byte head number ; and null byte ; used by cmd700

| mseek5 | call | zero       | ; byte-1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|--------|------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|        | push | hl         | ; save pointer                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|        | Îd   | hl,msgcylh | 2 <b>.</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|        | call | gethex2    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|        | pop  | hl         | ; restore pointer                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|        | ld   | (hl),a     | ; byte-2 is cylinder number high byte                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|        |      | hl         | , byte-2 is cylinder number nigh byte                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|        | inc  |            | · · · · · · · · · · · · · · · · · · ·                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|        | push | hl         | ; save pointer                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|        | ld   | hl,msgcyll |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|        | call | gethex2    | 5                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|        | pop  | hl         | ; restore pointer                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|        | ld   | (hl),a     | ; byte-3 is cylinder number low byte                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|        | inc  | hl         | ten in 🖷 the an in the index of 🕬 the basis in the basis in the second s |
|        | push | hl         | ; save pointer                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|        | ĺd   | hl,msghead | , F                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|        | call | gethex2    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|        |      | hl         | : rectore pointer                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|        | pop  |            | ; restore pointer                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|        | ld   | (hl),a     | ; byte-4 is head number                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |

| inc | hl        |
|-----|-----------|
| ld  | (hl),null |
| jp  | cl7send   |

; byte-5 null

; Set pattern of bytes ; used by cmd701

| mform5 | ld        | (hl),0000000b        | ; byte-1      |
|--------|-----------|----------------------|---------------|
|        | inc<br>ld | hl<br>(hl),01010010b | ; byte-2      |
|        | inc       | hl                   |               |
|        | ld        | (hl),01001111b       | ; byte-3      |
|        | inc<br>ld | hl<br>(hl),00000000b | ; byte-4      |
|        | inc       | hl                   | , 0yte-4      |
|        | ld        | (hl),0000000b        | ; byte-5 null |
|        | jp        | cl7send              |               |

; Byte-0 followed by 2 null bytes, pass count, 2 null bytes ; used by cmd702

cert5

| call      | zero       | ; byte-1                               |
|-----------|------------|----------------------------------------|
| call      | zero       | ; byte-2 is null                       |
| push      | hl         | ; save pointer                         |
| Îd        | hl,msgpcnt | ; allocation length requested          |
| call      | gethex2    | · ·                                    |
| pop       | ĥl         | ; restore pointer                      |
| pop<br>ld | (hl),a     | ; byte-3 is pass count                 |
| inc       | hl         | and a real of the second second second |
| call      | zero       | ; byte-4 null                          |
| ld        | (hl),null  | ; byte-5 null                          |
| jp        | cl7send    |                                        |

; Byte-0 followed by 3 null bytes, block count, 1 null byte ; used by cmd708 and cmd70a

frd5

| fwr5  | ld   | b,3         |                              |
|-------|------|-------------|------------------------------|
| fwr5a | call | zero        | ; bytes 1 to 3 are null      |
|       | djnz | fwr5a       |                              |
|       | call | setup5a     |                              |
|       | ld   | a,null      |                              |
|       | ld   | (scsiwrf),a | ; single byte write to drive |
|       | jp   | cl7send     |                              |

;\*\*\*\*\*\*SCSI Subroutines\*\*\*\*\*\*\*

; Read Current SCSI Bus Status Register and react to contents

; Status bit positions - stat1p

| phasem  | equ | 00011100b | ; phase mask       |
|---------|-----|-----------|--------------------|
| datoutp | equ | 0000000b  | ; data out phase   |
| cmdp    | equ | 00001000b | ; command phase    |
| datinp  | equ | 00000100b | ; data in phase    |
| statusp | equ | 00001100b | ; status phase     |
| msginp  | equ | 00011100b | ; message in phase |

; Status for Target Command Register - tcmdp

| datoutt | equ | 0000000b  | ; data out target |
|---------|-----|-----------|-------------------|
| cmdt    | equ | 00000010b | ; command target  |

| phaser | in             | a,stat1p  | ; read register            |
|--------|----------------|-----------|----------------------------|
|        | bit            | 6,a       | ; test busy                |
|        | jp             | z,start1  | ; all done?                |
|        | jp<br>bit      | 5,a       | ; test for request         |
|        | jr             | z,phaser  | ; not got one so try again |
|        | and            | phasem    | ; mask out all but phase   |
|        | cp             | datoutp   | ; data out phase           |
|        | jp             | z,scsiwr  |                            |
|        | cp             | datinp    | ; data in phase            |
|        | jp             | z,datain  |                            |
|        | cp             | statusp   | ; status phase             |
|        | cp<br>jp       | z,status  |                            |
|        | cp             | msginp    | ; message in phase         |
|        | jp             | z,message |                            |
|        | cp<br>jp<br>jp | phaser    | ; do not recognize it      |

; Acknowledge Drive

| ackdrv  | ld<br>out              | a,ack<br>icmdp,a                | ; acknowledge drive       |
|---------|------------------------|---------------------------------|---------------------------|
| statms1 | in<br>bit              | a,stat1p<br>5,a                 | ; wait for request false  |
|         | jr<br>ld<br>out<br>ret | nz,statms1<br>a,null<br>icmdp,a | ; reset acknowledge false |

; Read data byte from drive and output to VDU

| datain | in   | a,datap | ; read data byte    |
|--------|------|---------|---------------------|
|        | call | byteout |                     |
|        | call | ackdrv  | ; acknowledge drive |
|        | jr   | phaser  |                     |

; Read status byte from drive and output to VDU

| status | ld<br>call | hl,msgstat<br>outst | ; hl -> banner           |
|--------|------------|---------------------|--------------------------|
|        | in         | a,datap             | ; read drive status byte |
|        | call       | byteout             |                          |
|        | call       | ackdrv              | ; acknowledge drive      |
|        | jr         | phaser              |                          |

### ; Read message byte from drive and output to VDU

| message | ld<br>call | hl,msgmsg<br>outst | ; hl -> banner           |
|---------|------------|--------------------|--------------------------|
|         | in<br>call | a,datap<br>byteout | ; read drive status byte |
|         | call<br>jp | ackdrv<br>prog     | ; acknowledge drive      |

; Read data bytes from drive and output to VDU

| scsird | in                  | a,datap           | ; read data byte    |
|--------|---------------------|-------------------|---------------------|
|        | call<br>call<br>ret | byteout<br>ackdrv | ; acknowledge drive |

; Select drive

| select  | ld       | a,null            |                                      |
|---------|----------|-------------------|--------------------------------------|
|         | out      | modep,a           | ; set as initiator and no interrupts |
|         | out      | icmdp,a           | ; set initiator command register     |
|         | in       | a,prstp           | ; reset parity/interrupts port       |
|         | ld       | a,00000001b       | ; select drive address               |
|         | out      | datap,a           |                                      |
|         | ld       | a,datoutt         | ; data out target                    |
|         | out      | tcmdp,a           |                                      |
|         | ld       | a,sel             |                                      |
|         | out      | icmdp,a           |                                      |
| select1 | in       | a,stat1p          |                                      |
|         | bit      | 6,a               |                                      |
|         | jr<br>ld | z,select1         | ; wait for bsy true                  |
|         | ld       | a,null            | 5.3                                  |
|         | out      | icmdp,a           | ; reset select false                 |
|         | ret      | 8 <del>9</del> 83 |                                      |

; Send ten or six control bytes to drive ; hl -> buffer containing the six or ten bytes

| send6  | ld   | c,datap     |                          |
|--------|------|-------------|--------------------------|
|        | ld   | b,6*2       |                          |
|        | jr   | send6c      |                          |
| send10 | Ĭd   | c,datap     |                          |
|        | ld   | b,10*2      |                          |
| send6c | ld   | a,cmdt      | ; command target         |
|        | out  | tcmdp,a     |                          |
| send6a | in   | a,stat1p    | ; wait for request       |
|        | bit  | 5,a         |                          |
|        | jr   | z,send6a    |                          |
|        | outi |             | ; send byte              |
|        | call | ackdrv      | ; acknowledge byte ready |
|        | djnz | send6a      |                          |
|        | lď   | hl,crlf     |                          |
|        | call | outst       | ; cr/lf to tidy display  |
|        | ret  | 20222332222 | ,                        |

; Write data byte to drive from VDU ; single/block depends on flag in (scsiwrf) - null for single byte

| scsiwrb<br>scsiwr | db<br>ld<br>call<br>ld | cr,lf,'B: ',null<br>hl,scsiwrb<br>outst<br>hl,inhexs | ; ask for byte             |
|-------------------|------------------------|------------------------------------------------------|----------------------------|
|                   | call<br>call           | inhex<br>binary                                      |                            |
|                   | push                   | af                                                   | ; save the byte            |
|                   | ld                     | a,datoutt                                            | ; data out target          |
|                   | out                    | tcmdp,a                                              |                            |
|                   | ld                     | a,(scsiwrf)                                          |                            |
|                   | ср                     | null                                                 |                            |
|                   | cp<br>jr               | nz,scsiwb                                            | ; is it a block write?     |
|                   | рор                    | af                                                   | ; get the byte back        |
|                   | out                    | datap,a                                              | ; write data byte          |
|                   | call                   | ackdrv                                               | ; acknowledge drive        |
|                   | jp                     | phaser                                               |                            |
| scsiwb            | in                     | a,stat1p                                             | ; read register            |
|                   | bit                    | 5,a                                                  | ; test for request         |
|                   | jr                     | z,scsiwb                                             | ; not got one so try again |
|                   | and                    | phasem                                               | ; mask out all but phase   |

|         | ср   | datoutp     |
|---------|------|-------------|
|         | jr   | nz,scsiwb0  |
|         | pop  | af          |
|         | out  | datap,a     |
|         | push | af          |
|         | call | ackdrv      |
|         | jr   | scsiwb      |
| scsiwb0 | pop  | af          |
|         | jp   | phaser      |
|         | rept | [800h - \$] |
|         | db   | -1          |
|         | mend |             |
|         | end  | start       |

; data out phase ; return as all done ; get the byte back ; write data byte ; save the byte ; acknowledge drive ; look for next data in byte ; clean up the stack

; end of file

## APPENDIX C

# **BUS PHASE SEQUENCES**



ANBITRATION MUS FREF

SEL and BSY are both lake for at Implementation of this phase is a sustain option Bus Settle

During this phase the VO signal is dessented to distinguish this phase from the Re-selection Phase At least one Rus Free Delay but no more than one Rus Set Drav alter Bus Free Phase has been detected the NATLATOR asserts BSY and its own Rus Device 10 but on the data bus Nehrction Phase NON ANBITRATING SYSTENS in systems with the Arbitration Phase not integlemented after detecting the Bus Free phase the MITATOR waits a memicigun of one flus Ober Delay then it assents the Data Bus with bith the deared INITATOR to be after two restew of the TARGETS ID be after two restew of best TARGETS ID be

SELECTION

o dest ew delays

IN ALL SYSTEMS the TARGET determines that it is selected when SEL and its Bits Druce D bit are true and BSV and I/O are lake lot at least a Bus Settle Defay. The TARGET then assets BSV within a Selection About Time

Two deskew delays after the INTIATOR detects RSY true it releases SEL and may change Data Bus signals

The INITIATOR waits an Arbita tion Delay then avarinas the Data Bus it a higher priority flux Device 10 is from OB7 is the highest the NTITATOR loses NTITATOR loses Arbitration and releases BSY essenti SEL Angli RATING SYSTEMS In systems with the Abbration Phose motionerated the efflation the south RSV and SEL estimated and changes the Date Bus then assend bus then assend with both the deviced entitle down both Bus then assend mit lation to bit and the TARGETS to bit Two destiew defins COMMAND

The TARGET asserts C/D and cleasserts I/O and MSG for all of the handkhakes of the Phase The transfer is from INITIATOR in TARGET

HANDSHAKE

PROCERTIN The LARGET asserts REO The INITIATION there's data 12 0 11 in their decising values wards at least non-deskew deliny phics a cable stew integra and asserts ACK the NITIATOR continues. In drive data 12 0 11 then asserts REO

When REO becomes laise at the INITIATOR the INITIATOR may change or release data (7.0 C) and deasset ACk

The TARGET continuer requesting command bytes The number of bytes depends on the command group code detected from the first command byte mman

DATA IN OR OUT

DATA IN FLIASE Read Catalo he sent from TARCET to INITIATOR

TARGET assests I/O deaserts C/D and MSG during the REO/ ACK handshake of this place

PRESTONE

The FARGET first diverse data (2.0.17) in them iderund values works at least one destaw delay plus a cadio show delay, then asserts REO Data (2.0.11) sholl remain valid unit ACK is time at the TARGET

The INITIATOR shall read data (7.0 Pl after REQ is true then asserts ACK

When ACk becomes true at the TARGET the TARGET may change or infease data (7.0.17) and deassert REQ

After REO is false the INITIATOR deasers ACK after ACK is false the TARGET may continue the bander by though data 17 0 PT and asserting REO

DATA OUT MIASE

Data is to be sent from

TARGET deasserts C D 1 D and MSG during the RED/ACK handshake of this phase refer to the handshake procedure of the Command Phase

STATUS PHASE (Finding Status)

PHASE

MESSAGE IN PHASE Boterrupt) TARGET request massage byte(s) to be sent from TARGET (e INITIATOR TARGET I twin the sent to the INITIATION TARGET assents C/D and MO and deassents MSG during the handshake of this phase TARIJET asserts C/D, I/O and MSG during the REQ/ACK handshake(s) of the Phase Only one byte of status is transferred The niessage byte could indicate Complete (DO) indicating interrupt See handshake procedure uni See handshake procedure under Date in Chase

TARGET TARGET deasserts RSY to itch:-te that the bus is wailable for subsequent users TARGET releases all bus sensals within a Bu Clear Delay after RSY becomes continuenus faise for a Bus Settle Delay

The following Phase will be an Arbitration Phase

#### APPENDIX D

#### COMPARISON OF PERFORMANCE OF TTL BOARD AND NCR 53C80 BOARD

When this research work commenced, there was no VLSI SCSI interface chip (NCR 53C80) available for use. The Rodime RO652 hard disk drive interface was proprietary to Rodime PLC and could not be utilised. As a result, there was no alternative but to produce a prototype using purely TTL logic.

By using a TTL logic only interface, it was found that none of the SCSI maximum delay times could be realised and as such the TTL board does not conform to the American National Standards Institute (ANSI) X3T9 SCSI specification. The data transfer rate was

limited to such an extent on the TTL board, that it was realised that only when a VLSI chip became available, a true to SCSI specification interface could be constructed.

The TTL interface board, allowed a full understanding of SCSI handshaking to be developed. It also allowed the majority of the firmware to be written and tested. This firmware was subsequently used as the basis of the firmware for the Intelligent Interface

board.

The Intelligent Interface board was developed when the VLSI chip, NCR53C80, became available and unlike the TTL board, conformed to the ANSI SCSI specification data transfer rates.