# Model 721 VMEbus to SCSI Controller User's Manual



166-721-001 Revision A January 22, 1990

Copyright 1990 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.

# 721 Revision Level History

| Revision         | Description      |
|------------------|------------------|
| Rev. A (1/22/90) | Initial release. |

| List of  | Figures and Tables                                                                           | v  |
|----------|----------------------------------------------------------------------------------------------|----|
| Specific | ations                                                                                       | 1  |
| 1.1.     | General                                                                                      | 1  |
| 1.2.     | Using This Manual                                                                            | 1  |
| 1.3.     | Abbreviations                                                                                | 1  |
| 1.4.     | Design Reliability                                                                           | 3  |
| 1.5.     | Programmable Features                                                                        | 3  |
| 1.6.     | Physical                                                                                     | 3  |
| 1.7.     | Environmental                                                                                | 4  |
| 1.8.     | Electrical                                                                                   | 4  |
| 1.9.     | System-related Specifications                                                                | 4  |
| 1.10.    | SCSI-related Specifications                                                                  | 5  |
| 1.11.    | Floppy Disk Drive-related Specifications (not implemented in this version of the controller) | 6  |
| 1.12.    | VMEbus-related Specifications                                                                | 6  |
| 1.13.    | Software-related Specifications                                                              | 7  |
| 1.13.1.  | Software Interface                                                                           | 7  |
| 1.13.2.  | Software Drivers                                                                             | 8  |
| Installi | ng and Testing the 721                                                                       | 9  |
| 2.1.     | General                                                                                      | 9  |
| 2.2.     | Unpacking and Inspection                                                                     | 9  |
| 2.2.1.   | Inspect the Shipping Carton and the Controller                                               | 9  |
| 2.2.2.   | Contents                                                                                     | 9  |
| 2.2.3.   | Handling Precautions                                                                         | 9  |
| 2.3.     | Configuring the 721                                                                          | 10 |
| 2.3.1.   | Base Address Selection                                                                       | 11 |
| 2.3.2.   | Bus Request and Bus Grant Lines                                                              | 12 |
| 2.3.3.   | P2 Connector                                                                                 | 13 |
| 2.3.4.   | P2 Terminator Power                                                                          | 13 |
| 2.3.5.   | Controller Terminator Power                                                                  | 14 |
| 2.3.6.   | SCSI Timing                                                                                  | 14 |
| 2.3.7.   | Floppy Disk Jumper J3                                                                        | 14 |
| 2.3.8.   | Floppy Disk Jumper J17                                                                       | 15 |
| 2.4.     | EPROM and PAL Part Numbers                                                                   | 15 |
| 2.5.     | Light Emitting Diodes                                                                        | 15 |
| 2.6.     | Board Labels/Revision Control                                                                | 16 |
| 2.7.     | Preparing the Computer System for Installation                                               | 16 |
| 2.7.1.   | Backplane Jumpers                                                                            | 16 |
| 2.7.2.   | Card Cage Slot                                                                               | 16 |

| 2.7.3.  | Power Considerations                                | 17 |
|---------|-----------------------------------------------------|----|
| 2.8.    | Installing the 721                                  | 17 |
| 2.9.    | Cabling the Subsystem                               | 17 |
| 2.9.1.  | Mechanical Restraint                                | 17 |
| 2.9.2.  | SCSI Device Grounds                                 | 17 |
| 2.10.   | Power-up Self Test                                  | 17 |
| 2.11.   | Diagnostics                                         | 18 |
| 2.12.   | Cabling Multiple SCSI Devices                       | 18 |
| 2.12.1. | Terminators                                         | 19 |
| 2.12.2. | Target Select                                       | 20 |
| The 72  | 1 Registers                                         | 21 |
| 3.1.    | General                                             | 21 |
| 3.2.    | IOPB Address Registers                              | 22 |
| 3.3.    | IOPB Address Modifier/Priority IOPB Register        | 22 |
| 3.4.    | Control and Status Register                         | 22 |
| 3.4.1.  | Control Register (Write)                            | 23 |
| 3.4.2.  | Status Register (Read)                              | 24 |
| 3.5.    | Fatal Error Register                                | 26 |
| IOPB I  | Description                                         | 27 |
| 4.1.    | General                                             | 27 |
| 4.2.    | Standard IOPB                                       | 27 |
| 4.2.1.  | IOPB Byte 0 (Channel Byte)                          | 28 |
| 4.2.2.  | IOPB Byte 1 (Completion Code)                       | 28 |
| 4.2.3.  | IOPB Byte 2 (SCSI Status)                           | 29 |
| 4.2.4.  | IOPB Byte 3 (Controller Command)                    | 30 |
| 4.2.5.  | IOPB Byte 5 (Target Select)                         | 30 |
| 4.2.6.  | IOPB Byte 6 (Interrupt Level)                       | 31 |
| 4.2.7.  | IOPB Byte 7 (Interrupt Vector)                      | 31 |
| 4.2.8.  | IOPB Bytes 9 through B (DMA Count)                  | 32 |
| 4.2.9.  | IOPB Byte E (Data or Link Address Modifier)         | 32 |
| 4.2.10. | IOPB Byte F (Next IOPB Address Modifier) .          | 32 |
| 4.2.11. | IOPB Bytes 10 through 13 (DMA Data or Link Address) | 33 |
| 4.2.12. | IOPB Bytes 14 through 17                            |    |
|         | (Next IOPB Address)                                 | 33 |
| 4.2.13. | IOPB Bytes 18 through 23 (SCSI CDB)                 | 33 |
| 4.3.    | SCSI Command Descriptor Block                       | 33 |
| 4.3.1.  | Typical Six-byte Command Descriptor Block           | 34 |
| 132     | Typical Ten-byte Command Descriptor Block           | 34 |

| 4.3.3.  | Typical Twelve-byte Command Descriptor Block  | 35 |
|---------|-----------------------------------------------|----|
| 4.3.4.  | CDB Byte 0 (Operation Code)                   | 35 |
| 4.3.5.  | CDB Byte 1 (Logical Unit Number)              | 36 |
| 4.3.6.  | CDB Bytes 2 through 10 (Transfer Information) | 36 |
| 4.3.7.  | CDB Bytes 5, 9, and 13 (Control)              | 36 |
| Comma   | ands                                          | 37 |
| 5.1.    | General                                       | 37 |
| 5.2.    | SCSI Command Codes                            | 37 |
| 5.2.1.  | SCSI Group 0 Command Codes                    | 38 |
| 5.2.2.  | SCSI Group 1 Command Codes                    | 39 |
| 5.3.    | Command Structure                             | 40 |
| 5.4.    | No Operation                                  | 41 |
| 5.5.    | Read Controller Parameters                    | 42 |
| 5.5.1.  | Read Controller Parameters CDB                | 43 |
| 5.5.2.  | Parameter List                                | 43 |
| 5.6.    | Write Controller Parameters                   | 48 |
| 5.6.1.  | Write Controller Parameters CDB               | 49 |
| 5.6.2.  | Parameter List                                | 49 |
| 5.7.    | SCSI Bus Reset                                | 50 |
| Error I | Processing                                    | 51 |
| 6.1.    | General                                       | 51 |
| 6.2.    | SCSI Request Sense Data                       | 51 |
| 6.2.1.  | Sense Key Descriptions                        | 53 |
| 6.3.    | The Completion Code                           | 55 |
| 6.3.1.  | Completion Code Descriptions                  | 56 |
| 6.4.    | Fatal Error Codes                             | 59 |
| Progra  | mming Tutorial                                | 61 |
| 7.1.    | General                                       | 61 |
| 7.2.    | Programming the Controller                    | 61 |
| 7.3.    | Programming the Controller and the Driver     | 62 |
| 7.4.    | Executing a Read or Write Operation           | 63 |
| Special | Functions                                     | 65 |
| 8.1.    | General                                       | 65 |
| 8.2.    | Maintenance Mode                              | 65 |
| 8.2.1.  | Register Use in Maintenance Mode              | 65 |
| 8.2.2.  | Maintenance Mode Protocol                     | 66 |
| 8.3.    | Scatter/Gather                                | 66 |

| 8.3.1.  | Scatter/Gather Link List             | 67 |
|---------|--------------------------------------|----|
| 8.3.2.  | Setting Up a Scatter/Gather Transfer | 68 |
| 8.3.3.  | 721 Operation                        | 68 |
| 8.4.    | IOPB DMA Throttle/Throttle Dead Time | 69 |
| 8.5.    | Black Hole Transfers                 | 69 |
| 8.6.    | Block Mode Transfers                 | 70 |
| Interfa | ce Signals                           | 71 |
| 9.1.    | General                              | 71 |
| 9.2.    | VMEbus Interface Signals             | 71 |
| 9.3.    | SCSI Bus Interface Signals           | 75 |
| 9.3.1.  | Single-ended Pin Assignments         | 76 |
| Index   |                                      | 77 |
| Monuc   | I Evaluation Form                    | 81 |

# List of Figures and Tables

| Figure 2–1. | Approximate Jumper Locations              | 10 |
|-------------|-------------------------------------------|----|
| Figure 2-2. | Jumper Block JA                           | 11 |
| Figure 2-3. | Jumpering the Base Address                | 11 |
| Figure 2-4. | Jumpers JB, JC, and JD                    | 12 |
| Figure 2-5. | Jumper Blocks J5 and J6                   | 13 |
| Figure 2-6. | Jumper Blocks J7, J8, and J9              | 13 |
| Figure 2–7. | Jumper Block J15                          | 13 |
| Figure 2–8. | Jumper Block J16                          | 14 |
| Figure 2–9. | Jumper Block J18                          | 14 |
| •           | Jumper Block J3                           | 14 |
| •           | Jumper Block J17                          | 15 |
| •           | Sample Part Number                        | 16 |
| •           | Single Initiator, Multiple Target         | 18 |
| _           | Multiple Initiators, Multiple Targets     | 19 |
| Figure 3–1. | Register Map                              | 21 |
| Figure 6–1. | Non-extended Sense Data Format            | 51 |
| Figure 6–2. | Extended Sense Data Format                | 52 |
| Figure 7–1. | Initial Controller Values                 | 61 |
| Figure 7–2. | Programming the Controller and the Driver | 62 |
| Figure 7–3. | Read/Write                                | 63 |
| Figure 8–1. | Scatter/Gather Transfers                  | 68 |
| Table 2-1.  | PROM/PAL Part Numbers and Locations       | 15 |
| Table 3–1.  | Register Offsets                          | 21 |
| Table 3-2.  | Fatal Error Codes                         | 26 |
| Table 4–1.  | SCSI Status Codes                         | 29 |
| Table 4–2.  | Group Codes                               | 36 |
| Table 5-1.  | SCSI Group 0 Command Codes                | 38 |
| Table 5-2.  | SCSI Group 1 Command Codes                | 39 |
| Table 5-3.  | Read Controller Parameters List           | 44 |
| Table 5-4.  | AIO Response Times                        | 45 |
| Table 5-5.  | Throttle Values                           | 46 |
| Table 5-6.  | Write Controller Parameters List          | 49 |
| Table 6-1.  | Summary of Completion Codes               | 55 |
| Table 8-1.  | Register Use in Maintenance Mode          | 65 |
| Table 8-2.  | Scatter/Gather Link List                  | 67 |
| Table 8-3.  | Link List Field Values                    | 67 |
| Table 8-4.  | Throttle Dead Time Values                 | 69 |

# **Specifications**

1

# **Specifications**

#### 1.1. General

The Xylogics Model 721 VME to SCSI host adapter controls up to 56 SCSI target devices in any combination. Host software can set the configuration of SCSI targets via the 721 software interface. The 721 provides a single high-performance SCSI port that supports both synchronous and asynchronous transfers; it also offers an optional floppy disk drive port. Data transfers occur between the VMEbus™ and SCSI or between the VMEbus and floppy.

## 1.2. Using This Manual

This manual provides two software reference cards that display the IOPB structure and codes (see inserts). Section 1 describes the 721 specifications, Section 2 provides installation information, Section 3 describes the 721 registers, Section 4 describes the IOPBs, and Section 5 describes the commands. Section 6 describes error processing, Section 7 is a programming tutorial, Section 8 explains the 721's special functions, and Section 9 contains VME and SCSI interface information.

A detailed theory of operation is available on a per customer basis.

#### 1.3. Abbreviations

| AIO  | Add IOPB                 |
|------|--------------------------|
| AIOP | AIO Pending              |
| AIOR | AIO Response Time        |
| AM   | Address Modifier         |
| BDID | Bus Device ID            |
| BHT  | Black Hole Transfer      |
| CC   | Command Code             |
| CCID | Change Controller ID     |
| CDB  | Command Descriptor Block |

VMEbus is a trademark of the VMEbus International Trade Association.

# 1.3. Abbreviations (continued)

CHEN Chain Enable

CRIO Clear Remove IOPB

CRBS Clear Register Busy Semaphore

CRST Controller Reset
DRDY Drive Ready
ERRS Error Summary
FDMAC DMA Controller Chip

FERR Fatal Error

FIFO First In/First Out Buffer

H Notation for hexadecimal values

INTRAM 8031 Internal Random Access Memory

IOPB Input/Output Parameter Block IRAM IOPB Random Access Memory

LED Light Emitting Diode
LSB Least Significant Byte
LSI Large Scale Integration
LUN Logical Unit Number
MMA Maintenance Mode Active

MM Maintenance Mode
MSB Most Significant Byte

NPRM Non-privileged Request Mode

PRIO Priority IOPB Request
RBS Register Busy Semaphore

REGCEL Register Read, Write, and Interrupt

RIO Remove IOPB

ROM Read Only Memory
ROR Release on Request
RSTA Controller Reset Active

RT Register Test

SCSI Small Computer System Interface

SGM Scatter/Gather Mode SPC SCSI Protocol Chip

SWBY Swap Bytes SWWD Swap Words

TDT Throttle Dead Time

TGT Target Select
TMOD Transfer Mode

# 1.4. Design Reliability

The following Xylogics features minimize the likelihood of product failure:

- Design for worst case voltage and temperature
- Extensive evaluation testing
- Low parts count through extensive use of custom LSI
- Buffer parity for continuous error checking
- All components burned-in
- One card in backplane or expansion chassis
- Power-cycling under thermal stress during burn-in

# 1.5. Programmable Features

- Interrupt or polled operations
- DMA parameters
- Drive parameters

# 1.6. Physical

Packaging: The 721 resides on one printed circuit board.

Dimensions: The 721 is a 2 by 2 Eurocard that measures 9.2-inches high by 6.3-inches deep (233.35 mm by 160 mm). The 721 is identical in form-factor to the standard VME (dual high-dual wide) printed circuit board.

Shipping Weight: 3 pounds (1.4 kg).

Connectors: The 721 supports two SCSI bus connector schemes: the VME P2 connector with an external cable adapter and the front panel 50-pin header.

Front Panel: Xylogics offers the 721 with an optional front panel.

#### 1.7. Environmental

The 721 environmental requirements are 0 through 55°C, with a maximum relative humidity of 90% (non-condensing). Air flow across the board must maintain a maximum temperature differential of 7°C to prevent hot spots.

#### 1.8. Electrical

Power: The 721 uses 4.2 amperes at +5 volts DC (VDC).

Tolerance: Power voltage must be within  $\pm 5\%$  (4.75 to 5.25).

Grounding: Common earth ground must be established between the SCSI devices and the CPU chassis, backplane, and expansion cabinets.

# 1.9. System-related Specifications

Data Transfer Modes: The 721 transfers data in word or longword mode. It may use byte transfers to align subsequent transfers on word boundaries.

I/O Addressing Capability: The 721 decodes byte addresses for its on-board registers.

**Data Buffering:** The 721 has a 256 byte FIFO buffer. 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.

Command Buffer: The 721 reads commands into a separate buffer that holds up to 14 full commands (IOPBs); this minimizes host processor intervention and optimizes controller decode overhead. The 721 can also store an additional 35 IOPB addresses.

Status LEDs: The 721 has two status LEDs. The green LED indicates the controller is active; the yellow LED indicates the on-board diagnostics did not complete successfully or a fatal error occurred.

On-board Diagnostics: The 721 runs an extensive on-board diagnostic routine upon power-up or a bus reset. If an error occurs during this test, the 721 posts the failure in a special error register.

# 1.9. System-related Specifications (continued)

Multiprocessor Support: The 721 has a built-in register control semaphore. This flag allows multiple processors to share the 721 register set.

Scatter/Gather: The 721 supports Scatter Read and Gather Write commands. The controller gathers data from various memory locations and transfers it to the buffer for use in a Write command. It scatters the data out from the SCSI 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 containing a memory address and the number of 16-bit words to transfer to/from that location. The smallest granularity of scatter/gather is one 16-bit word.

**Priority IOPBs:** The 721 executes priority IOPBs over all IOPBs in its command buffer, except for the one in process.

Black Hole Transfers: The 721 may transfer all the DMA data into the same bus address without incrementing the address at each DMA.

Block Mode Transfers: The 721 supports block mode as per the VMEbus Specification. Block mode reduces data transfer times by allowing a DMA device to use one memory address strobe for up to 256 bytes.

# 1.10. SCSI-related Specifications

Small Computer System Interface: Conforms fully to the American National Standard for Information Systems (ANSI) X3.131-1986.

Data Transfer Rate: The 721 supports data transfer rates of up to 3 megabytes per second (MB/s) asynchronously and 5 MB/s synchronously.

Disconnect/Reconnect Facility: The 721 supports targets that can disconnect and reconnect at a later time.

Common Command Set: The 721 supports the SCSI Common Command Set (CCS).

SCSI Channel Controller: The 721 uses the Fujitsu MB87030 LSI SCSI Channel Controller.

SCSI Device Support: The 721 supports all SCSI devices, including magnetic and optical disks, and tape drives.

SCSI Bus Drivers: The 721 supports single-ended drivers and receivers.

# 1.11. Floppy Disk Drive-related Specifications

(not implemented in this version of the controller)

Data Transfer Rate: The 721 supports a floppy disk transfer rate of up to 500K-bits per second or less.

Sector Size: The 721 supports four different sector sizes: 128, 256, 512, and 1024 bytes.

Floppy Controller: The 721 uses the Western Digital 37C65 floppy controller with built-in drivers and receivers.

Number of Floppy Drives: The 721 supports up to two floppy drives in normal or PC/AT mode.

**Drive Types:** The 721 supports 3.5-, 5.25-, and 8-inch drives. The factory configures the 721 with connectors used on 5.25-inch form factor drives.

Drive Formats: The 721 supports IBM, PC/AT, and PC/XT formats.

# 1.12. VMEbus-related Specifications

VME Compliance Number: IEEE P1014/D1.0.

Transfer Mode: Direct Memory Access (DMA).

**DMA Throttle Control:** Each time the 721 becomes bus master, it executes DMA transfers to or from the buffer up to the maximum throttle parameter or the number of bytes/spaces available in the buffer.

**DMA Data Transfer Rate:** The 721 has a maximum transfer rate of 30 MB/s based on 30 nanoseconds (ns) memory response time assuming longword mode transfers.

**DMA Dead Time:** The 721 supports a programmable DMA dead time between throttle bursts. This prevents the 721 from taking over the bus and allows time for other DMA devices to access the bus.

Data Transfer Limit: From 0 to 2<sup>24</sup>-1 bytes.

Bus Compatibility: The 721 is compatible with the standard VMEbus (C.1).

# 1.12. VMEbus-related Specifications (continued)

Addressing Capability: Full 32-bit support. The 721 supports master A32, and slave A16, as per the VMEbus Specification. As a slave, the 721 responds to address modifiers 29H and 2DH. The 721 also supports block transfers.

Data Width: The 721 supports D16 and D32 as per the VMEbus Specification.

Release On Request: The 721 optionally releases the bus at the request of other VMEbus masters.

Release When Done: The 721 releases the bus after each throttle burst.

Bus Request Levels: The 721 supports four bus request levels.

Interrupt Priority: Software programmable interrupt level and vector.

# 1.13. Software-related Specifications

Controller IOPB Length: 36 bytes.

Controller Registers: Seven 8-bit I/O Registers; byte or word addressable. Only eight bits respond during word access.

**Software Control:** Software can program the 721 for use with various SCSI targets, controller parameters, and controller options

**Diagnostic Support:** Comprehensive set of stand-alone diagnostics written in the C language are available.

#### 1.13.1. Software Interface

The software interface includes seven byte-wide registers. The first four 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 (FER). The CSR includes two bits that are very important to IOPB processing: *Add IOPB* (AIO) and *Remove IOPB* (RIO).

#### 1.13.1. Software Interface (continued)

The IOPB is a block of command and status information that includes the bus address and the type of operation. The software driver sets up the IOPB in host memory, sends the IOPB address to the VME Address Registers, and sets AIO. After receiving the IOPB address, the 721 clears AIO, DMAs the IOPB to its IRAM, executes the IOPB and, upon completion or error, updates the IOPB status, DMAs it back and sets RIO. The VME Address Registers point to the completed IOPB. The software driver reads the address and clears RIO. Software may add IOPBs to the queue, providing AIO is clear, by writing the IOPB address to the address registers and setting AIO, regardless of the 721's Busy status.

#### 1.13.2. Software Drivers

Xylogics provides its customers with UNIX™ drivers for a variety of VME-based systems. Currently, Xylogics offers a full device driver and diagnostic support for Sun Microsystems'™ Sun-3 and Sun-4 series machines. Xylogics also provides UNIX System V drivers for a variety of machines. A format utility for these drivers enables formatting, defect management, and feature tuning.

UNIX is a trademark of AT&T Bell Laboratories. Sun Microsystems is a trademark of Sun Microsystems, Inc.

# **Installing and Testing the Controller**

2

# Installing and Testing the 721

#### 2.1. General

This section describes how to unpack, configure, install, and test your 721 controller.

# 2.2. Unpacking and Inspection

#### 2.2.1. Inspect the Shipping Carton and the Controller

Inspect the shipping carton. If it is damaged, do not unpack the unit. Notify Xylogics and the freight carrier immediately. If no damage is visible, carefully unpack the 721. Save the carton and other packing materials for future use.

#### 2.2.2. Contents

The 721 is a single printed circuit board. Optional items include a manual and/or software on a ¼-inch cartridge or ½-inch magnetic tape.

If any items are missing or damaged, please contact Xylogics at one of the following telephone numbers.

United States (Burlington, MA): (617) 272-8140; United Kingdom (Milton Keynes): 44-908-22212.

#### 2.2.3. Handling Precautions

Observing proper handling precautions minimizes the risk of damaging the 721 with electrostatic discharge. When transporting the 721, use an antistatic bag, antistatic bin, or the original shipping carton and packing material. Personnel handling the 721 should observe proper grounding methods including, but not limited to, wrist bands, heel straps, and antistatic mats.

# 2.3. Configuring the 721

You can configure the 721 with several jumper options. The following subsections describe these options.



Figure 2-1. Approximate Jumper Locations

#### 2.3.1. Base Address Selection

Jumper block JA controls the base address. Figure 2-3 shows how to set the jumpers for commonly used base addresses. Inserting a jumper makes the 721 respond to a zero on that address line; removing a jumper makes the 721 respond to a one. The 721 uses bits 1 through 3 to determine which register is being accessed. The 721 is an A16 slave, and responds to address modifier 2DH, and optionally to 29H. Factory setting: EEC0.



Figure 2-2. Jumper Block JA



Figure 2-3. Jumpering the Base Address

#### 2.3.2. Bus Request and Bus Grant Lines

The 721 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 721 drives one Bus Request line according to the jumper scheme you choose. The arbiter responds by driving the associated Bus Grant In line (i.e., BG0IN responds to BR0). If the 721 receives a Bus Grant on any of the Bus Grant In lines (BG0IN through BG3IN), and is not requesting the bus on that line, it passes the grant to the appropriate Bus Grant Out line: BG00UT through BG3OUT.

Select a request level by jumpering one Bus Request (BR0 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 3 (the pins are numbered for this example): jumper JB4 to JB8; then jumper JC4 to JC8, and JD4 to JD8. Jumper the remaining grant levels from JC5 to JD1, JC6 to JD2, and JC7 to JD3. Factory configuration: Bus Request Level 3.

Some VME systems only support Bus Request Level 3.



Figure 2-4. Jumpers JB, JC, and JD

#### 2.3.3. P2 Connector

When using the P2 connector, jumper J5n to J6n, where n = 1 to 18. Also, install all jumpers in J7, J8 and J9. Factory setting: all jumpers out.

Do not use the front panel SCSI connector when using the P2 connector.



Figure 2-5. Jumper Blocks J5 and J6



Figure 2-6. Jumper Blocks J7, J8, and J9

#### 2.3.4. P2 Terminator Power

To supply terminator power (TERMPWR) on the P2 bus, install jumper J15. Factory setting: J15 out.



Figure 2-7. Jumper Block J15

#### 2.3.5. Controller Terminator Power

The 721 accepts or generates terminator power, depending on J16's configuration. Factory setting: J16 3-4 in.

To generate terminator power locally to the 721, jumper J16 3-4 in.

To generate terminator power locally and to the SCSI bus, jumper J16 1-2 in and 3-4 in.

To accept terminator power from the SCSI bus, jumper J16 1-2 in.



Figure 2-8. Jumper Block J16

#### 2.3.6. SCSI Timing

To run the SCSI bus at a maximum speed of 4 MHz, jumper J18 2-3 in. To run the SCSI bus at a maximum speed of 5 MHz, jumper J18 1-2 in. Factory setting: J18 2-3 in.



Figure 2-9. Jumper Block J18

#### 2.3.7. Floppy Disk Jumper J3

Jumper J3 determines the floppy drive type (AT or other). Future versions of the controller will implement this feature. Factory setting: all jumpers out.



Figure 2-10. Jumper Block J3

#### 2.3.8. Floppy Disk Jumper J17

Jumper J17 determines the floppy drive type (AT or other). Future versions of the controller will implement this feature. Factory setting: J17 out.



Figure 2-11. Jumper Block J17

# 2.4. EPROM and PAL Part Numbers

Table 2-1. PROM/PAL Part Numbers and Locations

| B / N I     | 7.       | The second   |
|-------------|----------|--------------|
| Part Number | Location | Туре         |
| 181-001-088 | U31      | PAL 1        |
| 181-001-089 | U26      | PAL 2        |
| 181-001-090 | U37      | PAL 3        |
| 180-002-307 | U56      | <b>EPROM</b> |

# 2.5. Light Emitting Diodes

The 721 has two light emitting diodes (LEDs). When the green LED is lit, the 721 is active. During power-up, the yellow LED lights for a moment and then goes off. If it remains on, a fatal error or self test error occurred.

#### 2.6. Board Labels/Revision Control

All Xylogics controllers use revision control labels. They are located on the soldered side of the board. The revision level is important when discussing configuration issues.



Figure 2-12. Sample Part Number

# 2.7. Preparing the Computer System for Installation

The backplane of your system must provide a VMEbus slot for the 721. 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 721.

#### 2.7.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 721.

#### 2.7.2. Card Cage Slot

The card cage must have a slot at the proper DMA priority available for the 721. The 721 uses DMA to transfer data and IOPBs. Placement of the 721 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 721 to DMA enough data to keep up with the SCSI; consider this when choosing a slot. For example, if the 721 does not get a high enough priority, then its DMA falls behind the SCSI requirements, and the SCSI device must wait for the 721. If the 721 priority is high, it gets enough DMA time, but other boards having smaller buffers may not receive enough data within the allotted DMA time. The priorities must be balanced for your system to work properly.

#### 2.7.3. Power Considerations

The 721 affects the power consumption of the entire computer system. The 721 uses +5 volts (4.75 to 5.25 volts) at 4.2 amps. Make sure the power supplies can handle the entire power load. Readjust the voltages *after* plugging in the 721. A power supply that is just adequate may cause intermittent and unusual problems as it generates noise from occasional overcurrent protection.

# 2.8. Installing the 721

Place the 721 into the computer card cage; make sure it is firmly seated. Be careful not to dislodge any socketed ICs. Situate the SCSI device and connect it to its power source.

# 2.9. Cabling the Subsystem

#### 2.9.1. Mechanical Restraint

Mechanically restraining the SCSI cable at both ends prevents it from accidentally disconnecting. Using pull tabs on the cable greatly reduces connector damage.

#### 2.9.2. SCSI Device Grounds

Install a ground braid wire between the ground terminal on the SCSI device(s) and the computer system ground.

# 2.10. Power-up Self Test

The 721 initiates a self test upon power-up. The yellow LED lights for a moment, and then goes off. If it remains on, the board is not functioning properly or the SCSI cable is backwards. The Fatal Error Register may indicate the nature of the problem. Check the power supply voltage to ensure it is within limits (4.75 to 5.25 volts). Contact Xylogics for further assistance.

# 2.11. Diagnostics

When you run your diagnostics:

- Run a full pass of your diagnostic or determine that the system is working properly
- Cable and test any additional devices

# 2.12. Cabling Multiple SCSI Devices

If you are using multiple devices, make sure the cables are properly connected. Observe the pin l markings on both the cables and the devices (see Figure 2-13 and Figure 2-14).



Figure 2-13. Single Initiator, Multiple Target

# 2.12. Cabling Multiple SCSI Devices (continued)



Figure 2-14. Multiple Initiators, Multiple Targets

#### 2.12.1. Terminators

The SCSI bus requires terminators in the first and last connecting SCSI device. Since the 721 has an on-board terminator, only the last SCSI device on the bus requires a terminator. The 721 offers terminator power as a jumper option (J16) with three configurations: supply terminator power to the SCSI bus, supply terminator power locally, and accept terminator power from the bus (see Section 2.3.5.).

#### 2.12.2. Target Select

In a single initiator, multiple target application, assign each target a unique SCSI identification (ID) number. The 721 accesses targets with ID numbers ranging from 0 through 6. ID number 7 is reserved as the 721 default (see Section 5). Each target can connect up to eight logical units having logical unit numbers that range from 0 through 7.

# **The Controller Registers**

3

# The 721 Registers

# 3.1. General

The 721 programming interface uses seven, one-byte long, I/O registers. These registers have one function when read, and another when written. The bus address jumpers define the register set's base address. Table 3-1 lists the registers and the address offset from the base address. Figure 3-1 illustrates the register map, assuming you use EEC0 as the base address.

Table 3-1. Register Offsets

| Register                                     | Offset |
|----------------------------------------------|--------|
|                                              |        |
| 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      |

|      |   | 0 7 | 8 16                  |
|------|---|-----|-----------------------|
| EEC0 | 0 | х   | IOPB Address Byte 0   |
| EEC2 | 2 | х   | IOPB Address Byte 1   |
| EEC4 | 4 | x   | IOPB Address Byte 2   |
| EEC6 | 6 | x   | IOPB Address Byte 3   |
| EEC8 | 8 | х   | IOPB Address Modifier |
| EECA | A | х   | CSR                   |
| EECC | С | х   | FERR                  |

Figure 3-1. Register Map

# 3.2. IOPB Address Registers

The first four registers define the 32-bit address of an IOPB. When you write these registers, the 721 interprets the address of the IOPB ready for execution. When you read them, and Remove IOPB (RIO) is set in the Control and Status Register, the registers point to the IOPB that the 721 just completed (see Section 3.4.).

# 3.3. 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 (see the VMEbus Specification).

This register also specifies whether an IOPB has priority over the current set of IOPBs in the 721 command queue. Section 3.4. defines the protocol for reading and writing this register.

|                             | U        | 5 4 3 2 1 0      |
|-----------------------------|----------|------------------|
| Priority<br>IOPB<br>Request | Reserved | Address Modifier |

#### Bit Mnemonic Description

- 7 PRIO Priority IOPB Request: When set, the IOPB, 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 3DH (see the VMEbus Specification).

# 3.4. Control and Status Register

When written, this register provides the host with control of the 721 operation. When read, it provides the host with 721 status information. Section 3.4.1. defines the bits in this register when written; Section 3.4.2. defines the bits when read.

#### 3.4.1. Control Register (Write)

| 7                | 6        | 5              | 4        | 3                   | 2           | 1            | 0            |
|------------------|----------|----------------|----------|---------------------|-------------|--------------|--------------|
| Register<br>Test | Reserved | Maint.<br>Mode | Reserved | Controller<br>Reset | Add<br>IOPB | Clear<br>RIO | Clear<br>RBS |

#### Bit Mnemonic Description

REGISTER Test: In maintenance mode, when RT, MM, and AIO are set, the 721 echoes back the values previously written in all of the registers (except the CSR).

#### 6 Reserved.

5 MM Maintenance Mode: Setting MM and AIO places the 721 in maintenance mode. Maintenance mode supports a different register protocol; use it as a diagnostic tool.

#### 4 Reserved.

3 CRST Controller Reset: When set, the 721 performs a *soft* reset to recover from fatal errors; it reinitializes its IOPB and AIO address storage RAM, cancelling any IOPBs in its queues, and clears the Fatal Error Register and CSR. The 721 does not generate RIOs for cancelled IOPBs.

A controller reset does not affect the SCSI bus, and leaves outstanding SCSI transfers in an indeterminate state. A SCSI bus reset should follow a controller reset.

A Controller Reset takes up to one-half second to complete.

Add IOPB: When set, the 721 executes the IOPB at the address pointed to by the IOPB Address and Address Modifier Registers. As soon as the host sets AIO, the 721 sets AIO Pending (AIOP) in the Status Register indicating the 721 has received AIO, but has not yet processed the new IOPB address. The 721 clears AIOP after internally storing the new address. Setting AIO while AIOP is set violates the register protocol.

## 3.4.1. Control Register (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 reading the address of a completed IOPB from the IOPB Address and Modifier Registers. Clearing RIO enables the

721 to update the IOPB Address and Modifier Registers with the address and address modifier of a newly completed IOPB. Clearing RIO, if it is not

set in the Status Register, violates the register protocol.

0 CRBS Clear RBS: The host sets CRBS to clear RBS in the Status Register. Clearing

RBS releases the registers for use by another host. CRBS is relevant only in a

multiprocessor environment.

#### 3.4.2. Status Register (Read)

| 7    | 6              | 5                        | 4        | 3                             | 2              | 1              | 0                                  |
|------|----------------|--------------------------|----------|-------------------------------|----------------|----------------|------------------------------------|
| Busy | Fatal<br>Error | Maint.<br>Mode<br>Active | Reserved | Controller<br>Reset<br>Active | AIO<br>Pending | Remove<br>IOPB | Register<br>Busy<br>Sema-<br>phore |

#### Bit Mnemonic Description

7 BUSY

Busy: The 721 is processing IOPBs. The 721 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). The 721 redefines this bit in maintenance mode.

#### 3.4.2. Status Register (Read) (continued)

conditions:

#### Bit Mnemonic Description

- FERR Fatal Error: When set, the 721 detected a fatal hardware error. A fatal error asserts SYSFAIL. Setting CRST clears FERR. The Fatal Error Register holds more specific information. The 721 sets FERR under the following
  - Maintenance mode test failure
  - Power-up self test failure
  - IOPB DMA fatal
  - IOPB address alignment error
  - Firmware error
  - Illegal maintenance mode test number
- 5 MMA Maintenance Mode Active: When set, the 721 is in maintenance mode.
- 4 Reserved.
- 3 RSTA Controller Reset Active: The host set CRST in the Control Register and the 721 is reinitializing.
- 2 AIOP AIO Pending: When set, AIO has been set in the Control Register, but the 721 has not acknowledged its receipt. When clear, AIO may be set again.
- 1 RIO Remove IOPB: The 721 sets RIO after completing an IOPB, 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 CRIO in the Control Register.
- Register Busy Semaphore: RBS allows multiple hosts to share access to the 721 registers without simultaneous access. RBS is relevant only in a multiprocessor environment.

# 3.5. Fatal Error Register

If a fatal error occurs, the 721 returns the appropriate completion code in this register. Table 3-2 lists the fatal error codes. Section 6.4. describes them. All codes not listed are reserved.

Table 3-2. Fatal Error Codes

| Code       | Description                          |
|------------|--------------------------------------|
| <b>E</b> 1 | IRAM/8031 INTRAM Self Test Failure   |
| E2         | SCSI Cable Installed Backwards       |
| E3         | SPC Register Self Test Failure       |
| E5         | FDMAC Register Self Test Failure     |
| <b>E</b> 6 | REGCEL Self Test Failure             |
| E8         | FIFO Self Test Failure               |
| F1         | IOPB DMA Fatal                       |
| F2         | IOPB Address Alignment Error         |
| F3         | Firmware Error                       |
| F5         | Illegal Maintenance Mode Test Number |
| F6         | Abort Message Rejected               |
| F9         | SCSI Illegal Transfer Phase          |
| FC         | Global Timeout Error                 |

# **IOPB Description**

4

# **IOPB Description**

#### 4.1. General

The Input/Output Parameter Block (IOPB) passes messages between the 721 and host software. Software passes the type of transfer, target address, data address, and count to the 721; the 721 returns the transfer status and possibly the ending addresses upon command completion. Each IOPB includes 24 bytes of controller information, and 6, 10, or 12 bytes of SCSI command descriptor block (CDB).

# 4.2. Standard IOPB

The 721 uses the standard 36-byte IOPB for all commands.

|            | _                                                            |                     |          |                                       |                          | 2          | •          | 0      |  |  |
|------------|--------------------------------------------------------------|---------------------|----------|---------------------------------------|--------------------------|------------|------------|--------|--|--|
|            | 7                                                            | 6                   | 5        | 4                                     | 3 2 1 0  Controller Code |            |            |        |  |  |
| 00         | ERRS   DONE   CHEN   SGM   Controller Code   Completion Code |                     |          |                                       |                          |            |            |        |  |  |
| 01         |                                                              |                     |          |                                       |                          |            |            |        |  |  |
| 02         |                                                              |                     |          | SCSI                                  | Status                   |            | 0115115    | 014514 |  |  |
| 03         |                                                              |                     | 0        |                                       | CCID                     | 0          | SWWD       | SWBY   |  |  |
| 04         |                                                              |                     |          | · · · · · · · · · · · · · · · · · · · | 0                        |            |            |        |  |  |
| 05         |                                                              | 0                   |          | BHT                                   | 0                        |            | arget Sele |        |  |  |
| 06         |                                                              | Lini                | List Len | gth                                   |                          | In         | terrupt Le | vel    |  |  |
| .07        |                                                              |                     | In       | terrupt Ve                            | ector                    |            |            |        |  |  |
| 08         |                                                              | 0                   |          |                                       |                          |            |            |        |  |  |
| 09         |                                                              | DMA Byte Count High |          |                                       |                          |            |            |        |  |  |
| 0A         |                                                              |                     | D        | MA Byte (                             | Count                    |            |            |        |  |  |
| <b>₽</b> B |                                                              |                     | D        | MA Byte (                             | Count Low                |            |            |        |  |  |
| 0C         |                                                              |                     |          | 0                                     |                          |            |            |        |  |  |
| 0D         |                                                              |                     |          | 0                                     |                          |            |            |        |  |  |
| 0E         |                                                              |                     | Da       | ata or Link                           | Address                  | Modifier   |            |        |  |  |
| QF.        |                                                              |                     | Ne       | ext IOPB                              | Address M                | lodifier   |            |        |  |  |
| 10         |                                                              |                     | DI       | MA Data o                             | or Link Add              | dress High | 1          |        |  |  |
| 11         |                                                              |                     | DI       | MA Data o                             | or Link Add              | dress      |            |        |  |  |
| 12         |                                                              |                     | DI       | MA Data o                             | or Link Add              | dress      |            |        |  |  |
| ุ13        |                                                              |                     | DI       | MA Data o                             | or Link Add              | dress Low  |            |        |  |  |
| 14         |                                                              |                     | N        | ext IOPB                              | Address H                | igh        |            |        |  |  |
| 15         |                                                              |                     | N        | ext IOPB                              | Address                  |            |            |        |  |  |
| 16         |                                                              |                     | Ne       | ext IOPB                              | Address                  |            |            |        |  |  |
| _17        |                                                              |                     | No       | ext IOPB                              | Address L                | ow         |            |        |  |  |
| 18         |                                                              |                     | C        | DR Rytes                              | 0 through                | 11         |            |        |  |  |
| 23         |                                                              |                     |          | Dy (00                                | - anough                 |            |            |        |  |  |

## 4.2.1. IOPB Byte 0 (Channel Byte)

| 7                | 6    | 5               | 4                          | 3 2 1 0         |
|------------------|------|-----------------|----------------------------|-----------------|
| Error<br>Summary | Done | Chain<br>Enable | Scatter/<br>Gather<br>Mode | Controller Code |

| <u>Bit</u> | Mnemonic | Description                                                                                                                                                                                                                                                                                            |
|------------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7          | ERRS     | <b>Error Summary:</b> ERRS is only valid if <i>Done</i> is set. When set, a hard or soft error occurred during IOPB processing. When clear, the 721 successfully completed the IOPB.                                                                                                                   |
| 6          | DONE     | Done: The 721 sets Done after completing the IOPB.                                                                                                                                                                                                                                                     |
| 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.                                                                                                                                     |
| 4          | SGM      | Scatter/Gather Mode: When set, the IOPB is either a scatter read or a gather write transfer. A link list describes the number of 16-bit words and the address to which the 721 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

3-0 CD Controller Code: Always set this field to 0FH.

to/from contiguous memory.

# 4.2.2. IOPB Byte 1 (Completion Code)

After the 721 executes the IOPB, it sets *Done* and posts a completion code in this byte. Completion codes are only valid if *Done* is set. A code of 00H indicates a successful completion; any other value indicates an error occurred (see Section 6.3.).

# 4.2.3. IOPB Byte 2 (SCSI Status)

IOPB Byte 2 is the SCSI Status byte; it is valid only if *Done* is set. The selected target returns this byte after completing each command. It is the last SCSI status that the target returns while running this IOPB or it is an equivalent byte for the floppy drives (see Table 4-1).

Vendor-unique means the American National Standards Institute (ANSI) has not defined the bit, field, or code value. SCSI device manufacturers define these fields.

| 7        | 6 5           | 4 3 2 1     | 0                 |
|----------|---------------|-------------|-------------------|
| Reserved | Vendor-unique | Status Code | Vendor-<br>unique |

Table 4-1. SCSI Status Codes

| Value | Description                     |
|-------|---------------------------------|
| value | Description                     |
| 0000  | Good                            |
| 0001  | Check Condition                 |
| 0010  | Condition Met/Good              |
| 0011  | Reserved                        |
| 0100  | Busy                            |
| 0101  | Reserved                        |
| 0110  | Reserved                        |
| 0111  | Reserved                        |
| 1000  | Intermediate/Good               |
| 1001  | Reserved                        |
| 1010  | Intermediate/Condition Met/Good |
| 1011  | Reserved                        |
| 1100  | Reservation Conflict            |
| 1101  | Reserved                        |
| 1110  | Reserved                        |
| 1111  | Reserved                        |
|       |                                 |

# 4.2.4. IOPB Byte 3 (Controller Command)

| 7 6 5 4  | 3                          | 2        | 1             | 0             |
|----------|----------------------------|----------|---------------|---------------|
| Reserved | Change<br>Controller<br>ID | Reserved | Swap<br>Words | Swap<br>Bytes |

#### Bit Mnemonic Description

7-4

Reserved.

3 CCID

Change Controller ID: When set, you can change the 721 SCSI ID with a Write Controller Parameters command.

2

Reserved.

1 SWWD

Swap Words: When set, the 721 swaps the significance of the two words in a data longword. Swapping does not occur on IOPB transfers, scatter/gather lists, or 721 mode sense/select data, and is independent of setting TMOD. Swap word is not restricted to longword aligned data.

0 SWBY

Swap Bytes: When set, the 721 swaps the significance of the two bytes in a data word. Swapping does not occur on IOPB transfers, scatter/gather lists, or 721 mode sense/select data, and is independent of setting TMOD. Swap Byte transfers are illegal and cause an error if the data address (IOPB Byte 13) is an odd number. Swap bytes is not restricted to word aligned data.

#### 4.2.5. IOPB Byte 5 (Target Select)

| 7 6 5    | 4                         | 3        | 2 1 0         |  |  |
|----------|---------------------------|----------|---------------|--|--|
| Reserved | Black<br>Hole<br>Transfer | Reserved | Target Select |  |  |

#### Bit Mnemonic Description

7-5 Reserved.

## 4.2.5. IOPB Byte 5 (Target Select) (continued)

#### Bit Mnemonic Description

BHT Black Hole Transfer: When set, the 721 does not increment the bus address during a data transfer; IOPB transfers occur normally. When clear, the 721 does increment the bus address.

3 Reserved.

2-0 TGT Target Select: Contains the target device's SCSI bus ID.

## 4.2.6. IOPB Byte 6 (Interrupt Level)

| 7 6 5 4 3        | 2 1 0           |
|------------------|-----------------|
| Link List Length | Interrupt Level |
|                  |                 |

#### Bit Mnemonic Description

- 7-3 LLL Link List Length: Bits 7 through 3 specify the length, in elements, of a link list for Scatter/Gather commands. Each element is an 8-byte block in the link list (see Table 8-2).
- 2-0 INTL Interrupt Level: The 721 uses INTL as the VMEbus interrupt level after completing the IOPB. The 721 does not interrupt if the level is zero.

#### 4.2.7. IOPB Byte 7 (Interrupt Vector)

IOPB Byte 7 determines the interrupt vector that the 721 uses upon command completion. This byte is not valid if the interrupt level is zero.

#### 4.2.8. IOPB Bytes 9 through B (DMA Count)

IOPB Bytes 9 through B are the DMA Count. These bytes specify how many bytes the 721 transfers in a data transfer, Write Controller Parameters, or Read Controller Parameters IOPB. The DMA count must correspond to the transfer length in the CDB.

#### 4.2.9. IOPB Byte E (Data or Link Address Modifier)

| 7 6      | 5 4 3 2 1 0                   |
|----------|-------------------------------|
| Reserved | Data or Link Address Modifier |

Bit Description

7-6 Reserved.

5-0 **Data or Link Address Modifier:** If SGM is set, this field specifies the link list address modifier; if SGM is clear, it specifies the data address modifier.

#### 4.2.10. IOPB Byte F (Next IOPB Address Modifier)

| 7 6      | 5 4 3 2 1 0                |
|----------|----------------------------|
| Reserved | Next IOPB Address Modifier |

#### Bit Mnemonic Description

7-6 Reserved.

5-0 NIAM Next IOPB Address Modifier: This field, along with the Next IOPB Address, points to the next IOPB in the chain. NIAM must contain a valid modifier value if CHEN is set.

# 4.2.11. IOPB Bytes 10 through 13 (DMA Data or Link Address)

IOPB Bytes 10 and 11 are DMA Data Address High; Bytes 12 and 13 are DMA Data Address Low. These bytes comprise the data or SGM link list address pointers. The 721 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 721 uses the data address when transferring both data and mode sense or select information to or from host memory.

# 4.2.12. IOPB Bytes 14 through 17 (Next IOPB Address)

IOPB Bytes 14 and 15 are Next IOPB Address High; Bytes 16 and 17 are Next IOPB Address Low. These bytes comprise the Next IOPB Address pointers. The 721 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).

# 4.2.13. IOPB Bytes 18 through 23 (SCSI CDB)

IOPB Bytes 18 through 23 are the SCSI command descriptor block. The 721 passes the CDB to the SCSI target device (see Section 4.3.).

# 4.3. SCSI Command Descriptor Block

IOPB Bytes 18H through 23H comprise the SCSI command descriptor block (CDB). The CDB can be 6-, 10-, or 12-bytes long. The 721 uses the CDB to prepare its data transfer and DMA paths; it sends the complete CDB to the SCSI target. All reserved bits, fields, or bytes must equal zero. For all commands, if there is an invalid parameter in the CDB, the target terminates the command without altering the medium.

Each CDB has an operation code as its first byte, followed by a logical unit number, command parameters (if any), and a control byte. The ANSI X3.131–1986 Specification (pages 51–184) describes the SCSI CDB more fully.

# 4.3.1. Typical Six-byte Command Descriptor Block

The logical block address and the transfer length (specified in blocks or bytes) are not always required and depend on both the command and device type. The CDB transfer length must correspond to the IOPB DMA byte count.

| Offs<br>IOPB = |    | 7                                               | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----------------|----|-------------------------------------------------|---|---|---|---|---|---|---|
| 18             | 00 | Operation Code                                  |   |   |   |   |   |   |   |
| 19             | 01 | Logical Unit Number Logical Block Address (MSB) |   |   |   |   |   |   |   |
| 1A             | 02 | Logical Block Address                           |   |   |   |   |   |   |   |
| 1 <b>B</b>     | 03 | Logical Block Address (LSB)                     |   |   |   |   |   |   |   |
| 1C             | 04 | Transfer Length                                 |   |   |   |   |   |   |   |
| 1D             | 05 | Control                                         |   |   |   |   |   |   |   |

# 4.3.2. Typical\Ten-byte\ Command Descriptor Block

| Offset<br>IOPB = CDB |    | 7                     | 6                           | 5 | 4       | 3        | 2 | 1 | 0   |
|----------------------|----|-----------------------|-----------------------------|---|---------|----------|---|---|-----|
| 18                   | 00 |                       |                             |   | Operati | ion Code |   |   |     |
| 19                   | 01 | Logic                 | Logical Unit Number 0 RA    |   |         |          |   |   | RAD |
| 1A                   | 02 |                       | Logical Block Address (MSB) |   |         |          |   |   |     |
| 1B                   | 03 |                       | Logical Block Address       |   |         |          |   |   |     |
| 1C                   | 04 |                       | Logical Block Address       |   |         |          |   |   |     |
| 1D                   | 05 |                       | Logical Block Address (LSB) |   |         |          |   |   |     |
| 1E                   | 06 |                       | 0                           |   |         |          |   |   |     |
| 1F                   | 07 |                       | Transfer Length (MSB)       |   |         |          |   |   |     |
| 20                   | 08 | Transfer Length (LSB) |                             |   |         |          |   |   |     |
| 21                   | 09 |                       | Control                     |   |         |          |   |   |     |

# 4.3.3. Typical Twelve-byte Command Descriptor Block

| Offset<br>IOPB = CDB |    | 7     | 6        | 5      | 4       | 3              | 2         | 1    | 0   |  |
|----------------------|----|-------|----------|--------|---------|----------------|-----------|------|-----|--|
| 18                   | 00 |       |          |        |         | Operation Code |           |      |     |  |
| 19                   | 01 | Logic | cal Unit | Number |         | (              | )         |      | RAD |  |
| 1A                   | 02 |       |          |        | Logical | Block A        | ddress (1 | MSB) |     |  |
| 1B                   | 03 |       |          |        | Logical | Block A        | ddress    |      |     |  |
| 1C                   | 04 |       |          |        | Logical | Block A        | ddress    |      |     |  |
| 1D                   | 05 |       |          |        | Logical | Block A        | ddress (  | LSB) |     |  |
| iE                   | 06 |       |          |        |         | 0              |           |      |     |  |
| 1F                   | 07 |       | 0        |        |         |                |           |      |     |  |
| 20                   | 08 |       |          |        |         | 0              |           |      |     |  |
| 21                   | 09 |       |          |        | Transfe | er Length      | (MSB)     |      |     |  |
| 22                   | 0A |       |          |        | Transfe | er Length      | (LSB)     |      |     |  |
| 23                   | 0B |       |          |        | Contro  |                |           |      |     |  |

# 4.3.4. CDB Byte 0 (Operation Code)

The first byte of all CDBs is the operation code.

| 7 6 5      | 4 3 2 1 0    |  |  |  |  |  |
|------------|--------------|--|--|--|--|--|
| Group Code | Command Code |  |  |  |  |  |
|            |              |  |  |  |  |  |

# Bit Mnemonic Description

7-5 GC Group Code: Designates one of eight command groups. The 721 fully supports the mandatory, optional, and extended commands in Groups 0 and 1. Groups 2 through 7 are all vendor-unique or reserved commands. The 721 supports these commands by passing through software requests and transferring data or parameters according to the SCSI bus data phase.

## 4.3.4. CDB Byte 0 (Operation Code) (continued)

#### Bit Mnemonic Description

4-0 CC Command Code: Designates one of 32 commands available in the group.

Table 4-2. Group Codes

| Group | Description            |
|-------|------------------------|
| 0     | 6-byte commands        |
| 1     | 10-byte commands       |
| 2-4   | Reserved               |
| 5     | 12-byte commands       |
| 6-7   | Vendor-unique commands |

## 4.3.5. CDB Byte 1 (Logical Unit Number)

The second byte of all CDBs defines the logical unit number of the peripheral device attached to the selected SCSI target to which the command applies. It also contains other information that is command- and device type-dependent (see Section 5).

#### 4.3.6. CDB Bytes 2 through 10 (Transfer Information)

Six-byte CDBs use Bytes 2 through 4, 10-byte CDBs use Bytes 2 through 8, and 12-byte CDBs use Bytes 2 through 10. These bytes may be reserved, specify the logical block address for a command on a direct access device, or a transfer count on a sequential access device (see Section 5).

#### 4.3.7. CDB Bytes 5, 9, and 13 (Control)

Six-byte CDBs use Byte 5, 10-byte CDBs use Byte 9, and 12-byte CDBs use Byte 13.

# Commands

5

# **Commands**

#### 5.1. General

As an initiator, the 721 supports all SCSI commands for all SCSI devices (see your device manual for specific command information). The 721 also supports five controller-specific commands (see Sections 5.3. through 5.7.).

## 5.2. SCSI Command Codes

Table 5-1 and Table 5-2 list the SCSI Group 0 and Group 1 command codes. The directive (Dir.) column defines all the SCSI commands that transfer data between system memory and the target device. You can also use vendor-unique commands that are not listed since the 721 transfers data according to the SCSI bus requests.

Key to Table 5-1 and Table 5-2:

#### 721 Directive:

NO = No data transfer

RD = Read data from SCSI to system memory

WD = Write data from system memory to SCSI

RP = Read parameters from SCSI to system memory

WP = Write parameters from system memory to SCSI

#### SCSI Command Implementation Levels:

M = Mandatory

O = Optional

R = Reserved

V = Vendor-unique

E = Extended (required for self-configuring software)

#### 5.2.1. SCSI Group 0 Command Codes

Table 5-1. SCSI Group 0 Command Codes



# 5.2.2. SCSI Group 1 Command Codes

Table 5-2. SCSI Group 1 Command Codes



# 5.3. Command Structure

All 721 commands use the same IOPB structure. The following diagram shows which bytes the 721 absolutely requires for command execution, which bytes are optional, and which bytes it returns after execution.

Each IOPB is 36-bytes long. Reserving all 36 bytes in memory maintains IOPB integrity.



# 5.4. No Operation

This is an implementation of the SCSI Test Unit Ready command. Addressing the 721's target ID (seven) and logical unit zero executes a No Operation (NOP) command.



#### 5.5. Read Controller Parameters

This is a vendor-unique implementation of the SCSI Mode Sense command. Addressing the 721's target ID (seven) and logical unit zero executes a Read Controller Parameters command. The parameter list is vendor-unique (see Section 5.5.2.).



#### 5.5.1. Read Controller Parameters CDB

#### 5.5.1.1. Logical Unit Number

Always address the 721 as logical unit zero.

#### 5.5.1.2. Page Control

There are four valid page control values:

- 0H = Report Current Values
- 1H = Report Changeable Values
- 2H = Report Default Values
- 3H = Report Saved Values (same as default)

#### 5.5.1.3. Page Code

There are two valid page code values:

- 00H = Report Page Zero
- 3FH = Report All Pages (returns only page zero)

#### 5.5.1.4. Allocation Length

An allocation length of 13H or greater returns 19 bytes of mode sense data (all the 721's information). An allocation length of less than 13H returns that number of mode sense bytes.

#### 5.5.2. Parameter List

All the values listed in Table 5-3 are expressed in hexadecimal. The X represents a programmable value in the Read Controller Parameters command.

# 5.5.2. Parameter List (continued)

Table 5-3. Read Controller Parameters List

| Byte     | Description Pag                       | e Contro    | l = 0 | 1             | A 2 pt | 7 3 /    |     |
|----------|---------------------------------------|-------------|-------|---------------|--------|----------|-----|
| Header   |                                       |             | 10    | URRE          | JCK"   | FEF-AUCT | 151 |
| 00       | Campa Data Lameth                     |             | 13    | Citr          | 13     | 13       |     |
| 01       | Sense Data Length                     | 12          | 80    | 80            | 80     | 80       |     |
|          | Vendor-unique Medium Type<br>Reserved |             | 00    | 00            | 00     | 00       |     |
| 02       |                                       |             |       |               |        |          |     |
| 03       | Block Descriptor Length               |             | 00    | 00            | 00     | 00       |     |
| Page 0   |                                       |             |       |               |        |          |     |
| 04       | Page Code (Vendor-unique = 0)         | )           | 00    | 00            | 00     | 00       |     |
| 05       | Page Length                           |             | 0D    | 0D            | 0D     | 0D       |     |
| 06       | Controller Parameters                 |             | XX    | FF            | 00     | 00       |     |
| 07       | Throttle Dead Time and ROR            |             | X0    | $\mathbf{D0}$ | 00     | 00       |     |
| 08       | DMA Throttle                          |             | XX    | FF            | 00     | 00       |     |
| 09       | Sequential Device Types               | \           | XX    | FF            | 00     | 00       |     |
| 0A       | Host BDID                             |             | 0X    | 07            | 07     | 07       |     |
| 0B       | Inhibit Probe for Sync                |             | XX    | FF            | 00     | 00       |     |
| 0C-0D    | Reserved                              |             | 00    | 00            | 00     | 00       |     |
| 0E       | EPROM Number High                     |             | NN    | 00            | NN     | NN       |     |
| 0F       | EPROM Number Low                      | V design of | NN    | 00            | NN     | NN       |     |
| 10       | Firmware Release                      |             | NN    | 00            | NN     | NN       |     |
| 11       | Firmware Revision                     | 477         | NN    | 00            | NN     | NN       |     |
| 12       | Firmware Subrevision                  |             | NN    | 00            | NN     | NN       |     |
| 13       | Reserved                              | 1           | 00    | 00            | 00     | 00       |     |
|          |                                       |             |       |               |        |          |     |
| 5.5.2.1. | Controller Parameters                 |             |       |               |        |          |     |

| 7               | 6                | 5                 | 4              | 3                        | 2                                     | 1 0                  |
|-----------------|------------------|-------------------|----------------|--------------------------|---------------------------------------|----------------------|
| Auto-<br>update | Transfer<br>Mode | Disable<br>Timers | SCSI<br>Parity | Enable<br>DMA<br>Timeout | Non-<br>privileged<br>Request<br>Mode | AIO Response<br>Time |

#### 5.5.2.1. Controller Parameters (continued)

#### Bit Mnemonic Description

- AUD Auto-update: When set, the 721 updates the IOPB to the transfer's ending parameters; it updates the DMA count data address after completing the transfer or detecting an error. When clear, the 721 only updates the IOPB if an error occurs. The update includes the DMA count and the final data address plus one transfer. Default: set.
- Transfer Mode: When set, the 721 executes data 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 721 transfers a byte and/or a word, as necessary to align boundaries, and continues the transfer in the selected mode. The 721 may end the transfer with a byte and/or a word. Default: clear.
- 5 DT Disable Timers: Setting DT disables global timeouts. Clearing DT enables global timeouts. Default: clear.
- 6 SP SCSI Parity: When set, the SPC checks/generates parity on SCSI data. When clear, the 721 ignores SCSI parity. Default: clear.
- 3 EDT Enable DMA Timeout: When set, the 721 enables an on-board DMA bus error timer. When clear, the 721 relies on the external VMEbus transfer timer. The timeout period is one millisecond. Default: clear.
- NPRM Non-privileged Request Mode: When set, the 721 responds to address modifiers 2DH and 29H. When clear, the 721 only responds to 2DH. The VMEbus Specification describes address modifiers. Default: set.
- 1-0 AIOR AIO Response Time: This is the maximum time from setting AIO to the time the 721 clears it. The shorter the response time, the greater the 721 overhead. Default: 00.

Table 5-4. AIO Response Times

| Value | Time                  |
|-------|-----------------------|
| 00    | 100 microseconds (μs) |
| 01    | 75 μs                 |
| 02    | 62 μs                 |
| 03    | 50 μs                 |
|       |                       |

#### 5.5.2.2. Throttle Dead Time and Release on Request

| 7 6                   | 5        | 4                        | 3 2 1 0  |
|-----------------------|----------|--------------------------|----------|
| Throttle Dead<br>Time | Reserved | Release<br>on<br>Request | Reserved |

#### Bit Mnemonic Description

7-6 TDT Throttle Dead Time: TDT selects one of four minimum time periods that determines the time the 721 remains off the bus between throttle bursts (see Section 8.4.). Default: 00.

#### 5 Reserved.

ROR Release on Request: When set, the 721 releases the bus at the request of other bus masters; otherwise, it continues with the next throttle burst. The 721 monitors the bus request lines and releases Bus Busy only if another bus request is pending. It completes the specified throttle burst before releasing the bus due to a pending request. When clear, the 721 releases the bus at the end of each throttle burst and rearbitrates if more data transfers are pending. Default: clear.

#### 3-0 Reserved.

#### 5.5.2.3. DMA Throttle

Bits 0 through 7 are the *Throttle* (THRO) bits. The throttle is the maximum number of transfers allowed each time the 721 becomes bus master. The throttle value determines the maximum DMA burst length for both data and IOPB DMA transfers. This byte allows a throttle setting from 1 to 256. Default: *10H*.

Table 5-5. Throttle Values

| Setting | Transfer Count |
|---------|----------------|
| 0       | 256            |
| 1       | 1              |
| 2       | 2              |
| 3       | 3              |
| :       | :              |
| 255     | 255            |

## 5.5.2.4. Sequential Device Types

The timeouts for direct access and sequential devices are different. The bit settings indicate the device type so the 721 can implement the appropriate timeout.

Each bit position represents a target device, i.e., bit 7 represents target 7, bit 6 represents target 6, etc. When bit n is set, the target n is sequential; when clear, the target is direct access. Default: clear.

#### 5.5.2.5. Host BDID

By changing the values of bits 0 through 2 during a Mode Select/Write Controller Parameters (CCID must be set), you can change the 721's SCSI ID. Default: seven.

#### 5.5.2.6. Inhibit Probe for Synchronous Transfers

Each bit position represents a target device, i.e., bit 7 represents target 7, bit 6 represents target 6, etc. When bit n is set, the 721 will not issue a synchronous transfer request message; when clear, the 721 will issue a synchronous transfer request message. Default: clear.

#### 5.5.2.7. EPROM Part Number

The 721 returns a portion of the EPROM part number on a Read Controller Parameters command. The four nibbles in these two bytes refer to the part number's last four digits. For example, if the part number is 2307, Byte E is 23H and Byte F is 07H.

#### 5.5.2.8. Firmware Release Level

Byte 10 contains the release level of the 721 firmware.

#### 5.5.2.9. Firmware Revision Level

Byte 11 contains the revision level of the 721 firmware; Byte 12 contains the subrevision level.

#### 5.6. Write Controller Parameters

This is a vendor-unique implementation of the SCSI Mode Select command. Addressing the 721's target ID (seven) and logical unit zero executes a Write Controller Parameters command. The parameter list is vendor-unique (see Section 5.6.2.).



#### 5.6.1. Write Controller Parameters CDB

#### 5.6.1.1. Page Format

Setting Page Format (PF) indicates the data sent to the 721 complies with the page format.

#### 5.6.1.2. Save Parameters

Clear Save Parameters (SP); the 721 cannot permanently save any parameters.

#### 5.6.1.3. Parameter List Length

A paramter list length of 0EH delivers the complete mode select parameter list. A paramter list length of less than 0EH delivers that number of bytes; the current settings of the remaining parameters remains unchanged.

#### 5.6.2. Parameter List

Write Controller Parameters and Read Controller Parameters use a similar parameter list. Sections 5.5.2.1. through 5.5.2.9. describe the bytes that comprise the parameter list. All the values listed in Table 5-6 are expressed in hexadecimal; the X represents a programmable value in the Write Controller Parameters command.

Table 5-6. Write Controller Parameters List

| Byte   | Description               | Value |
|--------|---------------------------|-------|
| Header |                           |       |
| 00     | Reserved                  | 00    |
| 01     | Vendor-unique Medium Type | 80    |
| 02     | Reserved                  | 00    |
| 03     | Block Descriptor Length   | 00    |
| Page 0 |                           |       |
| 04     | Vendor-unique Page Zero   | 00    |
| 05     | Page Length               | 08    |
| 06     | Controller Parameters     | XX    |
| 07     | DMA Dead Time and ROR     | XX    |
| 08     | DMA Throttle              | XX    |
| 09     | Sequential Device Types   | XX    |
| 0A     | Host BDID                 | 0X    |
| 0B     | Inhibit Probe for Sync    | XX    |
| 0C-0D  | Reserved                  | 00    |

## 5.7. SCSI Bus Reset

The 721 asserts the RST line on the SCSI bus. This vendor-unique command clears all SCSI devices from the bus.



# **Error Processing**

6

# **Error Processing**

#### 6.1. General

The IOPB completion code, *Error Summary* (ERRS) bit, *Fatal Error* (FERR) bit, and Fatal Error Register represent the 721's status after command execution. FERR indicates the transfer failed and the 721 requires a *Controller Reset* before continuing (the IOPB address is not valid). ERRS affects only a specific IOPB. The completion code informs software that the 721 successfully completed a command, failed to complete a command, or encountered and corrected a problem with one of its internal recovery procedures.

The 721 sets FERR, ERRS, the completion code, and the Fatal Error Register. The SCSI target supplies the SCSI status after completing a command. A *good* status requires no further action. A *check condition* status requires that the host issue a Request Sense command (which gathers more information from the target regarding the failure).

# 6.2. SCSI Request Sense Data

A target can implement two formats for sense data: extended or non-extended. The vendor-unique *Error Class* field determines the sense data's format. Error Classes 0 through 6 use the non-extended sense data format. The *Address Valid* (AdVal) bit indicates that the *Logical Block Address* field contains valid information pertaining to the vendor-unique *Error Code* field.



Figure 6-1. Non-extended Sense Data Format

# 6.2. SCSI Request Sense Data (continued)

Error Class 7 and Error Code 0 use the extended sense data format (see Figure 6-2). The *Information Byte* field is not defined if *Valid* is clear. If *Valid* is set, the *Information Byte* field contains the following information:

- 1. The unsigned logical block address associated with the sense key for direct access, write once-read multiple and read only direct access devices.
- 2. The difference between the requested length minus the actual length in either bytes or blocks, as determined by the command, for sequential access, printer, and processor devices (negative values are indicated by two's compliment notation).
- The difference between the requested number of blocks minus the actual number of blocks copied or compared for the current segment descriptor of a Copy, Compare, or Copy and Verify command.

The Segment Number contains the number of the current segment descriptor if the extended sense is responding to a Copy, Compare, or Copy and Verify command. SCSI supports up to 256 segments beginning with segment zero.

The *Filemark* bit indicates the current command detected a file mark. Only sequential access devices use *Filemark*.

|           | 7                           | 6                    | 5   | 4 | 3 | 2       | 1        | 0 |
|-----------|-----------------------------|----------------------|-----|---|---|---------|----------|---|
| 00        | Valid                       | alid Error Class = 7 |     |   |   | Error ( | Code = 0 |   |
| 01        | Segment Number              |                      |     |   |   |         |          |   |
| 02        | Filemark                    | ЕОМ                  | ILI | 0 |   | Sens    | se Key   |   |
| 03        | Information Byte (MSB)      |                      |     |   |   |         |          |   |
| 04        | Information Byte            |                      |     |   |   |         |          |   |
| 05        | Information Byte            |                      |     |   |   |         |          |   |
| 06        | Information Byte (LSB)      |                      |     |   |   |         |          |   |
| 07        | Additional Sense Length (n) |                      |     |   |   |         |          |   |
| 08<br>n+7 | Additional Sense Bytes      |                      |     |   |   |         |          |   |

Figure 6-2. Extended Sense Data Format

# 6.2. SCSI Request Sense Data (continued)

The End of Medium (EOM) bit indicates that an end of medium condition (end of tape [EOT], beginning of tape [BOT], out of paper, etc.) exists on a sequential access or printer device. For sequential access devices, EOM indicates that the unit is at or past the early warning EOT in the forward direction, or that the target could not complete the command because it detected BOT in the reverse direction. Direct access devices do not use EOM; they report access attempts beyond EOM as an Illegal Request via the Sense Key field (which provide target status information; see Section 6.2.1.).

The *Incorrect Length Indicator* (ILI) bit indicates that the requested logical block length did not match the logical block length of the data on the medium.

The Additional Sense Length specifies the number of Additional Sense Bytes that follow. If the CDB's allocation length is too small to transfer all of the Additional Sense Bytes, the target does not adjust the Additional Sense Length to reflect the truncation.

The Additional Sense Bytes hold command- and peripheral device-specific data (or both) that further define the nature of the check condition status. The Copy, Compare, Copy and Verify, and Search Data commands define a standard purpose for some of these bytes. Except where otherwise noted, the Additional Sense Bytes are vendor-unique.

#### 6.2.1. Sense Key Descriptions

#### Kev(H) Description

- No Sense: The target has no specific Sense Key information for the designated logical unit. This is true for a successful command or a command with a check condition status because Filemark, EOM, or ILI is set to one.
- 1 Recovered Error: The target successfully completed the last command with some recovery action. The Additional Sense and Information Byte fields may have more information.
- 2 Not Ready: The target cannot access the selected logical unit; operator intervention may be required to correct this condition.
- 3 Medium Error: The target terminated the command with a non-recovered error condition that was probably caused by a flaw in the medium or an error in the recorded data.

# 6.2.1. Sense Key Descriptions (continued)

#### Kev(H) Description

- 4 Hardware Error: The target detected a fatal hardware failure (i.e., target controller or device failure, parity error, etc.) during command processing or the self test.
- Illegal Request: There was an illegal parameter in the CDB or in the additional parameters supplied as data for some commands (Format Unit, Search Data, etc.). If the target detects an invalid parameter in the CDB, it terminates the command without altering the medium. If the target detects an invalid parameter in the additional parameters supplied as data, it may have already altered the medium.
- 6 Unit Attention: The removable medium may have been changed or the target has been reset (see the ANSI Specification for more information).
- 7 Data Protect: A command that reads or writes the medium was attempted on a block that is protected from this operation. The target does not execute the read or write.
- 8 Blank Check: A write once, read multiple or sequential access device encountered a blank block while reading, or a write once, read multiple device encountered a non-blank block while writing.
- 9 Vendor-unique: Reports vendor-unique conditions.
- A Copy Aborted: The target aborted a Copy, Compare, or Copy and Verify command because of an error in the source or destination device (or both).
- B Aborted Command: The target aborted the command. The host may recover from the error by trying the command again.
- C Equal: A Search Data command satisfied an equal comparison.
- D Volume Overflow: A buffered peripheral device reached EOM and data remains in the buffer that was not written to the medium. A Recovered Buffered Data command can read the unwritten data from the buffer.
- E Miscompare: The source data did not match the data read from the medium.
- F Reserved.

# 6.3. The Completion Code

The 721 posts a completion code in IOPB Byte 1. A completion code is only valid if *Done* is set. Table 6-1 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.

Table 6-1. Summary of Completion Codes

| Action                      | Code (Hex) | Description                             |
|-----------------------------|------------|-----------------------------------------|
| No Action - Status Only     | 00         | Successful Completion                   |
| Non-retryable               | 11         | Illegal Logical Unit Address            |
| Programming Errors          | 12         | Mode Sense or Mode Select Error         |
|                             | 14         | Illegal Command                         |
|                             | 1C         | Illegal Scatter/Gather Length           |
|                             | 1E         | Next IOPB Address Alignment Error       |
|                             | 1F         | Scatter/Gather Address Alignment Error  |
|                             | 21         | Illegal Black Hole Transfer Address     |
|                             | 22         | Illegal Priority IOPB                   |
|                             | 23         | DMA Count Size Error                    |
| Hard Errors - Retry         | 41         | Reselection Timeout                     |
|                             | 42         | Device Selection Timeout                |
|                             | 43         | Operation Timeout                       |
|                             | 44         | FDMAC Timeout                           |
|                             | 45         | Illegal Address Boundary                |
|                             | 46         | FIFO Buffer Parity Error                |
|                             | 4A         | FDMAC Error                             |
|                             | 4B         | VMEbus Error                            |
| Hard Error - Reset and Retr | y 60       | Target Returned Invalid SCSI Status     |
|                             | 62         | Residual Error                          |
| Fatal Hardware Errors       | 71         | Firmware Failure                        |
|                             | 72         | Synchronous Protocol Error              |
|                             | 73         | Illegal Phase Change During Transfer    |
|                             | 74         | Synchronous Data Transfer Request Error |
|                             | 75         | Illegal Message Reject                  |
|                             | 76         | Drive Interface Fault                   |
|                             | 77         | Drive Requested Data after Count Zero   |
| Miscellaneous Errors        | 81         | IRAM Checksum Failure                   |
|                             | 83         | IOPB Aborted by Error                   |
|                             |            | · · · · · · · · · · · · · · · · · ·     |

# 6.3.1. Completion Code Descriptions

#### 6.3.1.1. No Action - Status Only

The following completion code usually requires no action; the 721 returns it for status only.

## Code(H) Description

00 Successful Completion: The 721 completed the IOPB without error.

#### 6.3.1.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) | <u>Description</u>                                                                                                                                                                                                                |
|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 11      | Illegal Logical Unit Address: The host specified a logical unit address greater than seven.                                                                                                                                       |
| 12      | Mode Sense or Mode Select Error: The allocation length for a floppy command was incorrect.                                                                                                                                        |
| 14      | Illegal Command: The command code in the CDB is invalid for the controller or target command.                                                                                                                                     |
| 1C      | 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.                                     |
| 1E      | Next IOPB Alignment Error: The Next IOPB address did not start on a 16-bit boundary; the 721 does not execute the Next IOPB.                                                                                                      |
| 1F      | Scatter/Gather Address Alignment Error: A scatter/gather address did not start on a 16-bit boundary.                                                                                                                              |
| 21      | Illegal Black Hole Transfer Address: During a black hole transfer, the data address did not start on a word boundary when the 721 was in word mode, or it did not start on a longword boundary when the 721 was in longword mode. |

#### 6.3.1.2. Non-retryable Programming Errors (continued)

## Code(H) Description

- 22 Illegal Priority IOPB: Only Request Sense and controller commands can be priority IOPBs.
- 23 DMA Count Size Error: The DMA count was greater than 16 megabytes.

#### 6.3.1.3. Hard Errors - Retry

These errors indicate the transfer failed; retry the operation. If several retries fail, you must intervene or the operating system may crash.

| Code(H) | Description                                                                                                                                           |
|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| 41      | Reselection Timeout: The target did not reconnect with the 721 within the device-dependent time limit.                                                |
| 42      | Device Selection Timeout: The device did not respond to the 721 within the 250 ms timeout.                                                            |
| 43      | Operation Timeout: The 721 did not complete the IOPB within the two second timeout period.                                                            |
| 44      | FDMAC Timeout: The FDMAC did not complete its task within the 1 ms time limit. Possibly, host memory did not respond in time.                         |
| 45      | Illegal Address Boundary: Following a reselect, the target tried to resume a data transfer to/from an odd address with SWBY set (see Section 4.2.4.). |
| 46      | FIFO Buffer Parity Error: The transfer failed; the 721 detected a FIFO buffer parity error.                                                           |
| 4A      | FDMAC Error: The FDMAC failed during the self test.                                                                                                   |
| 4B      | VMEbus Error: The VME BERR* signal was asserted while the 721 was bus master (see the VMEbus Specification).                                          |

#### 6.3.1.4. Hard Error - Reset and Retry

This error indicates the transfer failed.

# Code(H) Description

- Target Returned Invalid SCSI Status: The target detected a problem during command processing. The 721's reaction depends on the returned SCSI status.
- Residual Error: The number of bytes DMAed differs from the number of bytes requested.

#### 6.3.1.5. Fatal Hardware Errors

These errors indicate the hardware failed. Manual intervention or a *Controller Reset* may be the only recovery approaches that work.

| Code(H) | Description                                                                                                                                       |
|---------|---------------------------------------------------------------------------------------------------------------------------------------------------|
| 71      | Firmware Failure: An unexpected IOPB DMA overflow occurred (fatal during write operations).                                                       |
| 72      | Synchronous Protocol Error: The SCSI chips are incompatible.                                                                                      |
| 73      | Illegal Phase Change During Transfer: Device changed transfer phase illegally.                                                                    |
| 74      | Synchronous Data Transfer Request Error: The target does not respond to a synchronous data request with the correct information, i.e., data rate. |
| 75      | Illegal Message Reject: The target rejected a valid message, i.e., an identify message.                                                           |
| 76      | Drive Interface Fault: There is a problem with the acknowledge/request handshake, i.e., the drive does not remove the request.                    |
| 77      | Drive Requested Data after Count Zero: The DMA count in the IOPB did not match the transfer count in the CDB.                                     |

#### 6.3.1.6. Miscellaneous Errors

#### Code(H) Description

- 81 *IRAM Checksum Failure:* The calculated checksum from the IRAM and its stored value did not match during the self test. A soft bit in the IRAM, static, or probing the board with the power on can cause this error.
- 83 IOPB Aborted by Error: The 721 aborted the IOPB because a previous command returned a check condition status. It discards all subsequent commands, having non-zero interrupt levels, for the affected target/LUN until it receives a Request Sense or Test Unit Ready command.

#### 6.4. Fatal Error Codes

If a fatal error occurs, the 721 sets FERR 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). All codes not listed are reserved.

| Code(H) | <u>Description</u>                                                                                                                                                                   |
|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| E1      | IRAM/8031 INTRAM Self Test Failure: The 721 writes the IRAM/8031 INTRAM with an incrementing data pattern, then reads it with a decrementing pattern. An error indicates a bad IRAM. |
| E2      | SCSI Cable Installed Backwards: The SCSI cable is connected backwards on either the 721 or one of the devices.                                                                       |
| E3      | SPC Register Self Test Failure: The 721 writes the SPC registers and then reads them. An error indicates a bad SPC.                                                                  |
| E5      | FDMAC Register Self Test Failure: The 721 writes the FDMAC registers and then reads them. An error indicates a bad FDMAC.                                                            |
| E6      | REGCEL Self Test Failure: There is a problem with the REGCEL chip.                                                                                                                   |

## 6.4. Fatal Error Codes (continued)

| Code(H) | <u>Description</u>                                                                                                                                                                                        |
|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| E8      | FIFO Self Test Failure: The 721 fills the FIFO with sequential data and then reads it. An error indicates a problem with the FIFO.                                                                        |
| F1      | IOPB DMA Fatal: The 721 did not complete the DMA within the prescribed timeout period. The memory could be defective or not present, or the 721 may not have been able to become bus master.              |
| F2      | IOPB Address Alignment: The IOPB address did not start on a 16-bit boundary. Change the address and retry.                                                                                                |
| F3      | Firmware Error: Flag settings or counter values are inconsistent with the firmware routines; the 721 cannot DMA the appropriate error status. The 721's state is indeterminate. Issue a Controller Reset. |
| F5      | Illegal Maintenance Mode Test Number: The command is invalid.                                                                                                                                             |
| F6      | Abort Message Rejected: The 721 sent an abort message to the drive after an IOPB timed out and the drive responded with message reject. Issue a Controller Reset and a SCSI Bus Reset.                    |
| F9      | Illegal SCSI Transfer Phase: The SCSI bus signals indicate some phase other than command, message, selection/reselection, status, information transfer, or bus free.                                      |
| FC      | Global Timeout Error: The operation did not complete within the two minute timeout period.                                                                                                                |

# **Programming Tutorial**

7

## **Programming Tutorial**

#### 7.1. General

This section includes flow charts that illustrate the basic 721 programming procedures.

### 7.2. Programming the Controller

The first programming step involves setting up the 721 so that the system driver can execute Inquiry, Mode Sense, Mode Select, Read Controller Parameters, and Write Controller Parameters commands.



Figure 7-1. Initial Controller Values

## 7.3. Programming the Controller and the Driver

This sequence programs the 721 on a per device basis and sets up the block size between the software driver and the device.



Figure 7-2. Programming the Controller and the Driver

## 7.4. Executing a Read or Write Operation

This flow chart illustrates a read or write operation.



Figure 7-3. Read/Write

| <br> |  |   |
|------|--|---|
|      |  |   |
|      |  |   |
|      |  |   |
|      |  |   |
|      |  |   |
|      |  |   |
|      |  | ž |
|      |  |   |
|      |  |   |
|      |  |   |
|      |  |   |
|      |  |   |
|      |  |   |
|      |  |   |
|      |  |   |
|      |  |   |
|      |  |   |
|      |  |   |
|      |  |   |
|      |  |   |
|      |  |   |
|      |  |   |
|      |  |   |

# **Special Functions**

8

## **Special Functions**

#### 8.1. General

This section describes how to implement the 721's special functions.

#### 8.2. Maintenance Mode

Firmware supports a non-IOPB driven maintenance mode. Scripts containing maintenance mode commands are useful debugging tools. They allow you to perform basic testing within the 721 by setting control bits in the Control and Status Register (CSR) and entering the desired test number and data through the address registers. Maintenance mode also provides a window through which you can examine or modify internal registers.

#### 8.2.1. Register Use in Maintenance Mode

Table 8-1 lists the registers in maintenance mode. The CSR controls maintenance mode operations.

Table 8-1. Register Use in Maintenance Mode

| 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           |

#### 8.2.2. Maintenance Mode Protocol

#### 8.2.2.1. Entering the Maintenance Mode

First, familiarize yourself with the CSR; Busy does not have to be clear before entering maintenance mode. Simultaneously set the Maintenance Mode (MM) and Add IOPB (AIO) bits. The 721 responds by setting the Remove IOPB (RIO) and AIO Pending (AIOP) bits. Then set the Clear RIO (CRIO) bit. The 721 sets the Maintenance Mode Active (MMA) bit and clears AIOP.

#### 8.2.2.2. Testing in the Maintenance Mode

Xylogics has developed a series of diagnostics that test the 721 microprocessor, ASICs, and RAM. For example, the Register Test can verify the operation of the 721 registers:

Load arbitrary bit patterns into all the maintenance mode registers, except the CSR (see Table 8-1). Then simultaneously set RT, MM, and AIO. After the 721 clears AIOP, the host can read the registers and compare their contents with the patterns written. *Busy* remains set; setting RT clears *Busy*.

Contact Xylogics for information regarding additional maintenance mode functions.

#### 8.2.2.3. Exiting the Maintenance Mode

To exit the maintenance mode, the host simultaneously sets AIO and clears MM. The 721 sets AIOP and RIO, and clears Busy if it was set. Then the host sets CRIO.

#### 8.3. Scatter/Gather

Scatter/gather reduces software's workload in mapped memory systems. Data that is contiguous on the SCSI device can be transferred to or from pages and page fragments scattered throughout the physical address space. Pages can contain up to 64K bytes, but must be an even length and start on a word boundary. A scatter/gather IOPB can service up to 32 such pages.

#### 8.3.1. Scatter/Gather Link List

The DMA Data or Link Address in IOPB Bytes 10 through 13 points to a list of DMA page descriptors. Each 8-byte descriptor includes a byte count field and an address field, and transfers one page or page fragment. The list can have up to 32 descriptors.

The Link List Length in IOPB byte 6 must contain the number of descriptors in the list; a value of zero indicates the link list has 32 descriptors. The DMA Byte Count in IOPB Bytes 9 through B must contain the sum of the page descriptors' byte count fields. See Table 8-2 and Table 8-3.

Table 8-2. Scatter/Gather Link List

| Link Number | Byte  | Description                         |
|-------------|-------|-------------------------------------|
| 1           | 00-01 | Byte Count (Multiples of 2)         |
|             | 02    | Reserved                            |
|             | 03    | Data Address Modifier               |
|             | 04-07 | Data Address (Word boundaries only) |
| 2           | 08-09 | Byte Count                          |
|             | :     | ·                                   |
|             | :     |                                     |
| n           | xx    | •                                   |
|             |       |                                     |

Table 8-3. Link List Field Values

| Link List Length | Decimal Equivalent |
|------------------|--------------------|
| 0                | 32                 |
| 1                | 1                  |
| 2                | 2                  |
| :                | :                  |
| 9                | 9                  |
| Α                | 10                 |
| В                | 11                 |
| :                | :                  |
| 1E               | 30                 |
| 1F               | 31                 |
|                  |                    |

#### 8.3.2. Setting Up a Scatter/Gather Transfer

Elements of memory descriptors comprise the link list. Each element describes the starting address and the length, in bytes, of the memory block. The sum of the byte counts of all the elements in the link list must equal the SCSI logical block count times the block size (in bytes); this sum must appear in IOPB Bytes 9 through B.

The IOPB and link list in Figure 8-1 illustrate a read transfer to 6 blocks of memory. The block size in this case is 528-bytes per block; we are transferring 3 blocks of information. The 721 transfers the first 16 data bytes from each block to a separate buffer. It scatters the bulk of the data, 512-bytes per block, into memory as 3 blocks having 512 bytes each. Set SGM and execute the IOPB in Figure 8-1.

#### 8.3.3. **721** Operation

The 721 proceeds as if doing a normal read until it starts the data transfer into memory. The contents of the link list 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 described in each element on the list.



Figure 8-1. Scatter/Gather Transfers

#### 8.4. IOPB DMA Throttle/Throttle Dead Time

The 721 always transfers IOPBs in word mode; it uses the latest 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 721 waits before attempting to regain control of the bus between throttle bursts. There are four valid TDT values (see Table 8-4). Default: zero.

Table 8-4. Throttle Dead Time Values

| TDT Value | Time              |
|-----------|-------------------|
| 0         | 0 microseconds    |
| 1         | 3.2 microseconds  |
| 2         | 6.4 microseconds  |
| 3         | 12.8 microseconds |

#### 8.5. Black Hole Transfers

The normal DMA mode increments the bus address for each transfer so that the data is put into contiguous memory space. During black hole transfers, the 721 does not increment the bus address between each data transfer. Any transfer that DMAs data to a permanent memory location should have BHT set in IOPB Byte 5. The data address must be properly aligned: word aligned for word transfers and longword aligned for longword transfers.

#### 8.6. Block Mode Transfers

Block mode reduces data transfer times by allowing a DMA device to use one memory address strobe for up to 256 bytes. Each time the transfer crosses a 256-byte memory address boundary, the device generates another address and address strobe. Block mode does not affect DMA throttling. IOPB DMA can also occur in block mode, but it is not practical since the IOPBs are relatively small. For more detailed information see the VMEbus Specification. To put the 721 into block mode, use one of the two address modifiers in the the IOPB's Address Modifier byte (xF or xB, where x = don't care).

# **Interface Signals**

## **Interface Signals**

#### 9.1. General

This section provides useful interface information for your 721 SCSI controller.

## 9.2. VMEbus Interface Signals

|                 |       |            | Used By    |                    |
|-----------------|-------|------------|------------|--------------------|
| <b>Mnemonic</b> | Conn. | <u>Pin</u> | <u>721</u> | <b>Description</b> |
|                 |       |            |            |                    |
| A01             | P1A   | 30         | Y          |                    |
| A02             | P1A   | 29         | Y          |                    |
| A03             | P1A   | 28         | Y          |                    |
| A04             | P1A   | 27         | Y          |                    |
| A05             | P1A   | 26         | Y          |                    |
| A06             | P1A   | 25         | <b>Y</b>   |                    |
| A07             | P1A   | 24         | Y          |                    |
| A08             | P1C   | 30         | Y          |                    |
| A09             | P1C   | 29         | Y          |                    |
| A10             | P1C   | 28         | Y          |                    |
| A11             | P1C   | 27         | Y          |                    |
| A12             | P1C   | 26         | Y          |                    |
| A13             | P1C   | 25         | Y          |                    |
| A14             | P1C   | 24         | Y          |                    |
| A15             | P1C   | 23         | Y          | Address Bus        |
| A16             | P1C   | 22         | Y          |                    |
| A17             | P1C   | 21         | Y          |                    |
| A18             | P1C   | 20         | Y          |                    |
| A19             | P1C   | 19         | Y          |                    |
| A20             | P1C   | 18         | Y          |                    |
| A21             | P1C   | 17         | Y          |                    |
| A22             | P1C   | 16         | Y          |                    |
| A23             | P1C   | 15         | Y          |                    |
| A24             | P2B   | 4          | Y          |                    |
| A25             | P2B   | 5          | Y          |                    |
| A26             | P2B   | 6          | Y          |                    |

|                 |       |            | Used By    |                    |
|-----------------|-------|------------|------------|--------------------|
| <b>Mnemonic</b> | Conn. | <u>Pin</u> | <u>721</u> | <b>Description</b> |
| a <del>r</del>  |       |            |            |                    |
| A27             | P2B   | 7          | Y          |                    |
| A28             | P2B   | 8          | Y          |                    |
| A29             | P2B   | 9          | Y          |                    |
| A30             | P2B   | 10         | Y          |                    |
| A31             | P2B   | 11         | Y          |                    |
| 43.60           | D4D   | 1.6        | *27        |                    |
| AM0             | P1B   | 16         | Y          |                    |
| AM1             | P1B   | 17         | Y          | A 44 No. 4161      |
| AM2             | P1B   | 18         | Y          | Address Modifier   |
| - AM3           | P1B   | 19         | Y          |                    |
| AM4             | P1A   | 23         | Y          |                    |
| AM5             | P1C   | 14         | Y          |                    |
| D00             | P1A   | 1          | Y          |                    |
| D01             | P1A   | 2          | Ÿ          |                    |
| D02             | P1A   | 3          | Ÿ          |                    |
| D03             | P1A   | 4          | Y          |                    |
| D04             | P1A   | 5          | Y          |                    |
| D05             | P1A   | 6          | Y          |                    |
| D06             | P1A   | 7          | Y          |                    |
| D07             | P1A   | 8          | Y          | Data Bus           |
| D08             | P1C   | 1          | Y          |                    |
| D09             | P1C   | 2          | Y          |                    |
| D10             | P1C   | 3          | Y          |                    |
| D11             | P1C   | 4          | Y          |                    |
| D12             | P1C   | 5          | Y          |                    |
| D13             | P1C   | 6          | Y          |                    |
| D14             | P1C   | 7          | Y          |                    |
| D15             | P1C   | 8          | Y          |                    |
| D16             | P2B   | 14         | Y          |                    |
| D17             | P2B   | 15         | Y          |                    |
| D18             | P2B   | 16         | Y          |                    |
| D19             | P2B   | 17         | Y          |                    |
| D20             | P2B   | 18         | Y          |                    |
| D21             | P2B   | 19         | Y          |                    |
|                 |       |            |            |                    |

|                 |       |            | Used By    |                    |
|-----------------|-------|------------|------------|--------------------|
| <b>Mnemonic</b> | Conn. | <u>Pin</u> | <u>721</u> | <b>Description</b> |
|                 |       |            |            |                    |
| D22             | P2B   | 20         | Y          |                    |
| D23             | P2B   | 21         | Y          | Data Bus           |
| D24             | P2B   | 23         | Y          |                    |
| D25             | P2B   | 24         | Y          |                    |
| D26             | P2B   | 25         | Y          |                    |
| D27             | P2B   | 26         | Y          |                    |
| D28             | P2B   | 27         | Y          |                    |
| D29             | P2B   | 28         | Y          |                    |
| D30             | P2B   | 29         | Y          |                    |
| D31             | P2B   | 30         | Y          |                    |
|                 |       |            |            |                    |
| Strobes         |       |            |            |                    |
|                 |       |            |            |                    |
| AS*             | P1A   | 18         | Y          | Address Strobe     |
| DS0*            | P1A   | 13         | Y          | Data Strobe Zero   |
| DS1*            | P1A   | 12         | Y          | Data Strobe One    |
| DTACK*          | P1A   | 16         | Y          | Data Transfer Ack. |
|                 |       |            |            |                    |
| Clocks          |       |            |            |                    |
|                 |       |            |            |                    |
| SERCLK          | P1B   | 21         | N          | Serial Clock       |
| SYSCLK          | P1A   | 10         | N          | System Clock       |
|                 |       |            |            | -                  |
| DMA             |       |            |            |                    |
| DIMA            |       |            |            |                    |
| BBSY*           | P1B   | 1          | Y          | Bus Busy           |
| BCLR*           | P1B   | 2          | N          | Bus Clear          |
| BERR*           | P1C   | 11         | Y          | Bus Error          |
|                 |       |            |            |                    |

|                 |       |            | Used By    |                           |
|-----------------|-------|------------|------------|---------------------------|
| <b>Mnemonic</b> | Conn. | <u>Pin</u> | <u>721</u> | <b>Description</b>        |
|                 |       |            |            |                           |
| DMA (continued) | )     |            |            |                           |
|                 |       |            |            |                           |
| BG0IN*          | P1B   | 4          | Y          | D G . I                   |
| BG1IN*          | P1B   | 6          | Y          | Bus Grant In              |
| BG2IN*          | P1B   | 8          | Y          |                           |
| BG3IN*          | P1B   | 10         | Y          |                           |
| BG0OUT*         | P1B   | 5          | Y          |                           |
| BG1OUT*         | P1B   | 7          | Y          | Bus Grant Out             |
| BG2OUT*         | P1B   | 9          | Y          | Das Grant Gut             |
| BG3OUT*         | P1B   | 11         | Y          |                           |
| ВОЗООТ          | FID   | 11         | •          |                           |
| BRO*            | P1B   | 12         | Y          |                           |
| BR1*            | P1B   | 13         | ' <b>Y</b> | Bus Request               |
| BR2*            | P1B   | 14         | Y          |                           |
| BR3*            | P1B   | 15         | Y          |                           |
|                 |       |            |            |                           |
|                 |       |            |            |                           |
| Interrupts      |       |            |            |                           |
| IRQ1*           | P1B   | 30         | Y          |                           |
| IRQ2*           | P1B   | 29         | Y          |                           |
| IRQ3*           | P1B   | 28         | Ÿ          | Interrupt Request Levels  |
| IRQ4*           | P1B   | 27         | Y          |                           |
| IRQ5*           | P1B   | 26         | Ÿ          |                           |
| IRQ6*           | P1B   | 25         | Ÿ          |                           |
| IRQ0*           | P1B   | 24         | Y          |                           |
| INQ/            | מוו   | <b>4</b> 7 | •          |                           |
| IACK*           | P1A   | 20         | Y          | Interrupt Acknowledge     |
| IACKIN*         | P1A   | 21         | Y          | Interrupt Acknowledge In  |
| IACKOUT*        | P1A   | 22         | Y          | Interrupt Acknowledge Out |
| IACKOUI         | LIV   | 44         | 1          | interrupt Acknowledge Out |

| <u>Mnemonic</u>     | Conn.      | <u>Pin</u>      | Used By <u>721</u> | <u>Description</u>             |
|---------------------|------------|-----------------|--------------------|--------------------------------|
| Miscellaneous       |            |                 |                    |                                |
| ACFAIL* LWORD*      | P1B<br>P1C | 3<br>13         | Y<br>Y             | AC Failure<br>Longword         |
| RESERVED            | P2B        | 3<br>22         | N<br>N             | Reserved<br>Serial Data        |
| SERDAT* SYSFAIL*    | P1B<br>P1C | 10              | Y                  | System Failure                 |
| SYSRESET*<br>WRITE* | P1C<br>P1A | 12<br>14        | Y<br>Y             | System Reset<br>Write          |
| Power               |            |                 |                    |                                |
| +5V                 | P1A,B,C    | 32              | Y                  | +5 VDC                         |
| +5V                 | P2B        | 1,13,32         | Y                  | +5 VDC                         |
| +5V STDBY           | P1B        | 31              | N                  | +5 VDC Standby                 |
| +12V                | P1C        | 31              | N                  | +12 VDC                        |
| -12V                | P1A        | 31              | N                  | -12 VDC                        |
| GND                 | P1A        | 9,11,15,17,19   | Y                  | Signal Ground                  |
| GND                 | P1B        | 20,23           | Y                  | Signal Ground                  |
| GND<br>GND          | P2B<br>P1C | 2,12,22,31<br>9 | Y<br>Y             | Signal Ground<br>Signal Ground |

## 9.3. SCSI Bus Interface Signals

The SCSI bus supports up to eight devices, including any combination of initiators and targets. There are eighteen SCSI bus signals: nine for control and nine for data. Data signals include the parity signal option.

#### 9.3.1. Single-ended Pin Assignments

Connect all odd pins, except pin 25, to ground; leave pin 25 open. The minus sign preceding the signal name indicates active low.

| Signal Name | Pin Number |
|-------------|------------|
| -DB (0)     | 2          |
| -DB (1)     | 4          |
| -DB (2)     | 6          |
| -DB (3)     | 8          |
| -DB (4)     | 10         |
| -DB (5)     | 12         |
| -DB (6)     | 14         |
| -DB (7)     | 16         |
| -DB (P)     | 18         |
| Ground      | 20         |
| Ground      | 22         |
| Ground      | 24         |
| TERMPWR     | 26         |
| Ground      | 28         |
| Ground      | 30         |
| -ATN        | 32         |
| Ground      | 34         |
| -BSY        | 36         |
| -ACK        | 38         |
| -RST        | 40         |
| -MSG        | 42         |
| -SEL        | 44         |
| -C/D        | 46         |
| -REQ        | 48         |
| -I/O        | 50         |
|             |            |

### A

Abbreviations, 1

Add IOPB, 23

Address Modifier, 22

AIO, 23

AIO Pending, 25

AIO Response Time, 45

AIOP, 25

AIOR, 45

Allocation Length, 43

AM, 22

**AUD, 45** 

Auto-update, 45

### B

Backplane Jumpers, 16

Base Address, selection, 11

**BHT**, 31

Black Hole Transfer, 5, 69, 31

Block Mode, transfers, 5

Block Mode Transfers, 70

Board Labels, revision control, 16

Bus Grant, 12

Bus Request, 12

BUSY, 24

### C

Cabling, the subsystem, multiple drives, 17

Cabling Multiple SCSI Devices, 18—20

Card Cage Slot, 16

CC, 36

CCID, 30

CD, 28

CDB Byte 0, 35-36

CDB Byte 1, 36

CDB Bytes 2-10, 36

CDB Bytes 5, 9, and 13, 36

Chain Enable, 28

Change Controller ID, 30

Channel Byte, 28

CHEN, 28

Clear RBS, 24

Clear RIO, 24

Command Buffer, 4

Command Code, 36

Command Structure, 40-41

Commands, 37-50

Completion Code, 28-29

Completion Codes, 55-59

Configuring, jumpers, 10

Connectors, 3

Control, 36

Control and Status Register, 22-26

Control Register, write, 23-24

Controller Code, 28

Controller Command Byte, 30

Controller Parameters, 44-45

Controller Reset, 23

Controller Reset Active, 25

Controller Terminator Power Jumper, 14

CRBS, 24

CRIO, 24

CRST, 23

#### D

Data Buffering, 4

Data or Link Address Modifier, 32

Data Transfer, 4

Data Transfer Limit, 6

Data Width, 7

Diagnostics, 18

Dimensions, 3

Disable Timers, 45

DMA, data transfer rate, dead time, throttle control, processor, 6

DMA Count, 32

DMA Data or Link Address, 33

DMA Throttle, 46—47

DONE, 28

Drive Formats, 6

Drive Types, 6

DT, 45

#### Ε

EDT, 45
Electrical, 4
Enable DMA Timeout, 45
Environmental, 4
EPROM, PAL, part numbers, 15
EPROM Part Number, 47
Error Processing, 51—60
Error Summary, 28
ERRS, 28

### F

Fatal Error, 25
Fatal Error Codes, 59—60
Fatal Error Register, 26
Fatal Hardware Errors, 58
FERR, 25
Firmware Release Level, 47
Firmware Revision Level, Subrevision Level, 47
Floppy, controller, drives, 6

## G

GC, 35 Grounds, 17 Group 0 Command Codes, 38 Group Code, 35

## H

Handling Precautions, 9
Hard Errors
reset and retry, 58
retry, 57-58
Host BDID, 47

Inhibit Probe for Sync Transfers, 47 Installing, testing, the 721, 9—20 Interface Signals, 71—76 Interrupt Level Byte, 31 Interrupt Vector, 31 INTL, 31 IOPB, standard, 27—33 IOPB Address Modifier, Priority IOPB Register, 22 IOPB Address Registers, 22 IOPB Byte 0, 28 IOPB Byte 1, 28-29 IOPB Byte 2, 29-30 IOPB Byte 3, 30 IOPB Byte 5, 30 IOPB Byte 6, 31 IOPB Byte 7, 31—32 IOPB Byte E, 32 IOPB Byte F, 32 IOPB Bytes 10-13, 33 IOPB Bytes 14-17, 33 IOPB Bytes 18-23, 33

### L

IOPB Bytes 9-B, 32

IOPB Description, 27—36

Light Emitting Diodes, 15 Link List, 67—68 Link List Length, 31 LLL, 31 Logical Unit Number, 36, 43

### M

Maintenance Mode, 23, 65—66
Maintenance Mode Active, 25
Maintenance Mode Protocol, 66
Mechanical Restraint, 17
Miscellaneous Errors, 59
MM, 23
MMA, 25
Mode Select, 48
Mode Sense, 42

#### N

Next IOPB Address, 33 Next IOPB Address Modifier, 32 NIAM, 32 No Operation, 41 Non-privileged Request Mode, 45 NPRM, 45

## O

Operation Code, 35

## P

P2 Connector Jumpers, 13
P2 Terminator Power Jumper, 13
Packaging, 3
Page Code, 43
Page Control, 43
Page Format, 49
Parameter List, 43, 49
Parameter List Length, 49
Power Considerations, 17
Power-up, self test, 17
PRIO, 22

Priority IOPB Request, 22 Product Support, telephone numbers, 9 Programming Errors, non-retryable, 56—57 Programming Tutorial, 61—64

#### R

RBS, 25
Read Controller Parameters, 42—48
Register, descriptions, 21—26
Register Busy Semaphore, 25
Register Offsets, 21
Register Test, 23
Register Use, maintenance mode, 65—66
Release on Request, 7, 46
Release When Done, 7
Remove IOPB, 25
RIO, 25
ROR, 46
RSTA, 25
RT, 23

## S

Save Parameters, 49 Scatter/Gather, 5, 28, 66-69 Scatter/Gather Transfers, setting up, 68 SCSI Bus Interface Signals, 75-76 SCSI Bus Reset, 50 SCSI CDB, 33 SCSI Command Codes, 37—40 SCSI Command Descriptor Block, 33-36 SCSI Group 1 Command Codes, 39 SCSI Parity, 45 SCSI Request Sense Data, 51–55 SCSI Status Byte, 29-30 SCSI Timing Jumper, 14 Sense Key, descriptions, 53—56 Sequential Device Types, 47 SGM, 28 Shipping Weight, 3

Priority IOPB, 5

Single-ended Pin Assignments, 76
Six-byte CDB, 34
Software, drivers, interface, 8
Software Interface, 7— 8
SP, 45
Special Functions, 65—70
Specifications, 1— 8
Status LEDs, 4
Status Register, 24—26
Swap Bytes, 30
Swap Words, 30
SWBY, 30
SWWD, 30

#### T

Target Select, 20, 30 Target Select Bit, 31 TDT, 46 Ten-byte CDB, 34 Terminators, 19

TGT, 31

Throttle dead time, 69 values, 46

Throttle Dead Time, 46 Release on Request, 46

**TMOD, 45** 

Transfer Information Bytes, 36

Transfer Mode, 45

Twelve-byte CDB, 35

#### U

Unpacking, 9-10

#### V

VMEbus Interface Signals, 71-75

### W

Write Controller Parameters, CDB, 48-50

## **Manual Evaluation Form**

Please help us produce quality documentation by filling out this form. No envelope is needed, just fold this page, stamp, and return. Thank you.

| I rate this manual's:                                       | Excellent      | Good        | Fair                                  | Poor |
|-------------------------------------------------------------|----------------|-------------|---------------------------------------|------|
| Accuracy                                                    |                |             |                                       |      |
| Completeness                                                |                |             |                                       |      |
| Clarity                                                     |                |             |                                       |      |
| Organization                                                |                |             |                                       |      |
| Figures (usefulness)                                        |                |             |                                       |      |
| Tables (usefulness)                                         |                |             |                                       |      |
| Index                                                       |                | 닠           |                                       |      |
| Page layout                                                 |                | L           | $\sqcup$                              | Ш    |
| What I like best about this manual is                       |                |             |                                       |      |
|                                                             |                |             | · · · · · · · · · · · · · · · · · · · |      |
|                                                             |                |             |                                       |      |
| What I like least about this manual is                      |                |             |                                       |      |
|                                                             |                |             |                                       |      |
|                                                             |                | <del></del> |                                       |      |
| I found the following errors in this manu  Page Description | aal:           |             |                                       |      |
|                                                             |                |             |                                       |      |
|                                                             |                |             |                                       |      |
|                                                             |                |             |                                       |      |
|                                                             |                |             |                                       |      |
| Additional comments or suggestions for i                    | improving this | manual:     |                                       |      |
|                                                             |                |             |                                       |      |
|                                                             | #              |             |                                       |      |
| Name (Titale)                                               |                |             |                                       |      |
| Name/Title:                                                 |                |             |                                       |      |
| Address:                                                    |                |             |                                       |      |
| Audi ess.                                                   |                | Phor        | ne:                                   |      |
|                                                             |                |             |                                       |      |
|                                                             |                |             |                                       |      |

| fold here                            |
|--------------------------------------|
|                                      |
|                                      |
| Xylogics, Inc.                       |
| 53 Third Avenue                      |
| Burlington, MA 01803                 |
| Att: Technical Support/Documentation |
|                                      |
|                                      |
| <br>fold here                        |
|                                      |
|                                      |
|                                      |
|                                      |
|                                      |

•

Xylogics, Inc. 53 Third Avenue Burlington, MA 01803