SC04/C (RK06/RK07 COMPATIBLE) DISK CONTROLLER TECHNICAL MANUAL 2001 East Deere Avenue Santa Ana, California 92705 (714) 557-7580 TWX 910-595-2521 Copyright (C) 1981 Emulex Corporation The information in this manual is for information purposes and is subject to change without notice. Emulex Corporation assumes no responsibility for any errors which may appear in the manual. Printed in U.S.A. # TABLE OF CONTENTS | Section | 1 | INTRODUCTION | | |---------|-----------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------| | | 1.1<br>1.2<br>1.2.1<br>1.2.2<br>1.3<br>1.3.1<br>1.3.2<br>1.3.3<br>1.3.4<br>1.3.5<br>1.3.6<br>1.4.1<br>1.4.1 | SCOPE OVERVIEW General Description SCO4/C Emulation of RKO6 and RKO7 FEATURES Microprocessor Design Packaging Self-Test Buffering Error Correction Option and Configuration Switches FUNCTIONAL COMPATIBILITY Media Compatibility Disk Mapping | 1-1<br>1-1<br>1-1<br>1-1<br>1-1<br>1-2<br>1-2<br>1-2<br>1-2<br>1-3<br>1-3 | | Section | 2 | GENERAL DESCRIPTION | | | | 2.1<br>1.2<br>2.2.1<br>1.2<br>2.2.2<br>2.2.3<br>3.1<br>1.2<br>2.2.2<br>2.2.2<br>2.3<br>3.3<br>3.3<br>3.3<br>3.3<br>3.3<br>3 | Connectors ANSI Interface Connector Test Connector Switches LED Indicator Firmware PROM's Bootstrap ROM's INTERFACES Disk Interface ANSI Interface Connector Q Bus Interface | 2-1<br>2-2<br>2-2<br>2-2<br>2-3<br>3-3<br>3-3<br>2-4<br>2-4<br>2-7<br>2-9<br>2-9<br>2-9<br>2-9 | | | 2.5.3<br>2.5.4<br>2.5.5 | 22 Bit Memory Addressing<br>Line Clock<br>Bootstrap Routine | 2-11<br>2-12<br>2-12 | |---------|---------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------| | Section | 3 | INSTALLATION | | | | 3.2<br>3.2.1 | Unit Numbering CONTROLLER CONFIGURATION Address Selection Interrupt Vector Selection Drive Configuration Selection Line Clock Option Boot Strap Option User Selectable Options PHYSICAL INSTALLATION Q Bus Terminator Option Slot Selection Mounting CABLING ANSI Interface Cable Grounding TESTING Self-Test | 3-1<br>3-1<br>3-1<br>3-1<br>3-1<br>3-1<br>22<br>22<br>22<br>22<br>23<br>33<br>33<br>33<br>33<br>33<br>33<br>33<br>33 | | Section | 4 | CONTROLLER REGISTERS | | | | 4.1<br>4.23<br>4.56<br>7.89<br>1.12<br>4.15<br>4.15<br>4.15<br>4.16<br>4.16<br>4.16<br>4.16 | | 4-1<br>4-3<br>4-4<br>4-4<br>4-6<br>4-10<br>4-11<br>4-11<br>4-11<br>4-12<br>4-12<br>4-15<br>4-15<br>4-16 | | | 4.16.3<br>4.16.4 | B2 Status<br>B3 Status | 4 – 17<br>4 – 17 | |----------|----------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------| | Section | 5 | COMMANDS | | | | 5.1.5<br>5.2.1<br>5.2.2.3<br>5.3.3.1<br>5.3.3.4<br>5.3.3.4<br>5.3.3.4<br>5.3.3.4 | Read Data (21) Write Data (23) Read Header (25) Write Header (ormat Operation)(27) Write Check Data (31) POSITIONING COMMANDS Recalibrate (13) Offset (15) Seek Command (17) HOUSEKEEPING COMMANDS Select Drive (1) Pack Acknowledge (3) | 55555555555555555555555555555555555555 | | Appendix | A | SC04/C CONFIGURATION AND OPTION SELECT | | | | A.1<br>A.2<br>A.2.1<br>A.2.2<br>A.2.3 | CONTROLLER CONFIGURATION Single Drive Installations Multi Drive Installations (same type) | A-1<br>A-1<br>A-1<br>A-2<br>A-3 | # LIST OF TABLES | Table No. | <u>Title</u> | <u>Page</u> | |---------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------| | Table 1-1 | RK611/RK06/RK07 Disk Subsystems Characteristics | 1-3 | | Table 1-2 Table 2-1 Table 2-2 Table A-1 Table A-2 Table A-3 Table A-4 Table A-5 | General Specification Disk Drive Connections Q Bus Connections Drives Supported Drive Configuration Option Switch Settings Configuration Switch Settings | 1-4<br>2-5<br>2-6<br>A-4<br>A-7<br>A-8<br>A-8 | | | LIST OF FIGURES | | | Figure No. | <u>Title</u> | Page | | Figure 2-1 | Sector Format<br>Header Format | 2 <b>-</b> 8<br>2 <b>-</b> 8 | #### 1.1 SCOPE This manual provides information related to the capabilities, design, installation, and use of the SCO4/C Disk Controller. In addition, this manual provides diagnostics and application information. ## 1.2 OVERVIEW ## 1.2.1 General Description The SCO4/C Disk Controller is a one board, imbedded controller for LSI-11 computers manufactured by Digital Equipment Corporation. This controller can be used to interface any large disk having a ANSI X3T9/1226 interface. The SCO4/C controller emulates the RK611 disk controller manufactured by Digital Equipment Corporation for use with RKO6 and RKO7 disk drives. # 1.2.2 SC04/C Emulation of RK06 and RK07 The RK611 provides a convenient controller architecture for a wide variety of modern technology type disks. It is supported by all DEC operating systems and is easy to program. The SCO4/C controller can handle eight disk drives with up to two different drives in per configuration. The controller configures each drive from the information in a configuration PROM. This technique permits up to 64 different switch selectable combinations of disk drive configurations. #### 1.3 FEATURES ## 1.3.1 Microprocessor Design The SCO4/C design incorporates a unique 8-bit bipolar microprocessor to perform all controller functions. The microprocessor approach provides for a reduced component count, high reliability, easy maintainability, and most importantly, the ability to adapt a single set of hardware to a wide range of emulation capabilities through the use of microprogramming. The Emulex controllers achieve functional capability beyond that of the DEC controllers which they emulate, by providing enhancement features such as built-in self-test during power-up, built-in disk formatting and the ability to work with disk drives of various sizes. # 1.3.2 Packaging The SCO4/C is constructed on a single, quad-size, multi-layer PC board which plugs directly into the LSI-11 chassis or an expansion chassis. No cabling is required between the computer and the disk controller. The controller obtains its power from the chassis in which it is mounted. #### 1.3.3 Self-Test The controller incorporates an internal self-test routine which is executed upon power-up. This test exercises all parts of the microprocessor, buffer and disk data logic. Although this test does not completely test all controller circuitry, successful execution indicates a very high probability that the controller is operational. If the controller fails the self-test, it leaves the LED on and the controller cannot be addressed from the CPU. # 1.3.4 Buffering The controller contains a 1K $\times$ 8 high-speed RAM buffer. It is used to store the device registers of the controller plus a full 512 byte data sector. This buffering permits multiple sector reads with a 3-to-1 sector interlace format. Buffer operations eliminate the possibility of a data late condition and permits the controller to be operated at low bus priorities. # 1.3.5 Error Correction The controller incorporates a 32-bit error correcting code (ECC) capable of correcting single error bursts of up to 11 bits in length and detecting bursts of longer length. The controller determines the location of the error and the pattern so that the software may correct the data after it is transferred to memory. A 32-bit CRC is employed with the header of every sector. # 1.3.6 Option and Configuration Switches Sockets provide for insertion of optional 512 word boot strap PROMS and Q Bus termination resistor packs. Provisions are also made to enable an optional software-controlled line time clock (LTC) which is BDV11 compatible. DIP switches are used to configure the controller for various disk sizes, Q Bus addresses and options. It is possible to select one of 64 possible combinations of disk characteristics for the two drives which can be handled by the controller, inculuding mixtures of disk sizes and drive type codes. ## 1.4 FUNCTIONAL COMPATIBILITY # 1.4.1 Media Compatibility In all cases, the headers written on the drives are not standard RK06/RK07 headers. In addition a 3-to-1 sector interleave is generated by the hardware formatter. Packs may be formatted using software commands, or by utilizing the hardware formatting capability of the extended command set. Disk packs formatted with an SC04/C controller are not media compatible with other Emulex controllers or with RK06/RK07 packs. # 1.4.2 Disk Mapping Depending upon the type and size of the disk drive, one to eight logical units may be mapped on it. Various mapping organizations are used; most of which do not leave direct 1:1 correlation between the logical and physical addresses. Table 1-1 RK611/RK06/RK07 Disk Subsystem Characteristics | | Spec | eifications | |-------------------------|--------|-------------| | Characteristics | RK06 | RKO7 | | Platters/Drive | 2 | 2 | | MBytes/Logical Unit | 13.8 | 27.4 | | Blocks/Drive | 27,126 | 53,790 | | Tracks/Cylinder | 3 | 3 | | Cylinders/Drive | 411 | 815 | | Sectors/Track | 22 | 22 | | Data Bytes/Sector | 512 | 512 | | Drives/Controller, Max | 8 | 8 | | Speed, RPM | 2400 | 2400 | | Bit Density, (BPI) | 4040 | 4040 | | Data Rate, (KBYTES/SEC) | 204.8 | 204.8 | # Table 1-2 General Specification #### Functional Emulation DEC RK06 and RK07 Media Format 3-to-1 sector interlace Drive Interface ANSI Standard Number of Drives 8 maximum Error Control 32-bit ECC for data and 32-bit CRC for headers. Correction of single data error burst of up to 11 bits. Sector Size 256 words (512 bytes) Sectors/Track Selectable for each physical drive Tracks/Cylinder Selectable for each physical drive Cylinders/Drive Selectable for each physical drive Drive Type Code Selectable RK06 or RK07 for each physical drive Computer Interface LSI-11 Q Bus Vector Address 210 Standard, 150 Optional Priority Level Level 5 Data Bufferring 1 Sector (256 words) Data Transfer High speed DMA operation Self-Test Extensive internal self-test on powering up # Table 1-2 (Cont.) General Specification Functional Indicator Activity/Error/Status LED Options 512 word bootstrap/Q Bus terminators/BDV11 compatible line time clock(LTC) control Q Bus Addresses Controller registers: 777440-777476 Bootstrap prom: 773000-773776 and 765000-765776 LTC register: 777546 Design High-speed bipolar microprocessor using 2901 bit-slice components Physical Mounting Any LSI-11 Quad slot in CPU or expansion box Connectors One 60-pin A cable flat connector and two 26-pin B cable connectors. (Flat cable type.) Electrical Q Bus Interface DEC approved line drivers and receivers Drive Interface Differential line drivers and receivers. A cable accumulative length to 35 feet. B cable length to 25 feet. Power +5V,5%,5. ## 2.1 CONTROLLER ORGANIZATION A block diagram showing the major functional elements of the SCO4/C controller is shown in Figure 2-1. The controller is organized around a 8-bit high-speed bipolar microprocessor. The ALU and register file portion of the microprocessor are implemented with two 2901 bit slice components. The microinstruction is 48 bits in length and the control memory of 2K words is implemented with twelve $2K \times 4$ PROM's. The controller incorporates a 1K $\times$ 8 high-speed RAM buffer which is used to store the controller's device registers and one sector (512 bytes) of data buffering. The Cable Register (CR) provides the storage of all cable signals going to the disk drives. The inputs from the selected drive are testable by the microprocessor. Serial data from the drive is converted into 8-bit parallel data and transferred to the buffer via the microprocessor. Likewise, the data access from the buffer by the microprocessor is serialized and sent to the drive under the control of the servo clock received from the drive. A 32-bit ECC Shift Register is used to generate and check the ECC for the data field. The same register is also used in a 32-bit CRC mode for the headers. The actual ECC polynomial operation is done independent of the microprocessor, but the determination of the error position and error pattern is done under the control of the microprocessor. The Q Bus interface consists of 36 bidirectional and 2 unidirectional signal lines. The Q Bus interface is used for programmed I/O, CPU interrupts, and data transfers. The microprocessor responds to all programmed I/O and carries out the I/O functions required for the addressed controller register. The microprocessor also controls all DMA operations and transfers data between the Q Bus data lines and the buffer. Three sixteen pin sockets (U123, U129, U135) are provided if optional 180/390 ohm Q Bus termination is desired. In addition, two eighteen pin sockets (U101 and U103) are provided for the installation of optional bootstrap PROMS. #### 2.2 PHYSICAL DESCRIPTION The SCO4/C controller consists of a single quad-size board which plugs directly into a LSI-11 chassis. #### 2.2.1 Connectors ## 2.2.1.1 ANSI Interface Connector The 50-pin flat cable connector labeled J1 at the top edge of the board daisy-chains to all the drives for control and data transfer. Pin 1 is located on the left side of the connector. #### 2.2.1.2 Test Connectors Connectors J4 and J5 are used with the Emulex test panel during manufacturing test and factory repair. They have no use in normal operation. # 2.2.2 Switches There are three sets of switches labled SW1-SW3. SW1 is a four pole DIP 'piano-type' switch accessible from the PC board edge. Locating SW1 such that it is accessible to the operator while the controller is imbedded in a LSI type chassis, makes the selection of common options such as hardware format simpler to perform. The other two sets of switches SW2 and SW3 provide controller address decoding selection, option selection and drive configuration selection. (See Appendix A for a complete description of the switch functions.) #### 2.2.3 LED Indicator There is an LED indicator mounted between the connectors at the top of the board. The controller executes an extensive self-test when powering up. The microprogrammed organization of the controller permits most logic other than the interface circuitry to the disk to be validated before the controller becomes ready. The LED lamp is turned on as the controller starts its self-test and is turned off only when the controller successfully completes the test. If a malfunction is detected by the built-in diagnostics, the LED remains on and the controller will not respond to program I/O. The LED blinks at approximately a one second rate if the self-test is successful but no drive is seen on-line. The LED also functions as an activity indicator during read and write operations. #### 2.2.4 Firmware PROM's There are twelve PROM sockets, used for the control memory, located along the left edge of the board. The sockets are labeled ROM 0 through ROM 11 in a discontinuous physical order. The numbers on the top of the PROM ICs are Emulex part numbers, which identify the unique pattern of the PROM. When inserting PROMs in the board, the ID numbers are placed in the same sequence as the PROM numbers on the board beside each socket. ## 2.2.5 Bootstrap PROM's There are two sockets provided for the installation of optional bootstrap PROMs. The socket in location U101 receives P/N 014x and the socket in location U103 receives P/N 015x. #### 2.3 INTERFACES #### 2.3.1 Disk Interface The controllers's disk interface conforms to the ANSI X3T9/1226 Standard interface specification for disk drives. The controller has been tested with most drives using the ANSI interface and is compatable with these drives electrically and in timing. The following defines the electrical interface and the recommended cables. #### 2.3.1.1 ANSI Interface Cable The 50-conductor cable is daisy-chained to all drives and terminated at the last drive. The signals in this cable are listed in Table 2-1 along with their functions. The cable should be 50 conductor (28 AWG) ribbon cable with an impedance of 100 ohms and an accumulative length of no greater than 3 meters. The cable shield (if incorporated) shall connect to pin one of the connector. A 3M #3476-50 flate cable with shield and drain or its equivalent is recommended. It is possible to order cable assemblies from Emulex that are made up in one of four lengths: | EMULEX P/N | LENGTH (FT.) | |--------------------------------------------------------------|--------------------------| | SU0411201-01<br>SU0411201-02<br>SU0411201-03<br>SU0411201-04 | 2.0<br>4.0<br>6.0<br>8.0 | | SU0411201-05 | 10.0 | ## 2.3.2 Q Bus Interface The LSI-11 Bus consists of 36 bidirectional and 2 unidirectional signal lines. These form the lines along which the processor, memory and I/O devices communicate with each other. Addresses, data, and control information are sent along these signal lines, some of which contain time-multiplexed information. The lines are divided as follows: - 1. 18 Data/address lines BDAL00-BDAL17 - 2. Six data transfer control lines BBS7, BDIN, BDOUT, BRPLY, BSYNC, BWTBT - 3. Three direct memory access control lines BDMG, BDMR, BSACK - 4. Six interrupt control lines BEVNT, BIAK, BIRQ4, BIRQ5, BIRQ6, BIRQ7 - 5. Five system control lines BDCOK, BHALT, BINIT, BPOK, BREF # 2.3.2.1 <u>Interrupt Priority Level</u> The controller is hardwired to issue level 4 and level 5 interrupt requests. The level 4 request is necessary to allow compatibility with either a LSI-11 or LSI-11/2 processor. ## 2.3.2.2 Register Address The register address and the number of registers assigned to the controller are decoded by a PROM at U104. The selections available are determined by configuration switch SW1 as discussed in Appendix A. ## 2.3.2.3 DCOK and INIT Signals The DCOK and INIT signals both perform a controller clear. The self-test is performed only when DC power is initially applied. #### 2.4 DISK FORMAT\_ ## 2.4.1 Disk Pack Organization The formatting of a disk pack and the mapping of one or more logical drives onto a physical drive varies with the drive size. Some of this information is supplied by the configuration PROM. The rest is computed based upon configuration PROM information. In all cases, the headers actually written on the drives are not standard RK06/RK07 headers. In addition, a 3-to-1 sector interleave is generated by the hardware formatter. Disk packs formatted with an SCO4/C controller are not media compatible with other Emulex controllers or with RK06/RK07 packs. #### 2.4.2 Mapping Depending upon the type and size of the disk drive, one to eight logical units may be mapped on it. The controller can handle a maximum of eight logical units distributed across a maximum of eight physical disk drives. A logical drive may not be mapped across a physical unit boundary. The controller firmware multiplies the logical address out to obtain a block address which is then divided by the physical drive configuration constants to provide an address for the physical drive. For this reason a 1:1 correspondence between logical and physical addresses will most likely not exist. Table 2-1 <u>Disk Drive Connections</u> (J1) | Signal<br><u>Pin</u> | Ground<br><u>Pin</u> | Signal Name | Signal Source | |----------------------------------------------------------------------|----------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------| | 1 | | Ground<br>Control Bus | | | 2<br>3<br>4<br>5<br>6<br>7<br>8<br>9<br>11 | 10<br>10<br>10<br>10<br>10<br>10<br>10<br>10 | Bit 0, Select/Attn. Device 0 Bit 1, Select/Attn. Device 1 Bit 2, Select/Attn. Device 2 Bit 3, Select/Attn. Device 3 Bit 4, Select/Attn. Device 4 Bit 5, Select/Attn. Device 5 Bit 6, Select/Attn. Device 6 Bit 7, Select/Attn. Device 7 Parity (optional) | Host/Device Host/Device Host/Device Host/Device Host/Device Host/Device Host/Device Host/Device Host/Device | | 13<br>15<br>17<br>19<br>21<br>23<br>25<br>27<br>29<br>31<br>33<br>35 | 14<br>16<br>18<br>20<br>22<br>24<br>26<br>28<br>30<br>32<br>34<br>36<br>36 | Select Out/Attn. In Strobe Command Request Parameter Request Bus Direction Out Port Enable Address Mark Control (optional) Read Gate Write Gate Bus Acknowledge Index Sector/Address Mark Detected Attention Busy | Host Host Host Host Host Host Host Device Device Device Device Device | | 39<br>40<br>42<br>43<br>45<br>46<br>48 | 38<br>38<br>41<br>41<br>44<br>44<br>47<br>47 | Read Data + Read Data - Read/Reference Clock + Read/Reference Clock - Write Clock + Write Clock - Write Data + Write Data - Ground | Device Device Device Host Host Host | Table 2-2 Q Bus Connections | | | <u>A</u> | | <u>B</u> | |---|-------|-------------|----------------|----------| | | 1 | <u>2</u> | <u>1</u> | <u>2</u> | | A | BIRQ5 | <b>+</b> 5♥ | BDCOK | +5V | | В | BIRQ6 | | врок | | | C | BAD16 | GND | | GND | | D | BAD17 | | | | | E | | BDOUT | | BDAL02 | | F | | BRPLY | | BDAL03 | | Н | | BDIN | | BDAL04 | | J | GND | BSYNC | $\mathtt{GND}$ | BDAL05 | | K | | витвт | | BDAL06 | | L | | BIRQ4 | | BDAL07 | | M | GND | BIAKI | GND | BDAL08 | | N | BDMR | BIAKO | BSACK | BDAL09 | | P | BHALT | BBS7 | BIRQ7 | BDAL10 | | R | BREF | BDMGI | BEVNT | BDAL11 | | S | | BDMGO | | BDAL12 | | T | GND | BINIT | GND | BDAL13 | | U | | BDALOO | | BDAL14 | | V | | BDAL01 | | BDAL15 | ## 2.4.3 Sector Format Each sector contains a detached two-word header and a 256 word data field. The header field is terminated with a two vertical check characters and the data field is terminated with a 32-bit ECC. The controller attempts corrections only on the data field, never on the header. Each field is preceded by at least 11 bytes of zero's and an 8-bit SYNC byte. The second header check character is not visable to the software which allows the header to be compatible with existing RK06/RK07 software. In detail, each sector is organized as follows: # Figure 2-1 Sector Format | Sector Length 562 Bytes | | | | | | | | | | | |-------------------------|------|--------|-----|----------|------|------|-------|-----|----------|--| | Preamble | Sync | Header | CRC | Preamble | Sync | Data | Field | ECC | Recovery | | | | | | | | | | 3* | | | | <sup>\*</sup>Values shown are minimus which apply to most Winchester type units. However, these calues may vary to accommodate different physical drive types and are determined by configuration PROM data. ## 2.4.3.1 Header Field The header preamble is used to synchronize the Phase Locked Oscillator (PLO) in the drive to the data on the pack. The SYNC byte is used by the controller to synchronize to the data bytes and their boundaries, and by the drive to synchronize to the phase of the data stream. The two header data words are organized as follows: - Word #1 Logical cylinder address, right justified. - Word #2 Logical track and sector addresses, in low byte, sector in bits 4-0, track in bits 7-5. Flags in high byte, bits 15 and 14 are good sector flags, bit 9 is the 20 sector format flag, and bits 13, 12, and 10 are used to flag a replaced track. - Word #2 Header Check Word (exclusive-OR of words one and two). # Figure 2-2 Header Format | He | - 4- | . ~ | Mo | n d | 1. | |-----|------|-----|-----|------|-----| | ne: | ลดค | יץי | wo: | ריכו | 1 2 | | 15 | 14 | 13 | 12 | 11 | 10 | 09 | 08 | 07 | 06 | 05 | 04 | 03 | 02 | 01 | 00 | |----|----|----|----|----|----|----|----|----|------|------|------|----|----|----|----| | 0 | 0 | 0 | 0 | 0 | 0 | | | Су | lind | er A | ddre | ss | | | | # Header Word 2: | 15 | 14 | 13 | 12 | 11 | 10 | 09 | 08 | 07 | 06 | 05 | 04_ | 03 | 02 | 01 | 00_ | |-----------|----------|----|----|----|----|-----|----|----|-----|------|-----|------|------|------|-----| | G:<br>Fl: | S<br>ags | 0 | 0 | 0 | 0 | FMT | 0 | Tr | ack | Addr | | Sect | or A | ddre | ss | ## Header Word 3: Header Track ID Byte: Header Check Word: To provide additional header integrity, the physical unit trac': number is written. It is in turn followed by an additional check word. This information is not available to the software (i.e., it is transparent), and it is checked entirely under SCO4 control during header operations. ## 2.4.3.2 Data Field The data field preamble and SYNC bytes have the same functions as the header preamble and SYNC bytes. The data field itself is always 256 words long. Any unused portion of the sector will be terminated with zero bytes during a write operation. The 32-bit ECC is generated during a write, and is used during a read to check the validity of the data. Any single error burst anywhere in the data field of 11 bits or less can be corrected. The error pattern and position are located by the controller, the software may then perform the correction of the data after it is transferred to memory. # 2.4.3.3 Postambles The postambles provide areas for turning off the write amplifiers, for turning on read amplifiers, and for switching from read-to-write. Write splices will exist within all of these areas. The sector pulse postamble will also include a head-scatter area on removable media drives. #### 2.4.3.4 Recovery Area The recovery area along with the preceeding postamble is required for head - scatter tolerances on removable media drives. #### 2.5 GENERAL PROGRAMMING INFORMATION #### 2.5.1 Deleted Commands The SCO4/C emulates the RK611 controller in its responses to all normal commands and register modifications except the diagnostic mode commands. The diagnostic mode commands (DMD bit in RKMR1 set) will cause the controller to go busy for approximately 40 microseconds after which the controller will become ready and will request an interrupt if interrupts enabled as in other commands; however, the command function will be ignored and not executed. #### 2.5.2 Extended Commands The SCO4/C will execute an extended set of commands not found on the RK611 controller. To execute any of the extended commands, an enable flag must be set prior to issuing the command. To set the enable flag (flag exists only in firmware register), the Spare Register must contain a 1 in bit 15 and a 0 in bit 14 as the RKMR3 register is written (normally a read-only register) with all ones. The enable flag is cleared by a controller reset, subsystem clear, bus INIT, or by executing any command. The following commands are effective only if the enable flag is set. Attempting any extended command except "27" without the enable flag set will result in the illegal function (ILF) bit of RKDS being set along with the controller error (CERR) bit of RKCS1. ## 1. Hardware Format The hardware format command (code 27 in RKCS1) will cause the entire logical drive to be formatted. All headers are written and the data fields are written with the bad sector file format which includes the pack ID number. The number entered into the Spare Register (177462) will be used for the pack ID. The word count, Disk Address Registers and Bus Address Registers are not used in this command. The controller will become ready and will interrupt the processor (if enabled) when finished. # 2. Logical Write Protect This command serves many functions, one of which is to logically write protect a logical drive. This command is executed by writing a "33" command into RKCS1 after which bits 7-0 of the Spare Register will be copied and used as the write protect switches for drives 7-0 respectively. A set bit will cause a drive to be write protected; a reset bit will cause the drive to be not write protected only if the physical disk unit which the drive is mapped onto is also not write protected. A second function of this command is to load a firmware Switch Register. When the command is executed, bits 13-8 of the Spare Register (177462) are copied to an internal firmware Switch Register. The Switch Register bits are cleared by writing into them with this command or whenever a power-up sequence occurs on the controller. Only one switch (bit 9) is used presently. Its function when set, is to limit the number of disk revolutions before a header search may abort to one revolution. Normally the search is continued for four revolutions except for write check commands, for which it is limited to one revolution also. A third function of this command is to fill the data silo (177464) with the first 255 words of the Firmware Register block which contains the Controller Registers and configuration constants. Successive reads of the silo may then enable software to read this information for diagnostic purposes. As with other commands, the controller will become ready and interrupt the processor (if enabled) when its function is completed. ### 3. Read Unit Headers This command is used primarily to verify tracks of headers written to implement the track replacement function. It is executed by writing a "35" command in RKCS1. It differs from a standard read header command in that an entire track of headers (physical unit track) is read to the silo with one command. The headers are in order starting with the one after the index pulse and following the three to one interlace pattern until the last header is read. The RKDC and RKDA Registers must be loaded prior to this command with the desired physical cylinder and track to be read, as in the special write header command. # 4. Write Unit Headers This command is executed by writing a "37" command into RKCS1. Its primary function is to write headers to implement the track replacement function. It is similar to a normal write header command except that physical unit addresses are used instead of logical drive addresses. Before issuing the command, the RKDC Register must contain the physical cylinder address, the RKDA Register must contain the physical track address (no sector - just 10 bits of right justified track address), and the RKWC and RKBA Registers must point to a memory block with the data to be written in the headers and with enough data for an entire physical disk track of headers. To implement the track replacement function, the track to be replaced must be filled with headers of the following pattern: 1st Word - new physical cylinder address 2nd Word - new physical track address with bits 13, 12, and 10 additionally set to flag the track replace mode 3rd Word - exclusive "OR" of words one and two The replacement track must then be written using this command with the normal header format as would be found on the replaced track. #### 2.5.3 22 Bit Memory Addressing To use the 22 bit address capability, the Spare Register bits 0-5 become the extended memory address bits 16-21. Bits 0 and 1 of the Spare Register (177462) are identical to bits 8 and 9 of RKCS1 and may be accessed by using either register. This function is only enabled if the Spare Register contains 0220XX where XX is the extended memory address bits. #### 2.5.4 Line Clock The Line Clock Register has a bus address of 777546. It is a one-bit write-only register. Reads to this register return unspecified data. Bit 6 is the only bit implemented. Any write to this register with bit 6 = 1 enables the line clock. Any write to this register with bit 6 = 0 disables the line clock. Once the line clock is enabled (assuming the hardware enabling has been completed properly), the clock will interrupt via interrupt vector location 100. The enable bit need not be set again after an interrupt has been processed. The clock will continue to interrupt until bit 6 is reset or an INIT is generated. # 2.5.5 Bootstrap Routine The bootstrap routine is entered into at location 773000. Note that the CPU board can be jumpered to start at this location automatically on a power-up (or external DCLO set-reset). The bootstrap program will print a carriage return, line feed, and dollar sign (\$) on the standard terminal (bus addresses 777560-777564) when entered into. At that point it is ready for terminal input. If no \$ is printed, then the boot program failed one of the six CPU tests it executes prior to entering terminal input mode. Once the \$ has been printed, the boot program is ready for input from the terminal. The user should enter one of the two-character codes from the list at the end of this section (plus a single octal number if the unit number to be booted is not zero) followed by a carriage return. If the two-character code is recognized, then the routine that the code represents will be executed. If the code is not recognized, a question mark (?) is printed, followed by the \$. The code to use for this controller is "DM". If the code selected represents a peripheral device boot routine, then the controller will execute three more CPU tests and two memory tests prior to executing the actual boot. The two memory tests will check all available memory, but they require a minimum of 8K bytes (0-17776) to operate. The following codes are available (note: DB and DR are interchangeable): XC = Execute CPU tests 7-9 only. XM = Execute memory tests only. OD = ODT Halt. No routines executed. A proceed (P) returns the program to the terminal input mode. MTn = TM11 mag tape boot. Can boot units 0-7. DXn = RXV11 floppy disk boot. Can boot units 0-1. DKn = RK05 disk boot. Can boot units 0-7. RPn = RP02/3 disk boot. Can boot units 0-7. DMn = RK06/7 disk boot. Can boot units 0-7. DBn = RM02/3/5 disk boot. Can boot units 0-7. DRn = RP04/5/6 disk boot. Can boot units 0-7. RPn = RP02/RP03 disk boot. Can boot units 0-7. Note: If "n" is not entered, a default unit number of 0 is assumed. The following is a list of halt locations which the PROM program will execute should the boot be unsuccessful. | HALT Address | Reason for HALT | |---------------------------|---------------------------------------------------------------------| | 765320 | Non-existent unit, unit not on-line and ready, controller ready = 0 | | 765612 | Read Error, Disk Error aborted read | | 765674 | Read failed to complete within time limit | | 773434 | Failure in CPU test #7 | | 773530 | Failure in CPU test #8 | | 773550, 773556, or 773604 | Failure in CPU test #9 | | 773730 | Failure in Memory test #1 | | 773760 | Failure in Memory test #2 | This section describes the step-by-step procedure for installation of the SC04/C Disk Controller in a LSI-11 system. #### 3.1 INSPECTION A visual inspection of the board is recommended after unpacking. Specific checks should be made for such items as bent or broken connector pins, damaged components or any other visual evidence of physical damage. The PROM's should be examined carefully to insure that they are firmly and completely seated in the sockets. # 3.2 DISK DRIVE PREPARATION The disk drive must be configured for the proper number of sectors, and have an the address selection switches properly configured. #### 3.2.1 Sectoring See Appendix A for the correct sector count settings for the disk drives in use. The exact method of entering the sector count differs from one drive manufacturer to another and the particular drive manual should be consulted for the exact procedure. #### 3.2.2 Address Selection An address from 0 to 7 must be selected for each drive. Be careful that drives are not assigned the same number. Drive addresses are usually selected by means of switches or jumpers on one of the logic cards. The particular drive manual should be consulted for the exact procedure. #### 3.3 CONTROLLER CONFIGURATION The user must select between a number of physical and logical drive configurations and several other options including the controller's Q Bus address. Option and configuration selection must be done before inserting the controller into the chassis. The selections are made using SW1, SW2 and SW3. #### 3.3.1 Address Selection One of two Q Bus address ranges can be selected for the controller. The range from 177440 to 177476 is the standard controller address (SW3-2 CLOSED, SW3-3 OPEN). The range from 176700 to 176736 is the alternate controller address (SW3-2 OPEN, SW3-3 CLOSED). # 3.3.2 Interrupt Vector Selection One of two interrupt vectors cmust be selected for the controller, 210 or 150. The standard vector is 210 (SW2-7 OPEN). The alternate interrupt vector is 150 (SW2-7 CLOSED). # 3.3.3 Drive Configuration Selection The first six and the last two switches of ten pole DIP switch SW2 are used to form one of 192 binary numbers that correspond to a selected drive configuration. Refer to Appendix A for detailed switch setting instructions. # 3.3.4 Line Clock Option When SW3-5 is closed, the SC04/C emulates the DEC BVD11 clock. This option should be disabled if there is another clock present in the system. ## 3.3.5 Bootstrap PROM Option If the bootstrap PROM option is to be used, install PROM 015x in U101 and PROM 014x in U103 and CLOSE SW3-4. SW3-4 must be left OPEN if the option is not installed. ## 3.3.6 User Selectable Options Other switch selectable user options are available. See Appendix A, paragraph A.3 for switch function definitions. ## 3.4 PHYSICAL INSTALLATION #### 3.4.1 Q Bus Terminator Option To provide the equivalent of 120 ohms electrical termination to the Q Bus, DIP resistor networks are installed in U123, U129, and U135. These resistor packs provide a 180 ohm resistor connection to +5 volts and a 390 ohm resistor connection to ground on each Q Bus line. These three resistor networks may be ordered from Emulex or the custormer may provide his own terminating resistor networks by using an equivalent part such as BOURNS P/N 4116R-003-181/391, or BECKMAN 898-5-r180/390, or CTS 761-5-R181/391. ## 3.4.2 Slot Selection If the three optional Q Bus terminator resistor networks are installed, the SCO4 should be installed in a quad slot such that it provides the termination required at the end of the bus. If the optional Q Bus terminators are not installed, the SCO4 may be assigned to any desired slot since it uses the LSI four-level interrupt scheme to perform distributed interrupt arbitration. # 3.4.3 Mounting The controller board should be plugged into the LSI-type backplane with components oriented in the same direction as the CPU and other modules. Always insert and remove the board with the computer power OFF to avoid possible damage to the circuitry. Be sure that the board is properly situated in the throat of the connector before attempting to seat the board by means of the extractor handles. # 3.5 CABLING The subsystem cabling of the drives and controller is shown in Figure 3-1. # 3.5.1 ANSI Interface Cable The 50-wire ANSI interface cable should be plugged into connector J1 on the controller and wired to the first drive. If a second drive is used, then it is daisy-chained to the first. The last drive on the cable must have a terminator installed. This part is available from the drive manufacturer. The terminator is generally plugged into one of the two cable connectors on the drive. Some drives have only one connector. In such cases, a special cable or "T" connector is required to connect multiple drives. No terminator is required for the last drive if the that drive has only one connector (exception: if a "T" is used, the unused side of the "T" should be terminated). NOTE: The connectors are not keyed and can be physically reversed in the header. No damage should result, but the system will not operate. ## 3.5.2 Grounding For proper operation of the disk subsystem, it is very important that the disk drives have a good ground connection to the logic ground of the computer. The ground connection should be a 1/4 inch braid (preferably insulated) or AWG No. 10 wire or larger. The grounding wire may daisy-chain between drives. If the drive has a switch or jumper which connects the logical signal ground to the cabinet ground (DC ground to AC ground), this connection should be removed once the drive is put on-line with the controller. It can be connected for performing local off-line maintenance on the drive. NOTE: Failure to observe proper grounding methods will generally result in marginal operation with random error conditions. ### 3.6 TESTING ### 3.6.1 Self-Test When power is applied to the CPU, the controller automatically executes a built-in self test. This test is not executed with every bus INIT but only on powering up. If the self test has been executed successfully, the LED on the top edge of the controller board will be OFF or flashing. The LED flashes when the controller cannot address at least one drive after successfully executing its self test. This will occur if the cable is not properly plugged in, a drive is not powered up, or two drives have the same unit number. If the LED is ON steadily the controller did not pass its self test and the controller cannot be addressed from the CPU. # 3.6.2 Register Examination After powering up the CPU and noting that the LED indicator is not ON steadily, a quick check should be made to ensure that the controller registers can be read from the computer console. The Control Status Register (RKCS1) 177440 will contain 000200 if the controller is ready. To determine the on line status of the selected drive check the Device Status Register (RKDS) 177452 (see Section 4. If the CPU has a console emulator, all the registers of the controller should be examined. # 3.6.3 Hardware Formatting the Disk The controller has the means to format the disk by writing headers and bad sector file data in all sectors of the disk. This command does not verify the data or headers. If the drive is on line, the formatting is carried out as follows: - 1. Perform a subsystem clear by depositing 000040 into RKCS2 (177450). - 2. Select the drive to be formatted by depositing the drive number in the least significant bits of RKCS2 (177450). - 3. Deposit a number to be used as a pack ID in the Spare Register (177462); bit 15 of this number must be set, and bit 14 must be reset. - 4. Deposit a pack acknowledge command (38 for RK06 or 20038 for RK07) in RKCS1 (177440). - 5. Deposit all ones in RKMR3 (177476) which is a "read-only" register, to enabled extended command set. - 6. Deposit a hardware format command (278 for RK06 or 20278 for RK07) in RKCS1 (177440) to start formatting. The operation will finish in a couple of minutes with the RDY bit set in RKCS1. # Section 4 CONTROLLER REGISTERS There are 16 device registers in the controller. These are used to interface the controller to the computer. The registers are loaded and/or read under program control in order to initiate selected disk commands, and monitor status and error conditions. NOTE - The registers must be written with word operations. # 4.1 CONTROL/STATUS REGISTER 1 (RKCS1) 777440 | | | 01 00 | |----------------------------------------------|-------|-------| | CERR DI DTC CFMT CTO CDT A17 A16 RDY IE O F3 | F2 F1 | FO GO | The RKCS1 register can be read or written via program control and is used to store the current disk command code and operational status of the controller. In addition, the register can initiate command execution and controller clear operation. ## Combined Error/Controller Clear (CERR/CCLR) - Bit 15 As a Combined Error (CERR) indicator, bit 15 is set by the controller to indicate that a subsystem error has occurred. However, when the bit is set via program control, a controller initialize (CCLR) operation is enabled which clears the controller, and results in the clearing of bit 15 itself. Thus, if the bit is internally set (CERR) by an error that is followed by an external set (CCLR) to initialize the controller, bit 15 will be cleared. However, since only controller errors will be initialized by CCLR, any error originating in a drive will remain set in the drive. NOTE: When using a BIC instruction on the RKCS1 register, ensure that a 1 is set in bit 15 of the mask. If this is not done, and CERR is set, a CCLR will occur, and the RK611 will be cleared. For example, to clear the Interrupt Enable (IE) bit (bit 6 in RKCS1), the following instruction format is recommended: BIC #100100, @RKCS1 #### Drive Interrupt (DI) - Bit 14 Drive Interrupt is a read-only bit which is set to differentiate between a drive-initiated interrupt and a controller-initiated interrupt. The DI bit is set when any drive sets its Attention (ATNO-ATN7) bit (8-15 in RKAS/OF). Thus, if the Interrupt Enable (IE) bit is set, the setting of the DI bit in conjunction with Controller Ready (RDY), bit 7 in RKCS1, indicates a drive-initiated interrupt. The DI bit is reset by Initialize (INIT), Subsystem Clear (SCLR), or by the execution of Drive Clear commands to all drives asserting Attention. # Drive-To-Controller Parity Error (DTC PAR) - Bit 13 The DTC Parity Error is a read-only bit that is set on the termination of a command if Parity Test (bit 4 of RKMR1) is set. This bit is for diagnostic compatibility only. # Controller Format (CFMT) - Bit 12 This bit must alway be reset to indicate 22 sector format, which is all the controller emulates of the RKO6. # Controller Time-Out (CTO) - Bit 11 Controller Time-Out is a read-only error bit that is set to indicate that GO, bit O in RKCS1, has been set for approximately 800 ms. Since this interval exceeds the time required to execute the longest possible drive operation (i.e., a Seek from cylinder 410 to cylinder O followed by a 65K word data transfer), the set condition of this bit indicates that the last command has not been completed due to a malfunction. # Controller Drive Type (CDT) - Bit 10 This bit specifies the type of drive that will be selected by the controller. To specify RKO6 Disk Drives, the bit must be reset. # Extended Bus Address (A16, A17) - Bits 8, 9 The Extended Bus Address bits reflect Q Bus upper address bits 16 and 17, and as such are an extension of the 16-bit RKBA register which contains the memory address required for the current data transfer. #### Controller Ready (RDY) - Bit 7 Controller Ready (RDY) is a read-only bit. The bit can be externally set via conventional initialization (INIT, CCLR, SCLR), or internally set upon completion of a command. The RDY bit is reset when GO, bit O in RKCS1, is set. # Interrupt Enable (IE) - Bit 6 When the Interrupt Enable (IE) bit is set, the controller will be allowed to interrupt the processor at the end of a command execution or by any ATN being asserted. An interrupt is generated by writing 1's into IE and RDY at the same time. # Function Code (F3-F0) - Bits 4-1 The configuration of the Function Code bits (F3-F0), in conjunction with the setting of the GO bit, allows the selected drive to respond to the following command control configuration. | 01 | Celect Drive | 21 | Read Data | |----|------------------|----|------------------------------| | 03 | Pack Acknowledge | 23 | Write Data | | 05 | Drive Clear | 25 | Read Header | | 07 | Unload | 27 | Write Header | | 11 | Start Spindle | 31 | Write Check | | 13 | Recalibrate | 33 | *Set Logical Write Protect | | 15 | Offset | 35 | *Reset Logical Write Protect | | 17 | Seek | 37 | *Set Logical Write Protect | # Go (GO) - Bit 0 When the GO bit is set, the disk command Function Code (F4 FO) is executed. With the GO bit set, only two other device register bits can be set (Diagnostic Mode excepted), as follows: - controller Clear (CCLR), bit 15 in RKCS1, may be set via program control in order to initialize (general clear and preset) certain device registers within the controller. However, any status and/or error conditions set in the drives are not effected. - Subsystem Clear (SCLR), bit 5 in RKCS2, may be set via program control in order to initialize both the controller and all of the drives. When command execution is completed, the GO bit is reset and the controller is ready to accept a new command. However, the GO bit cannot be set if the Combined Error (CERR) bit is set. When CERR is set, the execution of a command can only occur following the initiation of a CCLR. These commands are illegal and will set the ILF bit in the RKER register unless an enabling procedure is performed before each issuance of the command. To enable these commands, location 177462 (spare register) must contain a one in bit 15 and a zero in bit 14 while location 177476 (RKMR3) is written with all ones. # 4.2 WORD COUNT REGISTER (RKWC) 777442 The RKWC is loaded with the 2's complement of the number of data words to be transferred to or from main memory. The register is incremented by 1 after each word transferred, and accommodates a maximum transfer of 65,356 words. The data transfer stops when the RKWC reaches zero. The RKWC is not cleared by INIT or controller clear. # 4.3 BUS ADDRESS REGISTER (RKBA) 777444 | | 15 | 14 | 13 | 12 | 11 | 10 | 09 | 08 | 07 | 06 | 05 | 04 | 03 | 02 | 01 | 00_ | |---|----|----|----|----|----|----|-------|------|------|------|----|----|----|----|----|-----| | | | | | | | | | | | | | | | 7 | | | | 1 | | | | | | Bu | ıs (M | emor | y) A | ddre | SS | | | | | 1 | | | | | | | | | | | | | | | | | | | The RKBA register is initially loaded with the low-order 16 bits of the Q Bus address of the main memory starting location for a data transfer. The low-order bit (0) is always forced to a 0. The RKBA register is incremented by 2 after transfer of a word to or from memory, if BAI (bit 4, RKCS2) is not set. Overflow of this counter increments A16 and A17 in RKCS1. # 4.4 DISK ADDRESS REGISTER (RKDA) 777446 | 15 | 14 | 13 | 12 | 11 | 10 | 09 | 08 | 07 | 06 | 05 | 04 | 03 | 02 | 01 | 00_ | |----|----|----|----|----|----|--------------|----|----|----|----|----|-------|------|------|-----| | 0 | 0 | 0 | 0 | 0 | 1 | rack<br>dres | | 0 | 0 | 0 | S | Secto | r Ad | dres | s | The RKDA is used to address the sector and track on the drive to or from which the data transfer is desired. It contains a 5-bit sector address counter which is incremented by one at the end of every sector transferred. After reaching a maximum count of 21, it resets to 0. The register also contains a 3-bit track address counter which is incremented everytime the sector address counter reaches maximum count. When this counter reaches maximum count of 2, it reset to 0 and causes the RKDC register to be incremented by one. #### 4.5 CONTROL/STATUS REGISTER 2 (RKCS2) 777450 | | 02 | 03 | 04 | 05_ | 06 | 07 | _08_ | 09 | 10 | 11 | 12 | 13 | 14 | _15 | |------------------------------------------------|----|----|-----|------|----|----|------|-----|-----|-----|-----|-----|-----|-----| | DLT WCE UPE NED NEM PGE MDS O OR IR SCLR BAI O | U2 | 0 | BAI | SCLR | IR | OR | 0 | MDS | PGE | NEM | NED | UPE | WCE | DLT | The RKCS2 register can be read or written via program control and is used to store the current drive select code, subsystem operational status, and Silo control information. In addition, the register can initiate a Subsystem Clear (SCLR) operation. #### Data Late Error (DLT) - Bit 15 This bit is not set during data transfers because of the full sector buffering used in the controller. It can only be set by accessing RKDB without the OR bit in RKCS2 set. # Write Check Error (WCE) - Bit 14 Write Check Error is a read-only error bit that is set to indicate that a data word read from the disk during the execution of a Write Check command did not compare with the corresponding data word contained in main memory. If a write check error is detected and the BAI bit is not set, the RKBA register will contain the memory address of the next data word location (mismatched word address plus two). # Q Bus Parity Error (UPE) - Bit 13 Q Bus Parity error is a read only bit that is set if a parity error occurs in the Q Bus memory while the controller is performing a Write or Write Check command. When the error occurs, the RKBA register contains the address of the word following the word with the parity error (if BAI is not set). #### Non-Existent Drive (NED) - Bit 12 Non-existent Drive is a read-only bit that is set when the program issues a command with the GO bit in RKCS1 set to a drive which is not emulated or is located on a physical unit which is not currently available at one of the controller ports. ## Non-Existent Memory (NEM) - Bit 11 Non-existent Memory is a read-only bit that is set when the controller is performing an NPR transfer and the memory does not respond within 10 microseconds. The memory address displayed in RKBA is the address of the word following the memory location causing the error. #### Programming Error (PGE) - Bit 10 Programming Error is a read-only error bit that is set if any controller register is written (bits for CCLR and SCLR excepted) while the GO bit in RKCS1 is set. #### Multiple Drive Select (MDS) - Bit 9 Multiple Drive Select is a read-only error bit that is set when the controller detects two or more physical disk units responding to the same address. #### Output Ready (OR) - Bit 7 Output Ready is a read-only bit that is set to indicate that a word is in the Silo output buffer. The bit is cleared by conventional initialization (INIT, CCLR, SCLR), or by the setting of the GO (bit O in RKCS1). # Input Ready (IR) - Bit 6 Input Ready is a read-only bit that is set to indicate that the Silo input buffer is ready to accept a word. Conversely, the bit is reset to indicate that the Silo is full and cannot accept a word. The IR bit is also set by conventional initialization (INIT, CCLR, SCLR), or by the setting of the GO (bit 0 in RKCS1). # Subsystem Clear (SCLR) - Bit 5 When the SCLR bit is set via program control, the controller is cleared and all status for the connected drives is initialized. # Bus Address Increment Inhibit (BAI) - Bit 4 When the BAI bit is set, the RKBA register is prevented from incrementing during data transfers. This is primarily a diagnostic aid. ### Unit Select (U2-U0) - Bits 2-0 The Unit Select bits select one of eight logical drives. These are read/write bits. # 4.6 DRIVE STATUS REGISTER (RKDS) 777452 | _15 | 14 | 13 | 12 | 11 | 10 | 09 | 08 | 07 | 06 | 05 | 04 | 03 | 02 | 01 | 00 | |-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----| | | | | | | | | | | | | | | | | DRA | The RKDS register is a read-only register that is used to store the operational status of the selected drive. However, information obtained from the drive is not necessarily current or correct unless bit 15 (SVAL) is set. Status information bits set in the RKDS register can be cleared by conventional initialization (INIT, CCLR, SCLR). However, a Controller Clear (CCLR) operation does not affect status or error condition bits that are currently set in the drives. In addition, a Q Bus Initialize (INIT) or Subsystem Clear (SCLR) operation can only reset status or error bits in a drive if the associated status or error condition no longer exists. # Status Valid (SVAL) - Bit 15 Status Valid is a read-only bit that is set to indicate that the bits in both the Drive Status (RKDS) and Error (RKER) registers have been updated for the selected drive. The bit is cleared by conventional initialization (INIT, CCLR, SCLR), initiating a new command (writing into RKCS1), selecting a new drive (writing into RKCS2), or whenever at Attention signal is asserted by the selected drive for a drive status change. ## Current Drive Attention (CDA) - Bit 14 Current Drive Attention is a read-only bit that is the logical equivalent of the Drive Status-Change (DSC) bit in the drive defined by the unit select in RKCS1. The assertion of attention indicates that the selected drive has completed a Seek, Offset, Recalibrate, Start Spindle, or Unload command, that the drive has been taken off-line or put on-line by the operator, or that a fault condition exists in the drive. ## Positioning-in-Progress (PIP) - Bit 13 Positioning-in-Progress is a read only bit that is set to indicate that the head carriage on the logical drive is in motion. ## Write Lock (WRL) - Bit 11 Write Lock is a read-only bit that is set if the selected drive is write protected. A drive may be physically or logically write protected. ## Disk Drive Type (DDT) - Bit 8 Disk Drive Type is a read-only bit that is internally conditioned to indicate the type of drive selected. This bit is set to indicate an RK07 drive or reset to indicate an RK06 drive. This bit must compare with the condition of Controller Drive Type, bit 10 in RKCS1, before any command may be executed. ## Drive Ready (DRY) - Bit 7 Drive Ready is a read-only bit that is set to indicate that the selected drive is up to speed and the heads are properly positioned over a valid cylinder. Under these conditions, the drive is prepared to receive a command. ## Volume Valid (VV) - Bit 6 Volume Valid is a read-only bit that is set to indicate that the Volume Valid flip-flop has been set in the selected drive by a Pack Acknowledge command. The set condition of the bit ensures the program that the cartridge and the unit number plug have not been changed since the last command was issued to the drive, and power has not been removed. The bit is reset when the cartridge, the unit number plug, or ac power is removed from the physical disk unit. #### Speed Loss (SL) - Bit 4 This bit is a read-only bit which is always reset for the SCO4/C emulation. ## Drive AC Low (ACLO) - Bit 3 Drive AC Low is a read-only bit that is always reset. ## Offset (OFS) - Bit 2 Offset is a read-only bit that is set to indicate that the selected drive is in Offset mode. ## Drive Available (DRA) - Bit 0 Drive Available is a read-only bit that is always set in single port configurations. # 4.7 DRIVE ERROR REGISTER (RKER) 777454 15 14 13 12 11 10 09 08 07 06 05 04 03 02 01 00 DCK UNS OPI DTE WLE IDAE COE 0 BSE ECH DT FMTE DPE NXF SKI ILF The RKER register is a read-only register that is used to store the error status of the selected drive. However, error information obtained from the drive is not immediately available to program control until the information is validated by the setting of SVAL (bit 15 in the RKDS register), which indicates that a complete status message frame has been received. Error bits set in the RKER register can be cleared by conventional initialization (INIT, CCLR, SCLR). However, a Controller Clear (CCLR) operation does not affect error bits that are currently set in the drive. In addition, a Q Bus Initialize (INIT) or Subsystem Clear (SCLR) operation can only reset error bits in a drive if the associated error condition no longer exists. #### Data Check (DCK) - Bit 15 Data Check is a read-only bit that is set to indicate that a data error was detected when the current sector was read. #### Drive Unsafe (UNS) - Bit 14 Drive unsafe is a read-only bit that is set to indicate a fault has occurred in the physical unit. This bit is also set if more than one unit responds to a unit address. ## Operation Incomplete (OPI) - Bit 13 Operation Incomplete is a read-only bit which is set when a command involving header search cannot find the header. #### Drive Timing Error (DTE) - Bit 12 Drive Timing Error is a read-only bit which is set when either the header or data sync pattern is not found. It is also set if a sector or index pulse is found in the sector's data field, or if there are not enough sectors on a physical unit during a firmware format operation. #### Write Lock Error (WLE) - Bit 11 Write Lock Error is a read-only bit that is set to indicate that an attempt was made to write on a write protected drive. #### Invalid Disk Address Error (IDAE) - Bit\_10 Invalid Disk Address Error is a read-only bit that indicates that the address in RKDA or RKDC was invalid at the beginning of a command which used one or both of these registers. #### Cylinder Overflow Error (COE) - Bit 9 Cylinder Overflow Error is a read-only bit that is set to indicate that a data transfer attempted to go beyond the last cylinder on a logical disk drive. #### Bad Sector Error (BSE) - Bit 7 Bad Sector Error is a read-only bit that is set to indicate that a data transfer has been attempted to or from a sector that has at least one of the two Good Sector Flags (Header Word 2, bits 14 and 15) reset, indicating a bad sector. ## Error Correction Hard (ECH) - Bit 6 Error Correction Hard is a read-only bit that is set to indicate that a data error detected by the Error Correction Code (ECC) logic in the controller cannot be corrected using ECC. ## Drive Type Error (DT) - Bit 5 Drive Type Error is a read-only bit that is set when the drive type status bit returned from the selected drive does not compare with the CDT bit (bit 10) in RKCS1. ## Format Error (FMTE) - Bit 4 Format Error is a read-only bit that is always zero for the SCO4/C. ## Control-to-Drive Parity Error (DPE) - Bit 3 Controller-to-Drive Parity Error is a read-only bit that is set when a command is issued to the controller with the PAT bit (bit 4) in RKMR1 set. ## Non-Executable Function (NXF) - Bit 2 Non-Executable Function is a read-only bit that is set to indicate that a Seek or a Write command has been received by the selected drive while Volume Valid was reset. ## Seek Incomplete (SKI) - Bit 1 Seek Incomplete is a read-only bit that is set whenever a seek error occurs in the physical disk unit, or a seek (explicit or implied) to track 3 or 7 is received by a logical unit. A seek incomplete may also be indicated if a fault occurs in the physical unit. ## Illegal Function (ILF) - Bit 0 Illegal Function is a read-only bit that is set to indicate that an illegal command $(33_8, 35_8, 37_8)$ has been loaded into RKCS1. ## 4.8 ATTENTION SUMMARY/OFFSET REGISTER (RKAS/OF) 777456 | 15 | 14 | 13 | 12 | 11 | 10 | 09 | 08 | 07 | 06 | 05 | 04 | 03 | 02 | 01 | 00 | |-----|--------------|-----|-----|-----|-----|-----|-----|----|----|----|----|----|----|----|----| | ATN | <u> ለ</u> ጥΝ | ΔΤΝ | ΔTN | ΔΤΝ | ΔΤΝ | ልጥክ | ΔTN | OF | 7 | | | | | | | | | | | | | | | | The RKAS/OF register can be read or written via program control and as such is used to store the head offset value required by an Offset command, and the current condition of the Attention signal line that is monitored for each drive. ## Attention (ATN7-ATN0) - Bits 15-8 The eight attention bits correspond to the eight drives. Each bit is the equivalent of the Drive Status-Change bit associated with each drive. Thus the clearing of this flip-flop clears the ATN bit in the register. The condition of the Drive Status-Change flip-flop for the selected drive is also shown in DSC (bit 14 in AO Status). ## 4.9 DESIRED CYLINDER REGISTER (RKDC) 777460 | | <u> 15</u> | 14 | 13 | 12 | 11 | 10 | 09 | _08 | _07_ | _06_ | 05 | 04 | 03 | 02 | 01 | 00 | |---|------------|----|----|----|----|----|----|-----|------|------|-----|------|-----|----|----|----| | Г | | | | | | | | | | | | | | | | | | | 0 | 0 | 0 | 0 | 0 | 0 | [ | | C | ylin | der | Addr | ess | | | | | L | | | | | | | | | | | | | | | | | The RKDC register can be read or written via program control, and is used to store the address of the desired cylinder. Following an initial load, the value in the RKDC register will be incremented by one whenever the track address value in the RKDA register overflows during a data transfer. Data may be entered and read from bits 10-15 only when "expanded" drives have been selected by the configuration PROM. ## 4.10 SPARE REGISTER (SPARE) 777462 The spare register may be written and read back. In the SCO4/C emulation the spare register is used for the Pack ID number for firmware format operations, and to setup extended commands. ## 4.11 DATA BUFFER REGISTER (RKDB) 777464 | | 15 | 14 | 13 | 12 | 11 | 10 | 09 | 08 | 07 | 06 | 05 | 04 | 03 | 02 | 01 | 00 | |---|----|----|----|----|----|----|----|-------|------|----|----|----|----|----|----|-----| | 1 | | | | | | | | | | | | | | | | | | | | | | | | | Da | ita B | uffe | r | | | | | | | | | | | | | | | | | | | | | | | | - 1 | The RKDB register can be read or written via program control. Reading from the register empties the Silo, while writing into the register fills the Silo. Both the RKDB register and the Silo are cleared by conventional initialization (INIT, CCLR, SCLR). ## 4.12 MAINTENANCE REGISTER 1 (RKMR1) 777466 | 15 | 14 | 13 | 12 | 11 | 10 | 09 | 08 | 07 | 06 | 05 | 04 | 03 | 02 | 01 | 00 | |----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----| | | | | | | | | | | | | | | | | MSO | The RKMR1 register can be read or written via program control, and is primarily used to select the particular A and B status messages. #### Diagnostic Mode (DMD) - Bit 5 When Diagnostic Mode bit is set, the controller is effectively disconnected from all of the drives. This mode is not supported by the SCO4/C emulation. ## Parity Test (PAT) - Bit 4 When the Parity Test bit is set, the controller will simulate even parity on status and control messages from and to the drives for diagnostic compatibility. #### Message Select (MS1, MS0) - Bits 1-0 These bits define one of the four pairs of 16-bit status messages (A0-A3 and B0-B3) that can be displayed in RKMR2 and RKMR3. The select bits are cleared by initialization or by loading a command (other than Select Drive) into RKCS1. #### 4.13 ECC POSITION REGISTER (RKECPS) 777470 | 1 | 5 | 14 | 13 | 12 | 11 | 10 | 09 | 08 | 07 | 06 | 05 | 04 | 03 | _02 | 01 | 00 | |---|---|----|----|----|----|----|----|----|-----|-----|------|----|----|-----|----|----| | | 0 | 0 | 0 | | * | | | | ECC | Pos | itio | n | | | | | The Error Correction Code (ECC) Position register is a read-only register that contains the position of the error pattern as determined by the ECC correction procedure. The error position is the number of bit positions from the beginning of the sector to the right most bit position of the error pattern stored in RKECPT. If the detected error is not correctable using ECC, the ECH error bit in RKER will be set. ## 4.14 ECC PATTERN REGISTER (RKECPT) 777472 | 0 0 0 0 ECC Pattern | 1 | 15 | <br>14 | 13 | 12 | 11 | 10 | 09 | 08 | 07 | 06 | 05 | 04 | 03 | 02 | 01 | 00 | |---------------------|---|----|--------|----|----|----|----|----|----|-----------------|-----|------|----|----|----|----|----| | | | ^ | ^ | | | | | | | <sub></sub> ፑርር | Pat | tann | | | | | | | | | U | U | U | U | U | | | | БСС | ıau | , | | | | | ] | The Error Correction Code (ECC) Pattern register is a read-only register that contains the 11-bit error correction pattern obtained from the ECC correction procedure. A 1 in the error pattern indicates a bit of the data in memory from the last read sector which is in error. The error pattern may straddle two 16-bit words in memory. The bit displacement to the right most bit of the pattern is determined by the bit count in RKECPS. ## 4.15 MAINTENANCE REGISTER 2 (RKMR2) 777474 RKMR2 is a read-only register that displays the "A" status messages for the slected drive. The particular A status is selected by MS1 and MS0 in RKMR1. Each status message has an odd parity bit in Bit 15 (for diagnostic compatability only) and the Unit No. of the drive in the low-order three bits. ### 4.15.1 AO Status | _15 | 14 | 13 | 12 | 11 | 10 | 09 | 08 | 07 | 06 | 05 | 04 | 03 | 02 | 01 | 00 | |-----|-----|-----|----|----|-----|-----|----|-----|----|-----|----|----|----|------|-----| | PAR | DSC | PIP | S0 | WL | OFO | FMT | DT | DRY | ۷V | DRA | 0 | 0 | Un | it 1 | No. | #### Drive Status-Change (DSC) - Bit 14 The bit is the OR of any status change due to: completion of a position command, loading or unloading of the heads or any fault condition. The bit is cleared by a Drive Clear command as well as a subsystem clear. ## Positioning in Progress (PIP) - Bit 13 This bit is set when a command is being executed that involves head movement. ## Spindle On (SO) - Bit 12 This bit is set when the drive is cycled up. #### Write Lock (WL) - Bit 11 This bit is set when the drive is in a write lock condition. ## Offset On (OFST) - Bit 10 This bit is set to indicate that the logical drive's heads are in an offset condition. #### Format (FMT) - Bit 9 This bit is 0 to indicate 22 sector (16 bit per word) format. #### Drive Type (DDT) - Bit 8 This bit is a 0 for an RKO6 drive, a 1 for an RKO7 drive. ## Drive Ready (DRDY) - Bit 7 This bit is set when the drive is cycled up, the heads are loaded and positioned over a cylinder, no unsafe condition exists, and the physical disk unit is on-line and ready. ## Volume Valid (VV) - Bit 6 This bit is set by the Pack Acknowledge command. It is reset by taking the disk unit off-line. #### Drive Available (DRAV) - Bit 5 This bit is always set in single port configurations. #### 4.15.2 A1 Status | 15 | 14 | 13 | 12 | 11 | 10 | 09 | 08 | 07 | 06 | 05 | 04 | 03 | 02 | 01 | 00 | |-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----| | PAR | | | | | | | | | | | | | i | | 1 | ## Heads Unloading (UNLD) - Bit 14 This bit is set during an Unload command to indicate that the heads are unloading. #### Return-to-Zero (RCAL) - Bit 13 This bit is set while a recalibrate operation is underway. ## Heads Loading (LOAD) - Bit 12 This bit is set during a Load command and is cleared when the unit is cycled up. ## Reverse (REV) - Bit 11 This bit indicates that the head carriage is moving toward the spindle. ## Forward (FWD) - Bit 10 This bit indicates that the head carriage is moving away from the spindle. ## Speed O.K. (SPOK) - Bit 9 This bit is set as long as the drive is cycled up. ## Cartridge Present (CRTG) - Bit 8 This bit is always set in an existing drive. ## Door Latched (DLTCH) - Bit\_7 This bit is always set in an existing drive. #### Brushes Home (BHOME) - Bit 6 This bit is always set in an existing drive. #### Heads Home (HHOME) - Bit 5 This bit is set whenever R/W UNSAFE condition (bit 14 of message BO) is set, or the drive is cycled down. ## Servo Signal Present (SRVSG) - Bit 4 This bit is asserted as long as the drive is cycled up. #### 4.15.3 A2 Status | 15_ | 14_ | 13_ | 12 | 11 | _10 | 09_ | _08_ | 07 | 06 | 05_ | 04_ | 03 | 02 | 01 | 00_ | |-----|-----|-----|----|------|-----|------|------|-------|------|------|------|----|----|------|-----| | PAR | 0 | 0 | С | ylin | der | Diff | eren | ice/0 | ffse | t Po | siti | on | Un | it N | 0. | This status message contains the difference between the current cylinder position the that specified by the RKDS; or the complement of the offset magnitude, if in offset mode. ## 4.15.4 A3 Status | 15 | 14 | 13 | 12 | 11 | 10 | 09 | _08 | 07 | 06 | 05 | 04 | 03 | 02 | 01 | 00 | |-----|----|----|------------|------|------|------------|--------|----|----|-----|------|----|----|------|-----| | PAR | | | rmwa<br>SD | re R | ev N | umbe<br>LS | r<br>D | | | Dri | ve N | 0. | | Unit | No. | This status message contains the "drive serial number" which consists of the logical drive number for the LSB and the firmware revision number for the most significant two bits. # 4.16 MAINTENANCE REGISTER 3 (RKMR3) 777476 RKMR3 is a read-only register that displays the "B" status messages for the selected drive. The particular A status is selected by MS1 and MS0 in RKMR1. Each status message has an odd parity bit in bit 15 (for diagnostic compatability only) and the status I.D. in the low-order two bits. ## 4.16.1 <u>BO Status</u> | _15 | 14 | 13 | 12 | 11 | 10 | 09 | 08 | 07 | 06 | 05 | 04 | 03 | 02 | 01 | 00 | | |-----|-----|----|-----|-----|-----|----|-----|-----|-----|-----|----|----|----|----|----|--| | PAR | RWU | 0 | SPL | WLE | SKI | PE | NXF | FLT | ACU | IAE | 0 | 0 | 0 | 0 | 0 | | ## Read/Write Unsafe (UNS) - Bit 14 This bit is set when a Fault is detected in the disk unit or when more than one disk unit responds to a given address. #### Drive-off-Track (DROT) - Bit 13 Always zero for SCO4/C emulations. #### Speed Loss Error (SPLS) - Bit 12 This bit is never set in the SCO4/C emulation. #### Write Lock Error (WLE) - Bit 11 This bit is set if an attempt is made to write on the disk when the logical drive or physical disk unit is write protected. #### Seek Incomplete Error (SEKI) - Bit 10 This bit is set whenever a Seek Error is set in the disk unit, or a seek (implied or explicit) is issued to track 3 or 7 on a logical drive. # Controller-to-Drive Parity Error (CDPE) - Bit 9 This bit is set when a command is issued with the Parity Test (bit 4 of RKMR1) set. # Non-Executable Function (NEXF) - Bit 8 This bit is set when a Seek or write command is attempted with the Volume Valid not set. It is reset with Drive Clear or a subsystem clear operation. ## Fault (FALT) - Bit 7 This bit is the OR of all the error conditions in this register. ## AC Low (ACLOW) - Bit 6 This bit is never asserted for the SCO4/C emulation. ## Invalid Address Error (IDA) - Bit 5 This bit is set when the address in RKDC or RKDA is not valid (too large). #### 4.16.2 B1 Status | 15 14 13 12 11 10 09 08 07 06 05 04 03 02 | | | <br> | <br>07 | 00 | 09 | 10 | 11 | 12 | _13_ | 14 | 15 | |-------------------------------------------|-----|--|------|--------|----|----|----|----|----|------|----|----| | PAR SU 0 0 SSE 0 IE 0 0 0 0 SE 0 0 | 0 1 | | | | | | | | | | | | #### Servo Unsafe (UNSF) - Bit 14 Always reset in SCO4/C emulation. #### Seek Limit (SKLIM) - Bit 13 Always reset in SCO4/C emulation. #### Seek No-Motion (SKNOM) - Bit 12 Set when seek incomplete error occurs (see RKER bit 2). #### Servo-Signal Error (SSE) - Bit 11 Set when drive unsafe condition detected (see RKER bit 14). #### Tribit Error (TBE) - Bit 10 Never set in SCO4/C emulation. #### Index Error (INDXE) - Bit 9 Never set in SCO4/C emulation. ## Multiple Head Select (MHS) - Bit 8 Never set in SCO4/C emulation. ## Head Fault (HFLT) - Bit 7 Set when unsafe condition exists (see RKER bit 14). ## Write Gate - No Transitions (WGNT) - Bit 6 Never set for SCO4/C emulation. ## No Write Gate (NWGT) - Bit 5 Never set for SCO4/C emulation. ## Sector Error (SERR) - Bit 4 Never set for SCO4/C emulation. # 4.16.3 <u>B2 Status</u> | _15 | 14 | 13 | 12 | 11 | 10 | 09 | 08 | 07 | 06 | 05 | 04 | 03 | 02 | 01 | 00_ | |-----|----|----|----|----|-----|------|------|------|----|----|----|----|----|----|-----| | PAR | 0 | 0 | | | Cyl | inde | r Ad | dres | s | | | 0 | 0 | 1 | 0 | This status message contains the current logical cylinder address of the positioner. ## 4.16.4 B3 Status | _ 15 | 14 | 13 | 12 | 11 | 10 | 09 | 08 | 07 | 06 | 05 | 04 | 03 | 02 | 01 | 00 | |------|----|----|----|-----|-------|-----|----|------|------|------|----|----|----|----|----| | PAR | 0 | 0 | 0 | Tra | .ck A | ddr | | Sect | or A | .ddr | | 0 | 0 | 1 | 1 | This status message contains the track and sector address of the drive after last data transfer command to the drive. Operations are initiated on the drive selected by the unit select bits in RKCS2 by loading the function code and GO bit into RKCS1. The function code specifies a specific command. The commands can be divided into three categories: data transfer commands, positioning commands, and housekeeping commands. Commands and their corresponding function codes (always odd since the bit must be asserted to execute the command) are described below: ## 5.1 DATA TRANSFER COMMANDS These commands involve data transfers to or from the disk and are designated by function codes 21 through 31. All data transfer commands have seek and sector search functions implied. When the desired cylinder does not equal the current cylinder during the execution of the data transfer, a seek will be issued to the desired cylinder. The controller will then search the desired track for the desired sector and, when found, will start the data transfer. On all commands except the Write Header command (which is the format operation) and Read Header command, a match of the sector header must be made before the data transfer is started. The desired sector, track and cylinder addresses are updated after the transfer of a sector. Therefore, at the end of a transfer, the disk is set up to transfer the next sequential sector. This allows multiple sector transfers and spiral transfers across tracks and cylinders. When the desired cylinder address changes during a transfer, the implied seek is performed and is termed a mid-transfer seek. The data transfer commands are described below: #### 5.1.1 Read Data (21) This command reads the 256-word data field from the selected sector and transfers the data to memory. When the sector data transfer is complete, the ECC is checked to Insure that the data read from the disk was error free. If a data error occurred, the ECC correction procedure is initiated to determine whether the error is correctable. When finished, the command is terminated to allow software to apply the correction procedure. Assuming no data errors, the word count in RKWC is checked; if not zero, the data transfer operation is repeated with the next sector. #### 5.1.2 Write Data (23) This command writes the 256-word data field of the selected sector with words obtained from memory. A two word ECC is appended to each sector. If the word count in RKWC goes to zero during the sector, the rest of the sector is 0 filled. After a sector transfer the word count in RKWC is checked, and if not zero, the data transfer operation is continued to the next sector; otherwise the command is terminated by setting the RDY bit. ## 5.1.3 Read Header (25) This command transfers the three words of the first header encountered into the Silo and then sets RDY. The three words may be read by examining RKDB three times. # 5.1.4 Write Header (Format Operation) (27) This command writes one logical track with headers. Data for the three word headers are obtained from memory. The data field and the ECC are zeroed. (Actual header is four words, the fourth being an extra check character; however, this is performed entirely by firmware and is not apparent to the software.) # 5.1.5 Write Check Data (31) This command reads data from the selected drive and compares it on a word by word basis with that obtained from memory. If the data fails to compare, the WCE status bit is set and the command is terminated immediately. ## 5.2 POSITIONING COMMANDS Positioning commands are mechanical movement commands used to position the heads over the disk pack and take milliseconds to complete. Upon initiating the positioning commands, the controller will set the PIP bit. Upon completion of the positioning operation, the controller resets the PIP bit. The positioning commands are described below: ## 5.2.1 Recalibrate (13) This command causes the drive positioner to position the heads over cylinder 0. A Return-to-Zero is automatically performed whenever a Seek Error is detected. #### 5.2.2 Offset (15) This command directs the selected drive to offset its heads a specific distance from the track center-line. The direction os the offset is determined by OS7 in RKAS/OF register and sets the OFO mode bit for the drive. The actual offset is done when the data transfer takes place. ## 5.2.3 Seek Command (17) This command causes the heads to be moved to the cylinder address specified by the contents of RKDC. When the controller sees the Seek command with the GO bit set, it sends the cylinder address to the corresponding drive. Upon completion of the seek operation, the ATN is set. #### 5.3 HOUSEKEEPING COMMANDS Housekeeping commands are used to place drive logic into a known or initialized state and usually takes only a few microsecondd to execute. The housekeeping commands are listed below: ## 5.3.1 <u>Select Drive (1)</u> This command selects a drive and obtains the status information defined by MS1 and MS0 in RKMR1. ## 5.3.2 Pack Acknowledge (3) This command sets the VV bit for the command controller. This command must be issued before any data transfer or positioning command can be given if the pack has gone off-line and then on-line. It is primarily intended to avoid unknown pack changes on a dual controller drive. #### 5.3.3 Drive Clear (5) This command is used to clear all error flags in the selected drive, provided that the error(s) are no longer present. In addition, the command resets the Status-Change flip-flop for the drive. ## 5.3.4 Unload (7) This command simulates the unloading of the heads if they are presently loaded in the selected drive. This operation can only be completed when the operator manually unloads the physical unit. #### 5.3.5 Start Spindle (11) This command simulates the starting of the spindle and the loading of the heads on the selected drive if the drive is presently in the unloaded state. This operation will be complete when the operator causes the drive to cycle up. ## 5.4 EXTENDED COMMANDS These commands are special to the SCO4/C emulation and are not found on the RK611 controller. The special commands are enabled by writing key word(s) in the spare register and RKMR1. The commands may then be executed as other commands by writing to RKCS1 with the GO bit set. The extended command enable sequence must be executed before each extended command given. To enable the extended command set, the spare register (177462) must contain a one in bit 15 and a zero in bit 14 as the RKMR3 register is written with all one's. The enable is removed with the execution of any command, a bus INIT, subsystem clear, or controller clear. The following special commands may be executed, after performing extended command enable operation. If the commands are issued without performing the enable operation, the "27" command will result in the execution of the standard track format operation, while the "33", "35", or "37" commands will cause the ILF (Illegal function) bit to set in RKER. ## 5.4.1 Format Drive (27) This command, normally a write header, when enabled to be an extended command will cause the entire drive to be hardware formatted. The data wich was written in the Spare Register prior to the command will be used for the pack ID number and all blocks will be written with the bad sector block format. ## 5.4.2 Write Protect (33) This command has multiple functions. The first is to logically write lock or unlock the logical drives. When the command is issued, the bits 7-0 of the Spare Register are used as the write lock switches for drives 7-0 respectively. A set bit will cause the drive to be write protected. A reset bit will remove the protect state, providing the physical unit on which the drive is mapped is not write protected. The command also fills the data buffer (silo) with the first 255 words of the hardware buffer (see symbol table) which contains the controller registers, configuration constants, and firmware registers. Successive reads of the silo will then enable software to read the drive size and configuration information, etc. for diagnostic purposes. The command also loads a firmware switch register when executed. Bits 13-8 of the Spare Register are copied and saved as the Switch Register. Presently only one switch is used (bit 9) which limits number of disk revolutions to one during a header search before the search is aborted. Normally, search is attempted for four revolutions, except for write check commands, for which it's also limited to one revolution. ## 5.4.3 Read Unit Headers (35) This read header command differs from the normal read header command in that an entire track of headers (physical unit track) is read to the silo in one command. The headers are in order starting with one after the index pulse. (The interlace pattern is followed such that consecutive headers are not physically adjacent.) The RKDC and RKDA registers must be loaded prior to this command with the desired physical cylinder and track to be read, as in the write unit headers command. ## 5.4.4 Write Unit Headers (37) This write header command is used to write headers in conjunction with the track replacement function. It is similar to the normal write header command except that physical unit addresses are used instead of logical drive addresses. Before issuing the command, the RKDC Register must contain the physical cylinder address; the RKDA Register must contain the physical unit track address (no sector, just ten bits of track address) and the Bus Address and Word Count Registers must point to a memory block with the correct amount of data for the number of headers-per-track on the physical unit. To write over a bad track, the header data should be as follows: 1st Word - New physical cylinder address. 2nd Word - New physical track address plus bits 13, 12, and 10 set to indicate track replace mode. 3rd Word - Exclusive "OR" of words one and two. #### APPENDIX A #### SCO4/C CONFIGURATION AND OPTION SELECTION #### A.1 INTRODUCTION To allow the user of the SCO4/C the greatest amount of flexibility in selecting disk drives for his system, the SCO4/C supports a wide variety of disk types and offers a number of other user selectable options. This appendix is designed as a quick reference to the various switches which make this flexibility possible. ## A.2 CONTROLLER CONFIGURATION The SCO4/C unit is capable of controlling a variety of disk drives of various sizes and types. The various drives that are supported are defined by the Configuration PROM. Table A-1 is a list of the drive types and sizes that are supported. The user may choose between the available options by means of configuration switch SW2. The correct switch settings for each of the various configurations are given in Table A-2. ## A.2.1 Single Drive Installations To find the configuration setting that is suitable for your single disk drive installation, use the following process. Note that all configurations require that the drive be hard sectored as noted in the Sec column of Table A-1. See the manufacture's drive installation manual for instructions. - 1. Locate your drive type and size in Table A-1. Note down the configuration number(s) assigned to your drive. Note also the cylinder (Cyl), track (Trk) and sector (Sec) figures for the drive. - 2. Set the switches on the drive that determine the number of hard sectors per track according to the sector figure from Table A-1. Also set the drive number to 0 using switches or jumpers on the drive. See the installation manual provided by the drive manufacturer for instructions. - 3. Find the configuration number for your drive in the CONF NO. column of Table A-2. If there is more than one number for an individual drive, start with the smallest. Note that for each configuration row, specifications are given for up to eight physical drives, Units 0 through 7. - 4. When you find the proper row, compare the Physical Drive cylinder, track and sector figures for Unit 0 in Table A-2 with the numbers you noted down from Table A-1. The track and sector numbers must match; the cylinder number from Table A-2 must be smaller than the number from Table A-1. If those conditions are not met, go on to the next higher configuration number, etc, until you find a match. 5. When you find a match, set the Configuration Switches (SW2) as indicated in Table A-2. (Generally, there is more than one match. In such cases, look at the Logical Unit and Drive Type column for each configuration where a match was found. Choose the Logical configuration you like best, and set the Configurations Switches accordingly.) # A.2.2 Multiple Drive Installations (same type drive) To find the configuration setting that is suitable for your multiple disk drive installation (drives same size and type), use the following process. Note that all configurations require that the drives both be hard sectored as noted in the Sec column of Table A-1. See the manufacture's drive installation manual for instructions. All multiple drive configurations that use only one type of drive have configuration numbers with a letter suffix. Configuration numbers without the suffix should be ignored. - 1. Locate your drive type and size in Table A-1. Note down the configuration number(s) assigned to your drives. Note also the cylinder (Cyl), track (Trk) and sector (Sec) figures for the drives. - 2. Find the configuration number for your drives in the CONF NO. column of Table A-2. If more than one number was given for the drives, start with the smallest. Note that for each configuration row, specifications are given up to eight physical drives, Units O through 7. Ignore all configuration numbers without a suffix. - 3. When you find the proper row, compare the Physical Drive cylinder, track and sector figures for both Unit 0 and Unit 1 in Table A-2 with the numbers you noted down from Table A-1. The track and sector figures must match; the cylinder number from Table A-2 must be smaller than the cylinder number from Table A-1. If those conditions are not met, go on to the next higher configuration number, etc, until you find a match. - 4. When you find a match, set the Configuration Switches (SW2) as indicated in Table A-2. (Generally, there is more than one match. In such cases, look at the Logical Unit and Drive Type column for each configuration where a match was found. Choose the Logical configuration you like best, and set the Configuration Switches accordingly.) - 5. Set the switches on the drive that determine the number of hard sectors per track according to the sector figure from Table A-1. Also assign each drive a unique drive number from 0 to 7 using switches or jumpers on the drive. See the installation manual provided by the drive manufacturer for instructions. ## A.2.3 Multiple Drive Installations (different drive types) To find the configuration settings that are suitable for your multiple disk drive installation (different drive size and type), use the following process. Note that all configurations require that the drives both be hard sectored as noted in the Sec column of Table A-1. See the manufacture's drive installation manual for instructions. All configurations that support different types and sizes of drives have no suffix following the configuration number. All configuration numbers with suffixes can be ignored. No more than two different types of drives are supported, and the odd drive is always physical unit zero. All other drives for that configuration will be of the same type. - 1. Locate your drive types and sizes in Table A-1. Note down the configuration code(s) assigned to each drive. Note also the cylinder (Cyl), track (Trk) and sector (Sec) figures for each drive. - 2. Once you have located and noted your drive configuration numbers, compare the numbers for each drive to one another. There must be at least one match if that drive combination is supported. Note that for all configurations that support different drive sizes, the configuration number does not have a letter suffix. - 3. Consult Table A-2. Find the configuration number that both drive types have in common in the CONF NO. column. If there is more than one matched number for the drives, start with the smallest. - 4. For each configuration row, specifications are given for up to eight physical drives, Units 0 through 7. The two sets of cylinder, sector and track numbers will be different. Compare the physical cylinder, track and sector numbers for each unit with the corresponding numbers from Table A-1. The physical drive that matches the numbers for physical unit 0 becomes unit 0. The physical drive(s) whose numbers match physical unit 1's or above becomes unit 1 or above. - 5. If there is more than one configuration supported, look at the Logical Unit and Drive Type column for each configuration where a match was found. Choose the Logical configuration you like best, and set the Configuration Switches (SW2) accordingly. - 6. Set the switches on the drives that determine the number of hard sectors per track according to the sector figures from Table A-1. Set the odd type drive number to 0 using switches or jumpers on the drive. Assign the other drives unique numbers from 1 to 7. See the installation manual provided by the drive manufacturer for instructions. TABLE A-1 DRIVES SUPPORTED | Mfg | Model | <u>Cyl</u> | Trk | Sec | Configuration No. | |-----------------------------------------------------------|----------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------|-----------------------------------------------------|----------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | BASF BASF PERTEC PERTEC PERTEC PRIAM PRIAM SLI SLI SLI 3M | 6172<br>6173<br>8033<br>8067<br>8084<br>2050<br>3450<br>3100-2<br>3100-3<br>3100-4<br>8432<br>8500 | 614<br>614<br>476<br>950<br>950<br>526<br>656<br>656<br>656<br>280<br>838 | 3<br>5<br>4<br>5<br>3<br>5<br>3<br>5<br>7<br>4<br>4 | 23<br>23<br>30<br>30<br>30<br>23<br>23<br>20<br>20<br>20<br>28<br>28 | 2*, 2A*, 3, 3B<br>0, 0A, 2, 2B, 3*, 3A*<br>7, 7B, 12, 12A<br>10, 10B<br>12, 12B<br>3, 3B, 7, 7A*<br>0, 0A, 2, 2B, 6*, 6A*<br>4*, 4A*, 5, 5B<br>0, 0B, 4, 4B, 5*, 5A*<br>1, 1A, 1B, 11A*<br>6, 6B, 10, 10A*<br>13, 13A*, 13B, 14A | | 3M | 0,000 | 0,0 | • | | 15, 15, 15 | \*These configurations produce non-standard emulations; i.e., an RK06 not equal to 411 cylinders or an RK07 not equal to 815 cylinders. Emulex will not supply diagnostic or operating system patches for the non-standard emulations. For users wishing to write their own drivers, the number of cylinders provided by the non-standard emulations are indicated in parentheses for those configurations in Table A-2. Emulex diagnostics will support these configurations, however. TABLE A-2 DRIVE CONFIGURATIONS | CONF | | | 5 | SW2 | 2- | | | | 1 | hys: | ical | | Logical | | |------|----|----------|----------|----------|----------|----------|----------|---|------|------------|--------|----------|-------------------------------------------------------------|--------| | NO. | 10 | <u>9</u> | <u>6</u> | <u>5</u> | <u>4</u> | <u>3</u> | <u>2</u> | 1 | Unit | Cyl | Trk | Sec | $\underline{\qquad \qquad \text{Unit(s)} = \text{Dr Type}}$ | Rev | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 472<br>543 | 5<br>5 | 23<br>20 | 0,1 = RK06<br>2,3 = RK06 | A<br>A | | | | | | | | | | | 2 | 543<br>543 | 5 | 20<br>20 | 4,5 = RKO6<br>6,7 = RKO6 | A<br>A | | OA | 0 | С | 0 | 0 | 0 | 0 | 0 | 0 | 3 | 472 | 5 | 23 | 0,1 = RK06 | A | | | | | | | | | | | 2 | 472<br>472 | 5 | 23<br>23 | 2,3 = RK06 $4,5 = RK06$ | A<br>A | | | | | | | | | | | 3 | 472 | 5 | 23 | 6,7 = RKO6 | A | continued next page TABLE A-2, cont. | CONF | | | 5 | SW2 | 2- | | | | ] | Physi | cal | | Logical | | |------------|----|---|----------|----------|----|----------|---|---|------------------------|--------------------------|------------------|----------------------|------------------------------------------------------------|------------------| | NO. | 10 | 9 | <u>6</u> | <u>5</u> | 4 | <u>3</u> | 2 | 1 | Unit | | | Sec | | ev | | 0B | С | С | 0 | 0 | 0 | 0 | 0 | 0 | 0<br>1<br>2 | 543<br>543<br>543 | 5<br>5<br>5 | 20<br>20<br>20 | 2,3 = RK06 | A<br>A<br>A | | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | С | 3<br>0<br>1 | 543<br>582<br>579 | 5<br>7<br>7 | 20<br>20<br>20 | 6,7 = RK06<br>0,1,2 = RK06<br>3 = RK07 4 = RK06 | A<br>A<br>A | | 1 A | 0 | С | 0 | 0 | 0 | 0 | 0 | С | 2<br>3<br>0<br>1 | 579<br>579<br>582<br>582 | 7<br>7<br>7<br>7 | 20<br>20<br>20<br>20 | 7 = RK07 $0,1,2 = RK06$ | A<br>A<br>A<br>A | | 1B | С | С | 0 | 0 | 0 | 0 | 0 | С | 2<br>0<br>1<br>2 | 582<br>579<br>579<br>579 | 7<br>7<br>7<br>7 | 20<br>20<br>20<br>20 | 6,7 = RK06<br>0 = RK07 0,1 = RK06<br>2 = RK07 3 = RK06 | A<br>A<br>A<br>A | | 2 | 0 | 0 | 0 | 0 | 0 | 0 | С | 0 | 3<br>0<br>1 | 579<br>613<br>468 | 7 | 20<br>23<br>23 | 6 = RK07 | A<br>A<br>A | | 2 <b>A</b> | 0 | С | 0 | 0 | 0 | 0 | С | 0 | 2<br>3-7<br>0<br>1 | 468<br>468<br>613<br>613 | 355533 | 23<br>23<br>23<br>23 | 3-7 = RKO7<br>0 = RKO6 ( 640 CYL )<br>1 = RKO6 ( 640 CYL ) | A<br>A<br>A<br>A | | 2B | С | С | 0 | 0 | 0 | 0 | С | 0 | 2<br>3-7<br>0<br>1 | 613<br>613<br>468<br>468 | 3<br>5<br>5 | 23<br>23<br>23<br>23 | 3-7 = RK06 (640 CYL) $0 = RK07$ | A<br>A<br>A<br>A | | 3 | 0 | 0 | 0 | 0 | 0 | 0 | С | С | 2<br>3-7<br>0<br>1 | 468<br>468<br>607<br>393 | 5<br>5<br>5<br>3 | 23<br>23<br>23<br>23 | 3-7 = RK07<br>0 = RK07 ( 1056 CYL ) | A<br>A<br>A<br>A | | 3 <b>A</b> | 0 | С | 0 | 0 | 0 | 0 | С | С | 2-7<br>0<br>1 | 393<br>607<br>607 | 3 | 23<br>23<br>23 | 0 = RK07 (1056 CYL)<br>1 = RK07 (1056 CYL) | A<br>A<br>A | | 3B | С | С | 0 | 0 | 0 | 0 | С | С | 2-7<br>0<br>1<br>2-7 | 607<br>393<br>393<br>393 | 555333 | 23<br>23<br>23<br>23 | 0 = RK06 1 = RK06 | A<br>A<br>A<br>A | | 4 | 0 | 0 | 0 | 0 | 0 | С | 0 | 0 | 0<br>1<br>2-7 | 652<br>538 | 335533 | 20<br>20<br>20 | 0 = RK06 (592 CYL) $1 = RK07$ | A<br>A<br>A | | 4 A | | | | | | С | | | 0<br>1<br>2-7 | | 3 | 20<br>20<br>20 | 1 = RK06 ( $592 $ CYL ) $2-7 = RK06 $ ( $592 $ CYL ) | A<br>A<br>A | | 4B | С | C | 0 | 0 | 0 | С | 0 | 0 | 0<br>1<br>2 <b>-</b> 7 | 538<br>538<br>538 | 5<br>5<br>5 | 20<br>20<br>20 | 1 = RKO7 | A<br>A<br>A | continued next page TABLE A-2, cont. | CONF | 10 | 9 | _ | 5W2 | _ | 3 | <u>2</u> | <u>1 (</u> | Jnit | hysic<br>Cyl I | al<br>rk | Sec | Un | Log<br>it(s) | | al<br><u>Dr Type</u> | | Rev | |------------|----|---|---|-----|---|---|----------|------------|--------------------|---------------------------------|-------------|----------------------------|-------------------|---------------------------------------------|---------------|--------------------------------------------------|---------------|-------------| | 5 | 0 | 0 | 0 | 0 | 0 | С | 0 | С | 0 | 655<br>453 | 5 | 20<br>20 | 0 = | RK07 | (= | 992 CYL<br>RK06 | ) | A<br>A | | 5 <b>A</b> | 0 | С | 0 | 0 | 0 | С | 0 | С | 2 <b>-</b> 7 | 453<br>655<br>655 | 3<br>5<br>5 | 20<br>20<br>20 | 0 =<br>1 = | 2-7<br>RK07<br>RK07 | = ( | RK06<br>922 CYL<br>922 CYL | ) | A<br>A<br>A | | 5B | С | С | 0 | 0 | 0 | С | 0 | С | 2-7<br>0<br>1 | 655<br>453<br>453 | 533 | 20<br>20<br>20 | • | RK07<br>0 | (<br>=<br>= | 922 CYL<br>RK06<br>RK06 | ) | A<br>A<br>A | | 6 | 0 | 0 | 0 | 0 | 0 | С | С | 0 | 2-7 | _ | 354 | 20<br>23<br>28 | 0 = | 2-7<br>RK07 | = ( | RKO6<br>912 CYL<br>RKO6 | ) | A<br>A<br>A | | 6 <b>A</b> | 0 | С | 0 | 0 | 0 | С | С | 0 | 2-7<br>0 | _ | 4<br>5<br>5 | 28<br>23<br>23 | 0 =<br>1 = | 2-7<br>RK07<br>RK07 | = ( | RK06<br>912 CYL<br>912 CYL | ) | A<br>A<br>A | | 6в | С | С | 0 | 0 | 0 | С | С | 0 | 2-7<br>0<br>1 | | 5<br>4<br>4 | 23<br>28<br>28 | | RKO7<br>0 | )<br>=<br>= | 912 CYL<br>RK06<br>RK06 | ý | A<br>A<br>A | | 7 | 0 | 0 | 0 | 0 | 0 | С | С | С | 2-7<br>0 | _ | 4<br>3<br>4 | 28<br>23<br>30 | 0 = | 2-7<br>RK06 | = ( | RKO6<br>544 CYL<br>RKO7 | ) | A<br>A<br>A | | 7 A | 0 | С | 0 | 0 | 0 | С | С | С | 2-7<br>0 | | 4<br>3<br>3 | 30<br>23<br>23 | 0 =<br>1 = | 2-7<br>RK06<br>RK06 | = ( | RK07<br>544 CYL<br>544 CYL | ) | A<br>A<br>A | | <b>7</b> B | С | С | 0 | 0 | 0 | С | С | С | 2-7<br>0 | - | 3 4 4 | 23<br>30<br>30 | 2-7 = | | (<br>=<br>= | 544 CYL<br>RK07<br>RK07 | ) | A<br>A<br>A | | 10 | 0 | 0 | 0 | 0 | С | 0 | 0 | 0 | 2-7<br>0<br>1-3 | 499<br>279 | 4<br>4<br>4 | 30<br>28<br>30 | 0 =<br>1-3 = | 2-7<br>RK06<br>RK07 | ( | RKO7<br>472 CYL<br>2 PER DR | )<br>V ) | A<br>A<br>A | | 10A | 0 | С | 0 | 0 | С | 0 | 0 | 0 | 4<br>0<br>1 | 897<br>279<br>279 | 4 4 4 | 30<br>28<br>28 | 0 = | 7<br>RKO6<br>RKO6 | · =<br>(<br>( | RK07<br>472 CYL<br>472 CYL | ) | A<br>A<br>A | | 10B | С | С | 0 | 0 | С | 0 | 0 | 0 | 2 <b>-</b> 7 | | 4<br>4<br>4 | 28<br>30 | 2-7 = | RK06<br>0.1 | (<br>=<br>( | 472 CYL<br>RKO7<br>2 PER DR | )<br>v ) | A<br>A<br>A | | 11<br>11A | | | | | | 0 | | | 0 | ( DO | NO' | T SE | LECT )<br>O = | RKO7 | ( | 1376 CY<br>1376 CY | L) | A<br>A | | 11B<br>12 | | | | | | 0 | | | 0 | ( DO<br>453 | NO'<br>4 | T SE | LECT ) | 0,1 | = | RKO6 | | A<br>A | | 12A<br>12B | | | | | | 0 | | | 2<br>0<br>1-3<br>0 | 899<br>899<br>453<br>453<br>899 | 4 | 30<br>30<br>30<br>30<br>30 | 5,6<br>2-7<br>0,1 | = RKO7<br>0,1<br>= RKO6<br>= RKO7<br>= RKO7 | = ( | 4 = RKO<br>RKO6<br>2 PER D<br>2 = RKO<br>5 = RKO | 6<br>RV)<br>6 | A<br>A | | | | | | | | | | | 2 | 899 | 5<br> | 30 | - , | 6,7 | = | RK06 | | A | continued next page TABLE A-2, cont. | CONF | | | 5 | SW 2 | 2- | | | | I | hysi | cal | | | Log | ica | al | | | | |-----------|----|--------|----------|----------|----|---|----------|---|-----------------------------|---------------------------------|-------------|----------------------|----------------------------|---------------------------|---------|------------------------------|------------------------------|---|-------------| | NO. | 10 | 9 | <u>6</u> | <u>5</u> | 4 | 3 | <u>2</u> | 1 | Unit | Cyl | Trk | Sec | Ur | it(s) | Ξ | Dr T | ype | | Rev | | 13 | 0 | 0 | 0 | 0 | С | 0 | С | С | 0<br>1<br>2 | 830<br>727<br>727 | 4<br>4<br>4 | 28<br>28<br>28 | 0 = | RK07<br>1-3<br>4-6 | | 1408<br>RK06<br>RK06 | | ) | A<br>A<br>A | | 13A | 0 | С | 0 | 0 | С | 0 | С | С | 3<br>0<br>1 | 727<br>830<br>830 | 4<br>4<br>4 | 28<br>28<br>28 | 0 = | 7<br>RKO7<br>RKO7 | = ( ( ( | RK06<br>1408<br>1408 | CYL<br>CYL | ) | A<br>A<br>A | | 13B | С | С | 0 | 0 | С | 0 | С | С | 2 <b>-</b> 7<br>0<br>1<br>2 | 830<br>727<br>727<br>727 | 4<br>4<br>4 | 28<br>28<br>28<br>28 | 2-7 = | RK07<br>0-2<br>3-5<br>6.7 | ) = = = | 1408<br>RK06<br>RK06<br>RK06 | | , | A<br>A<br>A | | 14<br>14A | 0 | 0<br>C | 0 | | C | | | 0 | 0<br>1<br>2<br>3 | 723<br>723<br>723<br>723<br>723 | | | LECT )<br>0<br>2<br>4<br>6 | | _ | 1 =<br>3 =<br>5 = | RKO6<br>RKO6<br>RKO6<br>RKO6 | | A<br>A<br>A | | 14B | С | С | 0 | 0 | С | C | 0 | 0 | | ( DC | ON | C SEI | LECT ) | | | | | | | ## A.3 USER SELECTABLE OPTIONS Several other options including the register starting address for the SCO4/C can be user selected. The functions of the switches that select those options are defined in Tables A-3, A-4 and A-5, below. TABLE A-3 OPTION SWITCH SETTINGS | Option Sw | <u>Open</u> | Closed | <u>Function</u> | |----------------|-------------|------------|---------------------------------------| | SW1-1<br>SW1-2 | Run | Halt-Reset | Controller Run/Halt-Reset<br>Not used | | SW1-3 | Disable | Enable | Header check error to be bad sector | | SW1-4 | Disable | Enable | Drives to be write-locked on power-up | All unused switches MUST BE OFF. TABLE A-4 CONFIGURATION SWITCH SETTINGS | SW2-1 SW2-2 Drive Configuration <sup>2</sup> SW2-3 SW2-4 Drive Configuration <sup>2</sup> Drive Configuration <sup>2</sup> Drive Configuration <sup>2</sup> SW2-5 Drive Configuration <sup>2</sup> Drive Configuration <sup>2</sup> Drive Configuration <sup>2</sup> | Config Sw | <u>Open</u> | Closed | <u>Function</u> | |----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------|-------------|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | SW2-6 SW2-7 SW2-8 SW2-9 SW2-9 SW2-10 Drive Configuration Drive Configuration Drive Configuration Drive Configuration | SW2-2<br>SW2-3<br>SW2-4<br>SW2-5<br>SW2-6<br>SW2-7<br>SW2-8<br>SW2-9 | | <del>-</del> | Drive Configuration <sup>2</sup> Drive Configuration <sup>2</sup> Drive Configuration <sup>2</sup> Drive Configuration <sup>2</sup> Drive Configuration <sup>2</sup> Interrupt vector address Head offset capability Drive Configuration <sup>2</sup> | See Table A-2 for settings # TABLE A-5 ADDRESS SWITCH SETTINGS | Address Sw | <u>Open</u> | Closed | <u>Function</u> | |----------------------------------------------------|--------------------------|--------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------| | SW3-1<br>SW3-2<br>SW3-3<br>SW3-4<br>SW3-5<br>SW3-6 | Disable<br>Disable<br>2K | 777440<br>776700<br>Enable<br>Enable<br>1K | Not used 1 Standard Q Bus Address 3 Alternate Q Bus Address 3 Boot PROM Option Line Clock Option Microcode Address Range (must be open for SCO4/C) | All unused switches MUST BE OFF. Only one address may be selected. All other address switches MUST BE OFF. | MANUAL PART NO. | REV. | _ Reader's Comments | |--------------------------------------------------------------------------|-----------------------------------|-----------------------------------| | Your comments and suggestions will help of our publications. | us in our continuous effort to in | mprove the quality and usefulness | | What is your general reaction to this manual? etc.? Is it easy to use? | | | | What features are most useful? | | | | What faults or errors have you found in the r | manual? | | | Does this manual satisfy the need you think i | it was intended to satisfy? | | | Does it satisfy your needs? | | | | ☐ Please send me the current copy of the C EMULEX's controller products. | | | | Name | Street | | | Title | | | | Company | | | | Department | | | Additional copies of this document are available from: Emulex Corp. 2001 East Deere Santa Ana, CA 92705 Attention: Customer Services Fold Here Do Not Tear - Fold Here and Staple NO POSTAGE NECESSARY IF MAILED IN THE UNITED STATES # **BUSINESS REPLY MAIL** FIRST CLASS PERMIT NO. 6251 SANTA ANA, CA POSTAGE WILL BE PAID BY ADDRESSEE **Emulex Corporation** ATTN: ENG. SERVICES 2001 E. Deere Ave. Santa Ana, CA 92705