Appendix A Rigid Disk Subsystem

\_\_\_\_

# Appendix A: Rigid Disk Subsystem

Appendix A contains supplementary material for the rigid disk subsystem. Information is presented in the following order:

- A.1 Disk Command Block (DCB) allowable commands, format, and operational errors.
- A.2 State machine PROM contents

Schematics for the rigid disk subsystem are located in Appendix D.

### A.1 Disk Command Block

# A.1.1.

**DBC Commands** Table A.1 lists the operations provided by the disk command block.

| Operation            | Fu     | inction |      | Opcode in DCB |  |  |  |  |
|----------------------|--------|---------|------|---------------|--|--|--|--|
|                      | header | label   | data |               |  |  |  |  |
| Restore-Recalibrate  |        |         |      | 0             |  |  |  |  |
| Format Tracks        | w      | w       | w    | 1             |  |  |  |  |
| Read Data            | v      | v       | r    | 2             |  |  |  |  |
| Write Data           | v      | v       | w    | 3             |  |  |  |  |
| Write Label and Data | v      | w       | w    | 4             |  |  |  |  |
| Read Label           | v      | r       | n    | 5             |  |  |  |  |
| Read Label and Data  | v      | r       | r    | 6             |  |  |  |  |
| Verify Data          | v      | v       | v    | 7             |  |  |  |  |
|                      |        |         |      |               |  |  |  |  |
| Read Diagnostic*     | r      | r       | r    | 10            |  |  |  |  |

## Table A.1. Disk Operations

\* Not yet implemented.

w = write v = verify r = read n = ignore

### A.1.2. DBC Format

In the Control Block, the rigid disk controller requires:

- Header image
- Label image

The rigid disk controller maintains: Current cylinder - 2 bytes

Table A.2 lists the header and label layout in the scratchpad and in FIFO. Information given in the table is subject to change.

Appendix A

| SP<br>Loc   | Contents of SP<br>bit7 - bit0 | Contents of FIFO<br>bit15 - bit0<br>If (xxxx), then set to xx when sending<br>If {xxxx}, then special case–see note |  |  |  |  |  |
|-------------|-------------------------------|---------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| BC<br>BD    | DTACRC<br>(+1)                | CRC syndrome, Wd 1 (0000)                                                                                           |  |  |  |  |  |
| BE<br>BF    | (00)<br>(00)                  | Reserved. Always 0                                                                                                  |  |  |  |  |  |
| C0<br>C1    | SECNTH<br>SECNTL              | -Number of sectors to transfer (two's complement)                                                                   |  |  |  |  |  |
| C2<br>C3    | 0<br>SECPT                    | (Max sector number) + 1 (per track)                                                                                 |  |  |  |  |  |
| C4<br>C5    | MCVRL<br>HDSPC                | Microcode revision level###<br>(No of heads)+1 per cylinder                                                         |  |  |  |  |  |
| C6<br>C7    | CTLPDH<br>CYLPDL              | (No of cylinders) + 1 per drive                                                                                     |  |  |  |  |  |
| C9<br>C9    | 0<br>FSEC                     | Inv/Non-inv flag. See # # below.<br>First sector number per track                                                   |  |  |  |  |  |
| CA<br>CB #  | WICYH<br>WICYL                | Reduce write current cylinder {FFFF}                                                                                |  |  |  |  |  |
| CC<br>CD    | PCCYH<br>PCCYL                | Precomp cylinder                                                                                                    |  |  |  |  |  |
| CE<br>CF ## | 0<br>WENDC                    | Sector length for diagnostics. Normal = $-1$ (FF)                                                                   |  |  |  |  |  |
| D0<br>D1    | 0<br>HDRERT                   | Header error type (0000)                                                                                            |  |  |  |  |  |
| D2 0<br>D3  | LBERT                         | Label error type (0000)                                                                                             |  |  |  |  |  |
| D4<br>D5    | 0<br>DTAERT                   | Data error type (0000)                                                                                              |  |  |  |  |  |
| D6<br>D7    | 0<br>LSTERT                   | Last error type (0000)                                                                                              |  |  |  |  |  |
| D8<br>D9    | FCURCH<br>FCURCL              | Current cylinder ** (FFFF)                                                                                          |  |  |  |  |  |
| DA<br>DB    | 0<br>1                        | Always 1                                                                                                            |  |  |  |  |  |
| DC<br>DD    | CYL H<br>CYL L                | CYL                                                                                                                 |  |  |  |  |  |
| DE<br>DF    | HD<br>SEC                     | HD   SEC Header image                                                                                               |  |  |  |  |  |

Table A.2. Header and Label Layout in Scratchpad (SP) and FIFO

– more –

Appendix A

----

<u>A - 2</u>

| SP<br>Loc | Contents of SP<br>• bit7 - bit0 | Contents of FIFO<br>bits15 - bit0                |  |  |  |  |  |  |  |  |  |  |
|-----------|---------------------------------|--------------------------------------------------|--|--|--|--|--|--|--|--|--|--|
| E0<br>E1  | RES1H<br>RES1L                  | Reserved 1 (0000)                                |  |  |  |  |  |  |  |  |  |  |
| E2<br>E3  | RES2H<br>RES2L                  | Reserved 2 (0000)                                |  |  |  |  |  |  |  |  |  |  |
| E4<br>E5  | DvSt<br>CntSt                   | Drive and controller status                      |  |  |  |  |  |  |  |  |  |  |
| E6<br>E7  | 0<br>OPER                       | Operation to be done                             |  |  |  |  |  |  |  |  |  |  |
| E8<br>E9  | TKFH<br>TKFL                    | -No. of track to be formatted (two's complement) |  |  |  |  |  |  |  |  |  |  |
| EA        | not used                        |                                                  |  |  |  |  |  |  |  |  |  |  |
| EB<br>EC  | FIDO H<br>FIDO L                | FID0                                             |  |  |  |  |  |  |  |  |  |  |
| ED<br>EE  | FID1 H<br>FID1 L                | FID1                                             |  |  |  |  |  |  |  |  |  |  |
| EF<br>FO  | FID2 H<br>FID2 L                | FID2                                             |  |  |  |  |  |  |  |  |  |  |
| F1<br>F2  | FID3 H<br>FID3 L                | FID3                                             |  |  |  |  |  |  |  |  |  |  |
| F3<br>F4  | FID4 H<br>FID4 L                | 1FID4                                            |  |  |  |  |  |  |  |  |  |  |
| F5<br>F6  | FPLo H<br>FPLo L                | FP low                                           |  |  |  |  |  |  |  |  |  |  |
| F7<br>F8  | FPHi&Flags H<br>FPHi&Flags L    | FPHi&Flags                                       |  |  |  |  |  |  |  |  |  |  |
| F9<br>FA  | FT Hi<br>FT Lo                  | FT                                               |  |  |  |  |  |  |  |  |  |  |
| FB<br>FC  | bootCLLo H<br>bootCLLo L        | bootCL Lo                                        |  |  |  |  |  |  |  |  |  |  |
| FD<br>FE  | bootCLHi H<br>bootCLHi L        | bootCl Hi                                        |  |  |  |  |  |  |  |  |  |  |
| FF        | not used                        |                                                  |  |  |  |  |  |  |  |  |  |  |

Table A.2. Header and Label Layout (continued)

Notes for Table A.2

- # ReduceWrite Current Cyl: If the drive does not need this signal, then put FFFF in this location.
- ## Sector Length: For normal length sectors, use -1. Some diagnostic operations will require longer data blocks, and they will use -2 here.
- \*\* Current cylinder: Load with FFFF. The value is a copy of the actual value. Between operations it is kept in a different location and copied here before it is sent to the FIFO. The value is the current cylinder number, with these exceptions:
  - between the beginning of an operation and the end of the implied seek

#### Appendix A

A - 3

• between the start and end of an implied seek occurring in the middle of an operation.

If the word content is FFFF, then the current cylinder is undefined. The contents are set to FFFF at the beginning of a seek and are set to the new value at the end of a seek.

## Inv/Non-Inv Flag: The early pre-prototype IOP board inverted data (including the DCB data) between the IOP and the RDC. Production IOPs do not invert this data. The flag byte enables the IOP to tell the difference.

This byte, the most significant byte of FSec, is written to 0 when the command, LoadCommandBloc (put current status in the DiscCommandBlock), is executed by the RDC.

If the DCB is read without software inversion, then this byte indicates whether the hardware is non-inverting or inverting.

If read as 0, then the hardware is non-inverting.

If read as FF, then the hardware is inverting.

If an inverting RDC is read with software inversion, then this byte is 0.

### Microcode revision level:

All microcode up to and including RDCENB = 0

Next microcode change that affects head and pilot = 1, and so forth.

The information sent to the RDC is sent back with appropriate changes.

Appendix A

A.1.3. DBC Errors

Errors are presented as one byte, the low order byte of the word, divided into two nibbles. Table A.3 lists the error codes.

# Table A.3. Error Codes

| High order nibble:                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |  |  |  |  |
|-------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|
| $\begin{array}{c} 0 \\ 1 \\ 2 \\ 3 \end{array}$ | = FIFO protocol error<br>= Header error<br>= Label error<br>= Data error                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |  |  |  |
| 8 or<br>higher                                  | = error not encoded. Each number is a specific, not encoded, error type.                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |  |  |  |
| Low order n                                     | ibble for types 1, 2, and 3                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |  |  |  |  |
| 1<br>2<br>3<br>4<br>5                           | <ul> <li>Address Mark error: AM not found where expected</li> <li>ID error: wrong ID byte found</li> <li>Verify (compare) error: data was not what was expected</li> <li>CRC error</li> <li>Both verify and CRC/ECC errors</li> </ul>                                                                                                                                                                                                                                  |  |  |  |  |  |  |  |
| FIFO errors                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |  |  |  |  |
| 01<br>03<br>04<br>05<br>07<br>More              | <ul> <li>FIFO empty at GetCommandBlock command</li> <li>FIFO not empty at start of read from disk</li> <li>FIFO has been full for four revolutions of the disk during a read from disk</li> <li>FIFO has been empty for N revolutions of disk during a write to disk</li> <li>FIFO not empty at LoadCommandBlock command<br/>To be defined</li> </ul>                                                                                                                  |  |  |  |  |  |  |  |
| Other errors                                    | S                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |  |  |  |
| 81<br>82<br>84<br>85<br>8A<br>8B<br>8C<br>8D    | <ul> <li>Sector not found</li> <li>Cylinder number too big during implied seek: no. of sectors went off top of disk</li> <li>Current cylinder unknown</li> <li>Write fault</li> <li>Illegal operation</li> <li>Illegal diagnostic operation</li> <li>Protocol sequence error: 2 (ExecuteCommandBlock) not preceded by<br/>1 (GetCommandBlock)</li> <li>Not Ready&amp;SeekComplete error: Not Ready&amp;seekComp at beginning of data<br/>transfer operation</li> </ul> |  |  |  |  |  |  |  |
| Contents of                                     | Drive Status                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |  |  |  |
| Bit<br>0<br>1<br>2<br>3<br>4<br>5<br>6<br>7     | <ul> <li>= Lock detected</li> <li>= Not Write fault</li> <li>= Not Track 000</li> <li>= Not Stored Index mark</li> <li>= Address Mark out (AMdetected)</li> <li>= always 0</li> <li>= Not Seek completed</li> <li>= Not Ready</li> </ul>                                                                                                                                                                                                                               |  |  |  |  |  |  |  |
| Contents of                                     | Controller Status                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |  |  |  |
| Bit<br>0<br>1<br>2<br>3<br>4<br>5<br>6<br>7     | <ul> <li>FIFO full, synchronized</li> <li>FIFO empty, synchronized</li> <li>FIFO A1B1 same</li> <li>Not SP MA max count</li> <li>Not SP MA bit 3</li> <li>FIFO empty at read</li> <li>Not BDONE</li> <li>Read data found</li> </ul>                                                                                                                                                                                                                                    |  |  |  |  |  |  |  |

Appendix A

A – 5

÷

# A.2 State Machine PROM Contents

Table A.4 lists the PROM contents of the state machine.

### Table A.4. States of the State Machine: PROM contents

|                                     | Data Out        |       |        |        |              |              |                                          |                             |   |     |            |        |              |        |  |  |              |
|-------------------------------------|-----------------|-------|--------|--------|--------------|--------------|------------------------------------------|-----------------------------|---|-----|------------|--------|--------------|--------|--|--|--------------|
|                                     | External Inputs |       |        |        |              |              | PROM Outputs (after Lo-to-Hi clock edge) |                             |   |     |            |        |              |        |  |  |              |
|                                     | Ru              | tunSM |        |        |              | ErrorTrap'   |                                          |                             |   |     |            | ad/I   | OWr          |        |  |  |              |
|                                     |                 | DHL   | SA     | RDY    | ,            |              |                                          | RDiskDmaintr<br>GateSLines' |   |     |            |        | FIFOPreFetch |        |  |  |              |
|                                     |                 |       |        | FIF    | <u>00B'1</u> |              |                                          |                             |   | AD  | Dr'/Data   |        | 1            |        |  |  |              |
| Comments                            |                 |       |        |        | EOX'         | StateNumber* |                                          |                             |   |     | DMA Active |        |              |        |  |  | Next State*  |
| WaitForHLDA<br>GotHLDA              | 1<br>1          | 0     | x<br>x | x<br>x | x<br>x       | 0010         | 1<br>1                                   | 0<br>0                      | 1 | 1   | 0<br>1     | 0<br>0 | 1            | 0<br>0 |  |  | 0010<br>0111 |
| T1State                             | 1               | x     | x      | x      | x            | 0100 ©       | 1                                        | 0                           | 0 | 0   | 1          | 1      | 1            | 1      |  |  | 0101         |
| T2State                             | 1               | X     | x      | x      | x            | 0101 💿       | 1                                        | 0                           | 0 | 1   | 1          | 1      | 1            | 0      |  |  | 0110         |
| T3State                             | 1               | x     | x      | x      | x            | 0110 ®       | 1                                        | 0                           | 1 | 1 · | 1          | 1      | 1            | 0      |  |  | 0111         |
| TwAndWait                           | 1               | x     | 0      | x      | x            | 0111 @       | 1                                        | 0                           | 1 | 1   | 1          | 1      | 1            | 0      |  |  | 0111         |
| T4Normal                            | 1               | 1     | 1      | 1      | 1            | 0111 🖲       | 1                                        | 0                           | 0 | 1   | 1          | 0      | 1            | 1      |  |  | 0100         |
| T4AndEOXfer                         | 1               | X     | 1      | X      | 0            | 0111 🖲       | 1                                        | 0                           | 1 | 1   | 1          | 0      | 1            | 0      |  |  | 1010         |
| T4AndOutOfBnd                       | 1               | X     | 1      | 0      | 1            | 0111 🖲       | 1                                        | 0                           | 1 | 1   | 1          | 0      | 1            | 0      |  |  | 1000         |
| T4AndEtherHld                       | 1               | 0     | 1      | x      | 1            | 0111 🖲       | 1                                        | 0                           | 1 | 1   | 1          | 0      | 1            | 0      |  |  | 1000         |
| DropHLD                             | 1               | x     | x      | x      | 1            | 1000         | 1                                        | 0                           | 1 | 1   | 1          | 0      | 0            | 0      |  |  | 1100         |
| SendIntReq                          | 1               | x     | x      | x      | 0            | 1010         | 1                                        | 1                           | 1 | 1   | 1          | 0      | 0            | 0      |  |  | 1100         |
| WaitForFIFO                         | 1               | x     | x      | 0      | x            | 1100 ③       | 1                                        | 0                           | 1 | 1   | 0          | 0      | 0            | 0      |  |  | 1100         |
| SendHld                             | 1               | X     | X      | 1      | X            | 1100 ③       | 1                                        | 0                           | 1 | 1   | 0          | 0      | 1            | 0      |  |  | 0010         |
| DMA Disabled<br>= (initial wait)    | 0               | x     | X      | х      | x            | 1100 🛈       | 1                                        | 0                           | 1 | 1   | 0          | 0      | 0            | 0      |  |  | 1100         |
| ErrorEntryPoint<br>(see note below) | 1               | x     | x      | x      | x            | 1101         | 0                                        | 1                           | 1 | 1   | 0          | 0      | 0            | 0      |  |  | 1100         |

\* No explicit State Number or State ID exists within the State Machine PROM. These numbers are for identification only.

Note: The PROM area not covered in the table is programmed as Error condition (same as ErrorEntryPoint). The circled numbers correspond to the numbers on the state diagrams shown on Figures 5.15, 5.16, and 5.17.

Requirement: All external inputs other than SARDY must maintain their new logic level for at least two clock cycles.

#### IMPORTANT NOTE:

The State Machine marches through its states by means of an inherent pattern created by a combination of external inputs and the PROM outputs from the previous clock cycle. Therefore, changing the timing of the signals by manipulating the PROM contents is NOT advisable.

If such a change should become necessary, then a thorough analysis of the State Machine PROM behavior under all circumstances will be required. The timing of all the signals from the PROM as well as their derivative signals must be carefully analyzed and examined before any PROM commitment.

<u>A</u> – 6

.

Appendix A