5MD Disks # **Xylogics** # Model 751 User's Manual YOUR PARTNER FOR PERFORMANCE. 166-751-001 Revision A July 23, 1986 Copyright 1986 Xylogics, Inc. The information in this manual is subject to change without notice, and should not be construed as a commitment by Xylogics. Xylogics assumes no responsibility for any errors that may appear in this document. # XYLOGICS 751 Disk Controller User's Manual # 751 REVISION LEVEL HISTORY | REVISION | DESCRIPTION | Ī | |-------------|------------------|---| | A (7/23/86) | Initial release. | 1 | | | · | | |---|---|--| | | | | | | | | | | | | | ÷ | | | | | PAGE | |-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | LIST | OF ILLUSTRATIONS xi | | SECTI | ON 1: SPECIFICATIONS | | 1.0 | GENERAL | | 1.1 | USING THIS MANUAL | | | 1.1.1 Abbreviations | | 1.2 | DESIGN RELIABILITY 2 | | 1.3 | PHYSICAL 3 | | 1.4 | ENVIRONMENTAL | | 1.5 | ELECTRICAL | | 1.6 | SYSTEM RELATED SPECIFICATIONS | | 1.7 | DISK DRIVE RELATED SPECIFICATIONS 5 | | 1.8 | VMEDUS RELATED SPECIFICATIONS 6 | | 1.9 | SOFTWARE RELATED SPECIFICATIONS 7 | | | 1.9.1 Software Interface 7 | | 1.10 | PROGRAMMABLE FEATURES | | SECTI | ON 2: INSTALLING AND TESTING THE 751 | | 2.0 | GENERAL 8 | | 2.1 | UNPACKING AND INSPECTION 8 | | | 2.1.1 Inspect the Shipping Carton 8 2.1.2 Contents 8 2.1.3 Handling Precautions 8 2.1.4 Inspect the 751 8 | | 2.2 | CONFIGURING THE 751 | | | 2.2.1 Base Address Selection | | | | Pi | AGI | |-------|-------------------------------------------|---------------------------------------------------------------------------------------------------------------------|----------------| | 2.3 | PROMS A | ND PALS | 13 | | 2.4 | SELF TE | ST DISABLE | 12 | | 2.5 | PROMS A | ND PALS | 12 | | 2.6 | LIGHT E | MITTING DIODES | 12 | | 2.7 | BOARD L | ABELS / REVISION CONTROL | 12 | | 2.8 | PREPARI | NG THE COMPUTER SYSTEM FOR INSTALLATION | 12 | | | 2.8.1<br>2.8.2<br>2.8.3 | Backplane Jumpers | 13 | | 2.9 | PREPARI | NG THE DISK DRIVE FOR INSTALLATION | 13 | | | 2.9.1<br>2.9.2<br>2.9.3<br>2.9.4<br>2.9.5 | Drive Unit Select Number of Sectors Per Track Sector and Index Pulses Tags 4 and 5 Extended Cylinder Addressing | 14<br>14<br>14 | | 2.10 | INSTALL | AND CABLE THE 751 | 15 | | | | Install the 751 | | | 2.11 | INITIAL | TESTS | 15 | | | | Power-up and Self Test Drive Ready | | | 2.12 | DIAGNOST | FICS | 16 | | 2.13 | CABLING | MULTIPLE DRIVES | 16 | | | 2.13.2<br>2.13.3 | Terminator "A" Cable (Daisy-chain) "B" Cable (Radial) Unit Select | 17<br>17 | | SECTI | ON 3: TH | HE 751 REGISTERS | | | 3.0 | GENERAL | ••••••••••• | 18 | # XYLOGICS 751 Disk Controller User's Manual | | | | PAGE | |--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------| | 3.1 | IOPB AD | DRESS REGISTERS | . 18 | | 3.2 | IOPB AD | DRESS MODIFIER / PRIORITY IOPB REGISTER | . 18 | | 3.3 | CONTROL | AND STATUS REGISTER | . 19 | | | 3.3.1<br>3.3.2 | Control Register (Write) | | | 3.4 | FATAL E | RROR REGISTER | . 23 | | SECTIO | ON 4: I | OPB DESCRIPTION | | | 4.0 | GENERAL | •••••• | . 24 | | 4.1 | STANDAR | D IOPB | . 24 | | | 4.1.1<br>4.1.2<br>4.1.3<br>4.1.4<br>4.1.5<br>4.1.6<br>4.1.7<br>4.1.8<br>4.1.9<br>4.1.10<br>4.1.11<br>4.1.12<br>4.1.13<br>4.1.14<br>4.1.15<br>4.1.16<br>4.1.17<br>4.1.18<br>4.1.19 | IOPB Byte 0 (Command) IOPB Byte 1 (Status Byte 1) IOPB Byte 2 (Status Byte 2) IOPB Byte 3 (Status Byte 3) IOPB Byte 4 (Subfunction) IOPB Byte 5 (Unit) IOPB Byte 6 (Interrupt Level) IOPB Byte 7 (Interrupt Vector) IOPB Bytes 8 and 9 (Count) IOPB Bytes A and B (Cylinder) IOPB Byte C (Head) IOPB Byte C (Head) IOPB Byte F (Next IOPB Address Modifier) IOPB Byte F (Next IOPB Address Modifier) IOPB Bytes 10 Through 13 (DMA Data Address) IOPB Bytes 14 Through 17 (Next IOPB Address) IOPB Bytes 18 and 19 (IOPB Checksum) IOPB Bytes 1A and 1B (ECC Pattern Word) IOPB Bytes 1C and 1D (ECC Offset Word) | 25<br>26<br>27<br>27<br>28<br>30<br>30<br>30<br>30<br>30<br>31<br>31 | | 4.2 | CONTROLL | LER PARAMETERS IOPB | . 32 | | | 4.2.1<br>4.2.2<br>4.2.3<br>4.2.4<br>4.2.5<br>4.2.6<br>4.2.7<br>4.2.8 | IOPB Byte 8 (Controller Parameters A) IOPB Byte 9 (Controller Parameters B) IOPB Byte A (Controller Parameters C) IOPB Byte B (Controller Parameters D) IOPB Byte E (Controller Type) IOPB Bytes 10 and 11 (EPROM Part Number) IOPB Byte 12 (Revision) IOPB Byte 13 (Subrevision) | 34<br>35<br>36<br>37<br>37<br>37 | | | | PAGE | |--------------|---------------------------------------------------------|------------| | 4.3 | DRIVE PARAMETERS IOPB | . 38 | | | 4.3.1 IOPB Byte 6 (Drive Parameters) | | | | | | | | 4.3.3 IOPB Byte 9 (Head Offset) | | | | 4.3.5 IOPB Byte C (Max Head) | . 40<br>40 | | | 4.3.6 IOPB Byte D (Max Sector) | | | | 4.3.7 IOPB Byte E (Sectors Per Track) | | | 4.4 | FORMAT PARAMETERS IOPB | | | | 4.4.1 IOPB Byte 6 (Interleave) | <b>4</b> 1 | | | 4.4.2 IOPB Byte 8 (Field 1) | | | | 4.4.3 IOPB Byte 9 (Field 2) | | | | 4.4.4 IOPB Byte A (Field 3) | 42 | | | 4.4.5 IOPB Byte B (Field 4) | | | | 4.4.6 IOPB Bytes C and D (Field 5 High/Low) | 43 | | | 4.4.7 IOPB Byte 10 (Field 6) | | | | 4.4.8 IOPB Byte 11 (Field 7) | | | | 4.4.9 IOPB Bytes 12 and 13 (Alternate Field 5 High/Low) | | | SECT | ION 5: COMMANDS | | | - 0 | | | | 5.0 | GENERAL | 44 | | | 5.0.1 Setting Up The Command | 44 | | | 5.0.2 Completing The Command | 44 | | - 1 | - | | | 5.1 | NO OPERATION | 45 | | 5.2 | WRITE DATA | 46 | | 5.3 | READ DATA | 47 | | 5.4 | REPORT CURRENT ADDRESS | 48 | | 5.5 | SEEK AND REPORT CURRENT ADDRESS | 49 | | 5.6 | START SEEK AND REPORT COMPLETION IMMEDIATELY | 50 | | 5 <b>.</b> 7 | DRIVE RESET | 51 | | 5.8 | WRITE CONTROLLER PARAMETERS | 52 | | 5.9 | WRITE DRIVE PARAMETERS | | | | I | PAGE | |-------|-------------------------------------------------|----------| | 5.10 | WRITE FORMAT PARAMETERS | 54 | | 5.11 | READ CONTROLLER PARAMETERS | 55 | | 5.12 | READ DRIVE PARAMETERS | 56 | | 5.13 | READ FORMAT PARAMETERS | 57 | | 5.14 | READ DRIVE STATUS EXTENDED | 58 | | 5.15 | WRITE TRACK HEADERS | 59 | | 5.16 | WRITE TRACK FORMAT | 60 | | 5.17 | WRITE HEADER, HEADER VERIFY, DATA, AND DATA ECC | 61 | | 5.18 | WRITE DEFECT MAP | 62 | | 5.19 | WRITE DEFECT MAP EXTENDED | 63 | | 5.20 | READ TRACK HEADERS | 64 | | 5.21 | VERIFY DATA | 65 | | 5.22 | READ HEADER, HEADER VERIFY, DATA, AND DATA ECC | 66 | | 5.23 | READ DEFECT MAP | 67 | | 5.24 | READ DEFECT MAP EXTENDED | 68 | | 5.25 | DIAGNOSTICS | 69 | | SECTI | On 6: ERROR PROCESSING | | | 6.0 | GENERAL | 70 | | 6.1 | THE COMPLETION CODE | 70 | | | 6.1.1 Completion Code Convention | 70<br>72 | | 6.2 | ERRORS AND ZERO LATENCY READS | 77 | | 6 3 | SUEM EDDUD COMDUSTITUM CODES | 77 | | | | | PAGE | |------|---------|-----------------------------------|------| | 6.4 | ERROR ( | CORRECTION CODE | 77 | | | 6.4.1 | Error Correction Code - Mode 0 | | | | 6.4.2 | Error Correction Code - Mode 1 | 78 | | | 6.4.3 | Error Correction Code - Mode 2 | 78 | | 6.5 | FATAL I | ERROR CODE DESCRIPTIONS | 78 | | 6.6 | IRAM C | HECKSUM | 79 | | SECT | ON 7: 1 | A TUTORIAL IN PROGRAMMING THE 751 | | | 7.0 | GENERAI | L | 80 | | 7.1 | NO OPEI | RATION | 80 | | | | | | | | 7.1.1 | Allocating Memory For An IOPB | | | | 7.1.2 | Point the 751 to the IOPB | | | | 7.1.3 | Starting the Operation | | | | 7.1.4 | 751 Operation | | | | 7.1.5 | Command Completion | | | | 7.1.6 | Returned Values | 82 | | 7.2 | READ CO | ONTROLLER PARAMETERS | 82 | | | 7.2.1 | Execute the IOPB | | | | 7.2.2 | 751 Operation | 82 | | | 7.2.3 | The Returned IOPB | 83 | | 7.3 | WRITE ( | CONTROLLER PARAMETERS | 84 | | | 7.3.1 | 751 Operation | 84 | | 7.4 | READ/WE | RITE FORMAT PARAMETERS | 85 | | | 7.4.1 | Execute the IOPB with Interrupts | 85 | | | 7.4.2 | 751 Operation | | | | 7.4.3 | Command Completion | | | | 7.4.4 | Returned Values | | | 7.5 | READ/WE | RITE DRIVE PARAMETERS | 86 | | | 7.5.1 | 751 Operation | 86 | | 7.6 | FORMAT | A TRACK | 87 | | | 7.6.1 | 751 Operation | . 88 | # XYLOGICS 751 Disk Controller User's Manual | | | | PAGE | |-------|----------------------------------|------------------------------------------------------------------------------------|--------------| | 7.7 | READ TR | ACK HEADERS | 89 | | | 7.7.1<br>7.7.2 | 751 Operation | 90<br>91 | | 7.8 | WRITE D | ATA | 92 | | | 7.8.1<br>7.8.2 | 751 Operation | | | 7.9 | READ DA | TA | 93 | | | 7.9.1<br>7.9.2<br>7.9.3 | 751 Operation | 93 | | 7.10 | MULTIPL | E SECTOR TRANSFERS | 95 | | 7.11 | SUMMARY | •••••• | 95 | | SECTI | ON 8: 7 | 51 SPECIAL FUNCTIONS | | | 8.0 | GENERAL | | 96 | | 8.1 | MEDIA D | EFECT HANDLING | 96 | | | 8.1.1<br>8.1.2<br>8.1.3<br>8.1.4 | Slipping a Sector Cylinder Sparing Track Remapping Recommended Remapping Procedure | . 98<br>. 99 | | 8.2 | CHAININ | G AND MULTIPLE I/O REQUESTS | 100 | | | 8.2.1<br>8.2.2<br>8.2.3 | Chaining | 100 | | 8.3 | FORMATT | ING | 100 | | | 8.3.1<br>8.3.2<br>8.3.3<br>8.3.4 | Allocating Spare Sectors | 101 | | | | | PAGE | |------|------------------------------------------------|--------------------------------------------------------------------------------|-----------------------------------------------| | 8.4 | ERROR F | ECOVERY | . 105 | | | 8.4.1<br>8.4.2<br>8.4.3 | Automatic Operation Retry ECC Error Recovery Using the Error Recovery Options | . 105 | | 8.5 | READ DE | FECT MAP | . 106 | | | 8.5.1<br>8.5.2<br>8.5.3<br>8.5.4 | The Defect Map | <ul><li>107</li><li>107</li></ul> | | 8.6 | MAINTEN | ANCE MODE | . 108 | | | 8.6.1<br>8.6.2 | Register Use in Maintenance Mode | | | 8.7 | ZERO LA | TENCY READS | . 110 | | 8.8 | MULTIPR | OCESSOR SUPPORT | . 111 | | | 8.8.1<br>8.8.2<br>8.8.3 | Interrupts Register Busy Semaphore Address Modifiers | . 111 | | 8.9 | COMMAND | OPTIMIZATION | . 111 | | 8.10 | | E CONTROL | | | | 8.10.1<br>8.10.2<br>8.10.3<br>8.10.4<br>8.10.5 | Modifying a Single Parameter | <ul><li>112</li><li>112</li><li>113</li></ul> | | 8.11 | SCATTER | /GATHER | . 113 | | | 8.11.2<br>8.11.3 | Scatter/Gather Link List | <ul><li>114</li><li>115</li></ul> | | 8.12 | DMA THRO | OTTLE / THROTTLE DEAD TIME | . 116 | | 8.13 | BLACK HO | OLE TRANSFERS | . 116 | | | | | PAGE | |---------|-----------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------| | 8.14 | PRIORIT | Y IOPBs | . 116 | | | 8.14.1<br>8.14.2<br>8.14.3 | Executing a Priority IOPB | . 117 | | 8.15 | IOPB CH | ECKSUM | . 117 | | 8.16 | FIXED/R | EMOVABLE MEDIA | . 117 | | | 8.16.1 | Head Offset | . 117 | | 8.17 | EMBEDDE | ED SERVO DRIVES | . 118 | | 8.18 | SUPPORT | ING TWO DRIVES WITH DIFFERENT SECTOR SIZES | . 118 | | | 8.18.1<br>8.18.2<br>8.18.3 | Setting the 751 Format Parameters | . 118 | | 8.19 | DUAL PO | RTED DRIVES | . 119 | | | 8.19.1 | Software Write Access Control | . 119 | | 8.20 | READ/WR | ITE HEADER, HEADER VERIFY, DATA, AND DATA ECC | 120 | | | 8.20.1 | Simulating an ECC Error | 120 | | 8.21 | INTERRU | PT AT END OF CHAIN | 121 | | 8.22 | RELEASE | ON REQUEST | 121 | | SECTION | ON 9: 7 | 51 THEORY OF OPERATION | | | 9.0 | GENERAL | •••••• | 122 | | 9.1 | The Har | dware | 122 | | | 9.1.1<br>9.1.2<br>9.1.3<br>9.1.4<br>9.1.5<br>9.1.6<br>9.1.7<br>9.1.8<br>9.1.9<br>9.1.10 | VMEbus Interface Register Read/Write and Interrupt The Microcontroller Direct Memory Access Controller Disk Data Buffer Disk Front End SMD-E Interface Power-up Power-down System Reset | 122<br>123<br>124<br>125<br>125<br>125<br>126<br>126 | | | | | PAGE | |-------|-------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------|---------------------------------| | 9.2 | THE MIC | CROCODE | 126 | | | 9.2.1<br>9.2.2<br>9.2.3<br>9.2.4<br>9.2.5 | The Kernel Is AIO Set? Is Start Queue Empty? Is Any IOPB Ready for Completion? Queuing IOPBs for Execution | 127<br>128<br>128 | | 9.3 | PERFORM | MING A FUNCTION | 128 | | | 9.3.1<br>9.3.2<br>9.3.3<br>9.3.4<br>9.3.5<br>9.3.6<br>9.3.7 | NOP Normal Reads and Writes Seeks Drive Reset Write and Read Parameters Extended Read and Write Commands Diagnostics | 128<br>129<br>129<br>129<br>129 | | 9.4 | COMPLET | FING A FUNCTION | 130 | | SECTI | ON 10: | 751 DRIVE INTERFACE | | | 10.0 | GENERAL | | 131 | | 10.1 | VMEbus | INTERFACE SIGNALS | 131 | | 10.2 | EXTENDE | ED STORAGE MODULE DRIVE INTERFACE | 134 | | TNDEX | | | 137 | # LIST OF ILLUSTRATIONS | | | PAG | Έ | |---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------|--------------------------| | FIGURES | | | | | FIGURES | 2-1. 2-2. 2-3. 2-4. 2-5. 7-1. 7-2. 7-3. 7-4. 7-5. 7-6. 7-7. 8-1. 8-2. 8-3. 8-4. 8-5. 8-6. 8-7. 8-8. 8-9. 8-10. 9-1. | 751 - Component Location Base Address Jumper Block | 012703457801246777772775 | | TABLES | 2-1.<br>2-2.<br>3-1.<br>3-2.<br>4-1.<br>4-2.<br>4-3.<br>4-4.<br>4-5.<br>4-6.<br>5-1.<br>5-2.<br>6-1.<br>6-2.<br>8-1.<br>8-2.<br>8-3.<br>8-4.<br>8-5.<br>8-6. | Base Address Selection | 283774772480L83460 | #### SECTION 1: SPECIFICATIONS #### 1.0 GENERAL The Xylogics Model 751 Disk Controller accommodates up to two SMD-E interface disk drives to VMEbus<sup>1</sup> systems. #### 1.1 USING THIS MANUAL This manual provides two Software Reference Cards for fast reference of the IOPB structure and codes (See insert). Section 2 describes how to install and test the 751; Section 3 describes the 751 registers; Section 4 describes the IOPBs; and Section 5 describes the 751 commands. Section 6 describes error processing; Section 7 is a programming tutorial; Section 8 explains the 751's special functions; Section 9 describes the 751 theory of operation; and Section 10 includes maintenance aides. #### 1.1.1 Abbreviations This manual uses the following mnemonics: AFE Alternate Field Enable AIO Add New IOPB AIOP AIO Pending AIOR AIO Response Time AM Address Modifier ASR Automatic Seek Retry AUD Auto-update BHT Black Hole Transfer C450 450-Compatible Format CHEN Chain Enable CRIO Clear Remove IOPB COP Command Optimization CRBS Clear Register Busy Controller Type CTYP DFLT Drive Fault Direct Memory Access DMA DPBDual Port Busy DRDY Drive Ready EC32 32-Bit ECC ECC Error Correction Code ECCM Error Correction Mode EDT Enable DMA Timeout ERRS Error Summary ESD Embedded Servo Drive <sup>1.</sup> VMEbus is a trademark of the VMEbus International Trade Association. #### 1.1.1 Abbreviations (continued) FERR Fatal Error FIFO First In/First Out Buffer FIXD Fixed/Removable Media H Notation For Numerical Values Expressed in Hexadecimal HDP Hold Dual Port ICS IOPB Checksum IEC Interrupt At End Of Chain IOPB Input/Output Parameter Block MMA Maintenance Mode Active MM Maintenance Mode NPRM Non-privileged Register Mode ONCL On-cylinder OVS Overlap Seek Enable PNUM Prom Number PRIO Priority IOPB PSEL Priority Select RBC Retry Before Correction RBS Register Busy Semaphore RIO Remove IOPB RMM Register Maintenance Mode ROR Release On Request SGM Scatter/Gather Mode SKER Seek Error TDT Throttle Dead Time THRO Throttle TMOD Transfer Mode WRPT Write-protect ZLR Zero Latency Reads #### 1.2 DESIGN RELIABILITY Xylogics implements the following features to minimize the likelihood of product failure: - o Design for worst case voltage and temperature. - o Extensive evaluation testing. - o Low parts count through extensive use of custom LSI. - o Buffer parity for continuous error checking. - o Low-stress design on all components. - o All components burned-in. - o One card; resides in backplane or expansion chassis. - o Controller is power-cycled under thermal stress during test. #### 1.3 PHYSICAL PACKAGING -- The 751 completely resides on one printed circuit board. DIMENSIONS — The 751 is a 2 by 2 Eurocard standard; it measures 9.2-inches high by 6.3-inches deep (233.35 mm by 160 mm). The 751 is identical in form-factor to the standard VME (dual high-dual wide) printed circuit board. SHIPPING WEIGHT -- 3 pounds (1.4 kg). FRONT PANEL -- Xylogics offers the 751 with an optional front panel. CONNECTORS — The SMD connectors are on the edge of the board facing out; they protrude through the optional face plate. The optional straight connectors do not protrude the face plate. #### 1.4 ENVIRONMENTAL The 751 environmental requirements are 0 - 550 C, with a maximum relative humidity of 90% (without condensation). Air flow across the board must maintain a maximum temperature differential of $7^{\circ}$ C to prevent hot spots. #### 1.5 ELECTRICAL POWER -- The 751 uses 4.1 amperes at +5 volts DC (VDC), and 0.5 amperes at -12 VDC. The -5 volts for the differential transceivers is derived on-board. TOLERANCE — Voltages must be within plus or minus five percent (4.75 to 5.25; -11.4 to -12.6). GROUNDING -- Common earth ground must be established between the disk drives and the CPU chassis, backplane, and expansion cabinets. #### 1.6 SYSTEM RELATED SPECIFICATIONS DATA BUFFERING — The 751 has a FIFO buffer that is 8K-bytes long and incorporates parity error detection. Data can be put into one end of the FIFO and simultaneously removed at the other end; there are no delays associated with filling and emptying the buffer. MULTIPLE IOPBS ON A SINGLE REVOLUTION — The 751 can execute multiple IOPBs on a single revolution. For example, if four IOPBs for four sectors on the same head and cylinder are chained, the 751 can transfer the sectors into the buffer on a single revolution, and transfer each one out to the correct memory location. #### 1.6 SYSTEM RELATED SPECIFICATIONS (continued) PRIORITY IOPBs — The 751 executes priority IOPBs over all IOPBs in its command queue, except for the one in process. FORMAT — The 751 Format command formats a specified number of tracks. Use the Read/Write Track Headers commands to incorporate custom interleaving schemes. Standard interleaving is 1:1; 2:1 to 15:1 interleaving is software programmable. MEDIA DEFECTS — The 751 has several methods for remapping bad blocks. One method leaves spare sectors on each track that can be slipped with Read/Write Track Headers commands. An alternate method has the spare sectors on the last part of the maximum track. The 751 also remaps entire tracks. This lessens the total number of spare sectors required with minimal affect on 751 performance. READ DEFECT MAP FEATURE — The 751 can read the manufacturer's defect information directly from the disk. STATUS LEDs — The 751 implements two status LEDs. II (BSY) indicates the controller is active; L2 (ERR) indicates the on-board diagnostics did not complete successfully, or a fatal error occurred. SCATTER/GATHER — The 751 supports Scatter/Gather on Read and Write commands. The controller can gather data from various memory locations and transfer it to the buffer for use in a Write command; it can scatter the data out from the disk drive to the appropriate memory locations with a Read command. To execute a scatter/gather, software issues a normal Read or Write command along with a DMA list that contains a memory address and the number of words to transfer to/from that location. The smallest granularity of scatter/gather is a 16-bit word. ERROR DETECTION AND CORRECTION — The 751 supports a 48-bit data ECC with a redundant header check; it optionally supports a 32-bit ECC on the header and data. Software controls automatic detection and correction. The 32-bit ECC detects an error burst up to 22-bits long, and corrects error bursts up to 11-bits long, assuring data integrity. The 48-bit ECC detects an error burst up to 28-bits long, and corrects error bursts up to 14-bits long. IMPLIED SEEK CAPABILITY — Data transfer instructions contain an implied seek. Data transfers cross sector, head, and cylinder boundaries as required (spiral read/write). OVERLAP SEEKS — The 751 supports overlap seeks. When overlap seeks are enabled, the 751 may have both drives simultaneously seeking to the appropriate cylinders. ELEVATOR SEEKS — When elevator seeks are enabled, the 751 reorders commands in ascending and then descending cylinder order to get the best throughput from the disk subsystem. #### 1.6 SYSTEM RELATED SPECIFICATIONS (continued) ZERO LATENCY READS — When the head arrives over the cylinder, the 751 reads the first sectors it finds that are included in the IOPB; it transfers the data to its own buffer and then out to the correct memory location. The controller finishes the track transfer when the initial sectors arrive under the head. BLACK HOLE TRANSFERS — The 751 may transfer all the DMA data into the same bus address without incrementing the address at each DMA. SOFTWARE SUPPORT — Sample software driver supplied for use in UNIX2 based systems (source included). #### 1.7 DISK DRIVE RELATED SPECIFICATIONS PHYSICAL DRIVE INTERFACE — The 751 supports the Extended SMD Interface ([SMD-E]; See the Control Data Corporation (CDC) 64712402, Revision A, and Fujitsu B03P-4760-0101A). INTERFACE DATA RATE AND STANDARD INTERLEAVE FACTOR — The 751 supports a maximum disk data rate of 2.4 Megabytes Per Second (MBS). The 751 supports this data rate at a 1:1 interleave factor. This allows continuous data transfers, crossing sector and head boundaries with no loss of disk revolutions (assuming the controller is allocated enough bus time to transfer the data). MIXED DATA RATES — The 751 mixes drives with different data rates (i.e., 1.2 MBS, mixed with 1.8 MBS, or mixed with 2.4 MBS drives). EMBEDDED SERVO DRIVES — The 751 supports embedded servo drives. NUMBER OF DISK DRIVES — The 751 supports up to two SMD disk drives. DISK SECTOR FORMAT — The 751 sector format includes a header field separated from a data field by a splice area. HEADER FORMAT — Header contains sector, head, cylinder address, and header ECC or a redundant header. CABLING - Standard SMD flat cabling; SMD compatible. DUAL PORT — The 751 supports dual port drives. 2. UNIX is a trademark of AT&T. #### 1.8 VMEbus RELATED SPECIFICATIONS TRANSFER MODE - Direct Memory Access (DMA). DMA THROTTLE CONTROL — Each time the 751 becomes bus master, it executes DMA transfers to or from the buffer up to the max throttle limit or the number of bytes/spaces available in the buffer. DMA DATA TRANSFER RATE — The 751 transfers data at a rate of up to 10 MBS; this rate requires Longword mode transfers and system memory that responds within 200 nanoseconds. DMA DEAD TIME — The 751 supports a programmable throttle dead time between throttle bursts. This prevents the 751 from taking over the bus and allows time for other DMA devices to access the bus. DATA TRANSFER LIMIT — Data transfer length, from 1 to 65,535 sectors with a single IOPB. BUS COMPATIBILITY — The 751 is compatible with the standard VMEbus. ADDRESSING CAPABILITY — The 751 supports Master A32, and Slave A16, as per the VMEbus Specification Manual. As a slave, the 751 responds to Address Modifiers 29H and 2DH (software programmable). DATA WIDTH — The 751 supports D16 and D32 as per the VMEbus Specification Manual. The 751 transfers one byte, one word, or a byte and a word until the transfer aligns with a word or longword boundary. RELEASE ON REQUEST — Software programmable; the 751 releases the bus at the request of other peripheral devices. RELEASE WHEN DONE — The 751 releases the bus after each bus access. BUS REQUEST LEVELS — The 751 supports four bus request levels. EARLY RELEASE OF BUS BUSY/ — The 751 does not support early release of Bus Busy/. INTERRUPT PRIORITY — Software programmable interrupt level and vector. CONTROLLER I/O PARAMETER BLOCK (IOPB) LENGTH - 30 bytes. CONTROLLER REGISTERS — Seven 8-bit I/O Registers; byte or word addressable. Only eight bits respond during word access. DIAGNOSTIC SUPPORT — Comprehensive set of stand-alone diagnostics written in 'C' are available. #### 1.9 SOFTWARE RELATED SPECIFICATIONS SOFTWARE INTERFACE — The 751 supports a high level software interface that allows host software to use the same method to add IOPBs to a chain while the controller is busy or while it is free. #### 1.9.1 <u>Software Interface</u> The software interface includes seven byte-wide registers. Four of these bytes comprise the VME Address Register, the fifth byte is the Address Modifier Register, the sixth byte is the Control and Status Register (CSR), and the last byte is the Fatal Error Register (the 751 returns the fatal error codes in this register). The CSR includes two bits that are very important to IOPB processing: Add IOPB (AIO) and Remove IOPB (RIO). The IOPB is a block of command and status information; it includes the disk address, the bus address, and the type of operation to be performed. The software driver sets up the IOPB in memory, sends the IOPB address to the VME Address Registers, and sets the AIO bit. After the 751 receives the IOPB address it resets AIO. The 751 then performs the IOPB function and, upon completion or error, updates the IOPB status and sets RIO. The VME Address Registers point to the completed IOPB; the software driver reads the address and then resets RIO. Software may add IOPBs to the queue, providing AIO is reset, by writing the IOPB address to the address registers and setting AIO (regardless of the 751's busy status). #### 1.10 PROGRAMMABLE FEATURES - Software Controlled Interrupt or Polled Operations. - o Software Programmable DMA Parameters. - o Software Programmable Drive Size Parameters (Including Sector Size). - o Software Programmable Sector Interleaving Standard 1:1. - o Software Controlled Register Response. - o Software Controlled Transfer Retry/Correction. #### SECTION 2: INSTALLING AND TESTING THE 751 #### 2.0 GENERAL Section 2 describes how to unpack, configure, install, and test your 75l controller. #### 2.1 UNPACKING AND INSPECTION #### 2.1.1 <u>Inspect the Shipping Carton</u> Inspect the carton for possible shipping damage. If you determine there is damage, do not unpack the unit. Notify Xylogics and the freight carrier immediately. If no damage is visible, carefully unpack the 751. Save the carton and other packing material for possible later use. #### 2.1.2 Contents The 751 is a single printed circuit board. Optional items include a manual and/or software on a floppy diskette, or 1/2-inch magnetic tape. If any items are missing or damaged, please contact Xylogics at one of the following telephone numbers. United States: (617) 272-8140 United Kingdom (Slough): 44-753-78921 #### 2.1.3 <u>Handling Precautions</u> Observing proper handling precautions minimizes the risk of damaging the 751 with electrostatic discharge. When transporting the 751, use an antistatic bag, antistatic bin, or the original shipping carton and packing material. Personnel handling the 751 should observe proper grounding methods including, but not limited to, wrist bands, heel straps, and antistatic mats. The 751 has a non-volatile memory circuit that employs a lithium battery (at location E8). Do not expose this device to excessive heat (greater than 125° C) as it may ignite or explode. #### 2.1.4 Inspect the 751 Inspect the 751 for socketed parts that may have loosened during shipment. Make sure all parts are firmly seated in their sockets. If any parts need reinsertion, observe proper orientation. #### 2.2 CONFIGURING THE 751 You can configure the 751 with several jumper options. The following subsections describe these options. FIGURE 2-1. 751 - COMPONENT LOCATION #### 2.2.1 Base Address Selection Jumper block JA controls the base address. Table 2-1 shows how to set the jumpers for commonly used base addresses. Inserting a jumper makes the 751 respond to a 0 on that address line; removing a jumper makes the 751 respond to a 1. Connect the jumper between similar pin numbers on each block. (The 751 uses bits 1 through 3 to determine which register is being accessed.) The 751 is an Al6 Slave, and responds to address modifier 02DH, and optionally 029H. \* These two pins are test points, not address jumpers FIGURE 2-2. BASE ADDRESS JUMPER BLOCK | Screen Label -> | F | E | D | С | В | A | 9 | 8 | 7. | 6 | 5 | 4 | |-----------------|---|-----|-----|----|-------|---|---|---|----|---|---|---| | Address: | | | | | | | | | | | | | | 0100 | I | I | I | I | I | I | I | 0 | I | I | I | I | | 0800 | I | I | I | I | 0 | I | I | I | I | I | I | I | | EE40* | 0 | 0 | 0 | I | 0 | 0 | 0 | I | I | 0 | I | I | | EE80 | 0 | 0 | 0 | I | 0 | 0 | 0 | I | 0 | I | I | I | | | 0 | = 0 | ut; | I: | = In; | | | | | | | , | <sup>\*</sup> Standard Factory Configuration TABLE 2-1. BASE ADDRESS SELECTION #### 2.2.2 Bus Request and Bus Grant Lines The 751 uses the Bus Request and Bus Grant lines to become bus master. In VMEbus arbitration, there are four Bus Request/Grant levels: 0 through 3. The 751 drives one Bus Request line according to the jumper scheme you choose. The arbiter drives the four Bus Grant In lines: BG0IN\* through BG3IN\*. If the 751 receives a Bus Grant, and is not requesting the bus, it passes the grant by driving the appropriate Bus Grant Out line: BG0OUT\* through BG3OUT\*. #### 2.2.2 Bus Request and Bus Grant Lines (continued) Select a request level by jumpering one Bus Request (BRO\* through BR3\*), one Bus Grant In, and one Bus Grant Out line to match the selected request level. Jumper the remaining Bus Grant In/Out lines so that the incoming signal passes through the board (i.e., jumper BGxIN\* to BGxOUT\*, where x represents the remaining grant levels). For example, Figure 2-3 shows the jumpering scheme for level 0 (Figure 2-3A shows the jumper blocks as they actually appear on the board; 2-3B is labeled for this example): jumper JBl to JB5; then jumper JCl to JC5, and JDl to JD5. Jumper the remaining Grant levels from JC6 to JD2, JC7 to JD3, and JC8 to JD4. Factory configuration: Bus Request Level 3. #### NOTE Some VME processors only support Bus Request Level 3. Figure 2-3A. Actual Board Layout Figure 2-3B. Sample Jumpering Scheme FIGURE 2-3. JUMPERING BUS REQUEST AND BUS GRANT LEVELS # 2.2.3 Parallel Ambitration If you are using the 751 in parallel arbitration, and the Bus Grant Out lines must be isolated from the next slot's Bus Grant In lines, remove all jumpers between JC 5-8 and JD 1-4 (See Figure 2-3B). #### 2.3 FORMAT PARAMETERS AND MAINTENANCE MODE LOCKOUT JUMPER When jumper JE 1-2 is removed, you may only modify format field lengths for fields 5 and 5A, and you may only execute the diagnostic portion of the Maintenance mode. When jumper JE 1-2 is installed, you may set all format parameters and have unrestricted use of the Maintenance mode. The non-diagnostic portion of the Maintenance mode is proprietary to Xylogics and subject to change without notice. #### 2.4 SELF TEST DISABLE When jumper JE 3-4 is installed, the 751 does not execute the Self Test on power-up. #### 2.5 PROMS AND PALS | LOCATION | PART NUMBER | TYPE | | | | |-----------|-------------|-------|--|--|--| | C7 | 180-002-098 | EPROM | | | | | K3 | 181-001-015 | PAL | | | | | L3 | 181-001-016 | PAL | | | | | <b>C2</b> | 181-000-017 | PAL | | | | | D2 | 181-000-018 | PAL | | | | TABLE 2-2. PROM / PAL PART NUMBER AND LOCATION #### 2.6 LIGHT EMITTING DIODES The 75l has two light emitting diodes (LEDs). L1 (BSY) is the Busy LED (it is located closest to the printed circuit board). L2 (ERR) is the Error LED (it straddles L1). When L2 is on, SYSFAIL is asserted on the VMEbus. #### 2.7 BOARD LABELS / REVISION CONTROL All Xylogics controllers use various revision control labels. This information is important when discussing configuration issues with us. Please familiarize yourself with your board revision levels before contacting us. FIGURE 2-4. SAMPLE PART NUMBER #### 2.8 PREPARING THE COMPUTER SYSTEM FOR INSTALLATION The backplane of your system must provide a VMEbus slot for the 751. The slot must be capable of handling a bus master, and the power source must handle the power consumption of the entire system, including the 751. #### 2.8.1 Backplane Jumpers Remove any jumpers that short, or cause the Interrupt Acknowledge (IACK IN/OUT) and DMA Grants (BG 0-3 IN/OUT) to bypass the slot in which you are installing the 751. #### 2.8.2 <u>Card Cage Slot</u> The card cage must have a slot at the proper DMA priority available for the 751. The 751 uses DMA to transfer data and IOPBs. Placement of the 751 in the DMA priority chain may be critical. The amount of bus bandwidth it uses will be high at times; this may affect other boards in the system. Likewise, other boards may not allow enough time for the 751 to DMA enough data to keep up with the disk; consider this when choosing a slot. If the 751 does not get a high enough priority, then its DMA falls behind what the disk requires, and it has to wait until the next revolution before continuing the transfer. If the 751 priority is high, it gets enough DMA time, but other boards having insufficient buffers may starve from lack of DMA time. The priorities must be balanced for your system to work properly. #### 2.8.3 Power Considerations The 75l affects the power consumption of the entire computer system. The 75l uses +5 volts for logic and -12 volts to provide -5 volts to power the differential drivers/receivers for the SMD interface. Be sure the power supplies can handle the entire power load. Readjust the voltages AFTER plugging in the 75l. A power supply that is just adequate may cause intermittent and unusual problems due to noise generated by occasionally going into overcurrent protection. Limits: +5 volts (4.75 to 5.25 volts) at 4.1 amps; -12 volts (-11.4 to -12.6 volts) at 0.5 amps. #### 2.9 PREPARING THE DISK DRIVE FOR INSTALLATION Follow the manufacturer's instructions for unpacking and inspecting the disk drive. Configure the drive for use with the 751. This entails setting up such parameters as the Unit Select, number of sectors per track, and ensuring the sector and index pulses are provided on the "A" cable. Consult the drive manual for the exact method of configuring your drive. #### 2.9.1 Drive Unit Select A plug on the front of the drive, or switches on one of the drive's internal circuit cards, usually selects the drive Unit Number. The 751 accesses drives with Unit Numbers ranging from 0 through 7. Set the first drive to Unit 0. #### 2.9.2 Number of Sectors Per Track Switches on one of the drive's internal circuit cards usually select the number of sectors per track. The 751 standard format uses 88-bytes of overhead per sector. This is a nominal number derived from the defaults set at the factory. See Section 8.3 for a more detailed description. If you are using the sector slip feature, the number of sectors available to the program is the total number of physical sectors on the drive less the spares (See Section 8.1 for more information on media defect mapping). Most disk drives have a runt sector (a very small sector at the end of the disk). The 751 requires all sectors except the runt to be formatted. The minimum runt size is six bytes. #### 2.9.3 Sector and Index Pulses Both the "A" (Control) cable and the "B" (Radial) cable can provide the sector and index pulses. Disk vendors usually provide drives with sector and index on the "A" cable. The 75l requires the "A" cable to carry sector and index. #### 2.9.4 Tags 4 and 5 Some disk drives use the Spare lines (See Section 10) for Maintenance functions (Tag 4). Other disk drives use the Spare lines for Extended Cylinder bits (Bit 10). The 751 supports both options; configure the drive for its intended use. #### 2.9.5 Extended Cylinder Addressing There are two methods for addressing cylinders beyond 1023. Xylogics supports the method that uses the Spare lines on the "A" cable as cylinder address bit 10. (The 751 does not support the alternate method of using the upper bits of the common interface bus and Tag 2 [Head Tag].) #### 2.10 INSTALL AND CABLE THE 751 #### 2.10.1 <u>Install the 751</u> Place the 751 into the computer card cage; make sure it is firmly seated. Be careful not to dislodge any socketed ICs. Situate the disk drive and connect it to its power source. #### 2.10.2 <u>Cable the Subsystem</u> #### 2.10.2.1 Connect the "A" Cable (Control) Install the "A" cable, observing "pin 1" markings on both ends. This cable connects to the 60-pin connector on the 751, and to the "A" cable connector on the drive. Use the "in" connector on the drive if there are two 60-pin connectors marked "in" and "out". The other connector should have a terminator, or the terminator should be built into the drive. Disable one of the ports if the drive is dual ported. (Only cable one disk drive for the initial system check. You can connect additional disk drives later.) #### 2.10.2.2 Connect The "B" Cable (Radial) Install a "B" cable (26-pin cable) from any "B" cable port on the 751 to the appropriate connector on the disk drive. The 751's "B" cable ports are not keyed to the logical disk drive unit number (i.e., Drive 0 can connect to Port 1 of the 751). When installing this cable, make sure the black stripe on the shielded cable lines up with the "pin 1" markings on the controller and drive. #### 2.10.2.3 Mechanical Restraint Make sure the "A" and "B" cables are mechanically restrained at both ends to prevent them from accidentally disconnecting. Using "pull tabs" on the cables greatly reduces connector damage. #### 2.10.2.4 Disk Drive Grounds Install a ground braid wire between the ground terminal on the disk drive(s) and the computer system ground. #### 2.11 INITIAL TESTS This section relies upon your familiarity with your computer system's monitor and diagnostics. #### 2.11.1 Power-up and Self Test The 75l initiates a self test upon power-up. The Error LED (L2) lights for a moment, and then goes off. If L2 remains on, and the Fatal Error Register indicates an IRAM Checksum error, then you need to load good parameters into the IRAM. Otherwise, if L2 remains on, the board is not functioning properly (the Fatal Error Register may indicate the nature of the problem). When L2 is on, SYSFAIL is asserted on the VMEbus. Contact Xylogics for further assistance. #### NOTE Check the power supply voltages to ensure they are within limits (4.75 to 5.25 volts, and -11.4 to -12.6 volts). #### 2.11.2 <u>Drive Ready</u> Spin the drive up and wait for it to become ready. Issue a Read Drive Parameters IOPB. The Drive Status byte indicates the drive status at execution time. If DRDY is not set, recheck the drive cable connections and try again. If you are still unable to get the proper status, check the -12V supply on the bus. If the problem persists, check the disk drive for functionality with an off-line tester. #### 2.12 DIAGNOSTICS When you run your diagnostics: - o Format the disk with either a diagnostic or format program. - o Run a full pass of your diagnostic (or determine that the system is working properly. - o Cable and test any additional drives (See Section 2.13). #### 2.13 CABLING MULTIPLE DRIVES If you are using multiple drives, make sure the "A" and "B" cables are properly connected; observe the "pin 1" markings on both the cables and the drives. #### 2.13.1 Terminator Remove the terminator from the drive currently connected to the controller. Install the terminator in the last drive in the chain (See Figure 2-5). #### 2.13.2 "A" Cable (Daisy-chain) Connect the "A" cable directly from the first drive in the chain to the 751; connect the second drive to the first drive (for example, the 751 connects to Drive 0; Drive 0 connects to Drive 1. (Be careful; do not reverse the cables) Terminate the "A" cable at the last drive in the chain. The "A" cable's maximum total length is 100 feet (See Figure 2-5). #### 2.13.3 "B" <u>Cable</u> (Radial) The "B" cables connect directly from each drive to a "B" cable port on the 751. A "B" cable may be up to 50-feet long (See Section 2.10.2.2). #### 2.13.4 Unit Select If you are daisy-chaining drives, assign each drive a unique Unit Select number. The 751 accesses drives with Unit Numbers from 0 through 7. FIGURE 2-5. CABLING MULTIPLE DRIVES #### SECTION 3: THE 751 REGISTERS #### 3.0 GENERAL The 751 programming interface is based on the use of seven, one-byte long, I/O registers. The bus address jumpers define the base address of the register set. Table 3-1 lists the registers along with the address offset from the base address. The 751 responds to either bytes or 16-bit words; when it responds to words, only 8 bits are valid. The registers have one function when read, and another when written. The following subsections detail their definitions. | REGISTER | | | | | | | |----------------------------------------------|---|--|--|--|--|--| | IOPB ADDRESS BYTE 0 (Least Significant Byte) | 1 | | | | | | | IOPB ADDRESS BYTE 1 | 3 | | | | | | | IOPB ADDRESS BYTE 2 | 5 | | | | | | | IOPB ADDRESS BYTE 3 (Most Significant Byte) | 7 | | | | | | | IOPB ADDRESS MODIFIER | 9 | | | | | | | CONTROL AND STATUS REGISTER | В | | | | | | | FATAL ERROR REGISTER | D | | | | | | #### TABLE 3-1. REGISTER OFFSETS #### 3.1 IOPB ADDRESS REGISTERS The first four registers define the 32-bit address of an IOPB or IOPB chain. When these registers are written, the 751 interprets it as the address of the IOPB or IOPB chain to be executed. When read, and the Remove IOPB (RIO) bit is set, the registers point to the IOPB or IOPB chain just completed by the 751. The protocol for reading and writing this address register is defined by the use of the Add IOPB (AIO) and Remove IOPB (RIO) bits in the Control and Status Register (See Section 3.3). #### 3.2 IOPB ADDRESS MODIFIER / PRIORITY IOPB REGISTER This register defines the IOPB address modifier. (Address modifiers are used for many purposes, such as memory mapping, privilege levels, and addressing range. Please consult the VMEbus Specification Manual for more information on address modifiers and their use.) This register also specifies whether an IOPB has # 3.2 IOPB ADDRESS MODIFIER / PRIORITY IOPB REGISTER (continued) priority over the current set of IOPBs in the 75l command queue. Section 3.3 defines the protocol for reading and writing this register. | | PRIORITY IOPB REGISTER | | | | | | | | | | | | | | | | | |-----------------------|------------------------|---|---|-----|---|-----|---|------|---|-----|---|-----|---|-----|---|---|---| | + | Ī | 7 | ١ | 6 | I | 5 | 1 | 4 | I | 3 | l | 2 | I | 1 | I | 0 | 1 | | | | I | | l | | l | | ļ | | l | | l | | 1 | | 1 | _ | | PRIORITY IOPB REQUEST | | _ | | 1 | | | | | | | | | | | | | | | ADDRESS MODIFIER | | | | - ' | | _i_ | | _ İ_ | | _i_ | | _i_ | | _i_ | | i | | | BIT | MNEMONIC | DESCRIPTION | |-----|----------|----------------------------------------------------------------------------------------------------------------------------------| | 7 | PRIO | PRIORITY IOPB REQUEST - When set, the IOPB, or IOPB chain, precedes all others (except the one in process) in the command queue. | | 6 | | RESERVED. | | 5-0 | AM | ADDRESS MODIFIER - Most systems use the standard AM code of 3D. See the VMEbus Specification Manual. | #### 3.3 CONTROL AND STATUS REGISTER When written, this register provides the host with control of the 751 operation; when read, it provides the host with 751 status information. Section 3.3.1 defines the bits in this register when written; Section 3.3.2 defines the bits when read. #### 3.3.1 <u>Control Register</u> (Write) | 1 | |---| | _ | | | | | | | | | | | ### 3.3.1 <u>Control Register</u> (Write) (continued) | BIT | MNEMONIC | DESCRIPTION | |-----|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7 | RMM | REGISTER MAINTENANCE MODE - When RMM and MM are set, the values previously written in all the registers (except the CSR) are echoed back. | | 6 | | RESERVED. | | 5 | ММ | ENABLE MAINTENANCE MODE - Setting MM and AIO places the 751 in Maintenance mode. This mode supports a different Register protocol and is used as a diagnostic tool. Section 8 outlines the Maintenance mode. | | 4 | | RESERVED. | | 3 | CRST | CONTROLLER RESET - This bit signals the 751 microprocessor to perform a "soft" reset; it deselects (releases dual port) all the drives, stops the DMA and Disk Sequencers (potentially during sector transfers), and cancels any IOPBs in the queue. When the Controller Reset completes, the 751 resets the CSR to zero. CRST does not initiate a Power-up Self Test. | ### NOTE A Controller Reset takes up to one second to complete. 2 AIO ADD IOPB - The host sets AIO to indicate that the 751 should execute the IOPB (chain) at the address pointed to by the IOPB Address and Address Modifier Registers. Essentially, AIO commands the 751 to begin executing a new IOPB (chain). As soon as the host asserts this bit, the 751 asserts the AIO Pending (AIOP) bit in the Status Register; this indicates that the 751 has received the AIO signal but has not yet processed the address of the new chain. AIOP is negated in the Status Register after the 751 internally stores the new (chain) address. The 751 can store up to 47 IOPB addresses in this manner. Reasserting AIO if AIOP is asserted in the Status Register violates the Register protocol. ### 3.3.1 <u>Control Register</u> (Write) (continued) | BIT | MNEMONIC | DESCRIPTION | |-----|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 1 | CRIO | CLEAR RIO - The host sets CRIO to clear RIO in the Status Register. Typically, the host sets CRIO after it reads the address of a completed IOPB chain from the IOPB Address and Modifier Registers. Clearing RIO enables the 751 to update the IOPB Address and Modifier Registers with the address and address modifier of a newly completed IOPB chain. Clearing RIO if it is not set in the Status Register violates the Register protocol. | | 0 | CRBS | CLEAR RBS - The host sets the Clear Register Busy (CRBS) bit to clear the RBS bit in the Status Register. Clearing RBS effectively releases the registers for use by another host (See Section 8.8.2). (CRBS is only relevant in a multiprocessor environment.) | ## 3.3.2 Status Register (Read) | | | | | S | ľA' | IUS | S I | Œ | SIS | STE | R | (F | Rea | ad) | | | | |------------------------------------|---|-----|---|---|-----|---------|-----|---|-----|---------|---|----|-----|-----|---|---|---| | | Ī | 7 | I | 6 | l | 5 | I | 4 | 1 | 3 | I | 2 | 1 | 1 | l | 0 | Ī | | BUSY | | | | ļ | | | | | | ļ | | | | | | ļ | | | FATAL ERROR | | . 1 | | _ | | ļ | | | | ļ | | ļ | | | | | | | MAINTENANCE MODE ACTIVE RESERVED | | | | | | - I<br> | | . | | | | | | | | | | | CONTROLLER RESET ACTIVE | | | | | | | | | | - l<br> | | _ | | | | | | | REMOVE IOPBREGISTER BUSY SEMAPHORE | | | | | | | | | | | | | | -1 | | | | ## BIT MNEMONIC DESCRIPTION BUSY - The 751 is executing IOPBs. The 751 sets BUSY when it clears AIOP to acknowledge the first IOPB address; it clears BUSY after completing all the IOPBs with no new ones pending (within 500 microseconds of the host clearing RIO on the last IOPB). This bit is redefined when the 751 is in Maintenance mode (See Section 8.6). # 3.3.2 <u>Status Register</u> (Read) (continued) | BIT | MNEMONIC | DESCRIPTION | |-----|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 6 | FERR | FATAL ERROR - The 751 detected a fatal hardware error (a fatal error asserts SYSFAIL). A Controller Reset clears this bit. The Fatal Error Register contains more specific information. The 751 asserts FERR under the following conditions: | | , | | <ol> <li>Maintenance Mode Test Failure;</li> <li>Power-up Self Test Failure;</li> <li>IOPB Checksum Miscompare;</li> <li>IOPB DMA Fatal;</li> <li>IOPB Address Alignment Error;</li> <li>Firmware Error;</li> <li>Illegal Maintenance Mode Test Number; and</li> <li>ACFAIL Asserted.</li> </ol> | | 5 | MMA | MAINTENANCE MODE ACTIVE - When set, the 751 is in Maintenance mode (See Section 8.6). | | 4 | | RESERVED. | | 3 | RSTA | CONTROLLER RESET ACTIVE - The host set Controller Reset in the Control Register and the 751 is currently resetting itself. | | 2 | AIOP | AIO PENDING - When set, AIO has been set in the Control Register, but the 751 has not acknowledged its receipt. When clear, AIO may be set again. | | 1 | RIO | REMOVE IOPB - The 751 sets RIO after completing an IOPB, or a chain of IOPBs, and placing the address in the IOPB Address and Address Modifier Registers. | | | | After the host reads the address and modifier, it must clear RIO by writing Clear RIO (CRIO) in the Control Register. | | 0 | RBS | REGISTER BUSY SEMAPHORE - RBS provides a means of allowing multiple hosts to share access to the 751 registers without simultaneous access (See Section 8.8.2). (RBS is only relevant in a multiprocessor environment.) | ### 3.4 FATAL ERROR REGISTER If a fatal error occurs, the 75l returns the appropriate Completion Code in this register. Table 3-2 lists the fatal error codes; Section 6.5 describes them. | CODE | DESCRIPTION | |-----------|----------------------------------------------------| | E0 | IRAM Checksum Failure | | El | IRAM Self Test Failure | | <b>E2</b> | EPROM Checksum Failure | | E3 | Maintenance Test 3 Failure (DSKCEL RAM) | | E4 | Maintenance Test 4 Failure (Header Shift Register) | | E5 | Maintenance Test 5 Failure (VMEDMA Registers) | | E6 | Maintenance Test 6 Failure (REGCEL Chip) | | E7 | Maintenance Test 7 Failure (Buffer Parity) | | E8 | Maintenance Test 8 Failure (Disk FIFO) | | E9-EF | Reserved | | F0 | IOPB Checksum Miscompare | | Fl | IOPB DMA Fatal | | F2 | IOPB Address Alignment Error | | F3 | Firmware Error | | F5 | Illegal Maintenance Mode Test Number | | F6 | ACFAIL Asserted | TABLE 3-2. FATAL ERROR CODES ### SECTION 4: IOPB DESCRIPTION ### 4.0 GENERAL The Input/Output Parameter Block (IOPB) passes messages between the 751 and host software: software passes the type of transfer, disk address, data address, and count to the 751; the 751 returns the transfer status and possibly the ending addresses upon command completion. This section begins with the standard IOPB for most data transfer commands and follows with variations of the IOPB. ### 4.1 STANDARD IOPB The 751 uses the standard IOPB for data transfer commands and some general purpose commands. #### 5 6 4 3 2 0 ERRS DONE CHEN SGM COMMAND 00 COMPLETION CODE 01 DPB SR CSE WRPT DFLT SKER ONCL DRDY 02 INTERNAL STATUS nτ SUBFUNCTION CODE 04 FIXD RDP PSEL BHT UNIT 05 LINK LIST LENGTH INTERRUPT LEVEL 06 INTERRUPT VECTOR 07 COUNT HIGH 08 COUNT LOW 09 CYLINDER HIGH OA CYLINDER LOW OB HEAD OC. SECTOR OD DATA OR LINK ADDRESS MODIFIER 0E PRIO 0 NEXT IOPB ADDRESS MODIFIER OF DATA OR LINK ADDRESS HIGH 10 DATA OR LINK ADDRESS 11 DATA OR LINK ADDRESS 12 DATA OR LINK ADDRESS LOW 13 NEXT IOPB ADDRESS HIGH 14 NEXT IOPB ADDRESS 15 NEXT IOPB ADDRESS 16 NEXT IOPB ADDRESS LOW 17 IOPB CHECKSUM HIGH 18 IOPB CHECKSUM LOW STANDARD IOPB 19 ## 4.1.1 IOPB Byte 0 (Command) | | - | | | | | | | | | | | | | | | | | |----------------|---|---|---|---|---|----|---|---|---|------|---|------|---|--------------|---|----|---| | | 1 | 7 | 1 | 6 | l | 5 | ١ | 4 | ١ | 3 | I | 2 | I | 1 | ١ | 0 | I | | | | 1 | | 1 | | I | | 1 | | I | | Ī | | 1 | | 1 | | | ERROR SUMMARY | | _ | | | | | | 1 | | ı | | | | - | | 1 | | | DONE | | | | _ | | 1 | | ı | | 1 | | 1 | | 1 | | 1 | | | CHAIN ENABLE | | | | | | _1 | | ĺ | | 1 | | 1 | | 1 | • | Ì | | | SCATTER/GATHER | | | | | | | | Ĺ | | Ì | | Ì | | İ | | Ì | | | COMMAND | | | | | | | | | | . İ_ | | _ İ_ | | _ <b>İ</b> _ | | -Ì | | | COMMANI | ) | | |---------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | BIT | MNEMONIC | DESCRIPTION | | 7 | ERRS | ERROR SUMMARY - ERRS is only valid if DONE is set. When set, a hard or soft error occurred during IOPB processing. When clear, the 751 successfully completed the IOPB. | | | | NOTE | | | | Clear DONE and ERRS before executing an IOPB. | | 6 | DONE | DONE - When set, the IOPB is complete; if chained, software may remove the IOPB from the chain and reuse it. | | 5 | CHEN | CHAIN ENABLE - When set, the Next IOPB Address Modifier and Next IOPB Address point to the next chained IOPB. When clear, this IOPB is not chained to another IOPB. If CHEN and IEC are set, the 75l returns the whole chain with one RIO; if CHEN is set and IEC is clear, the 75l returns one IOPB at a time. | | 4 | SGM | SCATTER/GATHER MODE - When set, the IOPB is either a scatter (read) or a gather (write) transfer; a linked list describes the number of 16-bit words and to what address the 751 transfers each section of the data. The link address modifier and the link address specify the link list location. When clear, this IOPB specifies the data transfer address; the data is transferred to/from contiguous memory. SGM is only valid for standard reads and writes. | # 3-0 COMM COMMAND - See Table 4-2. # 4.1.2 <u>IOPB Byte 1</u> (Status Byte 1) After the 751 executes the IOPB, it sets DONE and posts a Completion Code in this byte. Completion Codes are only valid if ## 4.1.2 <u>IOPB Byte 1</u> (Status Byte 1) (continued) DONE is set. A code of 0x indicates a successful completion; any other value indicates an error occurred (See Section 6). ## 4.1.3 <u>IOPB Byte 2</u> (Status Byte 2) IOPB Byte 2 is the Disk Status byte; it is only valid if DONE is set. Byte 2 (excluding bits 5 and 6) is read from the drive selected by this IOPB. | | 1 | 7 | I | 6 | I | 5 | l | 4 | 1 | 3 | l | 2 | 1 | 1 | I | 0 | 1 | |------------------------|---|---|---|---|---|-----|---|---|---|----|---|----|---|-----|---|----|---| | | | 1 | | 1 | | 1 | | 1 | | 1 | | 1 | | | | 1 | | | DUAL PORT BUSY | | _ | | ı | | 1 | | 1 | | ı | | 1 | | 1 | | 1 | | | SLIPPED REVOLUTION | | | | _ | | ı | | 1 | | ١ | | 1 | | 1 | | 1 | | | COUNT SECTORS EXECUTED | | | | | | _ [ | | ı | | l | | ı | | 1 | | 1 | | | WRITE-PROTECT | | | | | | | | _ | | ı | | 1 | | ı | | ĺ | | | DISK FAULT | | | | | | | | | | _1 | | Ĺ | | I | | ĺ | | | SEEK ERROR | | | | | | | | | | | | _ĺ | | İ | | Ì | | | ON-CYLINDER | | | | | | | | | | | | | | _ İ | | 1 | | | DRIVE READY | | | | | | | | | | | | | | | | -Ì | | | BIT | MNEMONIC | DESCRIPTION | |-----|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7 | DPB | DUAL PORT BUSY - Sets if the selected port in a dual ported drive is busy. | | 6 | SR | SLIPPED REVOLUTION - Sets if the 751 is unable to DMA enough data to keep up with the disk; it waits until the sector comes around on the next revolution. | | 5 | CSE | COUNT SECTORS EXECUTED - Sets if the current sector count is invalid and the 751 has to recount the sectors. | | 4 | WRPT | WRITE-PROTECT - Sets if the selected drive is write-protected. | | 3 | DFLT | DISK FAULT - Sets if a fault condition exists in the selected drive. | | 2 | SKER | SEEK ERROR - Sets if sofware selects a cylinder higher than the drive maximum, or a seek does not complete within 500 milliseconds. | | 1 | ONCL | ON-CYLINDER - The 751 sets ONCL when the selected drive is on-cylinder. | | 0 | DRDY | DRIVE READY - The 751 sets DRDY when the last drive selected is ready. | ## 4.1.4 <u>IOPB Byte 3</u> (Status Byte 3) IOPB Byte 3 is reserved. It reflects the 751's internal status and may be a non-zero value. ### 4.1.5 <u>IOPB Byte 4</u> (Subfunction) IOPB Byte 4 is the Subfunction byte. Subfunction Codes follow a convention that indicates whether the code is generic to all VME controllers, generic to a group of controllers (i.e., 772, 712, 751, etc.), or specific to a particular controller (See Table 4-1). The 751 combines standard Command Codes with Subfunction Codes to execute commands. The IOPB Command Code and Subfunction Code fields define the required operation. Table 4-2 lists the 751 Command and Subfunction Codes. | SUBFUNCTION CODES (HEX) | CLASS | | | | | | | | |-------------------------|----------------|--|--|--|--|--|--|--| | 00-1F | GENERIC TO ALL | | | | | | | | | 20-3F | Generic Tape | | | | | | | | | 40-5F | 772-Specific | | | | | | | | | 60-7F | Reserved | | | | | | | | | 80-9F | Generic Disk | | | | | | | | | AO-AF | 751-Specific | | | | | | | | | BO-BF | 712-Specific | | | | | | | | | CO-FF | Reserved | | | | | | | | TABLE 4-1. SUBFUNCTION CODE CLASSES | CODE | COMMAND | SUBFUNCTION | DESCRIPTION | |------|------------------|----------------|-------------------------------------------------------------------------------| | 0 | NOP | 00 | No Operation | | 1 | WRITE | 00 | Normal Write | | 2 | READ | 00 | Normal Read | | 3 | SEEK | 00<br>01 | Report Current Address<br>Seek and Report Current<br>Address | | | | 02 | Start Seek and Report<br>Completion Immediately | | 4 | DRIVE RESET | 00 | Drive Reset | | 5 | WRITE PARAMETERS | 00<br>80<br>81 | Write Controller Prmtrs.<br>Write Drive Parameters<br>Write Format Parameters | TABLE 4-2. 751 COMMAND/SUBFUNCTION CODES # 4.1.5 <u>IOPB Byte 4</u> (Subfunction) (continued) | CODE | COMMAND | SUBFUNCTION | DESCRIPTION | |------|-----------------|-------------|-------------------------------| | 6 | READ PARAMETERS | 00 | Read Controller Prmtrs. | | | | 80 | Read Drive Parameters | | | | 81 | Read Format Parameters | | | | A0 | Read Drive Status<br>Extended | | 7 | EXTENDED WRITE | 80 | Write Track Headers | | | | 81 | Write Track Format | | | | 82 | Write Header, Header | | | | | Verify, Data, and Data ECC | | | | A0 | Write Defect Map | | | | Al | Write Defect Map<br>Extended | | 8 | EXTENDED READ | 80 | Read Track Headers | | | | 81 | Verify Data | | | | 82 | Read Header, Header | | | | | Verify, Data, and Data ECC | | | | A0 | Read Defect Map | | | | Al | Read Defect Map Extended | | 9 | DIAGNOSTICS | 00 | Self Test | | A-F | RESERVED | | | TABLE 4-2. 751 COMMAND/SUBFUNCTION CODES (continued) # 4.1.6 <u>IOPB Byte 5</u> (Unit) | | <br>7 | | 6 | ı | 5 | <u> </u> | 4 | 1 | 3 | ı | 2 | 1 | 1 | ı | 0 | <u> </u> | |--------------------------------------------------------------------------------------------------|-------|--|-------------|---|--------------|----------|---|---|---|---|---|-------|---|---|---|----------| | FIXED/REMOVABLE MEDIA RELEASE DUAL PORT PRIORITY SELECT BLACK HOLE TRANSFER RESERVED UNIT NUMBER | _ | | <br> - <br> | | <br> -<br> - | | | | | | | s es- | | | | | | DIT | MINERAL | DESCRIPTION | |-----|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7 | FIXD | FIXED/REMOVABLE MEDIA - When set, the 751 is accessing the fixed media portion of a disk drive. When clear, the 751 is accessing the removable media portion of a drive. This bit allows you to treat a fixed/removable drive as two separate disk drives. See Section 8.16. | | | | | ## 4.1.6 <u>IOPB Byte 5</u> (Unit) (continued) | BIT | MNEMONIC | DESCRIPTION | |-----|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 6 | RDP | RELEASE DUAL PORT - This bit is specifically used with dual ported disk drives. When set, the 751 releases the disk drive's port when it completes a command. When clear, the 751 does not release the disk drive's port when it completes a command. See Section 8.19. | | 5 | PSEL | PRIORITY SELECT - When set, it forces the selection of a dual port drive. See Section 8.19. | | 4 | BHT | BLACK HOLE TRANSFER - When set, the 751 does not increment the bus address during a data transfer; IOPB transfers occur normally. When clear, the 751 does increment the bus address. | | 3 | | RESERVED. | | 2-0 | UNIT | UNIT NUMBER - This value specifies the Unit<br>Number of the attached drive to which the<br>transfer is directed (in the range of 0 to 7). | ## 4.1.7 <u>IOPB Byte 6</u> (Interrupt Level) BIT MNEMONIC DESCRIPTION | | 1 | 7 | l | 6 | I | 5 | I | 4 | I | 3 | I | 2 | ļ | 1 | I | 0 | I | |------------------|---|-----|---|-----|---|-----|---|-----|---|---|---|-----|---|-----|---|----|---| | LINK LIST LENGTH | | _ _ | | _ _ | | _ _ | | _ _ | | _ | | 1 | | 1 | | Ī | - | | INTERRUPT LEVEL | | | | | | | | | | | | _ _ | | _ _ | | _1 | | | 7-3 | III | LINK LIST LENGTH - Bits 3-7 specify the length, in elements, of a linked list for Scatter/Gather commands. Each element refers to an 8-byte block in the linked list. See Table 8-2. | |-----|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 2-0 | | INTERRUPT LEVEL - The 751 uses these bits as the VMEbus hardware interrupt level when it completes the IOPB. The 751 will not interrupt if bits 0 through 2 are clear. | ### NOTE Depending on the command, Bytes 6 through 13 have different definitions (See Sections 4.2 through 4.4). ### 4.1.8 <u>IOPB Byte 7</u> (Interrupt Vector) IOPB Byte 7 determines the interrupt vector that the 751 uses upon command completion. This byte is not valid if the interrupt level is zero. ### 4.1.9 IOPB Bytes 8 and 9 (Count) Byte 8 is Count High; Byte 9 is Count Low. These bytes specify the number of sectors to be transferred in a data transfer IOPB. The Format command uses this count to determine the number of tracks to format. ### 4.1.10 <u>IOPB Bytes A and B</u> (Cylinder) Byte A is Cylinder High; Byte B is Cylinder Low. These bytes specify the starting cylinder address for a transfer. ### 4.1.11 <u>IOPB Byte C</u> (Head) IOPB Byte C specifies the starting head number for a transfer. ### 4.1.12 IOPB Byte D (Sector) IOPB Byte D specifies the starting sector number for a transfer. ### 4.1.13 <u>IOPB Byte E</u> (Data or Link Address Modifier) | | | | | | | | | | | | | | | | | | - | |-------------------------------|---|---|---|----|---|------|---|---|---|----------|---|--------------|---|------|---|---|---| | | 1 | 7 | ١ | 6 | 1 | 5 | I | 4 | I | 3 | I | 2 | I | 1 | I | 0 | I | | RESERVED | | | | _1 | | ı | | ı | | 1 | | 1 | | I | | 1 | | | DATA OR LINK ADDRESS MODIFIER | | | | | | - İ_ | | Ĺ | | <u> </u> | | _ <b> </b> _ | | _ Í_ | | _ | | ### BIT DESCRIPTION - 7-6 RESERVED. - 5-0 DATA OR LINK ADDRESS MODIFIER If SGM is set, bits 0 through 5 specify the Link List Address Modifier; if SGM is clear, this field specifies the Data Address Modifier. The 751 uses these modifiers to complete the address. ## 4.1.14 <u>IOPB Byte F</u> (Next IOPB Address Modifier) | | <u> </u> | 7 | ı | 6 | 1 | 5 | ı | 4 | 3 | 1 | 2 | 1 | . | 0 | <u> </u> | |----------------------------|----------|---|---|---|---|------|---|----------|---|---|---|---|---|---|----------| | PRIORITY IOPB | | _ | | ı | | 1 | | <u> </u> | 1 | | 1 | | | 1 | | | RESERVED | | | | _ | | ! | | | ! | | | | | | | | NEXT IOPB ADDRESS MODIFIER | | | | | | _ _ | | . I | | | _ | | | _ | | | BIT | MNEMONIC | DESCRIPTION | |-----|----------|---------------------------------------------------------------------------------------------------------------------------------------------------| | 7 | PRIO | PRIORITY IOPB - If PRIO was set in the Address Modifier Register when AIO was set, setting PRIO in Byte F indicates that this is a priority IOPB. | | 6 | | RESERVED. | | 5-0 | | NEXT IOPB ADDRESS MODIFIER - The Next IOPB Address Modifier, along with the Next IOPB Address, point to the next IOPB in the chain. | ### 4.1.15 <u>IOPB Bytes 10 through 13</u> (DMA Data Address) IOPB Byte 10 is DMA Data Address High; Byte 13 is DMA Data Address Low. These bytes comprise the data or link list address pointers. The 751 uses these bytes with the data or link list address modifier to point to the data or linked list address. If SGM is set, this address points to the linked list; if SGM is clear, this address points to the data address. (The link list address must be on a 16-bit word boundary.) ### 4.1.16 <u>IOPB Bytes 14 through 17</u> (Next IOPB Address) IOPB Byte 14 is Next IOPB Address High; Byte 17 is Next IOPB Address Low. These bytes comprise the Next IOPB Address pointers. The 751 uses these bytes with the Next IOPB Address modifier to point to the next IOPB in the chain (if CHEN is set in Byte 0). (The Next IOPB address must be on a 16-bit word boundary.) ### 4.1.17 IOPB Bytes 18 and 19 (IOPB Checksum) Byte 18 is IOPB Checksum High; Byte 19 is IOPB Checksum Low. The 751 calculates the checksum by adding the IOPB bytes. See Section 8.15. ## 4.1.18 IOPB Bytes 1A and 1B (ECC Pattern Word) Byte 1A is ECC Pattern Word High; Byte 1B is ECC Pattern Word Low. These bytes are required for ECC Mode 0 and may be required for Mode 2 (See Section 6.4). # 4.1.19 IOPB Bytes 1C and 1D (ECC Offset Word) Byte 1C is ECC Offset Word High; Byte 1D is ECC Offset Word Low. These bytes are required for ECC Mode 0 and may be required for Mode 2 (See Section 6.4). ## 4.2 CONTROLLER PARAMETERS IOPB This IOPB sets and reads various controller parameters. The 751 uses the standard IOPB, but redefines bits in Bytes 8, 9, A, B, and E. #### 6 5 3 4 2 0 ERRS DONE CHEN SGM COMMAND 00 COMPLETION CODE 01 DPB SR CSE WRPT DFLT SKER ONCL DRDY 02 INTERNAL STATUS 03 SUBFUNCTION CODE 04 UNIT 05 0 INTERRUPT LEVEL 06 INTERRUPT VECTOR 07 AUD FOF ICS EDT NPRM TMOD AIOR 08 TDT ROR 09 ovs RBC COP IEC ASR ZLR ECCM 0A THROTTLE 0B 0 OC: 0D CONTROLLER TYPE 0E PRIO NEXT IOPB ADDRESS MODIFIER OF PROM PART NUMBER HIGH 10 PROM PART NUMBER LOW 11 REVISION 12 SUBREVISION 13 NEXT IOPB ADDRESS HIGH 14 NEXT IOPB ADDRESS 15 NEXT IOPB ADDRESS 16 NEXT IOPB ADDRESS LOW 17 IOPB CHECKSUM HIGH 18 IOPB CHECKSUM LOW ### CONTROLLER PARAMETERS ### 4.2.1 <u>IOPB Byte 8</u> (Controller Parameters A) | | 1 | 7 | I | 6 | I | 5 | 1 | 4 | I | 3 | 1 | 2 | 1 | 1 | l | 0 | 1 | |------------------------------|---|----|---|---|---|---|---|----|---|----|---|---|---|------|---|---|---| | AUTO-UPDATE | | _1 | | ļ | | I | | l | | ļ | | ļ | | ļ | | ļ | _ | | TRANSFER MODE | | | | _ | | ı | | ı | | | | 1 | | 1 | | ı | | | RESERVED | | | | | | . | | 1 | | 1 | | ı | | 1 | | 1 | | | IOPB CHECKSUM | | | | | | | | -1 | | 1 | | 1 | | 1 | | 1 | | | ENABLE DMA TIMEOUT | | | | | | | | | | Ì. | | İ | | Ì | | İ | | | NON-PRIVILEGED REGISTER MODE | | | | | | | | | | • | | Ĺ | | ĺ | | Ĺ | | | AIO RESPONSE TIME | | | | | | | | | | | | | | _ İ_ | | Ì | | ### BIT MNEMONIC DESCRIPTION 7 AUD AUTO-UPDATE - When set, the 751 updates the IOPB to the transfer's ending parameters; it updates the disk address, the sector count, and the data address after completing the transfer detecting an error. When clear, the 751 only updates the IOPB if an error occurs. The values are then set up so that host software can tell the 751 to continue (the values should point to the sector in error, the correct remaining sector count, and proper data address). TRANSFER MODE - When set, the 751 executes data 6 TMOD transfers in Longword mode. When clear, it executes transfers in Word mode. (IOPB transfers are always in Word mode.) If a transfer starts on an improper address boundary, the 751 first transfers a byte and/or a word, as ## 5 RESERVED. ICS IOPB CHECKSUM - When set, the 75l reads the IOPB, compares the checksum it generated during the read with the checksum the software driver appended to the IOPB. The 75l also updates the Checksum bytes in any IOPB if AUD is set. Clearing ICS disables this feature. See Section 8.15. ### NOTE necessary to align boundaries, and continues the transfer in the selected mode. The 751 may end the transfer with a byte and/or word. Since this feature adds 50 microseconds to each transfer, it effects the 751's performance. # 4.2.1 <u>IOPB Byte 8</u> (Controller Parameters A) (continued) | BIT | MNEMONIC | DESCRIPTION | |-----|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 3 | EDT | ENABLE DMA TIMEOUT - When set, the 751 enables a DMA bus error timer. When clear, the 751 relies on the VMEbus transfer timer. | | 2 | NPRM | NON-PRIVILEGED REGISTER MODE - When set, the 751 responds to address modifiers 2DH and 29H. When clear, the 751 only responds to 2DH. (See the VMEbus Specification Manual for more information on address modifiers.) | | 1-0 | AIOR | AIO RESPONSE TIME - These bits respond to the four values that indicate the maximum AIO response time. This is the time from setting AIO to the time the 751 clears it. The shorter the response time, the greater the 751 overhead. | | VALUE | T | IME | | | |-------|-----|-----|----------|---------| | 00 | 100 | us | (Factory | Default | | 01 | 75 | us | _ | | | 02 | 62 | us | | | | 03 | 50 | us | | | TABLE 4-3. AIO RESPONSE TIMES ## 4.2.2 <u>IOPB Byte 9</u> (Controller Parameters B) | | <u> </u> | 7 | ı | 6 | ı | 5 | l | 4 | : | 3 | 2 | ı | 1 | I | 0 | 1 | |----------------------------|----------|------|---|---|---|---|---|-----|---|--------------|-----------|---|-----------|---|---|---| | THROTTLE DEAD TIMERESERVED | | _ _ | | _ | | 1 | | | | <br> | | | | | | | | RELEASE ON REQUESTRESERVED | _ | | | | | _ | | _ İ | | <u> </u><br> | _ i<br>i_ | | <br> - - | | - | | | BIT | MNEMONIC | DESCRIPTION | |-----|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7-6 | TOT | THROTTLE DEAD TIME - TDT selects one of four minimum time periods that determines the time the 751 remains off the bus between throttle bursts (See Section 8.12). | | 5 | | RESERVED. | # 4.2.2 <u>IOPB Byte 9</u> (Controller Parameters B) (continued) RESERVED. | BIT | MNEMONIC | DESCRIPTION | |-----|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 4 | ROR | RELEASE ON REQUEST - When set, the 751 releases the bus at the request of other bus masters; otherwise, it continues with the next throttle burst. The 751 monitors the bus request lines and releases bus busy only if another bus request is pending. It completes its specified throttle burst before releasing the bus due to a pending request. When clear, the 751 releases the bus at the end of each throttle burst and rearbitrates if more data transfers are pending. See Section 8.22. | | | | | #### 4.2.3 IOPB Byte A (Controller Parameters C) 3-0 | | 1 | 7 | I | 6 | l | 5 | I. | 4 | 3 | I | 2 | ١ | 1 | I | 0 | 1 | |---------------------------------------------------------------------|---|---|---|--------|---|-----|----|----|---|---|-----|---|-----------|---|--------|---| | ENABLE OVERLAP SEEKS COMMAND OPTIMIZATION INTERRUPT AT END OF CHAIN | | _ | | <br> - | | | | | | | | | | | | | | AUTOMATIC SEEK RETRY ZERO LATENCY READ ENABLE | | | | | | - ' | | ٠İ | į | | į | | İ | | İ | | | RETRY BEFORE CORRECTION ERROR CORRECTION MODE | | | | _ | | | | | I | | _ i | | <br> - _ | | <br> - | | | BIT | MNEMONIC | DESCRIPTION | |-----|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7 | ovs | ENABLE OVERLAP SEEKS - When set, the 751 initiates overlap seeks if more than one drive is present. When clear, the controller does not initiate Overlap Seek operations. | | 6 | COP | COMMAND OPTIMIZATION - When set, the 751 initiates elevator seeks and command optimization. See Section 8.9. | | 5 | IEC | INTERRUPT AT END OF CHAIN - When set, the 751 returns all IOPB chains with one RIO and one interrupt; it does not relink or unlink IOPBs. The RIO address of a completed chain is the address of the first IOPB in the chain. | MATEMOATTO DTM ## 4.2.3 <u>IOPB Byte A</u> (Controller Parameters C) (continued) DECCETEMITON | BIT | MNEMONIC | DESCRIPTION | |-----|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 5 | IEC | INTERRUPT AT END OF CHAIN (continued) - The 751 also uses the interrupt level and vector of the first IOPB in the chain. Clearing IEC disables this feature. See Section 8.21. | | | | NOTE | | | | Do not set or clear IEC while the 751 is processing an IOPB chain. | | 4 | ASR | AUTOMATIC SEEK RETRY - When set, the 75l resets the drive, seeks to the commanded cylinder and retries the transfer up to two times on any of the following errors: Seek Error, Header Error/Cylinder, Header Error/Head, Drive Not On-cylinder, and Drive Faulted. | | 3 | ZLR | ZERO LATENCY READ - When set, zero latency reads are enabled; when clear, zero latency reads are disabled. See Section 8.7. | | 2 | RBC | RETRY BEFORE CORRECTION - When set, the 751 retries the operation once on an ECC error without calculating the error syndrome. If an error occurs, on the second try, the 751 reverts to the specified Error Correction mode. | | 1-0 | ECCM | ERROR CORRECTION MODE - There are three Error Correction modes. Mode 0 stops a transfer and provides the driver with the error's offset and pattern. The driver performs the actual correction. Mode 1 flags an error and continues the transfer. Mode 2 performs the correction in host memory, flags a soft error, and continues the transfer. | ## 4.2.4 <u>IOPB Byte B</u> (Controller Parameters D) Bits 0 through 7 are the Throttle (THRO) bits. The throttle is the maximum number of transfers allowed each time the 75l becomes bus master. The throttle value determines the maximum DMA burst length for both data and IOPB DMA transfers. Each bit position represents a binary weight, allowing a throttle from 1 to 256. See Table 4-4. ## 4.2.4 <u>IOPB Byte B</u> (Controller Parameters D) (continued) | VALUE | WEIGHT | |------------|--------| | 0 | 256 | | 1 | 1 | | 2 | 2 | | 3 | 3 | | : | : | | <b>255</b> | 255 | TABLE 4-4. THROTTLE VALUES ### 4.2.5 <u>IOPB Byte E</u> (Controller Type) IOPB Byte E is the Controller Type byte. Xylogics assigns each VME controller a unique controller type code. | CONTROLLER | CODE (H) | | |------------|----------|--------------------------| | 712 | 12 | (ESDI Disk Controller) | | 751 | 51 | (SMD Controller) | | 772 | 72 | (Pertec Tape Controller) | TABLE 4-5. CONTROLLER TYPE CODES ### 4.2.6 <u>IOPB Bytes 10 and 11</u> (EPROM Part Number) The 751 returns a portion of the EPROM part number on a Read Controller Parameters command. The 4 nibbles in these 2 bytes refer to the part number's last 4 digits. For example, if the part number is 180-002-098, Byte 10 holds 20H and Byte 11 holds 98H. ### 4.2.7 <u>IOPB Byte 12</u> (Revision) This byte contains the revision level of the EPROM plugged into the board (0=Unreleased Prototype, 1=A, 2=B, etc.). ### 4.2.8 <u>IOPB Byte 13</u> (Subrevision) This byte contains the subrevision level of the EPROM plugged into the board. Any value other than zero indicates that the microcode is an unreleased version available for testing purposes (0=Released, 1=1, 2=2, etc.). # 4.3 DRIVE PARAMETERS IOPB # **DRIVE PARAMETERS** | INTERNAL STATUS | 7 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----------|------|---------|------------|-----------|---------|-----------------------------------------|------|--|--|--|--|--|--|--|--| | COMPLETION CODE | RR | RS | DONE | CHEN | 0 | | COMMAND | | | | | | | | | | | | DPB | | | | | COMPLET | ION CODE | | | | | | | | | | | | | SUBFUNCTION CODE | DP | РВ | SR | CSE | WPRT | DFLT | SKER | ONCL | DRDY | | | | | | | | | | FIXD | | | | | INTERNA | L STATUS | | | | | | | | | | | | | AFE 0 C450 EC32 0 INTERRUPT LEVEL OT | | | | | SUBFUNC | TION CODE | | | | | | | | | | | | | INTERRUPT VECTOR | ١X | IXD | RDP | PSEL | | | | | | | | | | | | | | | MAX SECTOR LH | ΑF | FE | 0 | C450 | | | | | | | | | | | | | | | HEAD OFFSET | | | | | | | | | | | | | | | | | | | MAX CYLINDER HIGH | | | | | | | | | | | | | | | | | | | MAX CYLINDER LOW | | | | | | | | | | | | | | | | | | | 0C | | | | | | | | | | | | | | | | | | | MAX SECTOR | | | | | | | | | | | | | | | | | | | SECTORS PER TRACK (RD. DR. PRMTRS.) | | | | | | | | | | | | | | | | | | | OF PRIG 0 NEXT IOPB ADDRESS MODIFIER 10 0 0 11 0 0 12 0 13 0 14 NEXT IOPB ADDRESS HIGH 15 NEXT IOPB ADDRESS 16 NEXT IOPB ADDRESS | _ | | | SECTOR | | | | ] | | | | | | | | | | | 0 0 11 0 0 12 0 13 0 14 NEXT IOPB ADDRESS HIGH 15 NEXT IOPB ADDRESS 16 NEXT IOPB ADDRESS | PP | PIG | Ι ο | JECTOR. | | | | <u> </u> | | | | | | | | | | | 0 11 12 0 13 14 INEXT IOPB ADDRESS HIGH 15 INEXT IOPB ADDRESS 16 | | <u> </u> | | | | | | | | | | | | | | | | | 12 0 13 0 14 NEXT IOPB ADDRESS HIGH 15 NEXT IOPB ADDRESS 16 NEXT IOPB ADDRESS | | | | | | | | | | | | | | | | | | | 0 NEXT IOPB ADDRESS HIGH NEXT IOPB ADDRESS NEXT IOPB ADDRESS NEXT IOPB ADDRESS | | | | | 0 | ) | | *************************************** | | | | | | | | | | | NEXT IOPB ADDRESS HIGH NEXT IOPB ADDRESS NEXT IOPB ADDRESS NEXT IOPB ADDRESS | | | | | 0 | ) | | | | | | | | | | | | | NEXT IOPB ADDRESS NEXT IOPB ADDRESS | _ | | | N | EXT IOPB A | DDRESS HI | GH | | | | | | | | | | | | 16 NEXT IOPB ADDRESS | | | | | NEXT IOPE | B ADDRESS | | | | | | | | | | | | | | | | | | NEXT IOP | B ADDRESS | | | 7 | | | | | | | | | | 17 NEXT IOPB ADDRESS LOW | | | | N | EXT IOPB A | DDRESS LO | DW] | | | | | | | | | | | | 18 [IOPB CHECKSUM HIGH] | | | | | IOPB CHEC | KSUM HIGH | 1 | | | | | | | | | | | | 19 [IOPB CHECKSUM LOW] | | | | | IOPB CHEC | KSUM LOW | ם ב | | | | | | | | | | | # 4.3.1 <u>IOPB Byte 6</u> (Drive Parameters) | | 17 | ١ | 6 | 1 | 5 | I | 4 | I | 3 | 1 | 2 | ı | 1 | I | 0 | | |------------------------|----|---|------|---|--------|---|----|---|---|---|---|---|---|---|---|--| | ALTERNATE FIELD ENABLE | | | <br> | | | | | | | | 1 | | 1 | | | | | 450-COMPATIBLE MODE | | | | | _l<br> | | -1 | | | | 1 | | | | | | | TAPPED DE LEAVET. | | | | | | | | | • | | İ | | Ĺ | | _ | | ## 4.3.1 <u>IOPB Byte 6</u> (Drive Parameters) (continued) | BIT MNE | EMONIC DESCRI | PTION | | | |---------|---------------|------------------------------------------------------|--------------|-------------| | 7 AFE | Field | ATE FIELD ENABL<br>5A to determine<br>s Field 5. See | sector size. | When clear, | ### NOTE Using AFE, C450, and EC32 in different modes on the two connecting disks will have a detrimental effect on the disk subsystem's performance. The 751 must modify the DSKCEL code each time it switches drives. 6 RESERVED. 5 C450 450-COMPATIBLE MODE - When set, the 751 reads and writes 450-compatible format disks. The format is compatible with disks having less than 64-sectors per track. The 751 ignores the Drive Type field in the 450 header; it does not format in 450-Compatible mode. C450 does not override the format parameters set in the 751. (See the note below bit 7.) ### NOTE C450 only allows word boundary transfers since it swaps data bytes as DMAed to memory. 4 EC32 32-BIT ECC - When set, the 75l uses a 32-bit ECC on the header and data. When clear, it uses a redundant header check, and a 48-bit data ECC. EC32 must be set when using the 450-compatible mode. (See the note below bit 7.) 3 RESERVED. 2-0 INTERRUPT LEVEL - Bits 0 through 2 are the VMEbus Interrupt Level bits. The 75l does not interrupt if the interrupt level is set to zero. See Section 4.1.7. ### 4.3.2 <u>IOPB Byte 8</u> (Max Sector/Last Head) IOPB Byte 8 specifies the max sector value on the last head for use in cylinder sparing (this value is zero-based). Bytes ODH and O8H must be equal if cylinder sparing is not used. See Section 8.1.2. ### 4.3.3 <u>IOPB Byte 9</u> (Head Offset) IOPB Byte 9 specifies the drive's head offset value. Use zero for non-fixed/removable drives. Section 8.16 explains using the head offset to access fixed/removable drives. ### 4.3.4 <u>IOPB Bytes A and B</u> (Max Cylinder) IOPB Byte A is Max Cylinder High; Byte B is Max Cylinder Low. These bytes specify the drive's max cylinder value. This value is zero-based, i.e., the max cylinder on an 823 cylinder drive is 822. ### 4.3.5 <u>IOPB Byte C</u> (Max Head) IOPB Byte C specifies the drive's max head value. This value is zero-based. ### 4.3.6 <u>IOPB Byte D</u> (Max Sector) IOPB Byte D specifies the drive's max sector value. This value is zero-based. See Section 8.1. ### 4.3.7 <u>IOPB Byte E</u> (Sectors Per Track) IOPB Byte E returns the number of sectors per track (the 751 determines this value by counting the sector pulses from the drive) on a Read Drive Parameters command. This is the actual number of sectors; it has not been modified to be zero-based. This value does not include runts. The Format command uses this count to determine the number of sectors to format. Normal Read and Write commands use this count to limit the number of header compares before a Header Not Found error occurs. # 4.4 FORMAT PARAMETERS IOPB # **FORMAT PARAMETERS** | l | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | |-----|------------------------------|-----------------------------------------|----------|-----------|-----------------------|-------------|-------------|------|--|--|--|--|--|--| | 00 | ERRS | DONE | CHEN | SGM | | COMMAI | ND | | | | | | | | | 01 | | | | COMPLET | ION CODE | | | | | | | | | | | 02 | DPB | SR | CSE | WPRT | DFLT | SKER | ONCL | DRDY | | | | | | | | 03 | | | | INTERNAL | STATUS | | | | | | | | | | | 04 | | | | SUBFUNCT | TION CODE | | | | | | | | | | | 05 | FIXD 0 UNIT | | | | | | | | | | | | | | | 06 | INTERLEAVE 0 INTERRUPT LEVEL | | | | | | | | | | | | | | | 07 | | | | | | | | | | | | | | | | 08 | FIELD 1 | | | | | | | | | | | | | | | 09 | FIELD 2 | | | | | | | | | | | | | | | OA | FIELD 3 | | | | | | | | | | | | | | | ОВ | FIELD 4 | | | | | | | | | | | | | | | oc | | | | | 5 HIGH | | | | | | | | | | | OD | | | | FIELD | | | | | | | | | | | | 0E | | | | | ) | | ==- | | | | | | | | | OF | PRIO | 0 | | | | SS MODIFI | ER J | | | | | | | | | 10 | - | *************************************** | | | LD 6 | | | | | | | | | | | -11 | | | | | LD 7 | <del></del> | | | | | | | | | | 12 | | · · · · · · · · · · · · · · · · · · · | | | ALT. HIGH | <u></u> | | | | | | | | | | 13 | | | <u></u> | | ALT. LOW<br>ADDRESS H | nen] | | | | | | | | | | 14 | | | <u></u> | | | | | | | | | | | | | 15 | | | | | B ADDRES | | | | | | | | | | | 16 | | | | | ADDRESS I | | <del></del> | | | | | | | | | 17 | | ***** | <u>U</u> | | CKSUM HIG | | | | | | | | | | | 18 | | | | | CKSUM LO | | | | | | | | | | | 19 | | | | LIUPB CHE | CKSUII LU | <u>"</u> | | | | | | | | | # 4.4.1 <u>IOPB Byte 6</u> (Interleave) | • | | | | | | | | | | | | | | | | - | |-------------------|---|---|-----|---|-----|---|---|---|-----|---|-----|---|-----|---|----|---| | | 7 | I | 6 | 1 | 5 | I | 4 | 1 | 3 | 1 | 2 | I | 1 | I | 0 | I | | INTERLEAVE FACTOR | | | _ _ | | _ _ | | _ | | ı | | 1 | | 1 | | 1 | _ | | INTERRUPT LEVEL | | | | | | | | | -1_ | | _ _ | | _ _ | | -1 | | ## 4.4.1 <u>IOPB Byte 6</u> (Interleave) (continued) MNEMONIC BIT | 7-4 | INTF | INTERLEAVE FACTOR - The 751 uses INTF during | |-----|------|------------------------------------------------| | | | Format operations. For 1:1 interleaving, the | | | | interleave factor is zero. The interleave | | | | factor for other ratios is (n+1):1, where n is | | | | the interleave factor. | DESCRIPTION | INTERLEAVE FACTOR<br>BITS 7-4 | RATIO | |-------------------------------|-------| | 0 | 1:1 | | 1 | 2:1 | | 2 | 3:1 | | • | : | | F | 16:1 | ### TABLE 4-6. 751 INTERLEAVE FACTORS 3-0 INTL INTERRUPT LEVEL - See Section 4.1.7. ## 4.4.2 <u>IOPB Byte 8</u> (Field 1) Field 1 is the number of bytes from one byte after the index or sector pulse to when the 751 enables the Read Gate for headers; this value must be larger than one. (Xylogics recommends using one.) ### 4.4.3 <u>IOPB Byte 9</u> (Field 2) Field 2 is the number of bytes from when the 751 enables the Read Gate to when it starts looking for the Header Sync byte; this value must be larger than one. (Xylogics recommends OAH.) ### 4.4.4 IOPB Byte A (Field 3) Field 3 is the number of bytes from the sector pulse to the Header Sync byte; this value must be larger than two. (Xylogics recommends 1BH.) ## 4.4.5 <u>IOPB Byte B</u> (Field 4) Field 4 is the number of bytes between the Header ECC and the Data Sync byte; this value must be larger than two. (Xylogics recommends 14H.) ### NOTE Field 4 is actually four bits longer than this byte specifies. The 751 uses the extra four bits to test for a successful header compare and header verify. ## 4.4.6 <u>IOPB Bytes C and D</u> (Field 5 High/Low) Byte C specifies Field 5 High; Byte D specifies Field 5 Low. The sector size (in bytes) must be larger than 254, even, and smaller than 4098. (Xylogics ships units set to 200H.) ### 4.4.7 <u>IOPB Byte 10</u> (Field 6) Field 6 is the number of bytes from enabling Read Gate to when the 751 starts looking for data sync; this value must be larger than one. (Xylogics recommends OAH.) ## 4.4.8 <u>IOPB Byte 11</u> (Field 7) Field 7 is the number of bytes the Write Gate remains on after the Data ECC; this value must be greater than or equal to one. (Xylogics recommends three.) ### 4.4.9 <u>IOPB Bytes 12 and 13</u> (Alternate Field 5 High/Low) Byte 12 specifies Alternate Field 5 High; Byte 13 specifies Alternate Field 5 Low. This field defines the number of data bytes per sector when AFE is set for this unit; see Section 4.4.6 for limits. See Section 8.18. (Xylogics ships units set to 400H.) ### SECTION 5: COMMANDS ### 5.0 GENERAL Each disk command begins a new page. An IOPB diagram follows each command description. The diagrams are highlighted to indicate which fields the 751 absolutely requires for command execution, which fields are optional for the command, and which bytes return after execution. Each 751 IOPB is 30-bytes long. Reserving all 30 bytes for each IOPB maintains IOPB integrity. Generally, all commands use Bytes 0 through 19H (Bytes 1AH through 1DH are reserved). ### 5.0.1 <u>Setting Up The Command</u> Each IOPB diagram indicates the bytes or fields that must be set for each operation. Certain parameters are essential; others are optional. All commands require the Command, Unit, and Interrupt Level fields to contain valid information. The Interrupt Vector field must be valid if the Interrupt Level is not zero. ### 5.0.2 <u>Completing The Command</u> After the 751 completes the command, it updates IOPB Bytes 0 through 3 with ERRS, DONE, a Completion Code, and an internal status. The 751 only updates the entire IOPB if Auto-update (AUD) is enabled, an error occurs, or if Read Parameters or Read Extended Status commands are executed. If AUD is set, and no errors occur, the 751 sets DONE, posts a Completion Code of zero in Byte 1, and disk drive status information in Byte 2; for any command that DMAs data to/from memory, the 751 updates the data and disk addresses to point to the last address plus one of the transfer. See Table 5-1. ### STATUS ACTION AUD Clear/No Error 751 updates Bytes 0-3 with ERRS, DONE, Completion Code, and internal status AUD Set/No Error Occurs 751 updates the entire IOPB AUD Clear/Error Occurs 751 updates the entire IOPB AUD Clear/A Read 751 updates the entire IOPB AUD Clear/A Read Parameters or Read Extended Status Command is Executed TABLE 5-1. 751 COMMAND COMPLETION ### 5.1 NO OPERATION The No Operation (NOP) command is a diagnostic tool. The 751 reads the IOPB and marks it complete. ### 5.2 WRITE DATA The 751, after reading and decoding the IOPB, positions the disk drive heads at the target cylinder; it then reads in the data from host memory (indicated by the IOPB) and writes the data contiguously to the disk's sequential sectors. Write Data has two IOPB formats: Normal and Scatter/Gather. A Normal IOPB specifies one contiguous block of host memory to write to the disk. A Gather Write IOPB specifies up to 32 different blocks of host memory to be placed in contiguous sectors on the disk (See Section 8.11). The 751 stores IOPBs in a command queue that holds up to fourteen full IOPBs. This queue allows the 751 to optimize the commands for both elevator/overlap seeks and processing multiple IOPBs per revolution (See Section 8.9). ### ERRS DONE CHEN SGM COMMAND CODE = 1 00 COMPLETION CODE 01 WRPT DFLT SKER ONCL 02 INTERNAL STATUS 03 SUBFUNCTION CODE = 00 04 PSEL BHT 05 LINK LIST LENGTH INTERRUPT LEVEL 06 INTERRUPT VECTOR 07 COUNT HIGH 08 COUNT LOW 09 CYLINDER HIGH 0A CYLINDER LOW 0**B** HEAD OC. ΩĐ DATA OR LINK ADDRESS MODIFIER 0E PRIO NEXT IOPB ADDRESS MODIFIER 0F DATA OR LINK ADDRESS HIGH 10 DATA OR LINK ADDRESS 11 DATA OR LINK ADDRESS 12 DATA OR LINK ADDRESS LOW 13 NEXT IOPB ADDRESS HIGH 14 NEXT IOPB ADDRESS 15 NEXT IOPB ADDRESS 16 NEXT IOPB ADDRESS LOW IOPB CHECKSUM HIGH 18 IOPB CHECKSUM LOW Returned Required Optionally ## WRITE DATA Required For Execution Value ### 5.3 READ DATA The 751, after reading and decoding the IOPB, positions the disk drive heads at the target cylinder, then reads the disk data indicated by the IOPB, and writes the data in host memory. Read Data has two IOPB formats: Normal and Scatter/Gather. A Normal IOPB specifies one contiguous block of host memory that is used to place the data from the disk. A Scatter Read IOPB specifies up to 32 different blocks of host memory where the disk data will be placed (See Section 8.11). The 751 stores IOPBs in a command queue that holds up to fourteen full IOPBs. This queue allows the 751 to optimize the commands for both elevator/overlap seeks and processing multiple IOPBs per revolution (See Section 8.9). 47 #### 5.4 REPORT CURRENT ADDRESS The 751 selects the disk drive, reads the first good header field, and returns the address to the host via the IOPB; it updates the IOPB regardless of AUD's status. #### 5 3 2 6 4 0 ERRS DONE CHEN COMMAND CODE = 3 SGM=0 COMPLETION CODE 01 WRPT 02 INTERNAL STATUS 03 SUBFUNCTION CODE = 00 04 BHT 05 INTERRUPT LEVEL LINK LIST LENGTH 06 INTERRUPT VECTOR 07 COUNT HIGH 08 COUNT LOW 09 CYLINDER HIGH OA CYLINDER LOW 08 HEAD 00 SECTOR OD DATA OR LINK ADDRESS MODIFIER 0E PRIO 0 NEXT IOPB ADDRESS MODIFIER 0F DATA OR LINK ADDRESS HIGH 10 DATA OR LINK ADDRESS 11 DATA OR LINK ADDRESS 12 DATA OR LINK ADDRESS LOW 13 NEXT IOPB ADDRESS HIGH 14 NEXT IOPB ADDRESS 15 NEXT 10FB ADDRESS 16 NEXT IOPB ADDRESS LOW 17 IOPB CHECKSUM HIGH 18 IOPB CHECKSUM LOW Optionally Returned Required For Execution Value Required REPORT CURRENT ADDRESS ### 5.5 SEEK AND REPORT CURRENT ADDRESS The 751 issues a seek to the selected disk drive for the target cylinder. After the drive completes the seek, the 751 reads the first good header field it encounters and reports it to the host via the completed IOPB. The 751 updates the IOPB regardless of AUD's status. #### SEEK AND REPORT CURRENT ADDRESS 5 2 0 ERRS DONE CHEN SGM=0 COMMAND CODE = 3 COMPLETION CODE 01 CSE WRPT DFLT SKER ONCL 02 INTERNAL STATUS 03 SUBFUNCTION CODE = 01 04 BHT UNIT 05 LINK LIST LENGTH INTERRUPT LEVEL 06 INTERRUPT VECTOR 07 COUNT HIGH 08 COUNT LOW nq CYLINDER HIGH OA CYLINDER LOW OB HEAD OC. SECTOR OD DATA OR LINK ADDRESS MODIFIER 0E PRIO NEXT IOPB ADDRESS MODIFIER ΩF DATA OR LINK ADDRESS HIGH 10 DATA OR LINK ADDRESS 11 DATA OR LINK ADDRESS 12 DATA OR LINK ADDRESS LOW 13 NEXT IOPB ADDRESS HIGH 14 NEXT IOPB ADDRESS 15 NEXT IOPB ADDRESS 16 NEXT IOPB ADDRESS LOW 17 IOPB CHECKSUM HIGH 18 IOPB CHECKSUM LOW Required Optionally Returned Required For Execution # 5.6 START SEEK AND REPORT COMPLETION IMMEDIATELY The 751 issues a seek to the selected disk drive for the target cylinder, and reports a completion to the host without waiting for the seek to complete. START SEEK AND REPORT #### COMPLETION IMMEDIATELY ERRS DONE CHEN SGM=0 COMMAND CODE = 3 nη COMPLETION CODE 01 WRPT DFLT SKER 02 INTERNAL STATUS 03 SUBFUNCTION CODE = 02 04 BHT FIXD RDP PSEL 0 UNIT 05 INTERRUPT LEVEL LINK LIST LENGTH 06 INTERRUPT VECTOR 07 COUNT HIGH 08 COUNT LOW 09 CYLINDER HIGH OA CYLINDER LOW 08 HEAD OC. SECTOR OD DATA OR LINK ADDRESS MODIFIER 0 0E PRIO 0 NEXT IOPB ADDRESS MODIFIER 0F DATA OR LINK ADDRESS HIGH 10 DATA OR LINK ADDRESS 11 DATA OR LINK ADDRESS 12 DATA OR LINK ADDRESS LOW 13 NEXT IOPB ADDRESS HIGH 14 NEXT IOPB ADDRESS 15 NEXT IOPB ADDRESS 16 NEXT IOPB ADDRESS LOW 17 IOPB CHECKSUM HIGH 18 IOPB CHECKSUM LOW Returned Optionally Value For Execution Required ### 5.7 DRIVE RESET The 751 commands the disk drive to reset. First it issues a fault clear, and then a recalibrate (return to zero). The IOPB is complete when the recalibrate completes or times out on drives that are ready. The 751 does not wait for the recalibrate to complete on drives that are not ready. #### DRIVE RESET ERRS DONE CHEN SGM=0 COMMAND CODE = 4 nη COMPLETION CODE WRPT DFLT SKER ONCL DRDY 02 INTERNAL STATUS 03 SUBFUNCTION CODE = 04 RDP PSEL BHT UNIT 05 LINK LIST LENGTH INTERRUPT LEVEL 06 INTERRUPT VECTOR 07 COUNT HIGH 08 COUNT LOW 09 CYLINDER HIGH OA CYLINDER LOW 0B HEAD OC. SECTOR OD DATA OR LINK ADDRESS MODIFIER 0E PRIO NEXT IOPB ADDRESS MODIFIER 0 0F DATA OR LINK ADDRESS HIGH 10 DATA OR LINK ADDRESS 11 DATA OR LINK ADDRESS 12 DATA OR LINK ADDRESS LOW 13 NEXT IOPB ADDRESS HIGH 14 **NEXT IOPB ADDRESS** 15 NEXT IOPB ADDRESS 16 NEXT IOPB ADDRESS LOW 17 IOPB CHECKSUM HIGH 18 IOPB CHECKSUM LOW Required Optionally Returned For Execution Value Required ### 5.8 WRITE CONTROLLER PARAMETERS This command initializes the 75l with its operational parameters. No default parameters are assumed, but once written, the parameters remain in the 75l non-volatile memory. Section 4.3 defines how to change the parameters for individual applications; Section 6.6 explains the IRAM checksum. #### WRITE CONTROLLER PARAMETERS 5 3 2 0 DONE ERRS SGM=0 COMMAND CODE = 5 00 COMPLETION CODE 01 CSE WRPT DFLT SKER ONCL INTERNAL STATUS 03 SUBFUNCTION CODE = 00 04 05 INTERRUPT LEVEL 06 INTERRUPT VECTOR 07 TMOD ICS / NPRM AIOR 08 0 09 ECCM IEC ASR ZLR ( RBC OA THROTTLE OB 0 OC OD CONTROLLER TYPE ΩF PRIO NEXT IOPB ADDRESS MODIFIER OF PROM PART NUMBER HIGH 10 PROM PART NUMBER LOW REVISION 12 SUBREVISION 13 NEXT IOPB ADDRESS HIGH NEXT IOPB ADDRESS 15 NEXT IOPB ADDRESS 16 NEXT IOPB ADDRESS LOW 17 IOPB CHECKSUM HIGH 18 IOPB CHECKSUM LOW Returned Optionally Value For Execution Required #### 5.9 WRITE DRIVE PARAMETERS This command informs the 751 of the disk drive's physical characteristics. No default values are assumed, but once loaded, the parameters remain stored in the 751 non-volatile memory. Section 4.4. ### ERRS DONE CHEN SGM=0 COMMAND CODE = 5 COMPLETION CODE 01 CSE WPRT DFLT SKER ONCL 02 INTERNAL STATUS 03 SUBFUNCTION CODE = 80 04 05 C450 EC32 INTERRUPT LEVEL 0 AFE 06 INTERRUPT VECTOR 07 MAX SECTOR LH 08 HEAD OFFSET 09 MAX CYLINDER HIGH OA MAX CYLINDER LOW 0B MAX HEAD OC MAX SECTOR OD SECTORS PER TRACK (RD. DR. PRMTRS.) 0E PRIO NEXT IOPB ADDRESS MODIFIER 0F 10 0 11 0 12 13 NEXT IOPB ADDRESS HIGH 14 NEXT IOPB ADDRESS 15 NEXT IOPB ADDRESS 16 NEXT IOPB ADDRESS LOW 17 IOPB CHECKSUM HIGH 18 IOPB CHECKSUM LOW 19 Returned Required Optionally Value For Execution Required WRITE DRIVE PARAMETERS #### 5.10 WRITE FORMAT PARAMETERS This command informs the 751 of the disk drive's media format. No default values are assumed, but once loaded, the values remain stored in the 751 non-volatile memory. See Section 4.5; Section 8.1 defines how to change the media format for individual applications. #### 6 5 2 0 ERRS DONE CHEN SGM=0 COMMAND CODE = 5 COMPLETION CODE 01 WPRT DFLT 02 INTERNAL STATUS 03 SUBFUNCTION CODE = 81 04 FIXD UNIT 05 INTERLEAVE INTERRUPT LEVEL 06 INTERRUPT VECTOR 07 FIELD 1 08 FIELD 2 09 FIELD 3 0A FIELD 4 0B FIELD 5 HIGH OC. FIELD 5 LOW OD 0E NEXT IOPB ADDRESS MODIFIER PRIO 0F FIELD 6 10 FIELD 7 11 FIELD 5 ALT. HIGH 12 FIELD 5 ALT. LOW 13 NEXT IOPB ADDRESS HIGH NEXT IOPB ADDRESS 15 NEXT IOPB ADDRESS 16 NEXT IOPB ADDRESS LOW 17 IOPB CHECKSUM HIGH 18 IOPB CHECKSUM LOW Returned Required Optionally Value For Execution Required WRITE FORMAT PARAMETERS ## 5.11 READ CONTROLLER PARAMETERS The 751 returns its current operational parameters to the host via the IOPB; it verifies the IRAM checksum before completing the transfer, and updates the IOPB regardless of AUD's status. See Section 4.3. ### 6 0 COMMAND CODE = SGM=0 00 COMPLETION CODE 01 02 INTERNAL STATUS 03 SUBFUNCTION CODE = 00 04 05 INTERRUPT LEVEL 06 INTERRUPT VECTOR 07 TMOD 09 IEC THROTTLE OB 00 OD CONTROLLER TYPE 0E NEXT IOPB ADDRESS MODIFIER OF PROM PART NUMBER HIGH PROM PART NUMBER LOW 1 1 REVISION SUBREVISION 13 NEXT IOPB ADDRESS HIGH 14 NEXT IOPB ADDRESS 15 NEXT IOPB ADDRESS 16 NEXT IOPB ADDRESS LOW 17 IOPB CHECKSUM HIGH 18 IOPB CHECKSUM LOW Required Optionally Returned For Execution Required Value READ CONTROLLER PARAMETERS ## 5.12 READ DRIVE PARAMETERS The 751 returns the programmed disk drive's physical characteristics to the host via the IOPB; it returns the specified drive's actual number of sectors per track in Byte 0EH. The 751 verifies the IRAM checksum before completing the transfer; it updates the IOPB regardless of AUD's status. See Section 4.4. #### READ DRIVE PARAMETERS 6 DONE CHEN SGM=0 COMMAND CODE = 6 00 COMPLETION CODE 01 WPRT SKER ONCL IIIII SR CSE 02 INTERNAL STATUS 03 SUBFUNCTION CODE = 80 04 **PSEL** 05 INTERRUPT LEVEL C450 EC32 06 INTERRUPT VECTOR 07 MAX SECTOR LH 08 HEAD OFFSET 09 MAX CYLINDER HIGH OΔ MAX CYLINDER LOW 0B MAX HEAD OC. MAX SECTOR OD 0E NEXT IOPB ADDRESS MODIFIER PRIO 0F 10 0 11 0 12 13 NEXT IOPB ADDRESS HIGH 14 NEXT IOPB ADDRESS 15 NEXT IOPB ADDRESS NEXT IOPB ADDRESS LOW 17 IOPB CHECKSUM HIGH 18 IOPB CHECKSUM LOW Optionally Returned For Execution Required ## 5.13 READ FORMAT PARAMETERS The 751 returns the current disk drive's format parameters to the host via the IOPB; it verifies the IRAM checksum before completing the transfer, and updates the IOPB regardless of AUD's status. See Section 4.5. #### DONE CHEN SGM=0 ERRS COMMAND CODE = 6 00 COMPLETION CODE 01 DFLT WPRT 02 INTERNAL STATUS 03 SUBFUNCTION CODE = 81 04 05 INTERLEAVE INTERRUPT LEVEL 06 INTERRUPT VECTOR 07 FIELD 1 08 09 FIELD 3 ΠΔ 0B FIELD 5 HIGH OC FIELD 5 LOW OD 0 0E PRIO NEXT IOPB ADDRESS MODIFIER OF FIELD 6 10 FIELD 7 11 FIELD 5 ALT. HIGH 12 FIELD 5 ALT. LOW **NEXT IOPB ADDRESS HIGH** 14 NEXT IOPB ADDRESS 15 **NEXT IOPB ADDRESS** 16 NEXT IOPB ADDRESS LOW 17 IOPB CHECKSUM HIGH 18 IOPB CHECKSUM LOW Required Optionally Returned For Execution Required Value **READ FORMAT PARAMETERS** #### 5.14 READ DRIVE STATUS EXTENDED The 751 reads the SMD drive interface's extended status. returns the drive's status in IOPB Bytes 8 through A regardless of AUD's status (See Table 5-2). The drive-specific bytes follow the same bit alignment as the standard Status byte. | BYTE | TAG 4 | TAG 5 | BIT: 7 | <u>6</u> | <u>5</u> | 4 | <u>3</u> | 2 | 1 | <u>0</u> | |------|-------|-------|--------|----------|----------|------|----------|------|------|----------| | 02 | 0 | 0 | SECT | INDX | ADM | WRPT | DFLT | SKER | ONCL | DRDY | | 80 | 1 | 0 | * | * | * | * | * | * | * | * | | 09 | 0 | 1 | * | * | * | * | * | * | * | * | | 0A | 1 | 1 | * | * | * | * | * | * | * | * | \* Drive-specific TABLE 5-2. EXTENDED DRIVE STATUS #### DONE CHEN SGM=0 COMMAND CODE = 6 00 COMPLETION CODE 01 WRPT 02 INTERNAL STATUS 03 ..... SUBFUNCTION CODE = AO 04 BHT 05 INTERRUPT LEVEL LINK LIST LENGTH 06 INTERRUPT VECTOR 07 EXTENDED STATUS 08 EXTENDED STATUS 09 EXTENDED STATUS OΑ 08 0 OC. 0 OD 0 DATA OR LINK ADDRESS MODIFIER 0E PRIO NEXT IOPB ADDRESS MODIFIER 0F 10 0 11 0 12 13 NEXT IOPB ADDRESS HIGH 14 NEXT IOPB ADDRESS 15 NEXT IOPB ADDRESS 16 NEXT IOPB ADDRESS LOW 17 IOPB CHECKSUM HIGH 18 IOPB CHECKSUM LOW READ DRIVE STATUS EXTENDED Optionally Required Returned Value Required For Execution ## 5.15 WRITE TRACK HEADERS This command enables the host to write the sector header fields on a track (only one track per IOPB). The 751 takes the data for the header fields from host memory: four bytes per header; one header for each sector on the track. The data fields are not preserved. It places the data on the track starting from index. Section 8.1 defines the data format in each header. #### WRITE TRACK HEADERS CHEN DONE SGM=0 COMMAND CODE = 7 00 COMPLETION CODE CSE WRPT DFLT SKER ONCL DRDY 02 INTERNAL STATUS 03 SUBFUNCTION CODE = 04 BHT UNIT 05 INTERRUPT LEVEL LINK LIST LENGTH 06 INTERRUPT VECTOR 07 COUNT HIGH 08 COUNT LOW 09 CYLINDER HIGH 0A CYLINDER LOW 0B HEAD OC. SECTOR OD DATA OR LINK ADDRESS MODIFIER 0E NEXT IOPB ADDRESS MODIFIER PRIO 0F DATA OR LINK ADDRESS HIGH 10 DATA OR LINK ADDRESS 11 DATA OR LINK ADDRESS DATA OR LINK ADDRESS LOW 13 NEXT IOPB ADDRESS HIGH NEXT IOPB ADDRESS 15 NEXT IOPB ADDRESS NEXT IOPB ADDRESS LOW 17 IOPB CHECKSUM HIGH 18 IOPB CHECKSUM LOW Returned Required Optionally Required Value For Execution ## 5.16 WRITE TRACK FORMAT The Write Track Format command directs the 751 to format the drive, writing the header of all sectors with the appropriate sector ID. The data field contains zeros and a valid ECC. The Count bytes in this command refer to the number of tracks to be formatted. See Section 8.3. # WRITE TRACK FORMAT ## 5.17 WRITE HEADER, HEADER VERIFY, DATA, AND DATA ECC This command directs the 751 to write a sector header, header verify, data, and data ECC. There are always four bytes in the header, but the other fields vary according to the initial 751 set-up. The 751 does not cross head or cylinder boundaries while executing this command. The host must calculate the ECC in all ECC fields since the 751 does not calculate any ECC fields for this command. WRITE HEADER, HEADER VERIFY, ## 5.18 WRITE DEFECT MAP Write Defect Map is a useful maintenance command for debugging software. The 751 uses data from host memory and writes a manufacturer's defect map to the disk. See Section 8.5. #### WRITE DEFECT MAP ERRS DONE CHEN SGM=0 COMMAND CODE = 7 00 COMPLETION CODE 01 WRPT DFLT 02 INTERNAL STATUS 03 SUBFUNCTION CODE = 04 JUNIT RDP PSEL BHT 05 LINK LIST LENGTH INTERRUPT LEVEL 06 INTERRUPT VECTOR 07 COUNT HIGH ns. COUNT LOW 09 CYLINDER HIGH 0A CYLINDER LOW 0B HEAD OC. SECTOR OD DATA OR LINK ADDRESS MODIFIER 0E PRIO NEXT IOPB ADDRESS MODIFIER OF DATA OR LINK ADDRESS HIGH 10 DATA OR LINK ADDRESS 11 DATA OR LINK ADDRESS 12 DATA OR LINK ADDRESS LOW 13 NEXT IOPB ADDRESS HIGH 14 NEXT IOPB ADDRESS 15 NEXT IOPB ADDRESS 16 NEXT IOPB ADDRESS LOW 17 IOPB CHECKSUM HIGH 18 IOPB CHECKSUM LOW 19 Returned Required Optionally For Execution Required **62** #### WRITE DEFECT MAP EXTENDED 5.19 Write Defect Map Extended is a useful maintenance command for debugging software. The 751 uses data from host memory and writes a manufacturer's defect map to the alternate location on the track. This offsets the defect map from index, avoiding media defects. #### DONE COMMAND CODE = 7 COMPLETION CODE 01 WRPT 02 INTERNAL STATUS 03 SUBFUNCTION CODE = A1 04 BHT 05 INTERRUPT LEVEL LINK LIST LENGTH 06 INTERRUPT VECTOR 07 COUNT HIGH 08 COUNT LOW 09 CYLINDER HIGH OΑ CYLINDER LOW 0B HEAD OC. SECTOR OD DATA OR LINK ADDRESS MODIFIER 0 0E NEXT IOPB ADDRESS MODIFIER PRIO 0F DATA OR LINK ADDRESS HIGH 10 DATA OR LINK ADDRESS DATA OR LINK ADDRESS 12 DATA OR LINK ADDRESS LOW 13 NEXT IOPB ADDRESS HIGH 14 NEXT IOPB ADDRESS 15 NEXT IOPB ADDRESS 16 NEXT IOPB ADDRESS LOW 17 IOPB CHECKSUM HIGH 18 IOPB CHECKSUM LOW 19 Required Returned Optionally For Execution Value Required WRITE DEFECT MAP EXTENDED ## 5.20 READ TRACK HEADERS This command enables the host to read the sector header fields on a track. The 751 places the data from the header fields in host memory: four bytes per header; one header for each sector on the track. Section 8.1 defines the data format in each header. #### ERRS DONE CHEN SGM=0 COMMAND CODE = 8 nn COMPLETION CODE WRPT DFLT SKER ONCL 02 INTERNAL STATUS 03 SUBFUNCTION CODE = 80 04 BHT RDP PSEL UNIT 05 INTERRUPT LEVEL LINK LIST LENGTH 06 INTERRUPT VECTOR 07 COUNT HIGH 08 COUNT LOW 09 CYLINDER HIGH 0A CYLINDER LOW ОВ HEAD OC SECTOR OD DATA OR LINK ADDRESS MODIFIER 0E PRIO NEXT IOPB ADDRESS MODIFIER 0F DATA OR LINK ADDRESS HIGH 10 DATA OR LINK ADDRESS 11 DATA OR LINK ADDRESS DATA OR LINK ADDRESS LOW 13 NEXT IOPB ADDRESS HIGH NEXT IOPB ADDRESS 15 NEXT IOPB ADDRESS NEXT IOPB ADDRESS LOW IOPB CHECKSUM HIGH Optionally Required Returned Value **READ TRACK HEADERS** Required For Execution 17 ## 5.21 VERIFY DATA This command verifies the data on the disk. The 751 reads the data from the host and the disk simultaneously, and compares them on a bit-by-bit basis. The granularity of the mismatch reporting is one sector. The ending data address does not indicate where a mismatch error occurred. # 5.22 READ HEADER, HEADER VERIFY, DATA, AND DATA ECC This command directs the 751 to read a sector header, header verify, data, and data ECC. There are always four bytes in the header, but the other fields vary according to the initial 751 set—up. The 751 talks to physical sectors regardless of the interleave factor; it does not cross head or cylinder boundaries. See Section 8. # READ HEADER, HEADER VERIFY, DATA, AND DATA ECC ## 5.23 READ DEFECT MAP The 751 reads the manufacturer's defect map and returns the data to memory in the correct bit order. See Section 8.5. #### COMMAND CODE = 8 CHEN SGM=0 00 COMPLETION CODE 01 WRPT DFLT SKER ONCL DRDY 02 INTERNAL STATUS 03 SUBFUNCTION CODE 04 BHT 05 INTERRUPT LEVEL LINK LIST LENGTH 06 INTERRUPT VECTOR 07 COUNT HIGH 08 COUNT LOW 09 CYLINDER HIGH OA CYLINDER LOW ΟВ HEAD OC SECTOR OD DATA OR LINK ADDRESS MODIFIER 0E NEXT 10PB ADDRESS MODIFIER PRIO OF DATA OR LINK ADDRESS HIGH 10 DATA OR LINK ADDRESS 11 DATA OR LINK ADDRESS 12 DATA OR LINK ADDRESS LOW 13 NEXT IOPB ADDRESS HIGH 14 NEXT IOPB ADDRESS 15 NEXT IOPB ADDRESS 16 **NEXT IOPB ADDRESS LOW** 17 IOPB CHECKSUM HIGH 18 IOPB CHECKSUM LOW 19 Optionally Returned For Execution Value Required **READ DEFECT MAP** ## 5.24 READ DEFECT MAP EXTENDED The 751 bypasses any media defects and reads the manufacturer's defect map from the alternate location on the track. See Section 8.5. #### 4 SGM=0 ERRS DONE CHEN COMMAND CODE = 8 OΩ COMPLETION CODE 01 WRPT 02 INTERNAL STATUS 03 SUBFUNCTION CODE = A1 04 BHT JUNIT RDP 0 05 LINK LIST LENGTH INTERRUPT LEVE 06 INTERRUPT VECTOR 07 COUNT HIGH 80 COUNT LOW 09 CYLINDER HIGH 0A CYLINDER LOW 0B HEAD OC. SECTOR OD DATA OR LINK ADDRESS MODIFIER 0E PRIO NEXT IOPB ADDRESS MODIFIER 0F DATA OR LINK ADDRESS HIGH 10 DATA OR LINK ADDRESS 11 DATA OR LINK ADDRESS 12 DATA OR LINK ADDRESS LOW 13 NEXT IOPB ADDRESS HIGH 14 NEXT IOPB ADDRESS 15 NEXT IOPB ADDRESS 16 NEXT IOPB ADDRESS LOW 17 IOPB CHECKSUM HIGH 18 IOPB CHECKSUM LOW Returned Optionally For Execution Value Required **READ DEFECT MAP EXTENDED** #### 5.25 DIAGNOSTICS The 751 executes the on-board self test diagnostics. Do not chain this IOPB to another IOPB. It cannot be used in conjunction with other IOPBs in the command queue. #### COMMAND CODE = 9 ERRS DONE CHEN=0 SGM=0 COMPLETION CODE WRPT DFLT SKER ONCL DRDY 02 INTERNAL STATUS 03 SUBFUNCTION CODE = 00 04 FIXD PSEL BHT 05 LINK LIST LENGTH INTERRUPT LEVEL 06 INTERRUPT VECTOR 07 COUNT HIGH 08 COUNT LOW 09 CYLINDER HIGH OA CYLINDER LOW OB HEAD OC. SECTOR OD DATA OR LINK ADDRESS MODIFIER 0E NEXT IOPB ADDRESS MODIFIER PRI0 0F DATA OR LINK ADDRESS HIGH 10 DATA OR LINK ADDRESS 11 DATA OR LINK ADDRESS 12 DATA OR LINK ADDRESS LOW 13 NEXT IOPB ADDRESS HIGH 14 NEXT IOPB ADDRESS 15 NEXT IOPB ADDRESS 16 NEXT IOPB ADDRESS LOW 17 IOPB CHECKSUM HIGH 18 TOPB CHECKSUM LOW Returned Required Optionally For Execution Required Value DIAGNOSTICS ## SECTION 6: ERROR PROCESSING ## 6.0 GENERAL The 751 Error Summary (ERRS) bit, Fatal Error (FERR) bit, and Completion Code represent the controller's status after executing a command. FERR indicates the transfer failed and the 751 requires a Controller Reset before continuing. ERRS only affects the specific IOPB and may be tested in lieu of checking the Completion Code; the 751 does not require a Controller Reset before continuing. The Completion Code informs software that the 751 successfully completed a command, failed to complete a command, or encountered and corrected a problem with one of several internal recovery procedures. ## 6.1 THE COMPLETION CODE The 75l posts a Completion Code in IOPB Byte 1 (Status Byte 1); a Completion Code is only valid if DONE is set. Table 6-2 lists the Completion Codes (all codes not listed in this table are reserved). The following subsections describe these codes, along with any required corrective action. ## 6.1.1 <u>Completion Code Convention</u> Completion Codes follow a convention that indicates the action required by either the software driver or manual intervention. The byte's upper nibble is the recovery code, and the lower nibble is the actual error code (See Table 6-1). | RECOVERY CODE | RECOVERY PROCEDURE | |---------------|-----------------------------------| | 0 | No Action / Status Only | | 1 | Non-retryable Programming Error | | 3 | Successfully Recovered Soft Error | | 4 | Hard Error / Retry | | 6 | Hard Error / Reset and Retry | | 7 | Fatal Hardware Error | | 8 | Miscellaneous Error | | 9 | Requires Manual Intervention | TABLE 6-1. RECOVERY CODES # 6.1.1 <u>Completion Code Convention</u> (continued) | ACTION | CODE (HEX) | DESCRIPTION | |---------------------------------------|-------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | No Action / Status Only | 00<br>01 | Successful Completion<br>Set Format Fields 5 and<br>5A Only | | Non-retryable Programming<br>Errors | 10<br>11<br>12<br>13<br>14<br>15-1B<br>1C<br>1D<br>1E<br>1F<br>20<br>21 | Illegal Cylinder Address Illegal Head Address Illegal Sector Address Count Zero Unimplemented Command Illegal Field Lengths 1-7 Illegal Scatter/Gather Length Not Enough Sectors/Track Next IOPB Alignment Error Scatter/Gather Addr. Alignment Scatter/Gather With Auto ECC Illegal Black Hole Address | | Successfully Recovered<br>Soft Errors | 30<br>31<br>32<br>33 | Soft ECC Corrected<br>ECC Ignored<br>Auto Seek Retry Recovered<br>Soft Retry Recovered | | Hard Errors/Retry | 40<br>41<br>42<br>43<br>44<br>45<br>46<br>47<br>48<br>49<br>4A<br>4B | Hard Data ECC Header Not Found Drive Not Ready Operation Timeout VMEDMA Timeout Disk Sequencer Error FIFO Parity Error Dual Port Busy Timeout Header ECC Error Read Verify Fatal VMEDMA Error VMEDUS Error | | Hard Errors - Reset/Retry | 60<br>61<br>62<br>63<br>64 | Drive Faulted Header Error/Cylinder Header Error/Head Drive Not On-cylinder Seek Error | | Fatal Hardware Errors | 70<br>71 | Illegal Sector Size<br>Firmware Failure | | Miscellaneous Errors | 80<br>81 | Soft ECC<br>IRAM Checksum Failure | | Requires Manual Interventi | on 90 | Write-protect Error | TABLE 6-2. SUMMARY OF COMPLETION CODES ## 6.1.2 <u>Completion Code Descriptions</u> # 6.1.2.1 No Action / Status Only Typically, the following Completion Codes require no action; the 751 returns the codes for status only. ## CODE (H) DESCRIPTION - SUCCESSFUL COMPLETION Not an error; indicates the IOPB is complete and may be removed from the queue. - 01 SET FORMAT FIELDS 5 AND 5A ONLY -- Jumper JE 1-2 is removed; therefore only Fields 5 and 5A were set with this Write Format Parameters command. # 6.1.2.2 Non-retryable Programming Errors This group of errors is usually encountered while debugging drivers; they should not occur in a normal operating system environment. ## CODE (H) DESCRIPTION - 10 ILLEGAL CYLINDER ADDRESS Host software specified a cylinder address greater than the maximum cylinder number specified in the last Set Drive Parameters command for this drive. - 11 ILLEGAL HEAD ADDRESS Host software specified a head address greater than the maximum head address specified in the last Set Drive Parameters command for this drive. - 12 ILLEGAL SECTOR ADDRESS Host software specified a sector address greater than the maximum sector number specified in the last Set Drive Parameters command for this drive. - COUNT ZERO Host software issued the 751 an IOPB that required a count, but the count was zero. Read, Write, and Format commands require a valid count. - 14 UNIMPLEMENTED COMMAND This error occurs on all reserved commands. - 15 ILLEGAL FIELD LENGTH 1 See Section 8.3.3.1. - 16 ILLEGAL FIELD LENGTH 2 See Section 8.3.3.2. - 17 ILLEGAL FIELD LENGTH 3 -- See Section 8.3.3.3. # 6.1.2.2 Non-retryable Programming Errors (continued) | CODE (H) | DESCRIPTION | |------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 18 | ILLEGAL FIELD LENGTH 4 See Section 8.3.3.4. | | 19 | ILLEGAL FIELD LENGTH 5/5 ALT See Section 8.3.3.5. | | 1 <b>A</b> | ILLEGAL FIELD LENGTH 6 - See Section 8.3.3.6. | | 1B | ILLEGAL FIELD LENGTH 7 - See Section 8.3.3.7. | | 10 | ILLEGAL SCATTER/GATHER LENGTH — The linked list specified a number of words to transfer that does not agree with the amount of data contained in the requested number of sectors for transfer. | | 10 | NOT ENOUGH SECTORS PER TRACK — The format routine was unable to format since too few sectors were actually available on the track. | | 1E | NEXT IOPB ALIGNMENT ERROR — The Next IOPB Address did not start on a 16-bit boundary; the 751 does not execute the NIOPB. | | 1F | SCATTER/GATHER ADDRESS ALIGNMENT ERROR — A Scatter/Gather address started on a byte boundary. | | 20 | SCATTER/GATHER WITH AUTO ECC ERROR — A Scatter/Gather operation resulted in a correctable ECC error. Due to Scatter/Gather boundaries, the 751 did not automatically correct the error, but reverted to ECC Mode 0. | | 21 | ILLEGAL BLACK HOLE TRANSFER ADDRESS — During a Black Hole Transfer, the data address did not start on a word boundary when the 751 was in Word mode (or it did not start on a longword boundary when the 751 was in Longword mode). | ## 6.1.2.3 Successfully Recovered Soft Errors This group of errors is for status only. If some errors recur often, the operating system should try to map out the sectors involved. Allowing these errors to recur degrades performance. # CODE (H) DESCRIPTION 30 SOFT ECC CORRECTED — The 751 detected and corrected one or more ECC errors, during a disk read, in ECC Mode 2. # 6.1.2.3 Successfully Recovered Soft Errors (continued) ## CODE (H) DESCRIPTION - 31 ECC ERROR IGNORED The 751 detected an ECC error, during a Read command, in ECC Mode 1. - 32 AUTO SEEK RETRY RECOVERED The 751 completed the transfer successfully but, during the transfer, it recovered from an error by resetting the drive. This is a soft error. - 33 SOFT RETRY RECOVERED The 751 encountered an error while executing this command. A retry due to RBC being set or a zero latency read was successful. ## 6.1.2.4 Hard Errors/Retry These errors indicate the transfer failed; retry the operation. If several retries fail, manual intervention is required or the operating system may crash. ## CODE (H) DESCRIPTION - 40 HARD DATA ECC ERROR The 751 detected a hard data ECC error in the data field (longer than 11 bits) during a Read command. Retry the previous Read operation. - 41 HEADER NOT FOUND The 751 cannot find the requested sector. The controller searches for one disk revolution plus one sector to locate the header. See Section 9.3.2. - DRIVE NOT READY The selected drive is not ready, but not faulted; issue a Drive Reset. Causes include: - o Drive not up-to-speed. - o Drive hardware error. - o Bad or improperly connected cable(s). - o No drive of the specified Unit Number is connected to the 751. - 43 OPERATION TIMEOUT The 751 did not complete the IOPB within a two second timeout period. - VMEDMA TIMEOUT The DMA controller did not complete within its timeout. One reason could be that memory did not respond in time. - DISK SEQUENCER ERROR The disk sequencer did not complete its task within the allotted time limit. ## 6.1.2.4 Hard Errors/Retry (continued) ## CODE (H) DESCRIPTION - DISK SEQUENCER ERROR (continued) The 751 cannot send or receive the appropriate signals from the selected drive. Causes include: - o Drive is not connected. - o Improper or defective cabling. - o Unformatted drive. - 46 FIFO PARITY The transfer failed; the 751 detected a FIFO parity error. - DUAL PORT BUSY The 751 timed out while waiting for the port on a dual ported drive. The timeout is two seconds. - 48 HEADER ECC ERROR The 751 found a header match, but the Header ECC did not compare. - 49 READ VERIFY The data read from the disk did not match the data read from memory. - FATAL VMEDMA ERROR The VMEDMA stopped for no apparent reason. The count nor the address overflowed, and there was no bus error. - 4B VMEBUS ERROR The VME BERR\* signal was asserted while the 751 was bus master (See the VMEbus Specification Manual). ## 6.1.2.5 Hard Errors - Reset/Retry This group of errors indicate the transfer failed. Software should issue a Drive Reset command to the drive in use before retrying the operation. #### CODE (H) DESCRIPTION - DRIVE FAULTED The selected drive is faulted. Issue a Drive Reset. If the fault persists, you must intervene. - 61 HEADER ERROR/CYLINDER The cylinder address did not match during a sector search. Check the cylinder address and retry the operation. - 62 HEADER ERROR/HEAD The head address did not match during a sector search. ## 6.1.2.5 Hard Errors - Reset/Retry (continued) ## CODE (H) DESCRIPTION - DRIVE NOT ON-CYLINDER At some point during the transfer, the 751 expected the drive to be on-cylinder, and it was not. - 64 SEEK ERROR The disk drive reported a seek error. ## 6.1.2.6 Fatal Hardware Errors These errors indicate the hardware failed. Manual intervention or a Controller Reset may be the only recovery approach. # CODE (H) DESCRIPTION - 70 ILLEGAL SECTOR SIZE The disk drive's sector size is not large enough to hold the header, data, and specified field lengths. - 71 FIRMWARE FAILURE Flag settings or counter values are inconsistent with the firmware routines being executed. Document the conditions and call Xylogics. ## 6.1.2.7 Miscellaneous Errors # CODE (H) DESCRIPTION - 80 SOFT ECC ERROR The 751 detected a correctable 11-bit or less error in the data field of the current sector, during a Read operation, in ECC Mode 0. Software must perform the final correction. See Section 6.4. - IRAM CHECKSUM FAILURE The calculated checksum from the IRAM and its stored value did not match during the Self Test or read parameters command. The parameters that are in error are not necessarily in the parameters read by this IOPB; they may be elsewhere in the IRAM. Recheck all the programmable parameters. Any write parameters command resets the checksum, and any subsequent read parameters will be error free. A soft bit in the IRAM, static, or probing the board with the power on can cause this error. See Section 6.6. ## 6.1.2.8 Requires Manual Intervention The write-protect error requires you to manually remove the write-protection. ## 6.1.2.8 Requires Manual Intervention (continued) ## CODE (H) DESCRIPTION 90 WRITE-PROTECT ERROR — A command that writes to the disk (e.g., Write, Format, Write Track Headers) is issued, but the drive is write-protected. ## 6.2 ERRORS AND ZERO LATENCY READS If a disk error occurs during a zero latency read, the 75l may retry the operation as it finishes the command. The controller posts a retry successful code if the retry succeeds. If the retry fails, the disk address and sector count reflect the error point, and all previous sectors will be complete and without error. #### 6.3 SOFT ERROR COMPLETION CODES The 751 updates the IOPB with the last error it encounters; it may overwrite previous soft errors with a new soft error status or a hard error status. ## 6.4 ERROR CORRECTION CODE Most ECC algorithms require retrying the operation at least once before attempting the correction. When RBC is set, the 751 automatically retries the operation once before applying the correction algorithm. #### 6.4.1 Error Correction Code - Mode 0 When utilizing Mode 0, use the following procedure to correct a soft ECC error. The 75l provides a pattern and offset for the correction process. - 1. Reserve 32 bits of storage for the shifted ECC pattern, and initialize them to zero. Take the ECC Pattern word from the IOPB and put it in the lowest 16 bits of the reserved space. - 2. Get the offset from the IOPB and decrement by one. This makes the count zero-based instead of one-based. - 3. Use the three low order bits of the offset as a count to shift the pattern the number of count bits left. - 4. Divide the bit address by eight (by performing three logical shifts to the right). The result is the word offset into the bad sector. Adding this offset to the starting memory address of the sector in error creates a pointer to the first word to be corrected. # 6.4.1 Error Correction Code - Mode 0 (continued) 5. Exclusive—OR the three Memory bytes at the pointer and the two Pattern words generated in step 1. ## 6.4.2 Error Correction Code - Mode 1 The 751 does not correct any detected errors in Mode 1. After completing the operation, it posts a Completion Code indicating that at least one ECC error occurred during the transfer. ## 6.4.3 Error Correction Code - Mode 2 The 751 automatically corrects a soft ECC error in this mode. The 751 determines the pattern and offset, completes the DMA, and goes to host memory to fetch the data in error; it corrects the data, and returns it to memory. ## 6.5 FATAL ERROR CODES If a fatal error occurs, the 75l sets FERR in the Status Register and posts the error code in the Fatal Error Register. (The following error codes appear only in the Fatal Error Register.) The only way to clear a fatal error is by issuing a Controller Reset (CRST). ## CODE DESCRIPTION - EO IRAM CHECKSUM FAILURE The IRAM checksum did not match the expected checksum following bus initialization. - El IRAM SELF TEST FAILURE The 751 tests the IRAM with an incrementing data pattern then tests it with a decrementing pattern. An error indicates a bad IRAM. - E2 EPROM CHECKSUM FAILURE At power-up, the EPROM checksum did not match the IRAM checksum. Either the EPROM has degraded, or the IRAM changed during power-down. See Error Code 81 for more information. - E3 MAINTENANCE TEST 3 FAILURE The 751 tests the Writable Control Store in the DSKCEL with an incrementing data pattern then tests it with a decrementing pattern. An error indicates a bad DSKCEL. - E4 MAINTENANCE TEST 4 FAILURE The 751 shifts a pattern of 0's and 1's through the Header Shift Register (HSR). An error indicates a bad HSR. ## 6.5 <u>FATAL ERROR CODES</u> (continued) ## CODE DESCRIPTION - E5 MAINTENANCE TEST 5 FAILURE The 751 writes, and then reads, the VMEDMA Registers. An error indicates a bad VMEDMA. - E6 MAINTENANCE TEST 6 FAILURE There is a problem with the REGCEL chip. - E7 MAINTENANCE TEST 7 FAILURE The FIFO parity circuit failed its diagnostic. - E8 MAINTENANCE TEST 8 FAILURE The 751 fills the Disk FIFO with sequential data and then reads it. An error indicates a problem with the DSKCEL or FIFO. - FO IOPB CHECKSUM MISCOMPARE The generated checksum did not match the appended checksum. This error can only occur while IOPB checksum feature is active. ICS is controlled via controller parameters. See Section 8.15. - Fl IOPB DMA FATAL The 751 did not complete the DMA within the prescribed timeout period. The memory could be defective or not present; the 751 may not have been able to become bus master. - F2 IOPB ADDRESS ALIGNMENT ERROR The IOPB address did not start on a 16-bit boundary. Change the address of the IOPB and retry. - FIRMWARE ERROR Flag settings or counter values are inconsistent with the firmware routines being executed; the IOPB cannot DMA the appropriate error status. The 751's state is indeterminate; you must issue a Controller Reset. - F5 ILLEGAL MAINTENANCE MODE TEST NUMBER The command is invalid, or the Maintenance mode jumper is not in. - F6 ACFAIL ASSERTED The VMEbus signal ACFAIL is asserted, causing the 751 to stop. Correct the problem asserting ACFAIL and then reset the 751. #### 6.6 IRAM CHECKSUM Each time the 751 executes a read parameters command, it compares a generated checksum with the stored checksum. This checksum encompasses the area that contains all the parameters, not just the ones being read. When this error occurs, the checksums did not match; rewrite or check all the parameters. Any write parameters command generates and stores a new checksum. ## SECTION 7: A TUTORIAL IN PROGRAMMING THE 751 ## 7.0 GENERAL This section describes programming the 75l for basic use. This tutorial programming procedure begins with a single NOP IOPB and progresses to normal Read and Write commands. Each section builds on the previous section's information. (In the Sent/Returned portion of each sample IOPB, the x represents an indeterminate value that depends on the external conditions.) ## 7.1 NO OPERATION (NOP) The NOP command allows you to become familiar with the 751 programming interface. FIGURE 7-1. SAMPLE NOP IOPB # 7.1.1 Allocating Memory for an IOPB First, allocate space in host memory to store the IOPB. This allocation is a function of the operating system or the program that is currently executing. Next, set up the IOPB to execute a simple NOP command. ## 7.1.2 Point the 751 to the IOPB The IOPB is now in host memory. Point the 751 to the IOPB by loading the IOPB address and address modifier into the appropriate 751 registers. Make sure the address compensates for any memory mapping that may be done between virtual and physical addressing in your system. The 751 looks for the IOPB at the physical address to which the registers point. #### NOTE Make sure the address compensates for any memory mapping that may be done between virtual and physical addressing in your system. # 7.1.3 Starting the Operation The 751 now points to the IOPB in host memory. Writing the AIO bit in the CSR directs the 751 to process the IOPB. ## 7.1.4 <u>751 Operation</u> At this point, the 751 performs the following functions: - 1. Clears AIOP and sets BUSY. - 2. Reads the IOPB from host memory. - 3. Decodes the command. - 4. Performs the operation (NOP). - 5. Sets the DONE bit. - 6. Updates the IOPB. - 7. Puts the completed IOPB's address into the registers. - 8. Sets RIO. - 9. Clears BUSY. ## 7.1.5 <u>Command Completion</u> Software has been polling RIO (since interrupts are not enabled [Interrupt Level = 0]). Software knows that the 751 sets RIO when it is done. Software should get the completed IOPB's address from the registers, and then clear RIO. This completes the NOP command. #### NOTE Do not poll the DONE bit in the IOPB. The 751 sets DONE while the rest of the IOPB is still updating. ## 7.1.6 Returned Values DONE is set in the returned IOPB. Status Byte 2 reflects the status of Disk Drive 0. Status Byte 3 reflects the 751's internal status. #### NOTE Status Byte 3 is proprietary to Xylogics and may change definition without notice. ## 7.2 READ CONTROLLER PARAMETERS Next, implement a Read Parameters command with a Controller Parameters subfunction (See Section 4.3). This command returns several controller parameters in the IOPB. See Figure 7-2. # 7.2.1 Execute the IOPB Set up the IOPB in host memory; point the 751 to the IOPB. Set AIO and the 751 executes the IOPB in Figure 7-2. # 7.2.2 <u>751 Operation</u> The controller operation changes slightly from the example in Section 7.1.4: The 751 performs the Read Controller Parameters operation instead of the NOP. The controller gets the parameters from its internal store, and puts them in the proper IOPB locations. The 751 fully updates the IOPB, including the returned values. While reading the controller parameters, the 751 calculates a new internal RAM (IRAM) checksum and compares it to the previous value. The 751 returns the appropriate Completion Code if the values do not match. #### 7.2.3 The Returned IOPB The values in the returned IOPB describe the last setting of the software-programmable parameters. Determine if each value works for your application. After making any necessary changes, write the parameters back to the 751. The Controller Type byte Specific bytes have known values. contains a 51H; the PROM Part Number bytes contain 20H and 98H. See Section 4.3 for more information. READ CONTROLLER PARAMETERS FIGURE 7-2. SAMPLE READ CONTROLLER PARAMETERS IOPB ## 7.3 WRITE CONTROLLER PARAMETERS Next, write the controller parameters. Xylogics recommends reading the current parameters, modifying the ones in question, and then writing them back to the 751. This method allows you to change only those parameters that affect your system. ## 7.3.1 <u>751 Operation</u> The 751 executes the IOPB slightly different than in Sections 7.1.4 and 7.2.2: it performs this function by taking the values of all programmable parameters out of the IOPB and setting the appropriate flags and variables in its internal code. The 751 also calculates a new checksum in the IRAM and stores it for use in the next reading of any parameters. #### RETURNED SENT ERRS DONE CHEN SGM=0 COMMAND CODE = 5 OC COMPLETION CODE 00 00 O 1 CSE WRPT DFLT SKER ONCL 00 XX 02 INTERNAL STATUS 00 XX 03 00 00 SUBFUNCTION CODE = 00 04 0 00 00 J UNIT 05 00 00 INTERRUPT LEVEL 06 INTERRUPT VECTOR 00 00 07 AUD TMOD ICS 48 48 08 ROR TDT ٥ 00 00 09 TEC ( ASR OC. 00 04 THROTTLE 00 00 OB 00 00 0 00 00 00 OD CONTROLLER TYPE 00 00 ΟĒ PRIO NEXT IOPB ADDRESS MODIFIER 00 00 OF PROM PART NUMBER HIGH ດດ 00 10 PROM PART NUMBER LOW 00 00 11 REVISION 00 00 12 SUBREVISION 00 00 13 NEXT IOPB ADDRESS HIGH 00 00 00 NEXT IOPB ADDRESS 00 15 NEXT IOPB ADDRESS 00 00 16 NEXT IOPB ADDRESS LOW OΩ 00 17 IOPB CHECKSUM HIGH ٥٥ 00 18 00 00 TOPB CHECKSUM LOW Returned Required Optionally For Execution Value Required WRITE CONTROLLER PARAMETERS FIGURE 7-3. SAMPLE WRITE CONTROLLER PARAMETERS IOPB # 7.4 READ/WRITE FORMAT PARAMETERS The format parameters are handled similarly to the controller parameters. Use extra caution when modifying the format parameters as improper selection may cause data corruption and/or unreliable operation. The data field size is the only parameter Xylogics recommends changing. # 7.4.1 Execute the IOPB with Interrupts To build on 751 functionality, enable interrupts for this example by specifying an interrupt level and vector. #### RETURNED SENT SGM=0 COMMAND CODE = 6 COMPLETION CODE 00 00 01 SR CSE WPRT DFLT SKER ONCL DRDY 00 XX INTERNAL STATUS 00 XX 03 SUBFUNCTION CODE = 81 81 81 04 FIXD UNIT 00 00 05 INTERLEAVE INTERRUPT LEVEL 01 01 06 INTERRUPT VECTOR 66 66 07 FIELD 1 00 01 FIELD 2 ດດ ΩΔ FIELD 3 00 11 FIELD 4 00 14 FIELD 5 HIGH 00 02 OC. 00 00 ΩĐ 00 00 ΩF NEXT IOPB ADDRESS MODIFIER 00 00 OF FIELD 6 00 ΩA FIELD 7 00 03 FIELD 5 ALT. HIGH 00 04 FIELD 5 ALT. LOW 00 00 13 NEXT IOPB ADDRESS HIGH 00 NEXT IOPB ADDRESS 00 00 15 NEXT IOPB ADDRESS 00 00 16 NEXT IOPB ADDRESS LOW 00 00 IOPB CHECKSUM HIGH 00 00 IOPB CHECKSUM LOW 00 00 Required Optionally Returned Required Value **READ FORMAT PARAMETERS** FIGURE 7-4. SAMPLE READ FORMAT PARAMETERS IOPB ## 7.4.2 <u>751 Operation</u> The 751 performs the operation almost identically to the examples in Sections 7.2.2 and 7.3.1, but with two additional steps. It makes sure the new format parameters are within the valid ranges. After the 751 sets RIO, it performs an interrupt sequence. # 7.4.3 <u>Command Completion</u> Enabling interrupts modifies the command completion. Software does not poll RIO when it is set, but may be off doing something else (probably waiting for an interrupt). When the interrupt occurs, hardware and software execute an Interrupt Service Routine (ISR) and process the interrupt. Hardware resets the actual hardware interrupt when the ISR is called. The ISR reads the address of the completed IOPB from the registers, and clears RIO. This completes the Read/Write Format Parameters operation. ## 7.4.4 Returned Values Figure 7-4 illustrates the read portion of this subsection. The 751 returns the data for which it was last programmed. The sector size is set to 512 (200H) and the alternate sector size is set to 1024 (400H). The other fields are all set to the recommended values. ## 7.5 READ/WRITE DRIVE PARAMETERS The Drive Parameters commands allow you to configure the 751 to your drive's size and parameters. Section 4.4 describes the size and configuration variables that may be modified with these commands. The operation is similar to both Format and Controller Parameters. ## 7.5.1 <u>751 Operation</u> On a Write Drive Parameters command, the 751 performs an operation similar to that of both Controller and Format Parameters. The Read Drive Parameters function differs in that the 751 returns the number of physical sectors on the drive. The 75l selects the disk drive specified in the Unit bits. It times the interval between index pulses and, using this time value, counts the number of drive-generated sector pulses. The 75l puts this count into Byte E of the IOPB. This count is the number of sectors per track. See Figure 7-5. # 7.5.1 <u>751 Operation</u> (continued) ## WRITE DRIVE PARAMETERS FIGURE 7-5. SAMPLE WRITE DRIVE PARAMETERS IOPB ## 7.6 FORMAT A TRACK Up to this point we have been initializing the 751. Initialization informs the 751 of the drive size, and parameters it requires before it can properly function. Now, let's format one track of the drive. The 751 can only execute Read and Write commands on a formatted track. (Typically, formatting is done only once in the lifetime of the media.) ## 7.6 FORMAT A TRACK (continued) FIGURE 7-6. SAMPLE WRITE TRACK FORMAT IOPB ## 7.6.1 <u>751 Operation</u> The Format command is the first command in this tutorial that transfers data from the controller to the disk. The 751 operation for data transfer commands differs greatly from initialization commands. ## 7.6.1 <u>751 Operation</u> (continued) #### To format a track: - 1. The 751 still clears AIOP, sets BUSY, and reads the IOPB from memory. The next step occurs after the IOPB is in the 751. - 2. The 751 decodes the function, and determines if a seek is required. All Write, Read, Write Extended, and Read Extended functions require the drive to seek to the commanded cylinder. Format is a Write Extended function; it requires the drive to seek. The 751 issues a seek to the drive by sending it the commanded cylinder number. - 3. The 751 waits for the drive to complete the seek; the drive indicates it's done by returning on-cylinder. - 4. When the drive is on-cylinder, the 751 determines if the current physical sector count for that drive is valid. If the count is not valid, it repeats the sequence in Section 7.5.1 to determine the actual physical sector. The 751 proceeds to Step 5 when the count is valid. - 5. The 751 loads the data for the new sector header into the FIFO, waits for index, and writes the new header on Sector 0; it writes the data field with zeros, and writes the data field ECC. - 6. The 751 repeats Step 5 for each sector on the track, except it uses sector pulse instead of index pulse to start the operation. - 7. The 751 updates the IOPB with the ending values, and completes the command. ## 7.7 READ TRACK HEADERS Now that the track is formatted, read the headers back and verify they are correct. This command requires a data buffer; allocate space in host memory just as you did for the IOPB. The buffer length must be four bytes (per sector) times the number of sectors per track. (The Read Drive Parameters command gives you the number of sectors per track.) Make sure software passes the 751 the physical buffer address, not the virtual address. See Figure 7-7. ## 7.7 READ TRACK HEADERS (continued) #### SENT RETURNED ERRS DONE CHEN SGM=0 COMMAND CODE = 8 08 48 00 COMPLETION CODE 00 00 0: DPB SR CSE WRPT DFLT SKER ONCL DRDY 00 XX 0.2 INTERNAL STATUS 03 SUBFUNCTION CODE = 80 80 80 FIXD RDP ВНТ UNIT 00 00 05 INTERRUPT LEVEL LINK LIST LENGTH 01 01 06 INTERRUPT VECTOR 66 66 07 COUNT HIGH 00 00 08 COUNT LOW 00 00 09 CYLINDER HIGH 00 00 04 CYLINDER LOW 00 00 OB HEAD 00 00 OC. SECTOR 00 00 OD DATA OR LINK ADDRESS MODIFIER ດດ nn ΟE PRIO NEXT IOPB ADDRESS MODIFIER 00 00 OF DATA OR LINK ADDRESS HIGH 00 nο 10 DATA OR LINK ADDRESS 00 00 11 DATA OR LINK ADDRE 00 00 12 DATA OR LINK ADDRESS LOW 00 00 NEXT IOPB ADDRESS HIGH 00 00 00 NEXT IOPB ADDRESS 00 15 NEXT IOPB ADDRESS OΩ 00 16 NEXT IOPB ADDRESS LOW 00 00 17 IOPB CHECKSUM HIGH 00 00 18 TOPB CHECKSUM LOW 00 00 Required Optionally Returned For Execution Required **READ TRACK HEADERS** FIGURE 7-7. SAMPLE READ TRACK HEADERS IOPB ## 7.7.1 <u>751 Operation</u> The Read Track Headers is the first command in this tutorial that transfers data to or from host memory. Data transfers to or from memory modify the 751 operation as follows: ## 7.7.1 <u>751 Operation</u> (continued) - 1. The 751 reads the IOPB, issues a seek, and decodes the command identically to the previous examples. - 2. The 751 waits for index from the drive. It tests the physical sector count to determine if it is valid. If the count is not valid, the 751 determines the actual count (See Section 7.5.1). - 3. After index arrives, the 751 synchronizes itself with the data in the header, and reads the data into its on-board FIFO. - 4. The 751 repeats Step 3 for each sector on the track, except it waits for the sector pulse instead of index. The actual physical sector count determines the number of sectors the 751 transfers into its FIFO. - 5. After the 751 transfers all sector headers into the FIFO, it begins the DMA. The controller transfers the data from the FIFO to host memory. - 6. When the 751 completes the DMA transfer, it places the updated information into the IOPB, and completes the command. ## 7.7.2 <u>Verifying the Data</u> After the 751 completes the transfer, verify the data against what is expected. The data should be divided into groups having four bytes each. Each group describes a sector header. The first sector header should be four bytes of 00. The second header should be three bytes of 00 and one byte equal to 01. The third header should have the last byte equal to 02, etc. (See Section 8.1.2 for more information on headers). | HEADER 1 | HEADER 2 | HEADER 3 | | | | |-------------------|-------------------|-------------------|--|--|--| | 00 00 00 00 | 00 00 00 01 | 00 00 00 02 | | | | FIGURE 7-8. SAMPLE SECTOR HEADERS #### 7.8 WRITE DATA The format is valid after verifying the headers. This subsection describes a Write operation, and the following subsection describes reading back the data. Allocate space in host memory for the buffer, and set up a data pattern in this buffer; an incrementing count in the buffer will suffice. See Figure 7-9. FIGURE 7-9. SAMPLE WRITE DATA IOPB # 7.8.1 <u>751 Operation</u> The 751 operation is similar to the previous examples; the differences are in DMAing data into the FIFO, and writing data to the disk. The 751 starts the DMA from host memory to the FIFO after determining the drive is on-cylinder; it enables the disk sequencer when the FIFO contains one full sector of data. The 751 compares and verifies the header: the disk sequencer tests all the headers as they pass under the head, until it finds the sector designated for transfer. At the proper point in the sector, the 751 writes a new Sync byte, and then the data it read from memory. The 751, using the data to be written, generates and appends an ECC on the end of the sector. #### 7.8.2 <u>Command Completion</u> The command is complete as soon as the disk sequencer completes its operation. The 75l puts the ending values into the internal IOPB, and performs an appropriate update. ## 7.9 READ DATA In Section 7.8 the 751 wrote the data to the drive on Sector 0, Head 0, and Track 0. This subsection describes reading back the data and verifying it. You must allocate a data buffer for the 751 to write the data in memory. After allocation, it is a good idea to fill the buffer with a known pattern that differs from the expected data. See Figure 7-10. # 7.9.1 <u>751 Operation</u> The 751 treats this command like the previous operations, except in the way it DMAs the data into the FIFO and writes the data to the disk. The 751 enables the disk sequencer as soon as the drive is on-cylinder. After the controller finds the correct header, it transfers the data from the disk to the FIFO. As soon as the first word of data is available from the buffer, the DMA controller DMAs the data from the FIFO to host memory. The transfer is done when the DMA controller completes the DMA. # 7.9.2 <u>Command Completion</u> The 751 completes the command when the DMA to memory is complete. The next subsection describes how to verify the data. # 7.9.2 <u>Command Completion</u> (continued) #### 5 6 SENT RETURNED ERRS DONE CHEN SGM COMMAND CODE = 02 42 00 COMPLETION CODE 00 00 WRPT DFLT SKER ONC 01 00 XX 02 INTERNAL STATUS 00 ХX 03 00 SUBFUNCTION CODE = 04 RDP PSEL BHT 00 05 INTERRUPT LEVEL LINK LIST LENGTH 01 01 06 INTERRUPT VECTOR 66 66 07 COUNT HIGH 00 nn 08 COUNT LOW 01 01 09 CYLINDER HIGH 00 00 OA CYLINDER LOW 00 00 0B 00 oc SECTOR 00 00 OD 00 DATA OR LINK ADDRESS MODIFIER ΟĒ PRIO NEXT IOPB ADDRESS MODIFIER 00 00 0 OF DATA OR LINK ADDRESS HIGH 00 00 10 00 00 DATA OR LINK ADDRESS 1.1 DATA OR LINK ADDRESS 00 00 12 DATA OR LINK ADDRESS LOW 00 00 13 00 00 NEXT IOPB ADDRESS HIGH 00 NEXT IOPB ADDRESS 15 00 NEXT IOPB ADDRESS 16 NEXT IOPB ADDRESS LOW 00 00 17 00 00 IOPB CHECKSUM HIGH 18 OΩ 00 IOPB CHECKSUM LOW 19 ECC PATTERN WORD HIGH 00 ΩO 14 ECC PATTERN WORD LOW 00 00 18 00 00 ECC OFFSET WORD HIGH 10 00 ECC OFFSET WORD LOW 00 Returned Required Optionally For Execution Required **READ DATA** FIGURE 7-10. SAMPLE READ DATA IOPB # 7.9.3 <u>Verify Data</u> First, make sure the buffer was modified. If it was not modified, either an error occurred, or software specified the wrong buffer address. Next, compare the data written with the data read; they should match. #### 7.10 MULTIPLE SECTOR TRANSFERS You can repeat the steps in Sections 7.8 and 7.9 using a larger sector count. The 751 crosses head and cylinder boundaries, as required, to complete the required number of sectors. Be sure to allocate enough buffer space for the increased sector count. #### 7.11 SUMMARY This section was an exercise in testing the 751's functionality in your system. The steps are basically the same when the software driver controls the 751. (Operating systems always allocate the buffers.) #### SECTION 8: 751 SPECIAL FUNCTIONS # 8.0 GENERAL This section describes how to implement the various 751 special functions. Each subsection descibes how minor functions implement a given major function. #### 8.1 MEDIA DEFECT HANDLING There are three methods for handling media defects: 1) slipping a sector; 2) remapping a sector to a new sector on the last head of that cylinder; and 3) remapping the entire track to a different track on the disk. Each of these methods has a dedicated subsection (including information pertaining to its performance difference). Section 8.3 describes how to allocate spare sectors. Section 8.5 describes how to read the manufacturer's defect information. # 8.1.1 Slipping a Sector Slipping a sector requires using the Read and Write Track Headers commands to mark the bad sector and slip the rest of the sectors into the next position on the disk. Figure 8-1 shows an 8-sector track before and after slipping Sector 3. | Ī | 0 | ı | 1 | l | 2 | ı | 3 | I | 4 | I | 5 | 1 | 6 | I | 7 | l | Spa | re | |---|---|-----|---|---|---|---|-----|---|---|---|---|---|---|---|---|---|-----|----| | | | | | | | | | | | | | | | | | | | | | 1 | 0 | - 1 | 1 | ı | 2 | 1 | Bad | 1 | 3 | I | 4 | I | 5 | ı | 6 | 1 | 7 | 1 | FIGURE 8-1. SECTOR SLIP #### 8.1.1.1 Sector Slip Procedure - 1. Determine which sector is bad by writing and reading the track with several patterns. - 2. Read the track headers into a buffer in host memory. - 3. Compare each header with the bad sector's header. - 4. After locating the bad sector, mark it by writing EEH into each of the four header bytes (See Figure 8-3). #### 8.1.1.1 Sector Slip Procedure (continued) - Test the last sector to determine if it is a spare. If it is a spare, continue; if not, you must find an alternate method of sparing. - 6. Move each sector header into the next location, "slipping" the sectors down the track (See Figure 8-1). - 7. Write the track headers back to the disk. The following figures depict 751 headers: FIGURE 8-5. 751 RUNT HEADER \* <sup>\*</sup> This header is invisible in normal 751 operation. It appears here for informational purposes only. | Sync | New Cyl | Low | CC | New C | yl High | Head | |------|---------|-----|----|-------|---------|------| | | | | | | | | FIGURE 8-6. 751 TRACK REMAP HEADER # 8.1.1.2 Advantages of Sector Slipping A full track of information is still transferred in one revolution of the disk. Other methods of sector slipping require two or more revolutions to transfer one track of information. #### 8.1.1.3 Disadvantages of Sector Slipping Having one or more spares on each track uses disk space inefficiently. # 8.1.2 <u>Cylinder Sparing</u> Cylinder sparing is similar to sector slipping, except the spares are on the maximum head of the cylinder. # 8.1.2.1 Cylinder Sparing Procedure - 1. Determine the defective sector. - 2. Read the track headers and mark the defective sector bad (See Figure 8-3). - 3. Write the track headers back to the disk. - 4. Read the track headers on the maximum track of that cylinder. - 5. Find a spare sector; it contains four bytes of ODDH. (See Figure 8-4.) - 6. Put the bad sector's header into this sector. The header contains the head and sector values for the sector being remapped on the original track. - 7. Write the track headers back to the drive. # 8.1.2.2 Advantages of Cylinder Sparing Cylinder sparing uses less disk space for remapping bad sectors. You may decide to allow only ten spares for a drive with twenty heads. Sector slipping is less efficient as it requires a minimum of 20 sectors per cylinder for this drive (one per head). #### 8.1.2.3 Disadvantages of Cylinder Sparing Cylinder sparing is slower than sector slipping. The 751 looks for the commanded sector for one revolution plus one sector on the original track; then it switches to max head and looks for another # 8.1.2.3 Disadvantages of Cylinder Sparing (continued) revolution plus one sector. This method takes up to three revolutions to transfer one track of information (assuming only one bad sector). # 8.1.3 Track Remapping Track remapping allows remapping an entire track to another location on the same disk drive: the 751 writes the defective track's headers with a code and new disk address for the transfer to continue. # 8.1.3.1 Track Remapping Procedure - 1. Read and save the defective track's headers. - 2. Allocate space for a write track headers buffer. Each header has OCCH in the second byte. The first, third, and fourth bytes contain the new Head, Cylinder High, and Cylinder Low. Write this information to the defective track with a Write Track Headers command. See Figure 8-6. - 3. Write the track headers that were read in Step 1 to the destination track with a Write Track Headers command. # 8.1.3.2 Advantages of Track Remapping Track remapping is useful in sparing tracks with very large or multiple defects. #### 8.1.3.3 Disadvantages of Track Remapping Track remapping is slow as the 751 must seek to the first track and then determine if it has been remapped. Then the 751 seeks to the spare track area (usually at the end of the disk). This sequence can add up to four revolutions to the 751 overhead. # 8.1.4 Recommended Remapping Procedure Xylogics recommends using all three methods of defect mapping. Allowing one spare sector per track takes care of 95% of the media defects. An additional 0.2% of the sectors on the cylinder to be spared on the last head provide up to 99% remapping. Allowing three or four tracks for remapping should provide a defect-free media. Allocating this amount of disk space for defect handling totals 2% of the media. Having two spares per track on the same drive (a Fujitsu Eagle with 512-byte sectors) uses 4% of the media. ## 8.2 CHAINING AND MULTIPLE I/O REQUESTS The 751 has two ways of speeding up multiple IOPB execution. One method allows the driver to chain IOPBs together, and then give the 751 a command-chain. The second method allows the driver to add IOPBs to the 751's queue by the same procedure as starting the first IOPB. # 8.2.1 Chaining Each IOPB has a Chain Enable (CHEN) bit and a Next IOPB pointer. IOPBs can be chained together by setting CHEN and having the Next IOPB pointer point to the next IOPB to be executed. Each IOPB in the chain points to the next, and, in order to stop the chain, CHEN is not set in the last IOPB. #### NOTE The Next IOPB Address is the physical address, not the virtual address. # 8.2.2 Multiple I/O Requests The following procedure allows you to add IOPBs to the 751 queue: - 1. AIOP must be clear. If it is not clear, wait; it normally clears within 100 microseconds (See Section 4.3.1). - 2. Write the five IOPB address registers to point to the beginning of the IOPB or IOPB chain. - 3. Write the AIO bit. # 8.2.3 <u>751 Operation</u> The 751 treats IOPBs the same, regardless of how they were added to the queue. Overlap seeks and IOPB reordering function only when they are enabled and the 751 is working with a queue or chain of IOPBs. #### 8.3 FORMATTING This subsection describes formatting, including how to set the number of spares for use in media defect handling and setting the sector size. # 8.3.1 Allocating Spare Sectors You must allocate spare sectors at format time. The Write Drive Parameters command allows setting the maximum size parameters for the drive. Any sectors in excess of the drive size parameters are marked as spares. For example, a drive with 46 physical sectors is specified as having only 45 in the Write Drive Parameters command. The 751 formats 45 normal sectors and 1 spare sector. A separate variable (max sector/last head) specifies the number of sectors on max head. This allows extra spares on max head for use with cylinder sparing. Given the above example, max sector/last head is set to 40. The 751 formats the last head of the same drive with 40 normal sectors, and 6 spare sectors. # 8.3.2 <u>Specify Sector Data Size</u> The 75l operates with drives having different sector sizes. Field 5 in the Format Parameters commands specifies the standard sector size. This value must be greater than 255 and less than 4097, and have an even number of bytes. Field 5 Alternate specifies the alternate sector size. The alternate size has the same limitations as the standard size. Clearing AFE with a Write Drive Parameters command selects the standard sector size; setting AFE selects the alternate sector size. #### NOTE Using two drives with different sector sizes will have a detrimental effect on the disk subsystem's performance. The 751 must modify the DSKCEL code each time it selects a disk with a different sector size. #### 8.3.3 <u>Specify Sector Gap Size</u> First a note of caution, DON'T DO THIS. Modifying the gap sizes may be detrimental to the health of your disk subsystem. The drive interface has many specifications and parameters to which you must adhere. Slight miscalculations may not show up in the engineering lab, but may cause unreliability in the field. The failure modes may be undetectable because field lengths are only marginally long enough. A word to the wise: if you decide to utilize this feature, please be very careful. Xylogics' values work with all standard SMD drives. Modified values may work with some drives, and cause unreliable results with others. See Figure 8-7. # 8.3.3 <u>Specify Sector Gap Size</u> (continued) This subsection outlines the parameters that affect each of the gap sizes. Many of the parameters that affect the gap sizes are specifications for the drive in use. Drives from different manufacturers, and even drives in one manufacturer's line, may have very different specifications. FIGURE 8-7. SECTOR GAP SIZES # 8.3.3.1 Field 1 - Read Gate Delay - Gap 1 Field 1 specifies the time in bytes from one byte past the leading edge of sector or index to when Read Gate is asserted. The applicable drive specifications include head settling time, allowing enough time to lock the Phase Lock Oscillator, and the minimum Write Gate to Read Gate timing. Field 1 also provides for skipping over the write splice area. # 8.3.3.1 Field 1 - Read Gate Delay - Gap 1 (continued) The head settling time is the time required for the heads to settle after the drive completes a seek. We do not know how long before the Sector or Index pulse the seek completed, therefore this field must be large enough to encompass the head settling time. When subtracted from Field 3, this field indicates the amount of time left for the Phase Lock Oscillator in the drive to lock onto the data. Drive requirements vary from 3 to 16 bytes. When Write Gate is deasserted, a minimum time must be allowed for the read heads and amplifiers to stabilize. In a multisector transfer, Write Gate is deasserted after the last sector, and Read Gate is asserted for reading the next header. Figure 8-7 indicates this time as "C". Field 1 and the remaining bytes in the sector after Field 7 comprise this critical time. Drive requirements are usually in the 10 to 12 microsecond range. Write Splice: as Write Gate is asserted (or deasserted), the changing write current causes a magnetic field to build (or collapse) which "writes" garbage onto the disk. This is called the write splice, and it occurs whenever Write Gate is asserted or deasserted. # 8.3.3.2 Field 2 - Sync Search Delay Field 2 is the delay from asserting Read Gate to when data is compared for the Sync byte. Field 2 masks any read data from being detected as a sync until the data is stable. #### 8.3.3.3 Field 3 - Gap 1 Field 3 is equivalent to Gap 1. Fields 3 and 1 together define the amount of time allowed for the Phase Lock Oscillator (PLO) in the drive to lock up. See Section 8.3.3.1. # 8.3.3.4 Field 4 - Gap 2 Field 4 is equivalent to Gap 2. It is the time (in bytes) between the end of the Header ECC and the Data Sync byte. This field includes the time required to allow the PLO in the drive to sync to the data and to skip the write splice. On a Write command, Write Gate is asserted four bit cells after Read Gate is deasserted. This field is actually four bits longer than specified. These four bits are used to test the header. #### 8.3.3.5 Field 5, Field 5 Alternate - Sector Size Section 8.3.2 describes sector size. # 8.3.3.6 Field 6 - Read Gate Delay Field 6 asserts Read Gate after the write splice during Gap 2. The time left over, Field 4 minus Field 6, is the time allowed for the PLO in the drive to lock up. # 8.3.3.7 Field 7 - Write Continuation The write continuation field is necessary so that when Write Gate is deasserted, the collapsing magnetic field does not splash over the ECC that was just written. The end of Field 7 is the beginning of the minimum Write Gate to Read Gate period described in Section 8.3.3.1. #### 8.3.3.8 Head Switch Time The 751 requires 6 bytes of time after Field 7 to switch heads. If the sector size is too short to allow this 6-byte field, the 751 will miss revolutions on every head switch. This should not be a problem; typically, the minimum Write Gate to Read Gate time allows for this field. ## 8.3.4 Format Interleave The 751 can optionally format with an interleave pattern from 2:1 to 16:1. Specify the interleave factor when writing the format parameters; it is invisible to the operating system. Interleaving can increase the throughput of a disk subsystem on a fully loaded system by effectively cutting the disk speed in half. In a contiguously formatted pack (1:1 interleave), the sectors increase by one each time. As the disk spins, the sectors arrive under the head in the following order for a 32-sector disk: #### 0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 ...31 If you interleaved the same disk with a 2:1 interleave factor, it would look like this: ## 0 16 1 17 2 18 3 19 4 20 5 21 6 22 7 23 8 24 9 25 10 ...31 The 2:1 interleave allows the 751 two sector times to transfer a sector to memory. For example, if you are transferring sectors 0 and 1 to memory, the following occurs in each case. # 8.3.4 Format Interleave (continued) In 1:1 interleaving, when the first sector has completed reading from the disk, the next sector will soon be under the head and ready for reading. At this time there must be enough room in the buffer or the 751 will miss a revolution. In 2:1 interleaving, when the first sector has completed reading from the disk, the next sector is still a full sector time away, thereby giving the 751 twice the time to empty the buffer to memory. The diagram above shows the extra sector time as sector 16. Interleaving schemes from 2:1 to 15:1 are software programmable. This can be a great advantage on a fully loaded system. The current method for handling a data late is to drop a revolution; this means waiting until the next time the sector comes under the head. If you are transferring 16 sectors and drop a revolution on each sector, the transfer takes $16 \times 16.6$ milliseconds (ms) after the seek or 265.6 ms. If the disk had been interleaved 2:1, it may not have dropped a revolution, and taken only one revolution after the seek, or 17 ms. Interleaving is advantageous, but it doubles the transfer time on a lightly loaded system. Since the 751 determines which sector the drive is at by comparing headers, you can use the Write Track Headers command to customize the interleaving scheme to your application. For example, if your system transfers data in 4K-blocks, then the most effective interleaving scheme may be: 0 1 2 3 16 17 18 19 4 5 6 7 20 21 22 23 8 9 10 11 ... #### 8.4 ERROR RECOVERY The 75l may automatically retry operations that have errored. Two options are available. One option deals with retrying drive fault-and seek-type errors. The other option involves the retry algorithms for ECC recoveries. The Read and Write Controller Parameters commands enable or disable these options. #### 8.4.1 <u>Automatic Operation Retry</u> The 751 automatically retries an operation if the reason for the initial failure is a seek error or drive fault. Setting ASR with a Write Controller Parameters command enables this option. ## 8.4.2 <u>ECC Error Recovery</u> ECC algorithms have a much better chance of recovery if the 751 retries the operation before using the ECC correction. The 751 retries the Read operation once before applying the ECC correction if RBC is set. Set RBC with a Write Controller Parameters command. # 8.4.2 <u>ECC Error Recovery</u> (continued) There are three options for applying ECC correction. Using Mode 0, the 75l provides the correcting pattern and offset for the driver to go and correct the actual error in memory. Mode 1 flags the fact that an error occurred, but does not stop the transfer to calculate any correction information. Mode 2 calculates the correction information and applies it to the data in host memory. #### 8.4.3 <u>Using the Error Recovery Options</u> Changing the appropriate controller parameter enables or disables the error recovery options. Once set, the 751 takes care of applying the retries as requested. The 751 provides a completion status to indicate a recovery operation took place. The driver applies the ECC correction if ECC Mode 0 is utilized. If a retry fails, the Completion Code reflects the fatal error. #### 8.5 READ DEFECT MAP The 75l reads the data recorded on the media by the manufacturer that describes the location and length of factory-detected media defects. The defect map's format must conform to the following specifications: M2331/M2333 Disk Drive Engineering Specification; Fujitsu LTD. Doc. No. B03P-4760-0101A; and CDC Product Specification No. 64400400. #### 8.5.1 The Defect Map The header format is divided into two parts. The first part of the format is a fixed sector format; the second part is a variable sector format. The fixed sector format is normally included in the first 56 bytes following the index mark. The 751 does not support the variable sector format. The following rules apply to defect recording: - The position of a defect is listed in bytes (hex) after the index mark, plus or minus one byte. - 2. The length of a defect is in bits (hex), plus or minus one bit. - 3. The unused defect locations are all zeros. - 4. Every track is recorded with this defect format whether defects exist or not. - 5. More than one defect on a track causes the track to be flagged as defective. The first four media defects on the track are logged. # 8.5.1 The Defect Map (continued) 6. Figure 8-8 shows the format when there are no defects in the first 105 bytes after the index mark. FIGURE 8-8. DEFECT MAP FORMAT 7. Figure 8-9 shows the format when the beginning of a defect is located between Bytes 10 and 55; 60 bytes of zeros are added to Gap 1. In the extended defect map format, the defect map is always relocated to a defect-free area. FIGURE 8-9. EXTENDED DEFECT MAP FORMAT #### 8.5.2 Read the Defect Map Set up a 24-byte long buffer in memory. Issue an Extended Read with a subfunction of Read Defect Map. Since the defect maps do not use a checksum, verify the data for correctness. # 8.5.3 <u>Verify the Data</u> The first byte in the buffer should be a 19H. This is the second of two Sync bytes. The head and cylinder addresses should agree. The last byte should be an FOH. # 8.5.4 <u>Determining the Location of a Defect</u> The position of a defect is provided in bytes from the index mark. You must convert this value to a sector number before using it for defect mapping. The drive switch settings determine the actual number of bytes per sector. Divide this value into the defect position. This number, truncated, points to the physical sector containing the defect. Adjusting this physical sector number by any interleaving or skewing scheme determines the logical sector number for remapping. #### 8.6 MAINTENANCE MODE Firmware supports a non-IOPB driven Maintenance mode. It allows you to perform basic testing within the 75l by setting Control bits in the CSR and entering the desired test number and data through the address registers. This firmware also provides a window through which internal registers may be examined or modified. ## 8.6.1 Register Use in Maintenance Mode The Function Code in the Test Number Register determines whether or not the 751 uses the Input Data Byte and Output Data Byte Registers (See Table 8-1). Familiarize yourself with the Control and Status Register before reading this section (See Section 3.3). | REGISTER | DESCRIPTION | |----------|--------------------------------| | 1 | Test Number or Function Code | | 3 | Input Address Low | | 5 | Input Address High | | 7 | Input Data Byte (If Required) | | 9 | Output Data Byte (If Required) | | В | Control and Status Register | | D | Fatal Error Register | TABLE 8-1. REGISTER USE IN MAINTENANCE MODE # 8.6.2 <u>Maintenance Mode Protocol</u> # 8.6.2.1 Executing a Maintenance Command or Entering the Maintenance Mode First, set the Maintenance Mode (MM) and AIO bits. This forces entry into the maintenance kernel. The kernel initializes the CSR and Poll mask and sets the Remove IOPB (RIO) bit; then clear RIO. # 8.6.2.1 Executing a Maintenance Command or Entering the Maintenance Mode (continued) The kernel expects the Input Address Low Register to contain a maintenance test number or function code for execution. Data may be expected or may be returned (see register layout). BUSY and AIO are configured for polling. Setting BUSY and AIO selects the register image test; clearing BUSY returns control to the maintenance kernel. AIO causes the maintenance firmware to read and decode the command string from the Input Address Registers. After successfully decoding the command string, the firmware echoes it (command, address, and data) to the Output Address Registers and clears AIO. This acknowledges receipt of and attempts to execute the requested command. After completing the requested command, the 751 updates the Output Address Registers with test-pertinent data and sets the RIO bit. The AIO/RIO protocol is identical to Normal mode. (RIO indicates the end of firmware involvement and valid contents in the Output Address Registers.) Since each test and its expected results are different in nature, the Output Address Registers hold the test result information (address, data, etc.). In any case, the firmware sets RIO upon command completion; it sets the Fatal Error bit if a failure occurs or if host software issues an illegal command. ## 8.6.2.2 Exiting the Maintenance Mode To exit the Maintenance mode, clear MM and RIO, and set AIO. This returns control to the Normal mode kernel. The 751 acknowledges by setting RIO. # 8.6.2.3 Diagnostic Considerations The Input/Output Address Register Verify is the first test the diagnostic should execute. Firmware flags the Power-up Test failures by setting the Fatal Error bit while leaving the Maintenance mode bit set. Firmware saves the Self Test error numbers internally until it verifies the Input and Output Registers. #### 8.6.2.4 Register Tests You must request entry into the Maintenance mode to invoke the Register test. After the firmware acknowledges the request, you should set the BUSY bit. BUSY remains set during this test. #### 8.6.2.4 Register Tests (continued) #### NOTE You must enter the Maintenance mode as a separate step because the Normal mode firmware does not allow setting BUSY (defined as RMM when Maintenance mode is enabled). Writing the Input Address Registers, followed by AIO, signals the firmware to copy the data to the Output Address Registers. Firmware sets RIO when it completes the copy. Host software should then clear RIO. Clearing the BUSY bit exits this test and returns the 751 to Maintenance mode. #### 8.6.2.5 Test Variables Some of the internal tests require the address and data to perform their particular function. On-board memory has space allocated for this data. These locations are loaded with default values for initial use. However, you may alter these variables through the Manual mode. (As the internal tests are defined, the protocol and results expected will be made available.) #### 8.7 ZERO LATENCY READS To implement Zero Latency Reads, enable the function when executing a Write Controller Parameters command. Zero Latency Reads cause the 751 to examine the first sector header on the target cylinder. If this sector is within the transfer's boundaries, the 751 starts transferring data to the FIFO. It continues this transfer until it reads the last sector of the transfer on that track. The 751 then searches for the first sector of the transfer on that track and transfers that sector and the remaining sectors (up to the point where it began) into the FIFO. The 751 keeps track of the data, ensuring that it gets transferred to the proper memory location. If the 751 encounters an error during the initial part of the transfer, it sets the Completion Code to Retry Successful, marks the next sector as the one it started from, and continues the operation. The 751 automatically retries the errored sector after completing the transfer on this track. If the error recurs on the second try, all previous sectors will have been transferred, and the Completion Code reflects the hard error. #### 8.8 MULTIPROCESSOR SUPPORT The 751 has several options that make multiprocessor environments easiser to support: the programmable interrupt vector, interrupt level, register address modifiers, and busy semaphore. #### 8.8.1 Interrupts Each IOPB specifies the interrupt level and vector for that command. In a multiprocessor environment, each processor can have its own assigned interrupt level and vector. # 8.8.2 Register Busy Semaphore RBS allows multiple processors to share the registers without colliding. Hardware supports the RBS bit. The register access protocol involves reading the CSR. If RBS is clear, the host has control of the register, and retains control until it clears RBS in the Control Register. If the first read to the Status Register indicates that RBS is set, then another host has control of the register and this host must wait until RBS clears. The 751 sets RBS immediately after a host reads the CSR. If a host attempts a read, and RBS is clear, then the 751 sets RBS; any successive reads by other hosts will "see" that RBS is set. When the host using the registers is done, it must clear RBS. Clearing RBS and setting AIO can occur in the same register write. Clearing RBS without having control of the registers violates the register protocol. # 8.8.3 Address Modifiers The address modifiers can be used to assign separate address space for each of the processors. # 8.9 COMMAND OPTIMIZATION To implement Command Optimization, enable the function when executing a Write Controller Parameters command. Command Optimization is the reordering of IOPBs in the 751's command queue. The reordering causes the 751 to enable elevator seeks and process several IOPBs within one revolution. The 751 starts the first IOPB it receives, and then reorders IOPBs as they are DMAed into the queue. This feature is most effective when there are more than two IOPBs in the 751's queue. # 8.9 COMMAND OPTIMIZATION (continued) The 75l places the IOPB in a position relative to the other IOPBs in its internal queue. Then it tests the IOPBs to determine if any are contiguous on the disk. The 75l links together any contiguous IOPBs it finds, and executes them as one disk operation; it does not link the DMA portion of the transfer as this is not necessary. The 75l first links the IOPBs with respect to an ascending cylinder order. If the 75l receives an IOPB with a cylinder number lower than the current cylinder, it positions the IOPB at the end of the queue in descending cylinder order. Conversely, if the 75l is operating in descending cylinder order, it positions an IOPB with a cylinder number higher than the current cylinder at the end of the queue in ascending cylinder order. ## 8.10 SOFTWARE CONTROL The 751 has many parameters that can be modified by software control. The parameters can be set in bulk with three Write Parameters commands. The Write Format Parameters command modifies the format parameters. The Write Drive Parameters command modifies the drive parameters. The Write Controller Parameters command modifies the controller parameters. # 8.10.1 <u>Modifying a Single Parameter</u> The best method for modifying a single parameter is to first execute a Read Parameters command for the associated parameter block, modify the single parameter, and then write the parameter block back to the controller. # 8.10.2 <u>Modifying a Group of Parameters</u> Use the same method as in Section 8.10.1, or set all the parameters in the specific IOPB and execute the appropriate Write Parameters command. For example, Fields 1 through 7, 5A, and the interleave factor must be set to the appropriate values before issuing the Write Format Parameters command. The 751 sets all parameters to the new values contained in the IOPB. #### 8.10.3 Parameter Reference Point After the 751 is working as intended, read the parameters and save the information for future use. # 8.10.4 <u>Setting Parameters at Boot Time</u> It is not necessary to reload the parameters at each boot since the parameters are stored in a battery backed-up RAM. It is a good idea to reload them each time if you are not sure how the board was last used. #### 8.10.5 <u>Validate Current Parameters</u> The parameters are all protected by a checksum, and any Read Parameters command performs a checksum test. Any Read Parameters terminates with an error if the generated parameter checksum is different than the stored checksum (See Section 6.6). #### 8.11 SCATTER/GATHER The Scatter/Gather feature is used in conjunction with standard Read and Write commands. In a Scatter Read, the 751 transfers the data to up to 32 blocks of memory. Gather Writes gathers data from up to 32 blocks of memory and writes it to the disk. The size of each memory block must be an even byte count and less than 64K-bytes long. The blocks may be scattered throughout memory. #### 8.11.1 Scatter/Gather Link List You can determine the length of the linked list by multiplying the number of elements in the list by 8 (each element is 8-bytes long). All data addresses must be on word boundaries and the byte count must be even. For Read and Write operations, enter the number of elements in the linked list into Byte 6, bits 3 through 7. A zero in this field indicates the linked list has 32 elements. | LINK NUMBER | BYTE | DESCRIPTION | |-------------|----------------------------|------------------------------------------------------------------------------------------------| | 1 | 00-01<br>02<br>03<br>04-07 | BYTE COUNT (Multiples of 2) RESERVED DATA ADDRESS MODIFIER DATA ADDRESS (Word Boundaries Only) | | 2 | 09-07<br>08-09<br>: | BYTE COUNT | | n | XX | | TABLE 8-2. SCATTER/GATHER LINK LIST #### 8.11.1 Scatter/Gather Link List (continued) | LINK FIELD VALUE | DECIMAL FOUTVALENT | |------------------|--------------------| | 0 | 32 | | 1 | 1 | | 2 | 2 | | : | : | | 9 | 9 | | A | 10 | | В | 11 | | : | : | | 1E | 30 | | lF | 31 | | | | TABLE 8-3. LINK LIST FIELD VALUES # 8.11.2 <u>Setting Up a Scatter/Gather Transfer</u> The Data Address and Modifier bytes in the IOPB should now point to the start of the linked list. The linked list length field should give the total number of element descriptors on the list. Elements of memory descriptors comprise the linked list. Each element describes the starting address and the length in bytes of the memory block. The sum of the byte count of all the elements in the linked list must equal the sector count times the sector size in bytes. The IOPB and Linked List in Figure 8-10 illustrate a Read transfer to 6 blocks of memory. The sector size in this case is 528-bytes per sector; we are transferring 3 sectors of information. The 751 transfers the first 16 bytes of data from each sector to a separate data buffer. It scatters the bulk of the data, 512-bytes per sector, into memory as 3 blocks having 512 bytes each. Set SGM and execute the IOPB in Figure 8-10. # 8.11.2 <u>Setting Up a Scatter/Gather Transfer</u> (continued) | | 9 | CATT | ER / ( | SATHE | R RE | AD CO | MMAN | D | | | <b>→</b> 00020H | LINK LIST | |------------|-------------------------------------------|---------|---------|-------|---------|-------|------------|----------|--------------|------------|-----------------|-------------| | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | 00-01 | BC= 0010H | | 00 | ERRS | DONE | CHEN | SGM | | соми | MAND | | = | 12H | 02-03 | DAM=0004H | | 01 | | | | | ION COD | | | | = | ОН | 04-05 | DAH=0000H | | 02 | DPB | SR | CSE | | DFLT | | ONCL | DRDY | = | ОН | 06-07 | DAL= 1000H | | 03 | | | IN | | L STATU | | | | = | ОН | 00-01 | BC= 0200H | | 04 | | | | | NCTION | | | | = | ОН | 02-03 | DAM= 0002H | | 05 | FIXD | RDP | PSEL | BHT | 0 | | UNIT | | = | 02H | 04-05 | DAH = 0000H | | 06 | | LINKE | LIST L | ENGTH | | IN | T LEVE | <u>L</u> | = | 30H | 06-07 | DAL=2000H | | 07 | INT V | | | | | | | | = | ОН | 00-01 | BC= 0010H | | 80 | | HIGH | | | | | | | = | ОН | 02-03 | DAM=0004H | | 09 | COUNT LOW | | | | | | = | 03H | 04-05 | DAH=0000H | | | | 0 <b>A</b> | | IDER HI | | | | | | | <b> </b> = | ОН | 06-07 | DAL= 1010H | | 0B | CYLINDER LOW | | | | | | <b> </b> = | 02H | 00-01 | BC= 0200H | | | | OC. | HEAD | | | | | | | | = | 01H | 02-03 | DAM= 0002H | | 0D | SECTO | | | | | | | | = | 04H | 04-05 | DAH=0000H | | 0E | O DATA / LINK ADDRESS MODIFIER | | | | | | 1] = | 02H | 06-07 | DAL= 2200H | | | | OF | PRIO 0 NEXT IOPB ADDRESS MODIFIER | | | | | | # = | ОН | 00-01 | BC = 0010H | | | | 10 | | / LINK | | | | | | | <b>#</b> ] = | ОН | 02-03 | DAM=0004H | | 11 | | / LINK | | | | | | | <b> </b> = | ОН | 04-05 | DAH=0000H | | 12 | | / LINK | | | | | | | 厓 | ОН | 06-07 | DAL= 1020H | | 13 | THE R. P. LEWIS CO., LANSING, MICH. | / LINK | | | | | | | <b>!</b> = | 19H | 00-01 | BC=0200H | | 14 | | IOPB AI | | HIGH | | | | | = | ОН | 02-03 | DAM=0002H | | 15<br>16 | NEXT IOPB ADDRESS | | | | | | = | ОН | 04-05 | DAH=0000H | | | | | NEXT IOPB ADDRESS | | | | | | = | ОН | 06-07 | DAL=2400H | | | | 17 | NEXT IOPB ADDRESS LOW | | | | | | <b> </b> = | ОН | | | | | | 18 | IOPB CHECKSUM HIGH | | | | | | <b> </b> = | ОН | | | | | | 19 | IOPB CHECKSUM LOW | | | | | | = | ОН | | | | | | 1.8 | ECC PATTERN WORD HIGH | | | | | | = | ОН | | | | | | 1B<br>1C | ECC PATTERN WORD LOW ECC OFFSET WORD HIGH | | | | | | <b> </b> = | ОН | | | | | | | | | | | | | | | <b> </b> = | ОН | | | | 1D | ECC 0 | FFSET V | IOKD LC | . ₩ | | | | | ] = | ОН | | | FIGURE 8-10. SCATTER/GATHER TRANSFERS # 8.11.3 <u>751 Operation</u> The 751 proceeds as if doing a normal read until it starts the data transfer into memory. The contents of the linked list now controls the DMA processor; it gives the processor the byte count and address for each element on the list. The processor takes the data out of the FIFO and transfers it to memory as decribed in each element on the list. # 8.11.4 Zero Latency Reads and Scatter/Gather Due to the flexibility allowed in scatter/gather, the linked list elements may not align with sector boundaries. Thus, zero latency reads may not function properly. Xylogics does not recommend mixing these two options. #### 8.12 DMA THROTTLE / THROTTLE DEAD TIME The 751 always transfers IOPBs in Word mode; it uses the last specified values for the throttle and throttle dead time. Host software can set the Throttle Dead Time (TDT) field in the Controller Parameters IOPB. This value defines the time that the 751 waits before attempting to regain control of the bus between throttle bursts. There are four valid TDT values. | TOT VALUE | TIME | | |-----------|------|--------------| | 0 | 0 : | microseconds | | 1 | 3.2 | tt . | | 2 | 6.4 | Ħ | | 3 | 12.8 | n | TABLE 8-4. THROTTLE DEAD TIME VALUES #### 8.13 BLACK HOLE TRANSFERS Sometimes the data to be transferred has to go to a single memory location. This single location is usually a graphics controller with a single port on the bus. The normal DMA mode increments the bus address on each transfer so the data is put into contiguous memory space. When Black Hole Transfers are implemented, the 751 does not increment the bus address between each data transfer. Any transfer that includes a DMA to a single location should have BHT set in Byte 5 of the IOPB. This causes only the data transfer portion of the command to not have its bus address incremented. The IOPB DMA still occurs in Normal mode (i.e., the 75l increments the address). The data address must be properly aligned: word aligned for word transfers, and longword aligned for longword transfers. The 751 cannot do dynamic mode switching with this option. #### 8.14 PRIORITY IOPBS The 751 processes Priority IOPBs before any other IOPBs in its queue. This feature works on both a single IOPB and an IOPB chain. # 8.14.1 Executing a Priority IOPB To execute a priority IOPB, set PRIO in both the IOPB Address Modifier Register and the Next IOPB Address Modifier byte in the IOPB. Set the rest of the IOPB Address Registers to point to the IOPB (do not reset PRIO in the Address Modifier Register when loading it). Set AIO as you normally would. # 8.14.2 Executing a Priority Chain To execute a Priority chain, follow the directions in 8.14.1. All IOPBs in the chain must have PRIO set in the Next IOPB Address Modifier byte. # 8.14.3 751 Response to a Priority IOPB (Chain) The 75l finishes executing the IOPB that is currently active (if any). The next IOPB to execute is the priority IOPB (or the first in the priority chain). If the 75l starts a chain of priority IOPBs, it completes one at a time until it completes the chain, and then goes back to processing the IOPBs in its queue. All IOPBs in a priority chain must have PRIO set. # 8.15 IOPB CHECKSUM While debugging the driver, you may choose to append the checksum to the IOPB. The checksum is the sum of Bytes 0 through 17 in the IOPB, and is expressed as a 16-bit quantity. The 75l generates a checksum with the data from the IOPB and compares it to the appended checksum; a miscompare causes a fatal error. If AUD and ICS are set, the 75l appends a new checksum as it updates the IOPB. If you want to disable the checksum, the Write Controller Parameters IOPB must have a valid checksum. # 8.16 FIXED/REMOVABLE MEDIA Any physical drive with fixed and removable media, like the CDC CMD, or LMD, is accessed as one logical unit (FIXD is clear for the removable media of Unit 0, and set for the fixed media of Unit 0). # 8.16.1 Head Offset The head offset refers to the bit(s) that must be set during a drive head select sequence to select between the fixed and removable portions of the drive. Host software must specify a head offset value for fixed/removable drives: one for the removable portion of the drive, and one for the fixed portion. The offset # 8.16.1 <u>Head Offset</u> (continued) value is a hexadecimal number that the 751 adds to the head number in order to select either the fixed or removable portion of the disk. Two such fixed/removable drives are the CDC Lark and CMD. The head offset value for the removable portion of a CMD is zero; the head offset value for the fixed portion is 10H. Reference the appropriate vendor manual to determine the head offset values for the fixed and removable portions of the disk. #### 8.17 EMBEDDED SERVO DRIVES The 751 inherently supports embedded servo drives. Configure the drives to seek on every head select. The 751 always waits for an on-cylinder condition before starting a new sector. #### 8.18 SUPPORTING TWO DRIVES WITH DIFFERENT SECTOR SIZES The 751 can support two drives having different sector sizes. For example, Drive 0 can have 512-bytes per sector and Drive 1 can have 1024-bytes per sector. # 8.18.1 <u>Setting the 751 Format Parameters</u> When executing the format parameters command, Field 5 should be set to the standard sector size (200H [512]) and Field 5A should be set to the alternate sector size (400H [1024]). # 8.18.2 <u>Setting the 751 Drive Parameters</u> The Write Drive Parameters IOPB has an Alternate Field Enable (AFE) bit. If AFE is set, the drive specified by this command uses the alternate field size (1024). If AFE is clear, then the drive uses the standard sector size. For example, Unit 0 has 512-bytes per sector and AFE is clear in the drive parameters; Unit 1 has 1024-bytes per sector and AFE is set in the drive parameters. #### 8.18.3 Accessing Drives With Alternate Fields The 751 automatically sets the sector size according to the specified drive. When allocating buffers, host software must remember, and take into account, the sector size of the drive being accessed. #### 8.19 DUAL PORTED DRIVES Some SMD drives have an optional second port that connects to a second disk controller. This allows two computers to access a single disk drive. Dual ported drives are requested by executing a normal Unit Select (which is a normal controller function, invisible to the software). Once selected, the drive port remains selected and reserved until a Release command is issued. Deselecting the drive without a release leaves the drive deselected but reserved, and unavailable to the other port. If the Release Dual Port (RDP) bit is set, the 751 executes a Release command after completing the IOPB. RDP should be set for normal transfers to a dual ported drive, unless you are trying to lockout the other controller. Priority Select or Trespass is available if the other controller refuses to give up the port. This is an override command, and as such forces connection to a port, regardless of the other port's activity (including writing to the disk). Priority Select provides emergency access to the disk, but you must understand that it can clobber the disk if the other controller is updating the directory. Leaving the disk drive in a released state when it is not being accessed provides equal access for both controllers. #### 8.19.1 Software Write Access Control Host software must control access to the drive so that the two computers do not simultaneously write onto the same sectors or directory. This can corrupt the file system. Software can implement several methods for providing this control. One control method allows one computer read/write access, and the other only read access. A second method employs disk partitioning, allowing each controller read/write access to its own partition, and read only access to the other controller's partition. The most commonly used method allows both controllers read/write access to the files, but only one controller has read/write access to the directory and allocation maps. Another method for controlling drive access is to lock out the other controller while doing a write. Clearing RDP in the IOPB locks the other port by not releasing the first port. You have to lock out the other controller from the time you read the allocation map and directory, to when both are updated after the transfer. The IOPBs from the first read to the next to the last write have RDP clear; the last write has RDP set. # 8.20 READ/WRITE HEADER, HEADER VERIFY, DATA, AND DATA ECC This maintenance command is used to test the controller and software driver. It enables simulating ECC errors to verify the ECC is working. The operation includes reading a sector with its header into memory, modifying the data and then writing the sector back to the disk. The 751 does not recalculate the ECC for this command. The data read back is either 12 or 14 bytes larger than the data sector size (depending on EC32's status). For example, given a 512-byte sector size, the 751 returns 524 bytes if EC32 is set, and 526 bytes if EC32 is clear. Table 8-5 shows the relationship between EC32's status and the returned data. | BYTE | EC32 CLEAR | BYTE | EC32 SET | |--------------|-------------------|--------------|------------------------------------| | 0-3 | Header* | 0-3 | Header* Header ECC Data 32-bit ECC | | 4-7 | Redundant Header* | 4-7 | | | 8-(n+8) | Data | 8-(n+8) | | | (n+8)-(n+14) | 48-bit ECC | (n+8)-(n+12) | | <sup>\*</sup> Figures 8-2 through 8-6 describe the header information #### TABLE 8-5. EC32 VS. RETURNED DATA #### 8.20.1 Simulating an ECC Error To simulate an ECC error, read a sector by issuing a Read Header, Header Verify, Data, and Data ECC command. Then change a data byte or bit, and write the sector back by issuing a Write Header, Header Verify, Data, and Data ECC command. Reading this sector with a normal Read command should return an ECC error. There are two common problems associated with simulating an ECC error. First, the corrected data byte may be next to the one in error. Second, the data may not be serially written to the disk as you see it on your terminal screen. Thus, a "2-bit error" crossing a byte boundary may be uncorrectable. The 751 usually accesses memory in Word or Longword mode, but corrects data in ECC Mode 2 via byte transfers. Since some bus adapters reverse the byte addressing scheme within a word, the 751 corrects the wrong data. The only solution for this situation is to either correct the adapter or use ECC Mode 0. # 8.20.1 Simulating an ECC Error (continued) The serial data is placed on the disk with bit 0 of each byte first. Table 8-6 shows a simulated 2-bit error crossing byte boundaries. Since the two bits in error are really fifteen bits apart, they may be uncorrectable. This can only occur when testing because a 2-bit adjacent error refers to two adjacent bits on the media. #### BEFORE SIMULATED ERROR MEMORY DATA: 45 67 SERIAL DISK DATA: 5 4 7 6 1010 0010 1110 0110 #### SIMULATED ERROR MEMORY DATA: 44 E7 SERIAL DISK DATA: 4 4 7 E 0010 0010 1110 0111 #### TABLE 8-6. SIMULATED 2-BIT ERROR CROSSING BYTE BOUNDARIES # 8.21 INTERRUPT AT END OF CHAIN IEC prevents the 751 from interrupting after completing each IOPB in a chain. The 751 executes the entire chain and then interrupts (using the interrupt level and vector from the first IOPB in the chain). When IEC is clear, the 751 interrupts after completing each IOPB (providing the interrupt level is not zero). #### 8.22 RELEASE ON REQUEST When ROR is enabled, the 751 tests the VMEbus between each throttle for other pending bus requests. If another request is pending, the 751 releases the bus. If there are no bus requests, the 751 remains bus master. The throttle value determines how often the 751 tests the bus. Using lower throttle values causes the DMA to slow down; using higher throttle values causes the 751 to test the bus less frequently. #### SECTION 9: THEORY OF OPERATION #### 9.0 GENERAL This section is an overview of how the controller works. It deals with the functional blocks of the hardware and microcode, and how the code affects 751 operation. #### 9.1 The Hardware The 751 interfaces the VMEbus to up to two SMD-E disks and includes these logic blocks: VMEbus Interface Register Read/Write and Interrupt (REGCEL) Microcontroller Direct Memory Access Controller (VMEDMA) Disk Data Buffer (FIFO) Disk Front End (DSKCEL) SMD-E Interface # 9.1.1 <u>VMEbus Interface</u> This block contains interface logic for the signals on the VMEbus. The 751 is a VME slave for programming purposes, i.e., the register file. The 751 is also a slave when it responds to an interrupt acknowlege with the interrupt vector. The REGCEL performs both of these functions. The address modifier transceiver is used by the REGCEL (receive mode) and VMEDMA (driving mode). The 751 is a VME master for DMA purposes; it uses DMA to read and update IOPBs and also to read and write disk data from host memory. The VMEDMA chip performs this function. The VME data bus is 8-, 16-, or 32-bits wide; the VME address bus is 32-bits wide. #### NOTE The 751 uses only 16 address bits for decoding its register addresses (it only compares 12 bits). It drives all 32 address bits as a master. The VMEDMA updates the lower 16 address bits while the microcontroller updates the upper 16 address bits. #### 9.1.2 Register Read/Write and Interrupt The REGCEL provides the program interface for the 751. The 751 uses registers to point to an IOPB to be executed, to point to a completed IOPB, and to perform various control functions. # 9.1.2 Register Read/Write and Interrupt (continued) The VMEbus accesses the registers via a bus that is shared between the REGCEL and VMEDMA. There is no contention because the VMEDMA cannot acquire the bus while a slave (register) access is in progress. The REGCEL answers a register access by the VMEbus with the signal DTACK. The upper address bits are decoded and the proper address modifier is required to do a register access. The microcontroller (micro) accesses the registers via the internal data bus. It programs the REGCEL to interrupt it if certain bits are set in the CSR or if a timer overflows. Other conditions are programmed to assert another interrupt to the micro. The REGCEL also supports the VMEbus interrupt protocol. It is programmed by the micro to assert the request line to start an interrupt sequence. When the system responds with IACK and DSO the REGCEL drives the interrupt vector onto the bus and asserts DTACK. This process causes the system to execute an interrupt routine. The interrupt service routine should clear RIO in the CSR. In this way, the 751 passes the completed IOPB back to the system. The REGCEL has a register for storing the address modifier that the VMEDMA enables onto the bus. Like the VME address, the address modifier is pipelined. A new modifier can be loaded into the REGCEL while a different modifier is being driven onto the VMEbus. The REGCEL also has two timers. Timer 0 is a watchdog timer: it expires and interrupts the microcontroller if it is not periodically reset by the firmware. Timer 1 is a counter for header errors. A clock comes from the DSKCEL and is asserted when a disk header does not match the expected header. If Timer 1 overflows before the desired header is found, a Header Not Found error results. # 9.1.3 The Microcontroller The 751 uses a 16-MHz 8031 microcontroller. It fetches instructions by asserting an address on Port 0, latching the address with ALE-L, and reading the data from the EPROM; it reads data into Port 0. Many of the instructions cause the micro to access an external byte using strobe decoders and a transceiver. Many of these external bytes are in the Xylogics LSI chips: REGCEL, VMEDMA, and DSKCEL. External bytes are accessed through Port 0. Port 1 is used for DSKCEL related outputs. Port 2 is used for the upper byte of the EPROM address. Port 3 is used for miscellaneous control signals. Inputs can all be considered micro interrupts, although most are actually polled. Two inputs are from the REGCEL, one from the VMEDMA, and two from the DSKCEL. # 9.1.3 The Microcontroller (continued) This block also includes the internal RAM (IRAM) logic. The micro really uses the IRAM as a scratch pad RAM; it stores the controller, drive, and format parameters there as well as IOPBs. Since the RAM device is non-volatile, the 751 remembers its configuration. However, a board that has never been programmed has garbage for parameters. If in doubt, reprogram the board with the parameters for the drive you are using before using the 751. The IRAM is single ported, but is used by both the VMEDMA and the micro. Since the microcontroller starts the VMEDMA, it knows when the IRAM is off limits for micro access. IOPBs are always DMAed in full words for better performance. # 9.1.4 <u>Direct Memory Access Controller</u> The VMEDMA controls the transfer of data between the disk buffer or IRAM, and the VMEDUS. The micro programs the VMEDMA to transfer a certain amount of data to/from a specified area in system memory. To properly handle odd starting addresses, the amount of data is always a sector's worth or less. In this way, the DSKCEL can be instructed to do an even or odd address transfer on a per sector basis. Before the VMEDMA can transfer data, it must acquire the bus by sending out BUSREQ (which must be jumpered to one of the Bus Request lines). The system arbiter sends back BGIN via another jumper. The VMEDMA then asserts BUSY on the VMEDUS and enables the 751 to control the VME address, data, and control lines. A transfer involves asserting a valid address, asserting DSO and/or DSI and valid write data or read data, waiting for DTACK, and proper buffer control. The order of the buffer request and data strobe is reversed, depending on the direction of the transfer. The DMA circuitry pipelines data to increase performance. The pipeline allows one word of data to be transferred on the bus while another is transferred to the buffer. In this way, the access times of the buffer and the bus can be overlapped (except for the first and last transfers of a burst). A prefetch primes the pipeline, and at the end of the burst the pipeline is emptied. The disk buffer is word wide and uses a longword wide pipeline. The interface logic turns a VMEDMA longword request into two buffer (word) requests. The IRAM is byte wide and uses a word wide pipeline. The interface logic turns the VMEDMA word request into two IRAM requests. ## 9.1.5 Disk Data Buffer The 8K-byte buffer for disk data has byte parity. The parity bits are stored in a RAM. The buffer is organized word wide. DMA longwords must be written using two buffer requests. If an odd byte has been DMAed, the DSKCEL can be programmed to ignore the dummy byte in the other half of the buffer word. The buffer control logic is an 8x60 and accepts requests to read and write the buffer from the VMEDMA and DSKCEL. One device at a time is allowed to access the buffer and the micro tracks the buffer's full/empty status. The VMEDMA waits for the buffer to become ready before initiating a transfer. The DSKCEL will not start a write unless a sector's worth of data is in the buffer. The DSKCEL will not start a read unless the buffer has room for a sector's worth of data. The micro tracks buffer use and starts/stops the VMEDMA and DSKCEL as necessary. # 9.1.6 Disk Front End The DSKCEL is a downloadable disk sequencer. The micro loads the disk read, write, and format programs into the DSKCEL on power up, and modifies the programs when new format parameters are loaded or an alternate command (such as Read Header, Data, ECC) is received. The DSKCEL issues some SMD control signals, such as Read Gate and Write Gate, while the micro issues others, such as Cylinder Tag and Unit Tag. Generally, if timing is critical, the DSKCEL issues the signal since it runs off the disk bit clock. The DSKCEL has serial registers for FIFO data, the Header, and ECC. It performs sync bit search, header check, and ECC check and provides status bits to the micro. The DSKCEL interrupts the micro when done. DSKCEL Done may mean Header Found, End of Sector, or Bad Spot Found. Generally, the DSKCEL runs on a sector-by-sector basis, with the micro controlling how many sectors are transferred. The micro allows the DSKCEL to run. The program starts running when a sector or index pulse comes in from the disk. The micro informs the DSKCEL when the next sector involves an odd address DMA and when the current sector is the last. The DSKCEL also performs other functions, such as ECC correction, runt sector detection, and mid-transfer head tags. #### 9.1.7 SMD-E Interface This block contains interface logic for SMD Connectors. The micro controls the tags for Unit Select, Cylinder, Head, Control (read/write) and the Unit Select lines. Various disk status lines, and the sector and index pulses are received and used by either the micro or the disk sequencer. The micro controls whether the pulses to the DSKCEL include sector pulses or just the index pulse. # 9.1.7 <u>SMD-E Interface</u> (continued) The SMD interface chips require -5 volts from an on-board regulator in order to operate properly. A drive configured as any Unit Number, from 0 thru 7, can be used with either port. #### NOTE When no disk unit is selected, servo clock is a free-running 10-MHz clock. This is typically used during ECC correction. The clock synchronizer ensures that no clock slivers get into the DSKCEL when the Read Gate is switched. The disk sequencer clock is servo clock (interface clock) when writing the disk and read clock when reading the disk. The write clock is simply delayed servo clock. # 9.1.8 Power-up During power-up, the Open Cable Detect signal is asserted on the drive interface. This signal disables any erroneous writes. The bus signal SYSRESET sets the error LED (L2) and asserts SYSFAIL on the bus. The micro runs its diagnostics and then clears L2 and SYSFAIL. #### 9.1.9 Power-down During power-down, the 751 responds to ACFAIL by turning off the DSKCEL (it allows any writes to finish the current sector) and then asserting Open Cable Detect to the drive. This sequence generates a fatal error which cannot be reset until ACFAIL is deasserted. #### 9.1.10 System Reset When the 75l detects SYSRESET, it resets its internal micro and the three custom integrated circuits. This sequence immediately terminates any writes to the disk (possibly leaving it with an unreadable sector). The 75l then executes the power-up diagnostics. # 9.2 THE MICROCODE #### 9.2.1 The Kernel Figure 9-1 illustrates the kernel. It is entered after the Power-up test and initialization. It has four major functions, of which three will be discussed. The fourth function is scheduling DMA, and would needlessly complicate this discussion. # 9.2.2 <u>Is AIO Set?</u> Each time around the kernel, the 75l tests to see if the host set AIO. If AIO is set, the 75l must process the AIO. This processing entails reading the IOPB and placing it in its internal command queue. If the queue is full, the 75l saves the address of the IOPB so that it can later read it into the queue. The queue can accommodate 14 IOPBs, plus a priority IOPB; the 75l saves the next 32 IOPB (chain) addresses. This function is really tested several times in the kernel, but for simplicity Figure 9-1 shows it as a single function. FIGURE 9-1. THE MICROCODE KERNEL ## 9.2.3 <u>Is Start Oueue Empty?</u> The IOPBs in the internal queue are divided into three groups: seek not started queue, seek started, and seek complete or not required. When first entering the queue, the IOPBs belong to the first group, seek not started queue. This step examines the IOPBs to determine if a seek is required. If a seek is required, and the drive is not busy, the 751 issues the Seek command to the drive and assigns the IOPB to the second queue, seek started. If a seek is not required, the 751 marks the IOPB as having its seek complete and assigns it to the third group, seek done or not required. ## 9.2.4 Is Any IOPB Ready for Completion? The 751 checks for an IOPB in the third group, seek complete or not required. It does this by first checking if an IOPB has a seek done set; if not, it selects each drive in the second group, seek started, to determine if a seek is complete. The 751 executes the first seek done IOPB. When the 751 completes the function, it updates the IOPB and issues an interrupt. # 9.2.5 <u>Queuing IOPBs for Execution</u> The 751 command queue accommodates 14 IOPBs. The first AIOs have their respective IOPBs (IOPB chains) read directly into the queue until it is full. If COP is set, the 751 reorders the IOPBs inside the queue, so that it executes them in proper order. As the 751 completes an IOPB, it frees up a slot in the internal queue, and reads in a new IOPB. If COP is set, the 751 inserts the new IOPB at the proper point in the reordered IOPBs. ### 9.3 PERFORMING A FUNCTION The 751 performs each function differently. If a function requires a seek, the 751 issues the seek and waits for it to complete before performing the function. The following subsections group similar functions together and explains their differences. #### 9.3.1 NOP The function of a NOP is to do no operation, so the 751 goes on to complete the function. #### 9.3.2 Normal Reads and Writes Normal reads and writes are very similar commands regarding 751 processing. The 751 is optimized to perform these functions as fast as possible. The main difference between reads and writes is ## 9.3.2 Normal Reads and Writes (continued) which way the data moves and when. On writes, the data DMA begins and the 751 begins the disk transfer when one sector's worth of data is in the FIFO. On reads, the disk transfer begins immediately and the DMA begins as soon as the first word is available from the FIFO. When enabled, the disk sequencer starts to compare every header that arrives under the heads with the target sector. When a header compare is successful, the 751 also tests the header verify. If both tests are successful, the transfer occurs on that sector. To continue the transfer, the 751 loads the next target header so it can do a comparison on the next sector that arrives under the heads. The 751 does not wait for index before comparing headers. If more than one sector is specified, the 751 increments the disk address on successive sectors. First, the controller increments the sector number until it reaches the maximum sector address. When the 751 reaches the maximum sector address, it clears the sector address and increments the head address. When the 751 reaches the maximum head and sector addresses, it clears them and increments the cylinder address. When the 751 reaches the maximum sector, head, and clinder addresses, the next sector causes an Illegal Cylinder Address error. The 751 continues, and completes the IOPB as soon as it completes the DMA and disk transfers, or an uncorrectable error occurs. ### 9.3.3 <u>Seeks</u> Depending on the subfunction, the 751 may select the drive and read the first header that arrives under the heads. If it is a spare or bad header, the 751 reads the next header until it gets a good one. The 751 returns the data read in the header in the IOPB. #### 9.3.4 Drive Reset This command issues a Fault Clear and then a Recalibrate (Return To Zero) command to the drive. The 751 waits for the Recalibrate to complete before completing the IOPB. The wait for recalibrate done is a background task, and the contoller continues processing other IOPBs (not on the drive being recalibrated). #### 9.3.5 Write and Read Parameters Section 7 describes these functions in detail. #### 9.3.6 Extended Read and Write Commands This section is similar to Section 9.3.2; the following subsections detail their differences. #### 9.3.6.1 Track Headers Commands The disk sequencer waits for index before determining where to start the transfer. Track Headers commands always start at index. The number of sector headers returned equals the physical sector count (read with a Read Drive Parameters command). #### 9.3.6.2 Header, Header Verify, Data, and Data ECC The disk sequencer waits for index before determining where to start the transfer. Header, Header Verify, Data, and Data ECC commands use the sector address as an offset count from index to determine where to start. The 751 increments the sector address during a multisector transfer, but does not not clear it if it reaches maximum sector. Illegal Sector Address error is inhibited for this command. The 751 does not increment the head and cylinder address. ### 9.3.6.3 Defect Map Extended The disk sequencer waits for index, syncs up to the manufacturer's Defect Map and reads it into memory. The 751 only executes one track per IOPB. ## 9.3.6.4 Read Verify The disk sequencer executes a Read command, and the DMA sequencer performs as if it were doing a disk write. The 751 compares the serial data from the FIFO/SERDES with the data from the disk. A miscompare causes a verify failure. The 751 returns the failing disk address in the IOPB. #### 9.3.7 <u>Diagnostics</u> The 751 executes the power-up self test. #### 9.4 COMPLETING A FUNCTION The 751 completes the transfer when both the DMA and disk transfers are complete. The 751 updates the IOPB in host memory, interrupts, and clears BUSY if all IOPBs in its queue are complete. If an error occurs, the 751 completes the errored IOPB and continues processing the other IOPBs. If a fatal error occurs, the 751 finishes the IOPB(s) in process, sets the appropriate fatal error code, and sets FERR. The host must execute a Controller Reset before sending any IOPBs to the 751. # SECTION 10: MAINTENANCE AIDS ## 10.0 GENERAL This section provides useful information for installing and maintaining your Xylogics Model 751 Disk Controller. # 10.1 VMEbus INTERFACE SIGNALS | | | | USED BY | | |----------|-------|-----|------------|------------------| | MNEMONIC | CONN. | PIN | <u>751</u> | DESCRIPTION | | A01 | PlA | 30 | Y | | | A02 | PlA | 29 | Y | | | A03 | PlA | 28 | Y | | | A04 | PlA | 27 | Y | | | A05 | PlA | 26 | Y | | | A06 | PlA | 25 | Y | | | A07 | PlA | 24 | Y | • | | 80A | PlC | 30 | Y | | | A09 | PlC | 29 | Y | | | AlO | PlC | 28 | Y | | | All | PlC | 27 | Y | | | Al2 | PlC | 26 | Y | | | A13 | PlC | 25 | Y | | | Al4 | PlC | 24 | Y | | | A15 | PlC | 23 | Y | Address Bus | | Al6 | PlC | 22 | Y | | | A17 | PlC | 21 | Y | | | Al8 | PlC | 20 | Y | | | Al9 | PlC | 19 | Y | | | A20 | PlC | 18 | Y | | | A21 | PlC | 17 | Y | | | A22 | PlC | 16 | Y | | | A23 | PlC | 15 | Y | | | A24 | P2B | 4 | Y | | | A25 | P2B | 5 | Y | | | A26 | P2B | 6 | Y | | | A27 | P2B | 7 | Y | | | A28 | P2B | 8 | Y | | | A29 | P2B | 9 | Y | | | A30 | P2B | 10 | Y | | | A31 | P2B | 11 | Y | | | AMO | PlB | 16 | Y | | | AM1 | PlB | 17 | Y | | | AM2 | PlB | 18 | Y | Address Modifier | | AM3 | PlB | 19 | Y | - | | AM4 | PlA | 23 | Y | | | AM5 | PlC | 14 | Y | • | 10.1 VMEbus INTERFACE SIGNALS (continued) | | | | USED BY | | |------------|------------|----------|-------------|----------------------------| | MNEMONIC | CONN. | PIN | 75 <u>1</u> | DESCRIPTION | | | | | | | | 200 | מות | | v | | | D00 | PlA<br>PlA | 1<br>2 | Y<br>Y | | | D01<br>D02 | PlA | 3 | Y | | | D02<br>D03 | PlA | 4 | Y | | | | | 5 | Y | | | D04 | PlA | | Y | | | D05 | PlA | 6 | | | | D06 | PlA | 7 | Y | | | D07 | PlA | 8 | Y | | | D08 | PlC | 1 | Y | | | D09 | PlC | 2<br>3 | Y<br>Y | | | D10<br>D11 | PlC<br>PlC | 3<br>4 | Y | | | D11<br>D12 | PIC | 5 | Y | | | D12<br>D13 | | 6 | Y | | | D13<br>D14 | PlC<br>PlC | 7 | Y | | | D14<br>D15 | PlC | 8 | Y | Data Bus | | D16 | P2B | 14 | Y | Data Bus | | D10<br>D17 | P2B | 15 | Ÿ | | | D17<br>D18 | P2B | 16 | Ÿ | | | D18 | P2B | 17 | Ÿ | | | D20 | P2B | 18 | Ÿ | | | D20<br>D21 | P2B | 19 | Y | | | D21<br>D22 | P2B | 20 | Ÿ | | | D23 | P2B | 20<br>21 | Ÿ | | | D24 | P2B | 23 | Ÿ | | | D25 | P2B | 24 | Ÿ | | | D26 | P2B | 25 | Ÿ | | | D27 | P2B | 26 | Ŷ | | | D28 | P2B | 27 | Ÿ | | | D29 | P2B | 28 | Ÿ | | | D30 | P2B | 29 | Ÿ | | | D31 | P2B | 30 | Ŷ | | | 231 | 120 | 30 | - | | | | | | | | | STROBES | | | | | | AS* | PlA | 18 | Y | Address Strobe | | DSO* | PlA | 13 | Ÿ | Data Strobe Zero | | DS1* | PlA | 12 | Y | Data Strobe One | | DTACK* | PlA | 16 | Ÿ | Data Transfer Acknowledge | | ~ LENGT | LTV | 10 | <b>.</b> | Tara Transfer Montowiterde | | רד הרשים | | | | | | CLOCKS | | | | | | SERCLK | PlB | 21 | N | Serial Clock | | SYSCLK | PlA | 10 | N | System Clock | | | | | | <del>-</del> | 10.1 VMEbus INTERFACE SIGNALS (continued) | MNEMONIC | CONN. | PIN | USED BY<br>751 | DESCRIPTION | |--------------------------------------------------|----------------------------------------|----------------------------------------|----------------------------|--------------------------------------------------------------------------------| | DMA | | | | | | BBSY*<br>BCLR*<br>BERR* | PlB<br>PlB<br>PlC | 1<br>2<br>11 | Y<br>N<br>Y | Bus Busy<br>Bus Clear<br>Bus Error | | BG0 IN*<br>BG1 IN*<br>BG2 IN*<br>BG3 IN* | PlB<br>PlB<br>PlB<br>PlB | 4<br>6<br>8<br>10 | У<br>У<br>У<br>У | Bus Grant In | | BGOOUT* BGLOUT* BG2OUT* BG3OUT* | PlB<br>PlB<br>PlB<br>PlB | 5<br>7<br>9<br>11 | Y<br>Y<br>Y<br>Y | Bus Grant Out | | BR0*<br>BR1*<br>BR2*<br>BR3* | PlB<br>PlB<br>PlB<br>PlB | 12<br>13<br>14<br>15 | У<br>У<br>У<br>У | Bus Request | | INTERRUPTS | | | | | | IRQ1 * IRQ2 * IRQ3 * IRQ4 * IRQ5 * IRQ6 * IRQ7 * | PlB<br>PlB<br>PlB<br>PlB<br>PlB<br>PlB | 30<br>29<br>28<br>27<br>26<br>25<br>24 | Y<br>Y<br>Y<br>Y<br>Y<br>Y | Interrupt Request Levels | | IACK*<br>IACKIN*<br>IACKOUT* | PlA<br>PlA<br>PlA | 20<br>21<br>22 | Y<br>Y<br>Y | Interrupt Acknowledge<br>Interrupt Acknowledge In<br>Interrupt Acknowledge Out | | MISCELLANEOU | IS | | | | | ACFAIL* LWORD* RESERVED SERDAT* SYSRESET* WRITE* | P1B<br>P1C<br>P2B<br>P1B<br>P1C<br>P1A | 3<br>13<br>3<br>22<br>12<br>14 | Y<br>Y<br>N<br>N<br>Y<br>Y | AC Failure<br>Longword<br>Reserved<br>Serial Data<br>System Reset<br>Write | # 10.1 VMEbus INTERFACE SIGNALS (continued) | MNEMONIC | CONN. | PIN | SED BY<br>751 | DESCRIPTION | |-----------|---------------|---------------|---------------|----------------| | POWER | | | | | | +5V | PlA, PlB, PlC | 32 | Y | +5 VDC | | +5V | P2B | 1,13,32 | Y | +5 VDC | | +5V STDBY | PlB | 31 | N | +5 VDC Standby | | +12V | PlC | 31 | N | +12 VDC | | -12V | PlA | 31 | N | -12 VDC | | GND | PlA | 9,11,15,17,19 | Y | Signal Ground | | GND | P1B | 20,23 | Y | Signal Ground | | GND | P2B | 2,12,22,31 | Y | Signal Ground | | GND | PlC | 9 | Y | Signal Ground | #### 10.2 EXTENDED STORAGE MODULE DRIVE INTERFACE Several different pin-numbering systems define the SMD-E interface. This section lists both CDC's method, and the industry standard (STND). (Physically, the cables are ribbon cables with crimp connectors on each end.) NOTE Xylogics follows the industry standard for pin-numbering. | NAME | CABLE | PIN+/-<br>CDC | PIN+/-<br>SIND | DESCRIPTION | |--------------------------------------------------------------------------|--------|----------------------------------|----------------------------------|-------------------------------------------------------------------------------| | UNIT SELECT | | | | | | Unit Select Tag | A | 52/22 | 44/43 | Initiates a Unit Select<br>sequence along with the Unit<br>Select bits. | | Unit Sel. Bit 0<br>Unit Sel. Bit 1<br>Unit Sel. Bit 2<br>Unit Sel. Bit 3 | A<br>A | 53/23<br>54/24<br>56/26<br>57/27 | 46/45<br>48/47<br>52/51<br>54/53 | • | | Open Cable Det. | A | 44/14 | 28/27 | The 751 uses this signal to deselect the drive in the event of power failure. | | Unit Selected | В | 09/22 | 17/18 | A "B" cable signal; the drive has been selected. | | Unit Ready | A | 49/19 | 38/37 | The selected drive is up to speed; the heads are loaded, and not faulted. | 10.2 EXTENDED STORAGE MODULE DRIVE INTERFACE (continued) | NAME | CABLE | PIN+/-<br>CDC | PIN+/-<br>SIND | DESCRIPTION | |-----------------|-------|---------------|----------------|---------------------------------------------------------------------------------| | CONTROL | | | | | | Tag 1 | A | 31/01 | 02/01 | Cylinder Select Tag; the drive seeks to the cylinder selected by Bus bits 0-10. | | Tag 2 | A | 32/02 | 04/03 | Head Select Tag; the drive selects the head specified by Bus bits 0-9. | | Tag 3 | A | 33/03 | 06/05 | Control Tag; the drive executes the function defined by Bus bits 0-9. | | Pwr. Seq. Hold | A | 59 | 58 | Used for power-sequencing with Remote/Local; always enabled on the 751. | | Sequence Pick I | n A | 29 | 57 | Used for power-sequencing with Remote/Local; always enabled on the 751. | | Bus Bit 0 | A | 34/04 | 08/07 | Write Gate Enable or bit 0 of head or cylinder. | | Bus Bit 1 | A | 35/05 | 10/09 | Read Gate Enable or bit 1 of head or cylinder. | | Bus Bit 2 | A | 36/06 | 12/11 | Servo Offset (+) or bit 2 of head or cylinder. | | Bus Bit 3 | A | 37/07 | 14/13 | Servo Offset (-) or bit 3 of head or cylinder. | | Bus Bit 4 | A | 38/08 | 16/15 | Fault Clear or bit 4 of head or cylinder. | | Bus Bit 5 | A | 39/09 | 18/17 | Address Mark Enable or bit 5 of head or cylinder. | | Bus Bit 6 | A | 40/10 | 20/19 | Recalibrate or bit 6 of head or cylinder. | | Bus Bit 7 | A | 41/11 | 22/21 | Data Strobe Early or bit 7 of head or cylinder. | 10.2 EXTENDED STORAGE MODULE DRIVE INTERFACE (continued) | NAME | CABLE | PIN+/-<br>CDC | PIN+/-<br><u>STND</u> | DESCRIPTION | |-----------------|-------|---------------|-----------------------|---------------------------------------------------| | Bus Bit 8 | A | 42/12 | 24/23 | Data Strobe Late or bit 8 of head or cylinder. | | Bus Bit 9 | A | 43/13 | 26/25 | Release or bit 9 of head or cylinder. | | Bus Bit 10 | A | 60/30 | 60/59 | Bit 10 of cylinder address. | | CLOCKS and DATA | | | | | | Index | A | 48/18 | 36/35 | Pulses for every index mark. | | Read Clock | В | 17/05 | 08/09 | Synchronizes read data. | | Read Data | В | 16/03 | 06/05 | Reads data from drive. | | Sector | A | 55/25 | 50/49 | Pulses for every sector (except during index). | | Servo Clock | В | 14/02 | 02/03 | Synchronizes write data. | | Write Clock | В | 19/06 | 12/11 | Clock sent to drive with synchronized write data. | | Write Data | В | 20/08 | 14/15 | Write data sent to drive. | | STATUS | | | | | | Address Mark | A | 50/20 | 39/40 | The drive encountered a sector mark. | | Busy | A | 51/21 | 42/41 | One port is busy in a dual port drive. | | Fault | A | 45/15 | 30/29 | The drive is faulted. | | On-cylinder | A | 47/17 | 34/33 | The drive is on-cylinder. | | Seek End | В | 23/10 | 20/19 | The drive completed a seek, or loaded the heads. | | Seek Error | A | 46/16 | 32/31 | The drive has a seek error. | | Write-protect | A | 58/28 | 56/55 | The drive is write-protected. | | Abbreviations | |---------------------------------| | "A" Cable | | ACFAIL 79,126 | | Add IOPB | | Addressing Capability | | Address Modifier | | Address Modifier Register | | Address Register | | AFE | | AIO | | AIOP | | AIOR | | Alternate Field 5 | | Alternate Field Enable | | Alternate Sector Size | | AM | | ASR 36,105 | | AUD 33,44,48,49,55-57,117 | | Auto Seek Retry Recovered | | Auto-update | | Automatic Seek Retry | | Base Address | | "B" Cable | | BERR* | | BHT | | Black Hole Transfer 5,29,73,116 | | Bus Address | | Bus Error Timer | | Bus Request | | BUSY | | Bytes Per Sector | | C450 | | 450-Compatible Mode | | Chain 100 | | Chain Enable | | Checksum | | CHEN | | Clear RBS | | Clear RIO | | COMM | | Command | | Command Codes | | Command Optimization 35,111 | | Command Queue | | Completion Code | | Control and Status Register | | Control Register 111 | | P <b>A</b> GE | |---------------------------------------------------------| | Controller Parameters 33-37 | | Controller Reset | | Controller Reset Active | | Controller Type | | Count | | Count Bytes | | Count Sectors Executed | | Count Zero | | CRBS | | CRST | | CSE | | CSR 7,20,108,111,123 | | Cylinder 30,95,98,107,110,112,129,130 | | Cylinder Address | | Cylinder Sparing | | Data Address Modifier | | Data Buffering | | Data Field 59,60 | | Data Sync | | Defect Map | | DFLT | | Disk Drive Grounds | | Disk Fault | | Disk Sequencer Error | | Disk Status | | DMA | | DMA Priority | | DONE | | DPB | | DRDY | | Drive Faulted | | Drive Not On-cylinder | | Drive Parameters | | Drive Ready | | Drive Reset | | Drive Unit Number | | Dual Port 5,20 Dual Port Busy 26,75 | | Dual Ported | | EC32 | | ECC 4,32,39,60,61,73-78,89,93,103-106,120,125,126 | | ECC Error Ignored | | ECCM | | EDT | PAGE Elevator Seeks ...... 4,46,47,111 Fatal Error ...... 7,22,70,109,117,126,130 Fatal VMEDMA Error ...... 75 Field 1 ...... 42,102,103 Field 7 ...... 43,104 Firmware Error ..... 79 Fixed Media ...... 28 Format ...... 4,14,16,30,39,40,42,57,60,72,73,87,101,104,125 Gap Sizes ...... 101,102 Hard Data ECC Error ..... 74 Head ...... 30,95,104,107,118,125,130 Head Address ...... 75 Header ...... 36,42,49,89,93,97,103,110,120,123,129 Header ECC error ...... 75 Header Error/Cylinder ...... 75 ICS ...... 33,79 IEC ...... 35,36,79,121 | FASI | |--------------------------------------------------------| | | | Illegal Cylinder Address 72 | | Illegal Field Length | | Illegal Head Address | | Illegal Maintenance Mode Test Number | | | | Illegal Scatter/Gather Length | | Illegal Sector Address | | Illegal Sector Size | | Implied Seek | | Index | | Interleave | | Interrupt 29,30,39,42,44,45,86,111,121,122,123,128,130 | | Interrupt At End Of Chain | | NTF | | INIL | | IOPB | | IOPB Address | | IOPB Address Alignment Error | | IOPB Address Modifier 20,21,22,81,117 | | IOPB Checksum | | IOPB Checksum Miscompare | | IOPB DMA Fatal | | IRAM 76,78,82,124 | | IRAM Checksum | | IRAM Checksum Failure | | IRAM Self Teat Failure | | LED | | Link List Address | | Link List Address Modifier | | Link List Length | | Linked List 73,113,114,115,116 | | <u>LIL</u> | | Longword Mode | | Maintenance Mode | | Maintenance Test 3 Failure | | Maintenance Test 4 Failure | | Maintenance Test 5 Failure | | Maintenance Test 6 Failure | | Maintenance Test 7 Failure | | Maintenance Test 8 Failure | | Max Cylinder | | Max Head | | Max Sector | | Max Sector/Last Head | | Media Defect | | Media Format | | MM | | MMA | | MEXI TOLD | | PAGE | |------------------------------------------------| | | | Next IOPB Address | | Next IOPB Address Modifier | | Next IOPB Address Alignment Error | | No Operation | | Non-privileged Register Mode | | NOP | | Not Enough Sectors Per Track | | NPRM | | On-cylinder | | ONCL 26,36 | | Operation Timeout | | Optimize | | Overlap Seeks | | OVS | | Parity | | Physical Sector Count | | Power | | Power-up | | PRIO | | Priority IOPB | | Priority Select | | PROM Part Number | | PSEL 29 | | Queue | | RBC | | RBS | | RDP | | Read | | Read Controller Parameters | | Read Data | | Read Defect Map | | Read Defect Map Extended | | Read Drive Parameters | | Read Drive Status Extended | | Read Extended | | Read Format Parameters | | Read Header, Header Verify, Data, and Data ECC | | Read Only Access | | Read Track Headers | | Read Verify | | Read/Write Access | | Recalibrate | | Register Busy Semaphore | | Register Maintenance Mode | | Register Protocol | | Release Dual Port | | Release On Request | | Remapping | | rampharia #122/T00 | | Removable Media | Ω | |------------------------------------------------|------------| | Remove IOPB | | | Report Current Address 4 | | | Retry 77,10 | | | Retry Before Correction 3 | | | Retry Successful | | | Revision 3 | | | RIO 7,21,22,81,82,86,108,10 | | | RMM | | | ROR | | | RSTA | | | Scatter/Gather | | | Scatter/Gather Address Alignment Error | ٠ <u>٠</u> | | Scatter Gather With Auto ECC Error | 7 | | Sector | 0 | | Sector Count | | | Sector Header | | | Sector Size | | | Sector Slip | 8 | | Sectors Per Track 14,40,56,8 | 6 | | Seek | | | Seek and Report Current Address 4 | | | Seek Error | | | Self Test 16,20,69,109,13 | | | Set Drive Parameters | | | Set Format Fields 5 and 5A Only | | | SGM | | | Slipped Revolution | | | Soft ECC Error | | | Soft Retry Recovered | | | Spare Sectors | | | SR | 6 | | Standard IOPB 24 | | | Start Seek and Report Completion Immediately 5 | | | Status Register 7,20,44,78,11 | 1 | | Subfunction | 7 | | Subrevision | • | | Successful Completion | | | Sync Byte | | | SYSFAIL | | | SYSRESET | | | TDT | | | Terminator 1 | | | Test Number Register | - | | | | | Throttle | | | 6.34- | 36.116 | .121 | |-----------------------------------------------|-------------|-------------|-----------|-----------|------| | Throttle Dead Time | | | | | | | Timeout | | | | | | | TMOD | | | | • | • | | Track Headers | | | | | | | Track Remapping | | | | | | | Transfer Mode | | | | | | | Trespass | | | | | | | Unimplemented Command | | | | | | | Unit Number | | | 17,29 | ,44,74 | ,126 | | Verify Data | • • • • • • | | •••• | • • • • • | . 65 | | VMEbus Error | • • • • • • | | | | . 75 | | VMEDMA Timeout | • • • • • • | | • • • • • | | . 74 | | Word Mode | • • • • • • | 33 | ,73,1 | 16,120 | ,124 | | Write | 40,72,8 | 39,103, | 113,11 | 19,125 | ,128 | | Write Controller Parameters | • • • • • | 52,84, | 105,13 | 10-112 | ,117 | | Write Data | | • • • • • | •••• | 4 | 6,92 | | Write Defect Map | | | •••• | · | . 62 | | Write Defect Map Extended | | • • • • • | • • • • • | | . 63 | | Write Drive Parameters | | 53 | ,86,10 | 1,112 | ,118 | | Write Extended | | | • • • • • | | . 89 | | Write Format Parameters | | • • • • • | • • • • • | 54,72 | ,112 | | Write Header, Header Verify, Data, and Data 1 | ECC | • • • • • | • • • • • | 61 | ,120 | | Write Track Format | | • • • • • • | • • • • • | | . 60 | | Write Track Headers | • • • • • • | • • • • • | • • • • • | 59,99 | ,105 | | Write-protect | • • • • • • | • • • • • | • • • • • | • • • • • | . 26 | | Write-protect Error | | | | | | | WRPT | • • • • • • | • • • • • | • • • • • | | . 26 | | Zero Latency Read | | 5.3 | 6.74.7 | 7,110 | .116 | | | | | 201<br>10 | | |-------|---|--|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | • | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | • | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | * | | | | | | | | | | | A . * | | | | | | | | | | | | | | | | and the second s |