CHIPS AND TECHNOLOGIES, INC. 3050 ZANKER ROAD, SAN JOSE, CA 95134 408-434-0600

PRELIMINARY

# 82C5086 REFERENCE MANUAL

NOVEMBER 1989 CPI063/11-89 REV C

STK# 10063-001



The information in this publication is subject to change without notice.

No part of this publication may be reproduced, stored in a retrieval system, or transmitted, in any form or by any means, electronic, mechanical, photocopying, recording, or otherwise, without the prior written permission of Chips and Technologies Inc.

Copyright 1989 Chips and Technologies, Inc.

All Rights Reserved

CHIPS is a trademark of Chips and Technologies, Inc.

The following products trademarked by other companies are referenced in this manual:

IBM PC AT is an IBM trademark. Z8 is a Zilog trademark. 80286 is an Intel trademark.

# Revision History

| Revision | Change Activity | Date     | Approved   |
|----------|-----------------|----------|------------|
| А        | First Release   | 1/29/88  | P.H./ P.D. |
| В        | Second Release  | 10/31/88 | P.H/M.S.   |
| C        | Third Release   | 10/10/89 | BJM/JC     |
|          |                 |          |            |
|          |                 |          |            |
|          |                 |          |            |
|          |                 |          |            |
|          |                 |          |            |
|          |                 |          |            |
|          |                 |          |            |
|          |                 |          |            |
|          |                 |          |            |
|          |                 |          |            |
|          |                 |          |            |
|          |                 |          |            |
|          |                 |          |            |
|          |                 |          |            |
|          |                 |          |            |
|          |                 |          |            |



## PREFACE

#### AUDIENCE

This manual is intended for firmware design engineers who are interested in programming the CHIPS 82C5086 SCSI-Bus Interface Controller; however, such topics as pin descriptions that would be of interest to hardware design engineers are also addressed.

#### SCOPE

This manual contains the information a firmware design engineer needs to program this chip to implement the SCSI (Small Computer System Interface) interface on a host computer or a device controller. It is assumed the reader already has a working knowledge of the SCSI interface.

#### CONTENTS

The information in this manual is divided into five chapters, one appendix, and a glossary.

- Chapter 1 provides an overview of the CHIPS 82C5086 SCSI-Bus Interface Controller.
- Chapter 2 which is intended for hardware design engineers describes the 82C5086 hardware specifications. It supplies physical and functional pin specifications, signal descriptions, electrical specifications, and packaging specifications.
- Chapter 3 which is directed at firmware engineers describes the operational modes of the 82C5086.
- Chapter 4 which is intended for firmware engineers provides a detailed description of the function and operation of each of the 24 internal registers of the 82C5086.
- Chapter 5 provides a detailed description of the operation of each of the 46 commands of the 82C5086. This chapter is intended for firmware engineers.
- Appendix A contains a sample flow chart that illustrates the steps involved in completing an asynchronous data transfer to a target device.

The glossary provides a list of abbreviations, and definitions of the key terms used throughout this manual.

#### **RELATED PUBLICATIONS**

- CHIPS 5080 SCSI Multifunctional Device Reference Manual. (Document Number: 3001237, Revision A)
- American National Standard for Information Systems Small Computer System Interface (SCSI). (X3.131-1986.)

#### NOTATIONAL CONVENTIONS

+

The following conventions are used throughout this manual:

UPPERCASE is used to indicate names of commands, signals, SCSI bus phases.

a minus sign prefix to a signal name indicates an active low polarity.

a plus sign prefix to a signal name indicates an active high polarity.

## Table of Contents

## CHAPTER 1. AN OVERVIEW OF THE 82C5086

| INTRODUCTION                                                      | 1  |
|-------------------------------------------------------------------|----|
| Hardware Features                                                 | 2  |
| Firmware Features                                                 | 3  |
|                                                                   |    |
| TYPICAL APPLICATIONS                                              | Λ  |
|                                                                   |    |
| Host Adapter<br>Device Controller                                 |    |
|                                                                   |    |
| OPERATIONAL MODES                                                 | 6  |
| Initiator or Target Mode                                          | 6  |
| Initiator or Target Mode<br>Non-Differential or Differential Mode | 7  |
| Asynchronous or Synchronous Mode                                  | 7  |
| Asynchronous or Synchronous Mode<br>Master or Slave Mode          | 7  |
| SYSTEM INTEDEA OF                                                 | o  |
| SYSTEM INTERFACE.                                                 |    |
| I/O Interface                                                     | ð  |
| Command Set                                                       |    |
| Memory Structure                                                  | 10 |
| PERFORMANCE SPECIFICATIONS                                        | 10 |
| ELECTRICAL SPECIFICATIONS                                         | 11 |
| Absolute Maximum Ratings                                          |    |
| D.C. Characteristics                                              |    |
|                                                                   |    |
| PACKAGING                                                         | 12 |

### CHAPTER 2. 82C5086 HARDWARE SPECIFICATIONS

| PHYSICAL SPECIFICATIONS            |    |
|------------------------------------|----|
| 68-Pin PLCC Package                |    |
| 68-Pin PLCC Package Specifications |    |
| 80-Pin PFP Package                 |    |
| 80-Pin PFP Package Specifications  |    |
| 84-Pin PLCC Package                |    |
| 84-Pin PLCC Package Specifications | 23 |
|                                    |    |

| FUNCTIONAL CHIP SPECIFICATIONS                                                                                                                                                                                                                                                                                                                           |                            |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------|
| Functionality of the 82C5086 Host Adapter                                                                                                                                                                                                                                                                                                                |                            |
| Interfacing with the SCSI Control Bus                                                                                                                                                                                                                                                                                                                    |                            |
| Interfacing with the SCSI Data Bus                                                                                                                                                                                                                                                                                                                       |                            |
| Interfacing with the Host Computer's MPU                                                                                                                                                                                                                                                                                                                 |                            |
| Interfacing with the Host Computer's DMA Controller                                                                                                                                                                                                                                                                                                      |                            |
| Functionality of the 82C5086 Device Controller                                                                                                                                                                                                                                                                                                           | 27                         |
|                                                                                                                                                                                                                                                                                                                                                          |                            |
| SIGNAL DESCRIPTIONS                                                                                                                                                                                                                                                                                                                                      |                            |
| I/O Signals                                                                                                                                                                                                                                                                                                                                              |                            |
| Signals Specific to 8085/8051 Mode                                                                                                                                                                                                                                                                                                                       |                            |
| Signals Specific to Z8 Mode                                                                                                                                                                                                                                                                                                                              | 39                         |
| Signals Specific to Host Adapter Mode                                                                                                                                                                                                                                                                                                                    | 40                         |
| Signals Specific to Wide Data Bus Transfers                                                                                                                                                                                                                                                                                                              | 42                         |
| Signals Specific to The Differential SCSI Interface                                                                                                                                                                                                                                                                                                      | 44                         |
|                                                                                                                                                                                                                                                                                                                                                          |                            |
| Pad Drive Canacity                                                                                                                                                                                                                                                                                                                                       | 47                         |
| Pad Drive Capacity                                                                                                                                                                                                                                                                                                                                       | 45                         |
|                                                                                                                                                                                                                                                                                                                                                          | 45                         |
| ELECTRICAL SPECIFICATIONS                                                                                                                                                                                                                                                                                                                                |                            |
| ELECTRICAL SPECIFICATIONS<br>A.C. Specifications                                                                                                                                                                                                                                                                                                         | 46                         |
| ELECTRICAL SPECIFICATIONS<br>A.C. Specifications<br>Clock Timing                                                                                                                                                                                                                                                                                         | 46                         |
| ELECTRICAL SPECIFICATIONS<br>A.C. Specifications<br>Clock Timing<br>Z8 Mode Timing                                                                                                                                                                                                                                                                       | 46<br>46<br>47             |
| ELECTRICAL SPECIFICATIONS<br>A.C. Specifications<br>Clock Timing<br>Z8 Mode Timing<br>8085/8051 Mode Timing                                                                                                                                                                                                                                              | 46<br>46<br>47<br>49       |
| ELECTRICAL SPECIFICATIONS<br>A.C. Specifications<br>Clock Timing<br>Z8 Mode Timing<br>8085/8051 Mode Timing<br>Non-multiplexed Mode Timing                                                                                                                                                                                                               | 46<br>46<br>47<br>49<br>51 |
| ELECTRICAL SPECIFICATIONS<br>A.C. Specifications<br>Clock Timing                                                                                                                                                                                                                                                                                         |                            |
| ELECTRICAL SPECIFICATIONS<br>A.C. Specifications<br>Clock Timing<br>Z8 Mode Timing<br>8085/8051 Mode Timing<br>Non-multiplexed Mode Timing<br>Timing for Data Transfers to System Memory<br>Timing for I/O Interface to Buffer Memory                                                                                                                    |                            |
| ELECTRICAL SPECIFICATIONS<br>A.C. Specifications<br>Clock Timing<br>Z8 Mode Timing<br>8085/8051 Mode Timing<br>Non-multiplexed Mode Timing<br>Timing for Data Transfers to System Memory<br>Timing for I/O Interface to Buffer Memory<br>SCSI Interface Timing                                                                                           |                            |
| ELECTRICAL SPECIFICATIONS<br>A.C. Specifications<br>Clock Timing<br>Z8 Mode Timing<br>8085/8051 Mode Timing<br>Non-multiplexed Mode Timing<br>Timing for Data Transfers to System Memory<br>Timing for I/O Interface to Buffer Memory<br>SCSI Interface Timing<br>D.C. Specifications                                                                    |                            |
| ELECTRICAL SPECIFICATIONS<br>A.C. Specifications.<br>Clock Timing.<br>Z8 Mode Timing.<br>8085/8051 Mode Timing.<br>Non-multiplexed Mode Timing<br>Timing for Data Transfers to System Memory.<br>Timing for I/O Interface to Buffer Memory.<br>SCSI Interface Timing<br>D.C. Specifications.<br>Absolute Maximum Ratings.                                |                            |
| ELECTRICAL SPECIFICATIONS<br>A.C. Specifications.<br>Clock Timing.<br>Z8 Mode Timing.<br>8085/8051 Mode Timing.<br>Non-multiplexed Mode Timing.<br>Timing for Data Transfers to System Memory.<br>Timing for I/O Interface to Buffer Memory.<br>SCSI Interface Timing.<br>D.C. Specifications.<br>Absolute Maximum Ratings.<br>Standard Test Conditions. |                            |
| ELECTRICAL SPECIFICATIONS<br>A.C. Specifications<br>Clock Timing<br>Z8 Mode Timing<br>8085/8051 Mode Timing<br>Non-multiplexed Mode Timing<br>Timing for Data Transfers to System Memory<br>Timing for I/O Interface to Buffer Memory<br>SCSI Interface Timing<br>D.C. Specifications<br>Absolute Maximum Ratings                                        |                            |

## CHAPTER 3. 82C5086 OPERATION

| MODES OF OPERATION                      | 73 |
|-----------------------------------------|----|
| Initiator and Target Modes              | 73 |
| Role of Initiator                       |    |
| Role of the Target                      |    |
| Differential and Non-Differential Mode  |    |
| Transfer Modes                          | 74 |
| Asynchronous Transfers                  | 76 |
| Synchronous Transfers                   | 76 |
| Master/Slave Mode                       |    |
| Master/Master Mode                      |    |
| Slave/Master Mode                       |    |
| Slave/Slave Mode                        |    |
| Synchronizing Memory Data Bus Transfers |    |
| Synchronizing SCSI Bus Data Transfers   |    |
| Hardware Specifications                 |    |
|                                         |    |

| METHOD OF OPERATION                      | 81  |
|------------------------------------------|-----|
| I/O Interface                            | 81  |
| Command Set                              | 82  |
| Memory Structure                         | 82  |
| Ďata FIFO                                | .84 |
| MCS Script                               | 84  |
| Pipelining Structure                     | 85  |
| Example 1. SCSI Transfer Command         | 86  |
| Example 2. SCSI Select/Reselect Process. | 89  |

## CHAPTER 4. 82C5086 REGISTERS

| FUNCTION OF THE 5086'S REGISTERS | 93  |
|----------------------------------|-----|
| REGISTER DESCRIPTION             | 94  |
| REGISTERS 0-3                    | 95  |
| REGISTER 4                       |     |
| REGISTER 5                       |     |
| REGISTER 6                       | 105 |
| REGISTER 7                       |     |
| REGISTER 8                       |     |
| REGISTER 9                       |     |
| REGISTER 10                      | 116 |
| REGISTER 11                      |     |
| REGISTER 12                      |     |
| REGISTER 13                      |     |
| REGISTER 14                      |     |
| REGISTER 15                      |     |
| REGISTERS 16-18                  |     |
| REGISTER 19                      |     |
| REGISTER 20                      |     |
| REGISTER 21                      |     |
| REGISTER 22                      |     |
| REGISTER 23                      |     |
|                                  |     |

## CHAPTER 5. 82C5086 COMMANDS

(

| COMMAND FUNCTIONS                             |     |
|-----------------------------------------------|-----|
| COMMAND DESCRIPTION NOTATIONS AND CONVENTIONS |     |
| Command Code                                  |     |
| Bus Condition                                 |     |
| Execution Time                                | 139 |
| Operational Description                       |     |
| Possible Errors                               | 140 |
| CONTROL COMMAND DESCRIPTIONS                  |     |
| CNTL NOP - No Operation                       |     |
| CNTL RST FIFO - Control Reset Data FIFO       | 143 |
| CNTL RST ON - Control RESET On                | 144 |
|                                               |     |

| CNTL RST OFF - Control RESET Off1                                    | 144 |
|----------------------------------------------------------------------|-----|
| CNTL ATN ON - Control Attention On                                   | 145 |
| CNTL ATN OFF - Control Attention Off                                 | 145 |
| CNTL ENB SEL - Control Enable Select                                 | 146 |
| CNTL DIS SEL - Control Disable Select                                | 147 |
| CNTL ENB RESEL - Control Enable Reselect                             | 148 |
| CNTL DIS RESEL - Control Disable RESELECT                            | 149 |
| CNTL ENB ADV - Control Enable MCS Auto Advance                       | 150 |
| CNTL DIS ADV - Control Disable MCS Auto Advance                      | 151 |
| CNTL DATA PTM - Control Data from MPU to Memory Data Bus1            | 152 |
| CNTL DATA MTP - Control Data from Memory Data Bus to MPU1            | 153 |
|                                                                      |     |
| INITIATOR COMMAND DESCRIPTIONS                                       |     |
| INIT SWOA SEQ - Initiator Select without Attention Sequence          | 155 |
| INIT SWA SEQ - Initiator Select with Attention Sequence              | 157 |
| INIT SWOA CMD - Initiator Select without Attention Command           |     |
| INIT SWA CMD - Initiator Select with Attention Command               |     |
| INIT REC INFO - Initiator Receive Information                        |     |
| INIT DATA MTS - Initiator Receive Data from Memory Data to SCSI Bus1 | 162 |
| INIT DATA PTS - Initiator Receive Data from MPU to SCSI Bus          | 163 |
| INIT DATA STM - Initiator Receive Data from SCSI to Memory Data Bus  | 164 |
| INIT DATA STP - Initiator Receive Data from SCSI to MPU Bus          | 165 |
| INIT SEND MSG - Initiator Send Message                               |     |
| INIT SEND CMD - Initiator Send Command                               | 167 |
| INIT XFER PAD - Initiator Transfer Pad                               | 169 |
| INIT XFER BYTE - Initiator Transfer Byte                             | 170 |
| INIT CMDC SEQ - Initiator Command Complete/Disconnect Sequence       | 171 |
| INIT WFR CMD - Initiator Wait for Reselect                           | 173 |
| INIT WFR SEQ - Initiator Wait for Reselect Sequence                  | 174 |
|                                                                      |     |
| TARGET COMMAND DESCRIPTIONS                                          |     |
| TGT SEND MSG - Target Send Message                                   | 1// |
| TGT SEND STAT - Target Send Status                                   | 1/8 |
| TGT DATA MTS - Target Receive Data from Memory Data Bus to SCSI Bus1 | 1/9 |
| TGT DATA PTS - Target Receive Data from MPU to SCSI Bus              | 180 |
| TGT REC CMD - Target Receive Command                                 | 181 |
| TGT REC MSG - Target Receive Message                                 | 182 |
| TGT DATA STM - Target Receive Data from SCSI to Memory Data Bus      | 183 |
| TGT DATA STP - Target Receive Data from SCSI to MPU Bus              | 184 |
| TGT CMDC SEQ - Target Command Complete Sequence                      | 185 |
| TGT XFER BYTE - Target Transfer Byte                                 | 186 |
| TGT DISC CMD - Target Disconnect Command                             | 18/ |
| TGT DISC SEQ - Target Disconnect Sequence                            | 188 |
| TGT RCNT SEQ - Target Reconnect Sequence                             | 189 |
| TGT SEND BSY - Target Send Busy Command                              | 190 |
| TGT WFS CMD - Target Wait for Select Command                         | 191 |
| TGT WFS SEQ - Target Wait for Select Sequence                        | 192 |
| APPENDIX A. DEVICE FLOW CHART                                        | 105 |
|                                                                      | 170 |
| GLOSSARY                                                             | 197 |
| INDEX                                                                |     |
|                                                                      |     |

## TABLES

| 1-1. 82C5086 Commands                                    | 9   |
|----------------------------------------------------------|-----|
| 1-2. A List of D.C. Characteristics                      |     |
| 1-3. Supported Features                                  |     |
|                                                          |     |
| 2-1. A Pin List of the 68-pin Package                    |     |
| 2-2. A Pin List of the 80-pin Package                    | 19  |
| 2-3. A Pin List of the 84-pin Package                    |     |
| 2-4. Input/Output Signals                                |     |
| 2-5. Signals Specific to 8085/8051 Mode                  |     |
| 2-6. Signals Specific to Z8 Mode                         |     |
| 2-7. Signals Specific to Host Adapter Mode               | 40  |
| 2-8. Signals Specific to Wide Data Bus Transfers         |     |
| 2-9. Signals Specific to The Differential SCSI Interface |     |
| 2-10. Pad Drive Capacity                                 |     |
| 2-11. Absolute Maximum Ratings                           |     |
| 2-12. D.C. Characteristics                               |     |
| 2-13. D.C. Characteristics for Drivers/Receivers         |     |
|                                                          |     |
| 3-1. Mode Control Register Setting                       |     |
| 3-2. Master/Slave Mode                                   |     |
|                                                          |     |
| 4-1. Addressing The 82C5086 Registers                    |     |
|                                                          |     |
| 5-1. 82C5086 Control Commands                            |     |
| 5-2. 82C5086 Initiator Commands                          |     |
| 5-3. Command Length Codes                                |     |
| 5-4. 82C5086 Target Commands                             | 1/6 |

## FIGURES

| 1-1. Uses of the 82C5086                                    | 1  |
|-------------------------------------------------------------|----|
| 1-2. Block Diagram of the 82C5086                           | 2  |
| 1-3. Diagram of an AT Host Adapter System Configuration     |    |
| 1-4. Example Diagram of a Device System Configuration       |    |
| 1-5. Typical Wide SCSI Bus Configuration                    | 8  |
| 2-1. Physical Pin out of the 68-pin PLCC Package            | 15 |
| 2-2. Diagram of the 68-pin PLCC Package Specification       |    |
| 2-3. Physical Pin out of the 80-pin PFP Package             |    |
| 2-4. Diagram of the 80-pin PFP Package Specification        |    |
| 2-5. Physical Pin out of the 84-pin PLCC Package            |    |
| 2-6. Diagram of the 84-pin PLCC Package Specification       |    |
| 2-7. Functional Pin out of the 82C5086 Host Adapter         |    |
| 2-8. Functional Pin out of a 82C5086 Device Controller      |    |
| 2-9. Clock Timing Characteristics                           |    |
| 2-10. Write Operation Z8 Mode Timing Characteristics        |    |
| 2-11. Read Operation Z8 Mode Timing Characteristics         |    |
| 2-12. Write Operation 8085/8051 Mode Timing Characteristics |    |
|                                                             |    |

| 2-13.      | Read Operation 8085/8051 Mode Timing Characteristics               | 50  |
|------------|--------------------------------------------------------------------|-----|
|            | Write Operation, Non-multiplexed MPU Timing Characteristics        |     |
|            | Read Operation, Non-multiplexed MPU Timing Characteristics         |     |
| 2-16.      | MPU Write IORDY Timing Characteristics                             | 54  |
|            | MPU Read IORDY Timing Characteristics.                             |     |
|            | FIFO_RDY with Address Timing Characteristics                       |     |
|            | FIFO_RDY without Address Timing Characteristics                    |     |
|            | DMA Interface, Write to 82C5086 Timing Characteristics             |     |
| 2-21.      | DMA Interface, Read from 82C5086 Timing Characteristics            | 59  |
| 2-22.      | SCSI Arbitration Timing Characteristics                            | 60  |
| 2-23.      | SCSI Select/Reselect Timing Characteristics                        | 61  |
| 2-24.      | SCSI Target Asynchronous Transfer Output Timing Characteristics    | 62  |
| 2-25.      | SCSI Target Asynchronous Transfer Input Timing Characteristics     | 63  |
| 2-26.      | SCSI Initiator Asynchronous Transfer Output Timing Characteristics | 64  |
|            | SCSI Initiator Asynchronous Transfer Input Timing Characteristics  |     |
|            | SCSI Target Synchronous Transfer Output Timing Characteristics     |     |
|            | SCSI Target Synchronous Transfer Input Timing Characteristics      |     |
|            | SCSI Initiator Synchronous Transfer Output Timing Characteristics  |     |
| 2-31.      | SCSI Initiator Synchronous Transfer Input Timing Characteristics   | 69  |
| <b>.</b> . |                                                                    |     |
|            | Diagram of the 5086's Support of Differential SCSI Mode            |     |
|            | Functional Pin out of Cascaded 5086s                               |     |
| 3-3.       |                                                                    |     |
| 3-4.       | 5086's Command Queuing                                             | 87  |
| A 1        | Device Flow Obert                                                  | 100 |
| A-1.       | Device Flow Chart                                                  | 170 |

#### INTRODUCTION

The CHIPS 82C5086 SCSI controller provides all the functions needed to implement the SCSI interface on a host computer or a device controller. The chip provides an I/O interface to the SCSI bus and to the other system components (e.g., buffer memory, the on-board microprocessor (MPU), and the host computer).

Used as a host adapter, the 82C5086 functions as a bridge between the host computer bus and the SCSI bus. In this application, the 82C5086 connects an 8- or 16-bit host computer data bus to an 8-bit SCSI data bus. Used as a device controller, the 82C5086 interfaces such peripheral equipment as a Winchester drive to the SCSI bus. Refer to Figure 1-1 for an illustration of these two applications. For more details on 82C5086 applications refer to the section "Typical Applications".



#### Figure 1-1. Uses of the 82C5086

1

The 82C5086's hardware and firmware make it a flexible, as well as a powerful, chip. It is available in a number of package options, and can be purchased with or without firmware, standalone, or as part of a board product.

#### Hardware Features

The 82C5086's memory structure consists of 64 bytes of FIFO and six individual 32-byte Message/Command Space (MCS) scripts. The large **FIFO buffer** is used to store all the data transferred between the MPU's bus, the memory data bus or the SCSI bus. This increases system throughput by smoothing out the system's data transfers.

The MCS is a valuable tool for tailoring the 82C5086 to the needs of particular applications. It can be used to store blocks of frequently used commands, messages, and status. For instance, if the 82C5086 is used as a host adapter operating as an initiator in a system configuration with an 80286 host MPU, firmware engineers might decide to use the MCS to store messages frequently sent by the initiator. This improves system performance because the information can be accessed as a block, and does not have to be retrieved from system memory. Because the 82C5086 provides two MCS address pointers the MPU can be processing one MCS segment, while the 82C5086 state machine (SM) is simultaneously processing another 32-byte MCS segment. Figure 1-2 shows a simplified block diagram of the chip's functions.



Figure 1-2. Block Diagram of the 82C5086

The 82C5086's 24 registers provide a means for firmware engineers to control the 82C5086's internal operation, and to gain status on the 82C5086's operation. The 82C5086's first four registers, the command pipeline registers, in conjunction with the MCS, enable up to four 82C5086 commands to be queued.

The 82C5086 hardware has an internal state machine that manages the system flow of SCSI information. Because the 82C5086 hardware is managing this lower-level task, the firmware is free to manage such higher-level system activities as task scheduling and resource allocation.

The 82C5086's **bus structure** increases system performance and provides system design flexibility. The 82C5086 supports an 8-bit MPU data bus, an 8-bit SCSI bus, and an 8-bit high-speed memory data bus. This separate high-speed data bus increases system throughput by enabling data and control activities to be independent. The 82C5086's bus structure also adds to the chip's versatility. For instance, the bandwidth of the SCSI bus and the memory data bus can be extended from 8 to 16 or 32 bits by cascading 82C5086's. Cascading is supported by the 80- and 84-pin packages. The 82C5086 also supports the option of extending the MPU data bus to 16 bits by using the memory data bus as the MPU's upper data bus. Figure 1-3 shows a 82C5086 host adapter supporting 16-bit MPU data transfers. For more information on cascading 82C5086's refer to the section "Master or Slave Mode".

Other 82C5086 hardware features include a power-on flag, and input pins that support jumper-selectable options that reduce on-board circuitry.

Because the 82C5086 is built using proven CMOS low-power technology it requires only a single +5 Volt supply.

#### **Firmware Features**

Such firmware features as an extensive command set provide firmware engineers with a high degree of control over the 82C5086's operation. The 82C5086's large set of 46 commands enables firmware engineers to exercise a great deal of control over the SCSI bus activities, and to manage the system flow of SCSI information. These commands perform such simple tasks as transferring a byte from the SCSI bus into the MCS, or such series of tasks as receiving a command complete sequence from the SCSI bus, and transferring it into the MCS. Certain control commands can be used to establish a data path between the MPU's data bus, the memory data bus, and the SCSI bus.

One of the 82C5086's main firmware features is command queuing which reduces command overhead. The 82C5086 enables up to four 82C5086 commands to be queued in the pipeline registers. These commands can enable the 82C5086 to sequence through several SCSI bus phases without firmware intervention. For example, the 82C5086 command can handle a complete SCSI command sequence from disconnect, to connect, and to bus free. For more details refer to the section "Command Queuing".

The 82C5086's set of 24 registers provide maximum programming flexibility because registers record the status of all commands executed, and keep records of previous executions. This facilitates the monitoring of command flow, and error recovery.

Another important feature is the 82C5086's support of programmable conditions for interrupt generation. This enables firmware engineers to dictate the conditions under which an interrupt should be generated to the on-board MPU. This is useful because the conditions for interrupt generation will vary depending on the amount of firmware control desired, and whether the 82C5086 is used as an initiator or a target. Thus, firmware engineers can tailor the conditions for interrupt generation to fit their particular applications.

#### TYPICAL APPLICATIONS

The 82C5086 provides application flexibility because it can be designed into a system as a host adapter or a device controller. It also provides system design flexibility. For instance, as well as supporting the option of cascading, the 82C5086 provides two different ways of wiring the 82C5086 to support data transfers to/from system memory. System design engineers can connect the 82C5086's FIFO\_RDY pin to a DMA controller on the system's memory data bus, or they can connect the 82C5086's IORDY pin to the MPU's wait state generator to support burst transfers (string operation) from the MPU to the 82C5086.

#### Host Adapter

Used as a host adapter, the 82C5086 functions as a bridge between the host computer bus and the SCSI bus. The 8-bit bidirectional MPU address/data bus and its associated control signals connect the 82C5086 to the host computer's MPU. The 82C5086 uses the SCSI control bus, comprised of nine 82C5086 control signals, as a path to the SCSI bus. For 16-bit host computer MPU's, the 8-bit memory data bus is used to transfer the high byte. Figure 1-3 shows a configuration in which the 82C5086 is used as a host adapter.

Typically, the host computer requires such information as status or data from the devices connected to the SCSI bus. The host adapter queues up these requests, and sends them to the appropriate device(s) via the SCSI bus. The host adapter enables SCSI peripheral devices to communicate with such host systems as an IBM PC AT that do not directly support the SCSI interface. If system design engineers need a drive capability greater than 4 mA, they must use data bus transceivers. In host adapter mode, the MPU data bus can be extended up to 16 bits; the memory data bus functions as the MPU's upper data bus. In this mode, the 82C5086 performs byte to word packing and unpacking.





#### **Device Controller**

Used as a device controller, the 82C5086 interfaces between such peripheral equipment as a Winchester drive, printers, CD ROMs, optical disks, and the SCSI bus. The device controller communicates with the host adapter via the SCSI bus. Like the host adapter, the device controller provides an interface to the SCSI bus, and an interface to the on-board MPU and DMA controller. Communication with the MPU is via an 8-bit address and data bus and its associated control signals. Communication with the DMA controller is over the bidirectional 8-bit memory data bus. Refer to Figure 1-4.



Figure 1-4. Example Diagram of a Device System Configuration

#### **OPERATIONAL MODES**

The 82C5086 offers application flexibility because of the wide range of operational modes it supports. Used as either a host adapter or a device controller, the 82C5086 supports the SCSI bus initiator or target mode, differential or non-differential mode, asynchronous or synchronous transfer mode, and master or slave mode.

## **Initiator or Target Mode**

Systems can be configured with single or multiple initiators and targets. Typically, the initiator is the host adapter responsible for originating the operation. The 82C5086 initiator arbitrates for the SCSI bus, selects the target device, and sends it a stored multi-byte SCSI command from the MCS. A 82C5086 operating in target mode saves the initiator's device ID, receives the multi-byte command, sends a DISCONNECT message or terminates the sequence, then switches to the BUS FREE phase.

#### Non-Differential or Differential Mode

SCSI bus signals transmitted between initiators and targets can be single-ended or differential. The SCSI-interface controllers must operate in non-differential mode if single-ended drivers/receivers are used, or differential mode if multiple-ended drivers/receivers are used. In differential mode, the 82C5086 supports operation over cables up to 25 meters long. A six meter cable is the maximum supported in non-differential mode.

#### Asynchronous or Synchronous Mode

The 82C5086 supports both asynchronous and synchronous data transfers over the SCSI bus. For high-performance systems, the 82C5086 device can operate in synchronous mode to support one of the highest transfer rates in the industry today.

In asynchronous transfer mode, one byte of information is transferred over the SCSI bus with each REQ/ACK handshake. In this mode, the 82C5086's large, internal FIFO acts as a buffer that evens out data transfers between the SCSI bus and buffer memory to support transfers at 4 megabytes/second. For systems with sustained transfers this buffering can increase system performance. Three of the 82C5086's internal registers, Registers 16-18, provide two 24-bit transfer counters that track data transferred to/from the FIFO.

When the 82C5086 is operating in synchronous mode, a transfer rate and an offset can be specified. This offset, in conjunction with the 82C5086's clock rate of 32 MHz, results in the 82C5086's unbeatable synchronous transfer rate of 5.3 megabytes/second with an offset of up to 64 bytes.

#### Master or Slave Mode

To extend the bandwidth of the SCSI bus and the memory data bus up to 32 bits, the 80-pin or 84-pin 82C5086's can be cascaded. Refer to Figure 1-5. Cascading is supported by the 82C5086's ability to operate in master or slave mode. Through the Mode Control Register, firmware engineers can configure the 82C5086 as a master or slave chip for its main operational mode (e.g., performing such basic operations as transferring data to/from buffer memory), and for its SCSI bus operational mode. In slave mode, the 82C5086 is under the control of the 82C5086 master chip. For instance, the master 82C5086 is responsible for synchronizing the slaves' transfer of data.





#### SYSTEM INTERFACE

The 82C5086 contains functional blocks that support these operational modes (e.g., master/slave, synchronous/asynchronous). These blocks provide the logic necessary for the 82C5086 to interface with the other system components, and to manage the flow of SCSI information through the system. They can be grouped into three categories: the I/O interface, the set of 82C5086 commands, and the memory structure.

#### I/O Interface

It is through its I/O interface that the 82C5086 is able to send/receive signals, addresses, and data to/from the system's other components. This interface enables the 82C5086 to interface to the buffer memory, the on-board MPU, and the SCSI bus.

#### **Command Set**

Through its set of commands, the 82C5086 provides the SCSI protocol for the system flow of command, data, message and status, and allows firmware engineers to transfer data between the MPU and memory data bus. These commands are arranged in control, initiator, and target groups. Refer to Table 1-1.

|                        | CONTROL COMMANDS                                                    |                |                                                                                  |  |  |
|------------------------|---------------------------------------------------------------------|----------------|----------------------------------------------------------------------------------|--|--|
| Command                | Function                                                            | Command        | Function                                                                         |  |  |
| CNTL NOP<br>FIFO.      | No Operation                                                        | CNTL RST FIFO  | Reset 82C5086 data                                                               |  |  |
| CNTL RST ON            | Assert reset signal to SCSI bus.                                    | CNTL RST OFF   | Deassert reset signal to SCSI bus.                                               |  |  |
| CNTL ATN ON            | Assert -ATN signal to SCSI bus.                                     | CNTL -ATN OFF  | Deassert -ATN signal to SCSI bus.                                                |  |  |
| CNTL ENB SEL           | Enable selection.                                                   | CNTL DIS SEL   | Disable selection.                                                               |  |  |
| CNTL ENB RESEL         | Enable reselection.                                                 | CNTL DIS RESEL | Disable reselection.                                                             |  |  |
| CNTL ENB ADV           | Enable MCS auto advance.                                            | CNTL DIS ADV   | Disable MCS auto advance.                                                        |  |  |
| CNTL DATA PTM          | Receive MPU data<br>and send it to the<br>memory data bus.          | CNTL DATA MTP  | Receive data from the memory data bus and send it to MPU.                        |  |  |
|                        |                                                                     | COMMANDS       |                                                                                  |  |  |
| Command                | Initiator Function                                                  | Command        | Initiator Function                                                               |  |  |
| INIT SWOA SEQ          | Select target without attention sequence.                           | INIT SWA SEQ   | Select target with attention sequence.                                           |  |  |
| INIT SWOA CMD          | Select target without attention.                                    | INIT SWA CMD   | Select target with attention.                                                    |  |  |
| INIT REC INFO          | Receive information.                                                | INIT DATA MTS  | Receive data from the<br>memory data bus and<br>send it to the SCSI<br>data bus. |  |  |
| INIT DATA PTS          | Receive data from<br>MPU and send it to<br>the SCSI data bus.       | INIT DATA STM  | Receive data from<br>SCSI bus and send it to<br>the memory data bus.             |  |  |
| INIT DATA STP          | Receive data from<br>SCSI bus and send it<br>to the MPU's data bus. | INIT SEND MSG  | Send message.                                                                    |  |  |
| INIT SEND CMD          | Send multi-byte command.                                            | INIT XFER PAD  | Transfer filler data.                                                            |  |  |
| INIT XFE <b>R BYTE</b> | Transfer byte.                                                      | INIT CMDC SEQ  | Perform COMMAND<br>COMPLETE/DIS-<br>CONNECT sequence.                            |  |  |
| INIT WFR CMD           | Wait for reselect phase.                                            | INIT WFR SEQ   | Wait to be reselected,<br>then reconnect.                                        |  |  |

## Table 1-1. 82C5086 Commands

| Table 1-1. 82C50 | 86 Commands | (continued) |
|------------------|-------------|-------------|
|------------------|-------------|-------------|

| TARGET COMMANDS |                                                                          |               |                                                                            |  |
|-----------------|--------------------------------------------------------------------------|---------------|----------------------------------------------------------------------------|--|
| Command         | Target Function                                                          | Command       | Target Function                                                            |  |
| TGT SEND MSG    | Send message.                                                            | TGT SEND STAT | Send status to the initiator.                                              |  |
| TGT DATA MTS    | Receive data from the<br>memory data bus and<br>send it to the SCSI bus. | TGT DATA PTS  | Receive data from the MPU bus and send it to the SCSI bus.                 |  |
| TGT REC CMD     | Receive a multi-byte command.                                            | TGT REC MSG   | Receive a single-byte<br>or multi-byte<br>message.                         |  |
| TGT DATA STM    | Receive data from the SCSI bus and send it to the memory data bus.       | TGT DATA STP  | Receive data from the<br>SCSI bus and send it<br>to the MPU's data<br>bus. |  |
| TGT CMDC SEQ    | Perform COMMAND<br>COMPLETE sequence.                                    | TGT XFER BYTE | Transfer byte.                                                             |  |
| TGT DISC CMD    | Disconnect from the SCSI bus.                                            | TGT DISC SEQ  | Perform<br>DISCONNECT<br>sequence.                                         |  |
| TGT RCNT SEQ    | Perform RECONNECT sequence.                                              | TGT SEND BSY  | Wait for select, then<br>send busy response<br>and disconnect.             |  |
| TGT WFS CMD     | Wait for select.                                                         | TGT WFS SEQ   | Perform Wait for<br>Select sequence.                                       |  |

#### Memory Structure

The first segment of 82C5086 memory, the 64-byte FIFO, is used in SCSI bus data transfers, and in data transfers between the MPU's data bus and the memory data bus. The second segment, the MCS, stores SCSI sequences and supports the 82C5086's command queuing capability.

#### PERFORMANCE SPECIFICATIONS

When the 82C5086 is operating in synchronous mode, a transfer rate of 5.3 megabytes/second at a clock rate of 32 MHz is supported. The transfer rate in asynchronous mode is 4 megabytes/second (over a 20 foot cable length).

When upgrading a system from a 5080 chip to a 82C5086, it is recommended that the system configuration be upgraded with a faster clock to ensure higher performance. The clock frequency for the 82C5086 chip should be increased to 24-32 MHz. Command overhead is 25 microseconds.

#### ELECTRICAL SPECIFICATIONS

The 82C5086 is built using CMOS low-power technology. It operates from a single +5 Volt supply. Refer to the following sections for information on absolute maximum ratings and D.C. characteristics.

#### Absolute Maximum Ratings

Absolute maximum ratings are as follows:

- A power supply voltage of -0.3 to 7.0 VDC
- An ambient operating temperature of 0 to +70.0 degrees C
- A storage temperature of -65.0 to +150.0 degrees C.

#### CAUTION

Stresses greater than those indicated may cause permanent damage to the chip. Operation of the chip at conditions above those shown is not implied. Exposure to absolute maximum rating conditions for extended periods may affect the chip's reliability.

#### **D.C.** Characteristics

Refer to Table 1-2 for a list of D.C. characteristics.

| PARAMETER                      | MIN  | MAX             | UNIT |
|--------------------------------|------|-----------------|------|
| Input High Voltage             | 2    | Vœ              | V    |
| Input Low Voltage              | -0.3 | 0.8             | V    |
| Output High Voltage            | 2.4  | V <sub>cc</sub> | V    |
| Output Low Voltage             |      | 0.4             | V    |
| High-level Output Current      |      | -4              | mA   |
| Low-level Output Current       |      | 4               | mA   |
| Input Leakage                  | -30  | 10              | μA   |
| Output Leakage                 | 10   |                 | μА   |
| V <sub>cc</sub> Supply Current |      | 50              | mA   |

#### Table 1-2. A List of D.C. Characteristics

D.C. characteristics for drivers/receivers are as follows:

- Drivers sink 48 mA @ 0.5 VDC asserted.
- Receivers are asserted when input equals 0 to 0.8 VDC.
- Receivers are non-asserted when input equals 2.0 to 5.25 VDC.

## PACKAGING

.

The 82C5086 is available in a number of package options: the 68-pin PLCC, the 80-pin PFP, and the 84-pin PLCC; each providing a different level of support. Refer to Table 1-3.

| Feature                            | 68-Pin<br>PLCC<br>Package | 80-Pin<br>PFP<br>Package | 84-Pin<br>PLCC<br>Package |
|------------------------------------|---------------------------|--------------------------|---------------------------|
| 5080 compatability                 | √                         | V                        |                           |
| Non-differential drivers/receivers | √                         | 1                        | $\checkmark$              |
| Differential drivers/receivers     |                           | $\checkmark$             | $\checkmark$              |
| Non-multiplexed MPU buses          |                           | $\checkmark$             | $\checkmark$              |
| Multiplexed MPU buses              | $\checkmark$              | √                        | $\checkmark$              |
| 32-bit SCSI and memory data buses  |                           | $\checkmark$             | $\checkmark$              |
| Asynchronous transfers             | √                         | V                        | $\checkmark$              |
| Synchronous transfers              | √                         | $\checkmark$             | $\checkmark$              |
| Host adapter mode                  |                           |                          | $\checkmark$              |

| Table | 1-3. | Supported | Features  |
|-------|------|-----------|-----------|
|       |      | Capponea  | r cutulog |

This chapter is directed at hardware engineers intending to design the 82C5086 SCSI-bus interface controller into their systems. Physical and functional pin specifications, signal descriptions, timing specifications, and electrical specifications are provided.

#### PHYSICAL SPECIFICATIONS

The 82C5086 device is available in a 68-pin PLCC, 80-pin PFP, or 84-pin PLCC package. Each of these versions of the chip, like the 5080 chip, supports the following functions:

- Asynchronous SCSI data transfers
- Non-differential (single-ended drivers/receivers) SCSI interface
- Connection to a multiplexed MPU address/data bus (e.g., Z8 or 8085/8051)
- An 8-bit wide SCSI bus.

Advantages of upgrading from a 5080 to a 82C5086 include the following added functionality:

- Synchronous, as well as faster asynchronous data transfers, are supported. The asynchronous transfer rate with the 82C5086 is 4 megabytes per second verses the 5080's rate of 1.1 megabytes per second. The 5080C and 20513B KOMBO II support a transfer rate of 2.5 megabytes per second. Synchronous data transfer rates at 5.3 megabytes per second are supported by the 82C5086.
- The 82C5086 has on-chip memory that enables up to four SCSI commands to be queued.
- The 82C5086 provides 64 bytes of data FIFO to even out data transfers and to increase system performance.
- The 82C5086 command set, which is comprised of 46 commands, performs the SCSI protocol for command, data, message and status flow. This enables the firmware to manage system level activities.

Because the 68- and 80-pin packages are pin compatible with the 5080 chip, hardware engineers can upgrade a 5080 board with a 82C5086 chip without having to modify the system hardware. However, it is recommended that the system configuration be upgraded with a faster clock for higher performance. Clock frequency for the 82C5086 chip should be increased to 24-32 MHz.

The 80-pin package supports all of the functions available with the 68-pin package plus the following additional capabilities:

- Support of the differential (multiple-ended drivers/receivers), as well as non-differential, SCSI interface
- Connection to MPUs that have non-multiplexed address/data buses, as well as connection to multiplexed MPUs
- Support of wide SCSI and wide memory data bus transfers of 16 or 32 bits, as well as 8-bit data transfers.

Because the 84-pin package is a superset of the 68- and 80-pin packages it provides all the preceding functionality plus full AT host adapter support. The additional signals that enable the 84-pin package to be connected directly to the AT bus are the system -16BHAM, -MPU\_ACK, and MPU\_AEN signals. Data bus transceivers are required when connecting a 82C5086 as an IBM AT data bus.

Refer to the following three sections for details on each of these packages.

#### 68-Pin PLCC Package

Refer to Figure 2-1 for a physical pin out of the 68-pin PLCC package.

Table 2-1 provides a pin list for the 68-pin package. Note an active low polarity is indicated by a minus sign (-) prefix; a plus sign (+) indicates an active high polarity. Refer to the section "Functional Chip Specifications" later in this chapter for information on the pin functions.



Figure 2-1. Physical Pin out of the 68-pin PLCC Package

| Pin<br>Number | Pin<br>Name | I/O            | Pin<br>Number | Pin<br>Name | I/O      |
|---------------|-------------|----------------|---------------|-------------|----------|
| 1             | GND 0       | I              | 35            | GND_1       | <u> </u> |
| 2             | +A_D[0]     | <br>I/         | 36            | +MEM D[0]   |          |
| 3             | +A D[1]     | <u></u><br>1/O | 37            | +MEM D[1]   | I/O      |
| 4             | +A D[2]     | I/O            | 38            | +MEM_D[2]   | I/O      |
| 5             | +A_D[3]     | I/O            | 39            | +MEM_D[3]   | I/O      |
| 6             | +A_D[4]     | I/O            | 40            | +MEM_D[4]   | I/O      |
| 7             | +A_D[5]     | I/O            | 41            | +MEM_D[5]   | I/O      |
| 8             | +A_D[6]     | I/O            | 42            | +MEM_D[6]   | I/O      |
| 9             | +A_D[7]     | 1/0            | 43            | +MEM_D[7]   | I/O      |
| 10            | -HOST_D_P   | I/O            | 44            | -ATN        | I/O      |
| 11            | -HOST_D[7]  | Į٥             | 4             | -BSY        | I/O      |
| 12            | DRV_GND_0   | I              | 46            | DRV_GND_3   | I        |
| 13            | HOST_D[6]   | I/O            | 47            | -ACK        | I/O      |
| 14            | -HOST_D[5]  | I/O            | 48            | -RESET_IN   | I/O      |
| 15            | -HOST_D[4]  | I/O            | 49            | VDD_1       | I        |
| 16            | -HOST_D[3]  | 1/0            | 50            | -MSG        | I/O      |
| 17            | DRV_GND_1   | Ι              | 51            | -SEL        | I/O      |
| 18            | -HOST_D[2]  | I/O            | 52            | DRV_GND_4   | Ι        |
| 19            | -HOST_D[1]  | ΙO             | 5             | -C_D        | I/O      |
| 20            | VDD_0       | Ι              | 54            | -REQ        | I/O      |
| 21            | -HOST_D[0]  | Į/O            | 55            | -I_O        | I/O      |
| 22            | +BUF_OUT    | 0              | 56            | -RESET_CAP  | I        |
| 23            | DRV_GND_2   | Ι              | 57            | DRV_GND_5   | Ι        |
| 24            | +INP1[0]    | Ι              | 58            | -RESET_OUT  | 0        |
| 25            | +INP1[1]    | Ι              | 59            | +CLOCK      | Ι        |
| 26            | +INP1[2]    | Ι              | 60            | +INTERRUPT  | 0        |
| 27            | +INP1[3]    | I              | 61            | -XOR[7]     | Ι        |
| 28            | +INP1[4]    | I/O            | 62            | -XOR[6]     | Ι        |
| 29            | +BUF_IN     | Ι              | 63            | -XOR[5]     | Ι        |
| 30            | IORDY       | 0              | 64            | +CONFIG1    | Ι        |
| 31            | +FIFO_RDY   | 0              | 65            | +IO-MEMDM   | Ι        |
| 32            | NC[1]       | N/A            | 66            | -IORDDS     | Ι        |
| 33            | -DMA_ACK    | I              | 67            | -IOWR_R-W   | Ι        |
| 34            | -DMA_REQ    | 0              | 68            | +ALEAS      | Ι        |

## Table 2-1. A Pin List of the 68-pin Package

### 68-Pin PLCC Package Specifications

Figure 2-2 provides a diagram of the package specifications for the 68-pin PLCC package.





#### 80-Pin PFP Package

Refer to Figure 2-3 for a physical pin out of the 80-pin package. Table 2-2 provides a pin list for the 80-pin package. Note an active low polarity is indicated by a minus sign (-) prefix; a plus sign (+) prefix indicates high polarity. For information on this package's pin functions refer to the "Functional Chip Specifications" section later in this chapter.



Figure 2-3. Physical Pin out of the 80-pin PFP Package

| Pin    | Pin        | I/O | Pin    | Pin        | I/O |
|--------|------------|-----|--------|------------|-----|
| Number | Name       |     | Number | Name       |     |
| 1      | +INTERRUPT | 0   | 41     | +INP1[2]   | I   |
| 2      | +DIF_ENB   | I   | 42     | -DIF_BSY   | Ι   |
| 3      | +ARB       | 0   | 43     | -DIF_SEL   | I   |
| 4      | -XOR[7]    | I   | 44     | +INP1[3]   | I   |
| 5      | XOR[6]     | I   | 45     | +INP1[4]   | I/O |
| 6      | -XOR[5]    | I   | 46     | +BUF_IN    | I   |
| 7      | +CONFIG1   | I   | 47     | IORDY      | 0   |
| 8      | +IO-MEMDM  | I   | 48     | +FIFO_RDY  | 0   |
| 9      | -IORDDS    | I   | 49     | +A3        | I   |
| 10     | -IOWR_R-W  | Ι   | 50     | -DMA_ACK   | I   |
| 11     | +ALEAS     | I   | 51     | -DMA_REQ   | 0   |
| 12     | GND_0      | I   | 52     | GND_1      | I   |
| 13     | +A_D[0]    | I/O | 53     | +MEM_D[0]  | I/O |
| 14     | +A_D[1]    | I/O | 54     | +MEM_D[1]  | I/O |
| 15     | +A_D[2]    | I/O | 55     | +MEM_D[2]  | I/O |
| 16     | +A_D[3]    | I/O | 56     | +MEM_D[3]  | I/O |
| 17     | +A_D[4]    | I/O | 57     | +MEM_D[4]  | I/O |
| 18     | +A_D[5]    | I/O | 58     | +MEM_D[5]  | I/O |
| 19     | +A_D[6]    | I/O | 59     | +MEM_D[6]  | I/O |
| 20     | +A_D[7]    | Į/O | 60     | +MEM_D[7]  | I/O |
| 21     | +DIF_DIR   | 0   | 61     | +CONFIG2   | I   |
| 22     | +TAR_ENB   | 0   | 62     | -WPAR      | I/O |
| 23     | +INR_ENB   | 0   | 63     | -DSYNC     | I/O |
| 24     | -HOST_D_P  | I/O | 64     | -ATN       | I/O |
| 25     | HOST_D[7]  | I/O | 65     | -BSY       | I/O |
| 26     | DRV_GND_   | I   | 66     | DRV_GND_3  | I   |
| 27     | -HOST_D[6] | I/O | 67     | -ACK       | I/O |
| 28     | -HOST_D[5] | I/O | 68     | -RESET_IN  | I/O |
| 29     | -HOST_D[4] | I/O | 69     | VDD_1      | Ι   |
| 30     | -HOST_D[3] | I/O | 70     | -MSG       | I/O |
| 31     | DRV_GND_1  | Ι   | 71     | -SEL       | I/O |
| 32     | -HOST_D[2] | I/O | 72     | DRV_GND_4  | I   |
| 33     | -SSYNC     | I/O | 73     | +A4        | I   |
| 34     | -HOST_D[1] | I/O | 74     | -C_D       | I/O |
| 35     | VDD_0      | Ι   | 75     | -REQ       | I/O |
| 36     | -HOST_D[0] | I/O | 76     | -I_O       | I/O |
| 37     | +BUF_OUT   | 0   | 77     | -RESET_CAP | I   |
| 38     | DRV_GND_2  | Ι   | 78     | DRV_GND_5  | I   |
| 39     | +INP1[0]   | Ι   | 79     | -RESET_OUT | 0   |
| 40     | +INP1[1]   | I   | 80     | +CLOCK     | I   |

···· /

Table 2-2. A Pin List of the 80-pin Package

## 80-Pin PFP Package Specifications

Figure 2-4 provides a diagram of the package specifications for the 80-pin PFP package.



Figure 2-4. Diagram of the 80-pin PFP Package Specification

#### 84-Pin PLCC Package

Refer to Figure 2-5 for a physical pin out for the 84-pin package. Table 2-3 provides a pin list of the 84-pin package. Note an active low polarity is indicated by a minus sign (-) prefix; a plus sign (+) prefix indicates an active high polarity. Refer to the section "Functional Chip Specifications" later in this chapter for functional information on this package's pins.



Figure 2-5. Physical Pin out of the 84-pin PLCC Package

| Pin<br>Number | Pin<br>Name          | I/O      | Pin<br>Number | Pin<br>Name | 1/0             |
|---------------|----------------------|----------|---------------|-------------|-----------------|
| 1 1           | GND 0                | Y        | 43            | GND 1       | T               |
| 2             | +A_D[0]              | 10       | 44            | +MEM_D[0]   |                 |
| 3             | $+A_D[0]$<br>+A_D[1] |          | 45            | +MEM_D[1]   |                 |
| <u> </u>      | $+A_D[1]$<br>+A_D[2] | 10       | 45            | $+MEM_D[2]$ | -1/0            |
| <u>4</u><br>5 |                      | 10       | 40            | +MEM $D[3]$ | <u>_1/O</u>     |
| <u> </u>      | +A_D[3]<br>+A_D[4]   | 10       | 47            | $+MEM_D[3]$ | -10             |
| 7             | $+A_D[4]$<br>+A_D[5] | 10       | 40            | +MEM_D[5]   | 1/0             |
| 8             |                      |          | 50            | $+MEM_D[6]$ | <u>_10</u>      |
| <u>8</u><br>9 | +A_D[6]              | 10       | 51            | +MEM $D[7]$ | $\frac{10}{10}$ |
|               | +A_D[7]              | 1/0      |               | — • • • •   |                 |
| 10            | +DIF_DIR             | 0        | 52            | +CONFIG 2   | I               |
| 11            | +TAR_ENB             | 0        | 53            | -WPAR       | 1/0             |
| 12            | GND_2                | l        | 54            | -MPU_ACK    | I               |
| 13            | +INR_ENB             | 0        | 55            | -DSYNC      | 1/0             |
| 14            | -HOST_D_P            | 1/0      | 56            | -ATN        | 1/0             |
| 15            | -HOST_D[7]           | Į(O      | 57            | -BSY        | 1/0             |
| 16            | DRV_GND_0            | <u> </u> | 58            | DRV_GND_3   | 1               |
| 17            | -HOST_D[6]           | I/O      | 59            | -ACK        | 1/0             |
| 18            | -HOST_D[5]           | I/O      | 60            | -RESET_IN   | Į/O             |
| 19            | -HOST_D[4]           | I/O      | 61            | VDD_1       | <u> </u>        |
| 20            | -HOST_D[3]           | I/O      | 62            | -MSG        | ١/O             |
| 21            | DRV_GND_1            | I        | 63            | -SEL        | 1/0             |
| 22            | -HOST_D[2]           | I/O      | 64            | DRV_GND_4   | I               |
| 23            | -SSYNC               | I/O      | 65            | +A4         | Ι               |
| 24            | -HOST_D[1]           | I/O      | 66            | -C_D        | I/O             |
| 25            | VDD_0                | Ι        | 67            | -REQ        | I/O             |
| 26            | -HOST_D[0]           | I/O      | 68            | -I_O        | 1/0             |
| 27            | +BUF_OUT             | 0        | 69            | -RESET_CAP  | I               |
| 28            | DRV_GND_2            | I        | 70            | DRV_GND_5   | Ι               |
| 29            | +INP1[0]             | I        | 71            | -RESET_OUT  | 0               |
| 30            | +INP1[1]             | I        | 72            | +CLOCK      | I               |
| 31            | +INP1[2]             | Ī        | 73            | +INTERRUPT  | 0               |
| 32            | -DIF_BSY             | <u>_</u> | 74            | +MPU_AEN    | Ī               |
| 33            | -16BHAM              | ō        | 75            | +DIF_ENB    | I               |
| 34            | -DIF_SEL             | Ī        | 76            | +ARB        | 0               |
| 35            | +INP1[3]             | Ī        | 77            | -XOR[7]     | Ī               |
| 36            | +INP1[4]             | 1/0      | 78            | -XOR[6]     | Ī               |
| 37            | +BUF_IN              | <u> </u> | 79            | -XOR[5]     | <u> </u>        |
| 38            | IORDY                | 0        | 80            | +CONFIG1    | - i             |
| 39            | +FIFO_RDY            | 0        | 81            | +IO-MEMDM   |                 |
| 40            | +A3                  |          | 82            | -IORDDS     |                 |
| 40            | -DMA_ACK             |          | 83            | -IOWR_R-W   | <u> </u>        |
| 41 42         | -DMA_ACK             | <br>     | 84            | +ALEAS      | 1               |

Table 2-3. A Pin List of the 84-pin Package
## 84-Pin PLCC Package Specifications

Figure 2-6 provides a diagram of the package specifications for the 84-pin PLCC package.





### FUNCTIONAL CHIP SPECIFICATIONS

The 82C5086 can be used as a host adapter or a device controller. When used as a host adapter, the 82C5086 connects an 8- or 16-bit, host computer data bus to an 8-bit SCSI data bus. As a device controller, the 82C5086 interfaces such peripheral equipment as a Winchester drive to the SCSI bus, and provides a data path between the MPU and memory data buses.

It is through its I/O interface, that the 82C5086 controller can receive/send signals, addresses, and data from/to the system's other components (e.g., DMA controller, MPU). Refer to the following two sections for annotated illustrations of the 82C5086 host adapter and device controller.

#### Functionality of the 82C5086 Host Adapter

As a host adapter, the 82C5086 functions as a bridge between the host computer bus and the SCSI bus. Typically, the host computer requires information (e.g., status) and/or data from the devices connected to the SCSI bus. The 82C5086 host adapter can queue up these requests and send them to the appropriate device(s) via the SCSI bus. Consequently, a host adapter enables SCSI peripheral devices to communicate with host systems that do not directly support the SCSI interface (e.g., IBM PC AT).

Refer to Figure 2-7 for a functional pin out of a 82C5086 AT host adapter. The 82C5086 host adapter is configured for the following system: (1) the system is operating with 16 bits of MPU data and has an Intel 80286 with a non-multiplexed address/data bus; the bus has been de-multiplexed, and (2) the system has an 8-bit wide SCSI data bus.

As illustrated, the 82C5086 host adapter provides an interface with the following system components:

- SCSI control bus
- SCSI data bus
- Host computer's MPU address/control/data bus
- Host computer's DMA controller.

Figure 2-7. Functional Pin out **Q** the 82C5086 Host Adapter



Chapter N 82C5086 Hardware Specifications

25

#### Interfacing with the SCSI Control Bus

The SCSI control bus consists of nine bidirectional lines. Firmware engineers can control these SCSI bus control signals (e.g., -BSY and -ATN) by means of the 82C5086 command set. For example, by issuing the CNTL ATN ON (Control Attention On) pipeline command, firmware engineers can assert the -ATN signal on the SCSI bus. By reading the contents of certain 82C5086 internal registers, firmware engineers can monitor the activities and contents of the SCSI bus.

Interfacing with the SCSI Data Bus

SCSI data bus signals enable the 82C5086 host adapter to handle the device controller's requests for information transfers to/from the host computer's memory.

#### Interfacing with the Host Computer's MPU

IORDY, MPU\_AEN, -MPU\_ACK, and -16BHAM are the four pins that enable the 82C5086 host adapter to interface with the host computer's MPU. Whenever the MPU accesses the MPU FIFO Buffer Register and data is not available to be read/written, the IORDY signal is deasserted. Using the IORDY pin is only one of several ways the MPU can check if data is available or if the FIFO is ready for another byte. (The description of MPU FIFO Buffer Register in Chapter 4 describes the other options.)

MPU\_AEN and -MPU\_ACK are used to override the MPU address bits, and force access to the MPU FIFO Buffer Register. These signals enable the 82C5086 host adapter to send data to the host MPU (via data bus transceivers) without the host MPU generating a valid address to the MPU FIFO Buffer Register.

The -16BHAM AT host adapter signal enables 16-bit data transfers between the host computer's MPU and the SCSI data bus. This signal is asserted when the MPU reads/writes 16 bits of data to/from the 82C5086 host adapter. Bits 0-7 are sent/received via pins A\_D[0-7] that comprise the lower MPU data bus. Bits 8-15 are transferred simultaneously via pins MEM\_D[0-7], the memory data bus.

CONFIG1 is the line that is pulled up internally, and used to select the MPU's strobe input. This signal is grounded because the system MPU, an Intel 80286, uses separate read/write signals.

CONFIG2 is also pulled up internally, and held low because the 82C5086 host adapter is configured to operate with the non-multiplexed MPU address/data bus.

INTERRUPT is a programmable pin that enables the firmware engineer to decide under what conditions (e.g., a parity error) the 82C5086 host adapter should generate an interrupt to the system MPU.

-RESET\_CAP is tied to an external capacitor. -RESET\_OUT is asserted any time the 82C5086 is reset. The 82C5086 can be reset by asserting the -RESET\_CAP or -RESET\_IN signals, or by a programmed reset.

Interfacing with the Host Computer's DMA Controller

Typically, the FIFO\_RDY pin is connected to the host computer's DMA controller. When this pin is asserted, it indicates the 82C5086 is ready to process more data. When FIFO\_RDY is asserted, the host DMA controller will send a new byte to a 82C5086 internal register, the MPU FIFO Buffer Register 12. Thus this register can be used to pass data to/from the MPU and the 82C5086's internal FIFO.

Refer to Tables 2-4 through 2-9 later in this chapter for a complete list of the 82C5086's I/O signals and their functions.

#### Functionality of the 82C5086 Device Controller

As a device controller, the 82C5086 interfaces peripheral equipment, such as a Winchester drive, to the SCSI bus. Figure 2-8 provides a functional pin out of a 82C5086 device controller. This pin out makes the following system configuration assumptions: (1) the device MPU supports a multiplexed MPU address/data bus, and (2) there is an 8-bit wide SCSI control/data bus.

The 82C5086 device controller communicates with a host adapter via the SCSI bus. For details on the functionality of a 82C5086 host adapter refer to the preceding section.

In Figure 2-8, MEM\_D[0-7] are the eight bidirectional lines that comprise the memory data bus: a high-speed data bus for transfers to/from the 82C5086 device controller and buffer memory. Unlike the 16-bit host adapter system configuration shown in Figure 2-7, the memory data bus is independent from the MPU bus; it is not being used as the MPU's upper data bus.



Ì



### SIGNAL DESCRIPTIONS

Tables 2-1 through 2-3 list the signals in sequential order. Tables 2-4 through 2-9 list signals in alphabetical order. Note that in all the tables an active low state is indicated by a negative sign (-) prefix. When the pin(s) can be configured for more than one function, such as  $A_D[0]-A_D[7]$ , the other functions are listed as a subset. An N/A under a pin number indicates that the pin is not available on that particular version of the 82C5086.

Note that in all the signal descriptions, references to direction (e.g., MESSAGE OUT phase) is in reference to the initiator. For example, a MESSAGE OUT phase indicates the initiator wants to send a message to the target. Figures 2-7 and 2-8 provide functional pin outs of 84-pin version as an AT host adapter and as a target device controller, respectively. Refer to Table 2-10 for pad drive capacity of the 82C5086's pins.

# I/O Signals

Table 2-4 lists the 82C5086 input/output signals and their functions.

| Signal   | Signal              | I/0 |     | in Numb |     | Function                                                                                                                                                                                                                                                                                                                      |
|----------|---------------------|-----|-----|---------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Symbol   | Name                |     | 68  | 80      | 84  |                                                                                                                                                                                                                                                                                                                               |
| A_D[0-7] | Address/Data<br>Bus | ĮΟ  | 2-9 | 13-20   | 2-9 | These are active high, tri-state<br>signals. When the active high<br>CONFIG2 pin is high, these<br>address/data lines interface with<br>the MPU's lower 8-bit<br>address/data bus. The addresses<br>are latched into the internal,<br>address register by the falling<br>edge of the ADDRESS<br>LATCH ENABLE signal<br>(ALE). |
|          |                     |     |     |         |     | If the address is within the<br>range of the internal chip<br>select, the 8-bit data is<br>written/read to/from a register,<br>depending on the I/O write or<br>I/O read input control lines.                                                                                                                                 |
| D0-D7    | Data Bus            | I/O |     |         |     | When CONFIG2 is pulled low, these lines carry only data.                                                                                                                                                                                                                                                                      |
| A3       | Address Bit 3       | I   | N/A | 49      | 40  | When the active high<br>CONFIG2 signal is low, this<br>active high line provides<br>address bit 3 for internal<br>register selection. Refer to<br>Table 4-1 for 82C5086 register<br>addresses.                                                                                                                                |
| A4       | Address Bit 4       | I   | N/A | 73      | 65  | When the active high<br>CONFIG2 signal is low, this<br>active high line provides<br>address bit 4 for internal<br>register selection. Refer to<br>Table 4-1 for the addresses of<br>the 82C5086 internal registers.                                                                                                           |

# Table 2-4. Input/Output Signals

| Signal  | Signal               | I/O |    | in Numb |    | Function                                                                                                                                                                                                                                                                                                                                                                    |
|---------|----------------------|-----|----|---------|----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Symbol  | Name                 |     | 68 | 80      | 84 |                                                                                                                                                                                                                                                                                                                                                                             |
| -ACK    | SCSI<br>Acknowledge  | I/O | 47 | 67      | 59 | The initiator drives this active<br>low signal to indicate<br>acknowledgment of a<br>REQ/ACK handshake for a<br>SCSI data bus transfer. In<br>target mode, the 82C5086<br>receives this bidirectional I/O<br>line. In initiator mode, this<br>line is driven by the 82C5086<br>in response to the target's<br>request for data to be transferred<br>over the SCSI data bus. |
| -ATN    | SCSI Attention       | I/O | 44 | 64      | 56 | Initiator asserts this active low,<br>SCSI bus control signal to<br>indicate the ATTENTION<br>condition and to request a<br>MESSAGE OUT phase.                                                                                                                                                                                                                              |
| -BSY    | SCSI Busy            | I/O | 45 | 65      | 57 | This active low, SCSI bus<br>control signal indicates the bus<br>is currently in use.                                                                                                                                                                                                                                                                                       |
| BUF_IN  | Buffer In            | I   | 29 | 46      | 37 | This input signal provides<br>direct control of the BUF_OUT<br>signal if SCSI differential<br>mode is disabled. Its value can<br>be read by the MPU.                                                                                                                                                                                                                        |
| BUF_OUT | Buffer Out           | 0   | 22 | 37      | 27 | This open drain 48 mA output<br>line can be driven from the<br>BUF_IN signal in<br>non-differential (single-ended<br>drivers/receivers) SCSI mode.<br>This signal provides the reset<br>out signal to the SCSI bus<br>when differential drivers<br>(multiple-ended drivers) are<br>connected.                                                                               |
| -C_D    | SCSI<br>Control/Data | ΙØ  | 53 | 74      | 66 | In target mode, the 82C5086<br>drives this bidirectional I/O<br>line for all SCSI command and<br>data transfers.<br>In initiator mode, the 82C5086<br>receives this active low signal<br>that indicates the target has<br>SCSI command/data to<br>transfer.                                                                                                                 |

# Table 2-4. Input/Output Signals (continued)

 $\left( \begin{array}{c} \end{array} \right)$ 

| Table 2-4. | Input/Output | Signals | (continued) |
|------------|--------------|---------|-------------|
|------------|--------------|---------|-------------|

| Signal<br>Symbol | Signal<br>Name     | I/0 | P<br>68 | in Numbe<br>80 | er<br>84 | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|------------------|--------------------|-----|---------|----------------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CLOCK            | Clock              | I   | 59      | 80             | 72       | This active high, input signal<br>is for a free running clock used<br>for all internal timing.<br>Recommended clock frequency<br>is 24 to 32 MHz.                                                                                                                                                                                                                                                                                                           |
| CONFIG1          | Configuration 1    | I   | 64      | 7              | 80       | This line is pulled up<br>internally and used to select the<br>MPU's strobe inputs. When<br>this active high, input signal is<br>grounded, the 82C5086 chip is<br>configured for an<br>8085/8051-type MPU that uses<br>individual read and write<br>strobes. When this signal is<br>left open, the 82C5086 chip is<br>configured for a Z8-type MPU<br>that uses separate strobe and<br>read/write signals.                                                  |
| CONFIG2          | Configuration2     | I   | N/A     | 61             | 52       | When this active high signal is<br>high, the 82C5086 chip is<br>configured to operate with a<br>multiplexed address and data<br>MPU bus. When this line is<br>low, pins A0-A4 (-XOR[5-7],<br>A3, and A4) are used to select<br>the internal registers. Refer to<br>Table 4-1 for a list of the<br>addresses of the 82C5086<br>internal registers. This signal<br>is pulled up internally.<br>Typically it will be pulled up<br>by a resistance of 25 Kohms. |
| -DMA_ACK         | DMA<br>Acknowledge | I   | 33      | 50             | 41       | This active low, input signal<br>provides the 82C5086 with the<br>acknowledge handshake signal<br>from the memory data bus<br>DMA controller. When this<br>active low signal is asserted,<br>the 82C5086 gates data onto<br>the memory data bus (write), or<br>clocks data into (read) the<br>82C5086 on the trailing edge<br>of -DMA_ACK.                                                                                                                  |

| Signal<br>Symbol | Signal<br>Name              | I/O | 6 8                  | in Numb<br>80             | er<br>84             | Function                                                                                                                                                                                                                                                                                                                               |
|------------------|-----------------------------|-----|----------------------|---------------------------|----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -DMA_REQ         | DMA Request                 | 0   | 34                   | 51                        | 42                   | This active low, output signal<br>provides the memory data bus<br>DMA controller with a request<br>handshake signal from the<br>82C5086.                                                                                                                                                                                               |
| DRV_GND[0-5]     | Drive ground                | I   | 12,57,17<br>23,46,52 | 26,31,<br>38,66,<br>72,78 | 16,21,28<br>58,64,70 | Drive ground. Required around 48 mA drivers.                                                                                                                                                                                                                                                                                           |
| GND[0-2]         | Ground                      | I   | 1,<br>35             | 12,<br>52                 | 1,43<br>12           | Ground                                                                                                                                                                                                                                                                                                                                 |
| -HOST_D[0-7]     | SCSI<br>Host Data<br>0-7    | I/O | 21,19-18<br>16-13,11 | 36,34,<br>30-27,<br>25    | 26,24,22<br>20-17,15 | These eight active low signals<br>comprise the SCSI data bus.<br>This 8-bit bidirectional data<br>bus is used to transfer parallel<br>data to/from the host system.                                                                                                                                                                    |
| -HOST_D_P        | SCSI<br>Host Data<br>Parity | I/O | 10                   | 24                        | 14                   | When the 82C5086 is driving<br>the SCSI bus with data, this<br>activelow signal indicates odd<br>parity (flow through). When the<br>82C5086 receives data from the<br>SCSI host data bus, this odd<br>parity bit is used to check for<br>valid parity.                                                                                 |
| INP1[0-4]        | Input Port 1                | I   | 24-<br>28            | 39-<br>41<br>44,<br>45    | 29-31,<br>35-36      | These active high signals can<br>be used for setup information<br>and are pulled high internally.<br>For example, the SCSI<br>controller ID can be set with<br>this port's bits. These bits<br>are accessible to the MPU in a<br>Port 1 read operation. The<br>INP1_[4] pin can be used for a<br>parity bit to the memory data<br>bus. |

C

# Table 2-4. Input/Output Signals (continued)

| Signal    | Signal                | I/O | P        | in Numb |    |                                                                                                                                                                     | Function                                                                                                                                                                                                                |                                                                                                                                 |
|-----------|-----------------------|-----|----------|---------|----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------|
| Symbol    | Name                  |     | 68       | 80      | 84 |                                                                                                                                                                     |                                                                                                                                                                                                                         |                                                                                                                                 |
| INTERRUPT | Interrupt             | 0   | 60       | 1       | 73 | program to<br>when the 8<br>generate a<br>MPU. Th<br>low on ress<br>output is a<br>enabled in<br>detected.<br>cleared wh<br>Interrupt S<br>For unlatc<br>when the p | engineers c<br>his signal to<br>2C5086 sh<br>n interrupt t<br>is signal is<br>set. If it is o<br>ctive when<br>terrupting s<br>For latched<br>en the MPU<br>Status Regis<br>hed bits, it<br>pass-throug<br>ondition dis | o control<br>would<br>to the<br>active<br>enabled,<br>any<br>equence is<br>bits, it is<br>J reads<br>ster 5.<br>is cleared<br>h |
| -I_O      | SCSI Input/<br>Output | Į/O | 55       | 76      | 68 | line is driv<br>to indicate<br>data/comm<br>to the initiator<br>receives th                                                                                         | node, this<br>hal, active leven by the c<br>the target l<br>hand/status<br>iating contr<br>r mode, the<br>his line to ir<br>of the data t                                                                               | ontroller<br>has<br>to transfer<br>oller.<br>82C5086<br>ndicate the                                                             |
| IOMEMDM   | I/O Data<br>Memory    | I   | 65       | 8       | 81 | access to asserted p                                                                                                                                                | enable pin<br>the 82C508<br>plarity is dis<br>and 2-6, au<br>follows:<br>CONFIG1<br>Low                                                                                                                                 | 6. Its scussed in                                                                                                               |
|           |                       |     | <b> </b> |         |    | CONFIG2                                                                                                                                                             | LOW                                                                                                                                                                                                                     | <u>nugu</u>                                                                                                                     |
|           |                       |     |          |         |    | Low                                                                                                                                                                 | Low                                                                                                                                                                                                                     | High                                                                                                                            |
|           |                       |     |          |         |    | CONFIG2<br>High                                                                                                                                                     | High                                                                                                                                                                                                                    | Low                                                                                                                             |

| Table 2-4. | Input/Output | Signals | (continued) |
|------------|--------------|---------|-------------|
|------------|--------------|---------|-------------|

| Signal     | Signal             | I/O | -     | in Numb   |       | Function                                                                                                                                                                                                    |
|------------|--------------------|-----|-------|-----------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Symbol     | Name               |     | 68    | 80        | 84    |                                                                                                                                                                                                             |
| MEM_D[0-7] | Memory Data<br>Bus | I/O | 36-43 | 53-<br>60 | 44-51 | These eight active high signals<br>comprise the 8-bit<br>bidirectional data bus to/from<br>the buffer memory. This<br>high-speed data bus is called<br>the memory data bus.<br>In 16-bit host adapter mode, |
|            |                    |     |       |           |       | these lines are used as the<br>MPU's upper data bus to<br>transfer bits 8-15 to/from<br>buffer memory. This enables<br>two bytes per cycle to be<br>transferred.                                            |
| -MSG       | SCSI Message       | I/O | 50    | 70        | 62    | This active low signal is driven<br>by the target during a<br>MESSAGE phase.                                                                                                                                |
|            |                    |     |       |           |       | In target mode, the 82C5086<br>drives this I/O signal to<br>indicate a MESSAGE phase<br>(e.g., MESSAGE IN) is in<br>progress. In initiator mode,<br>the 82C5086 receives this<br>signal.                    |
| -REQ       | SCSI Request       | Ι/O | 54    | 75        | 67    | In target mode, the 82C5086<br>drives this active low I/O<br>signal to request data transfer<br>to/from the initiator.                                                                                      |
|            |                    |     |       |           |       | In initiator mode, the 82C5086 receives this signal that indicates the target has command/data to transfer.                                                                                                 |

# Table 2-4. Input/Output Signals (continued)

| Signal                 | Signal                     | I/O |                 | in Numb   |                  | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|------------------------|----------------------------|-----|-----------------|-----------|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Symbol<br>-RESET_CAP - | Name<br>Reset<br>Capacitor | I   | <u>68</u><br>56 | 80        | <u>8 4</u><br>69 | The 82C5086 contains an<br>internal POR reset circuit that<br>generates a reset pulse for<br>approximately 5 us. at power<br>up. If a longer pulse is<br>required, the hardware design<br>engineer should connect this<br>signal to an external capacitor<br>to provide a power-on reset<br>signal of externally<br>controllable pulse width. An<br>internal pull-up resistor of 100<br>Kohms and a voltage threshold<br>of 3.2 Volts should be used for<br>reset pulse width calculations. |
| -RESET_IN              | SCSI Reset                 | Ι⁄Ο | 48              | 68        | 60               | When this active low SCSI<br>bus control signal is asserted,<br>the 82C5086 assumes a known<br>reset condition. Firmware<br>engineers can obtain this<br>signal's unlatched status by<br>reading bit 7 (RESET Pin) of<br>Input Port 1 Register 8. The<br>latched status can be read from<br>bit 6 (SCSI RESET) of the<br>Interrupt Status Register 5.                                                                                                                                       |
| -RESET_OUT             | Reset Out                  | 0   | 58              | 79        | 71               | This active low output signal<br>is always true during power up.<br>It can also be asserted during a<br>SCSI bus reset if the firmware<br>engineer has deasserted bit 4<br>(Disable SCSI RESET_OUT<br>Pin) of Auxiliary Control<br>Register 19.                                                                                                                                                                                                                                             |
| -SEL                   | SCSI Select                | I/O | 51              | 71        | 63               | Initiator uses this active low<br>signal to select the target, or<br>the target uses it to reselect the<br>initiator.                                                                                                                                                                                                                                                                                                                                                                       |
| VCC[0-1]               | VCC                        | I   | 20,<br>49       | 35,<br>69 | 25,61            | +5 VDC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |

Table 2-4. Input/Output Signals (continued)

| Signal    | Signal                      | I/O | Pi        | n Numb | er    | Function                                                                                                                                                                                                                                                                                                                                                                       |
|-----------|-----------------------------|-----|-----------|--------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Symbol    | Name                        |     | 68        | 80     | 84    |                                                                                                                                                                                                                                                                                                                                                                                |
| -XOR[5-7] | Exclusive-OR<br>Address 5-7 | I   | 63-<br>61 | 6-4    | 77-79 | When the active high<br>CONFIG2 pin is high<br>(multiplexed MPU bus<br>addressing), these active low<br>input signals are used for<br>internal chip select. They are<br>pulled up internally. They<br>control the polarity of the<br>corresponding address line. For<br>example, if these pins equal<br>1 1 1, then the 82C5086 will<br>respond only to addresses<br>below 32. |
| A0-A2     | Address Bits<br>0-2         | I   |           |        |       | When the CONFIG2 signal is<br>low, these active high lines<br>connect to address bits 0-2<br>(A0-A2). Address bits 0-2 are<br>used for internal register<br>selection.                                                                                                                                                                                                         |

| Table | 2-4. | Input/Output | Signals | (continued) |
|-------|------|--------------|---------|-------------|
|-------|------|--------------|---------|-------------|

### Signals Specific to 8085/8051 Mode

Table 2-5 describes the signals used only when the 82C5086 is operating in 8085/8051 mode (multiplexed mode). Note the 8085/8051 uses multiplexed address/data buses. The 68-pin version must be connected to multiplexed MPU address/data bus; whereas the 80 and 84-pin packages support non-multiplexed, as well as a multiplexed, MPU address/data buses.

### NOTE

In this mode the CONFIG1 signal is low.

### Table 2-5. Signals Specific to 8085/8051 Mode

| Signal    | Signal                     | I/O | Pir | n Numb | er | Function                                                                                                                                                                                                        |
|-----------|----------------------------|-----|-----|--------|----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Symbol    | Name                       |     | 68  | 80     | 84 |                                                                                                                                                                                                                 |
| ALEAS     | Address<br>Latch<br>Enable | I   | 68  | 11     | 84 | This input strobe is for<br>latching the address from the<br>MPU into the internal address<br>register on the falling edge of<br>ALE. The address bits are used<br>for internal chip and register<br>selection. |
| IOMEMDM   | I/O Data<br>Memory         | I   | 65  | 8      | 81 | If true (high), this input signal<br>enables I/O read and I/O write<br>signals. If this I/O Data<br>Memory signal is false (low),<br>I/O read and I/O write signals<br>a r e d i s a b l e d.                   |
| -IORDDS   | I/O Read                   | I   | 66  | 9      | 82 | MPU uses this active low<br>input signal to read status<br>information from the 82C5086.                                                                                                                        |
| -IOWR_R-W | I/O Write                  | I   | 67  | 10     | 83 | MPU uses this active low<br>input signal to load the 82C5086<br>with the proper address for<br>internal chip and register<br>selection.                                                                         |

# Signals Specific to Z8 Mode

Table 2-6 provides signal descriptions for signals used only when the 82C5086 is interfacing with a Z8 microprocessor (multiplexed mode).

#### NOTE

In this mode the CONFIG1 signal is high.

# Table 2-6. Signals Specific to Z8 Mode

| Signal<br>Symbol | Signal<br>Name | I/O | Pir<br>68 | n Numt<br>80 | er<br>84 | Function                                                                                                                                                                                            |
|------------------|----------------|-----|-----------|--------------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ALEAS            | Address Strobe | : I | 68        | 11           | 84       | This active low input strobe is<br>for latching the address from<br>the MPU into the internal<br>address register. Address bits<br>are used for internal chip and<br>register selection.            |
| IOMEMDM          | Data Memory    | I   | 65        | 8            | 81       | If true (low), this input signal<br>enables data strobe (DS). If<br>this active low signal is false<br>(high), data strobe is disabled.                                                             |
| -IORDDS          | Data Strobe    | I   | 66        | 9            | 82       | If R/W is true (high), the MPU<br>uses this active, low input to<br>read status information from<br>the 82C5086. If R/W is false<br>(low), the MPU uses it to load<br>information into the 82C5086. |
| -IOWR_R-W        | Read/Write     | I   | 67        | 10           | 83       | This active high input signal<br>determines whether the MPU<br>wants to perform a read<br>operation (R/-W is true), or<br>write operation (R/-W is false).                                          |

### Signals Specific to Host Adapter Mode

Table 2-7 describes signals used only when the 82C5086 is operating in host adapter mode. The 84-pin version provides full AT host adapter support. When the 84-pin package MPU\_AEN, -MPU\_ACK, IO\_MEM\_-DM and -IORD\_-DS or -IOWR\_R-W signals are asserted, the 82C5086 forces the MPU to access the MPU FIFO Data Register 12. This function is required for AT compatibility and would be used in conjunction with the FIFO\_RDY pin for transferring data over the AT bus. Refer to Figure 2-7 for a functional pin out of a 82C5086 in AT host adapter mode.

### Table 2-7. Signals Specific to Host Adapter Mode

| Signal<br>Symbol | Signal<br>Name              | I/O | Pir<br>68 | Numb<br>80 | er<br>84 | Function                                                                                                                                                                                                                                                                                                                                                           |
|------------------|-----------------------------|-----|-----------|------------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -16BHAM          | 16-Bit Host<br>Adapter Mode | 0   | N/A       | N/A        | 33       | This open drain pin is active<br>low, sink 24 mA. Its output<br>is asserted when the MPU<br>reads/writes 16-bit data from/to<br>the 82C5086 host adapter (MPU<br>FIFO Data Register 12).<br>It is enabled by bit 0 (Host<br>Adapter Pins) of the Mode<br>Control Register 7.                                                                                       |
| FIFO_RDY         | FIFO Request                | 0   | N/A       | 48         | 39       | This tri-state active high<br>signal is asserted when the<br>FIFO is waiting for a new byte<br>from the MPU, or it has a byte<br>ready to send to the MPU.<br>When the MPU FIFO Buffer<br>Register 12 is accessed, this<br>signal is cleared.<br>This pin is enabled by bit 2<br>(FIFO RDY Pin) of the Mode<br>Control Register 7.                                 |
| IORDY            | I/O Ready                   | 0   | N/A       | 47         | 38       | This open drain pin sinks 24<br>mA. It is enabled by bit 0<br>(Host Adapter Pins) of the<br>Mode Control Register 7.<br>Whenever the MPU accesses<br>the MPU FIFO Buffer Register<br>12, and data is not available to<br>be read/written, this signal is<br>deasserted.<br>Hardware engineers should tie<br>this output signal to the MPU<br>Wait State Generator. |

| Signal   | Signal                | I/O | Pin Number |     |    | Function                                                                                                                                                        |
|----------|-----------------------|-----|------------|-----|----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Symbol   | Name                  |     | 68         | 80  | 84 |                                                                                                                                                                 |
| MPU_AEN  | MPU Address<br>Enable | I   | N/A        | N/A | 74 | This active high signal is used<br>as a qualifier to override the<br>MPU address bits. It is<br>internally pulled up.                                           |
| -MPU_ACK | MPU<br>Acknowledge    | I   | N/A        | N/A | 54 | This active low signal is used<br>as a qualifier to override the<br>MPU address bits and also<br>forces an internal chip select.<br>It is internally pulled up. |

# Table 2-7. Signals Specific to Host Adapter Mode (continued)

### Signals Specific to Wide Data Bus Transfers

Table 2-8 describes signals used only when two or more 5086s are cascaded to support wide SCSI bus data transfers. This support is provided by the 80 and 84-pin packages. The 68-pin package supports an 8-bit SCSI data bus. Refer to Figure 1-3 for a diagram of a system configuration with two 5086s cascaded to support 16-bit data transfers over the SCSI bus. Figure 3-2 provides a functional pin out of 5086s cascaded.

### Table 2-8. Signals Specific to Wide Data Bus Transfers

| Signal<br>Symbol | Signal<br>Name | I/O | Pir<br>68 | Numt<br>80 | er<br>84 | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|------------------|----------------|-----|-----------|------------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -DSYNC           | DMA Sync       | I/O | N/A       | 63         | 55       | The master 82C5086 does not<br>generate a DMA request (assert<br>-DMA_REQ) signal until this<br>active low input signal is<br>deasserted.<br>The slave(s) 82C5086 asserts<br>this signal to indicate a not<br>ready condition. Hardware<br>engineers should tie this pin on<br>all master and slave 5086s<br>together.<br>In master mode, this pin is an<br>input and is pulled high. In<br>slave mode, this pin is an open<br>drain output. For more details<br>refer to Chapter 3's section |
| -SSYNC           | SCSI Sync      | I/O | N/A       | 33         | 23       | "Master/Slave Mode."<br>The master 82C5086 does not<br>generate a SCSI<br>request/acknowledge                                                                                                                                                                                                                                                                                                                                                                                                 |
|                  |                |     |           |            |          | (REQ/ACK) signal until this<br>active low input signal is<br>deasserted.<br>To indicate a not ready                                                                                                                                                                                                                                                                                                                                                                                           |
|                  |                |     |           |            |          | condition the slave(s) 82C5086<br>asserts this signal. Hardware<br>engineers should tie this pin on<br>all master and slave 5086s<br>together.                                                                                                                                                                                                                                                                                                                                                |
|                  |                |     |           |            |          | In master mode, this pin is an<br>input and is pulled high. In<br>slave mode, this pin is an open<br>drain output. For more details<br>refer to Chapter 3's section<br>"Master/Slave Mode."                                                                                                                                                                                                                                                                                                   |

 $\left( \right)$ 

| Signal | Signal                  | I/O | Pir | Pin Number |    | Function                                                                                                                                                                                                                                                                                                                                                                                            |
|--------|-------------------------|-----|-----|------------|----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Symbol | Name                    |     | 68  | 80         | 84 |                                                                                                                                                                                                                                                                                                                                                                                                     |
| -WPAR  | Wide Data<br>Bus Parity | Ι⁄Ο | N/A | 62         | 53 | In asynchronous or<br>synchronous mode, this active<br>low input signal indicates the<br>external 82C5086 slave chip(s)<br>has a data parity error or<br>over/under run error.<br>In master mode, this signal is<br>an input and is pulled high.<br>In slave mode, this signal is an<br>open drain output. Hardware<br>engineers should tie this pin on<br>all masters and slave 5086s<br>together. |

# Table 2-8.Signals Specific to Wide Data Bus Transfers<br/>(continued)

### Signals Specific to The Differential SCSI Interface

Table 2-9 describes signals used only when the 82C5086 is operating in the differential SCSI interface mode. The 80 and 84-pin packages support this mode; however, the 68-pin package supports only the non-differential SCSI interface mode.

### Table 2-9. Signals Specific to The Differential SCSI Interface

| Signal   | Signal                         | I/O | Pir | Numb | er | Function                                                                                                                                                                                                                                                                                              |
|----------|--------------------------------|-----|-----|------|----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Symbol   | Name                           |     | 68  | 80   | 84 |                                                                                                                                                                                                                                                                                                       |
| ARB      | Arbitration                    | 0   | N/A | 3    | 76 | When this active high output<br>signal is high, the 82C5086 has<br>placed an ID on the SCSI data<br>bus. The 82C5086 will receive<br>all data bits (including any bits it<br>has driven low), and determine<br>if it won the SCSI bus<br>arbitration.                                                 |
| BUF_OUT  | Reset Out                      | 0   | 22  | 46   | 27 | In differential SCSI mode, this<br>active low output signal drives<br>the SCSI control bus -RST<br>signal. The 82C5086's -RST<br>signal is used for input only.                                                                                                                                       |
| -DIF_BSY | Busy Input                     | I   | N/A | 42   | 32 | In differential mode, this active<br>low input receives the SCSI<br>bus -BSY control signal.<br>-BSY signal is driven by the<br>same signal used in single-<br>ended (non-differential) operation.                                                                                                    |
| DIF_DIR  | Data Direction<br>Enable       | 0   | N/A | 21   | 10 | When this active high<br>signal is low, the 82C5086<br>transfers data onto the<br>SCSI host data bus. When<br>it is high, data is<br>transferred from the SCSI<br>host data bus to the 82C5086.                                                                                                       |
| DIF_ENB  | Differential<br>Drivers Enable | I   | N/A | 2    | 75 | When this active high input<br>signal is high, the 82C5086<br>assumes operation in the<br>differential SCSI mode. This<br>mode causes the -SEL, -BSY<br>and -RST signals to be output<br>only, and enables the other<br>signals listed in this table.<br>The DIF_ENB pin is internally<br>pulled low. |

| Signal   | Signal              | I/O | Pir | Numb | er | Function                                                                                                                                                                                                               |
|----------|---------------------|-----|-----|------|----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Symbol   | Name                |     | 68  | 80   | 84 |                                                                                                                                                                                                                        |
| -DIF_SEL | Select Input        | Ι   | N/A | 43   | 34 | In differential mode, this<br>active low input signal receives<br>the SCSI bus -SEL control<br>signal. The -SEL signal is<br>driven by the same signal used<br>in single-ended<br>(non-differential)<br>bnm operation. |
| INR_ENB  | Initiator<br>Enable | 0   | N/A | 23   | 13 | This active high output<br>signal enables SCSI bus<br>control signals -ACK and<br>-ATN.                                                                                                                                |
| TAR_ENB  | Target Enable       | 0   | N/A | 22   | 11 | This active high output signal<br>enables the following SCSI<br>bus control signals: -REQ,<br>-C_D, -I_O, and -MSG.                                                                                                    |

# Table 2-9 Signals Specific to The Differnetial SCSI Interface

# Pad Drive Capacity

Refer to Table 2-10 for a list of the pad drive capacity of the 82C5086 pins.

 Table 2-10.
 Pad Drive Capacity

| Pin Name     | Drive Pad<br>Capacity (mA) | Pin Name    | Drive Pad<br>Capacity (mA) |
|--------------|----------------------------|-------------|----------------------------|
| -ACK         | 48                         | +INR_ENB    | 4                          |
| -ATN         | 48                         | +INTERRUPT  | 4                          |
| -BSY         | 48                         | +DIF_DIR    | 4                          |
| +BUF_OUT     | 48                         | +DMA_REQ    | 4                          |
| -C_D         | 48                         | +MEM_D[0-7] | 8                          |
| -HOST_D[0-7] | 48                         | +A_D[0-7]   | 8                          |
| -I_O         | 48                         | +ARB        | 4                          |
| -MSG         | 48                         | -RESET_OUT  | 4                          |
| -REQ         | 48                         | +TAR_ENB    | 4                          |
| -RESET_IN    | 48                         | +INP1[4]    | 4                          |
| -SEL         | 48                         | -DSYNC      | 4                          |
| IORDY        | 24                         | -WPAR       | 4                          |
| -16BHAM      | 24                         | -SSYNC      | 4                          |
| +FIFO_RDY    | 8                          |             |                            |

### ELECTRICAL SPECIFICATIONS

### A.C. Specifications

The relevant timing diagrams and A.C. characteristics for interfacing the 82C5086 are provided in the following timing specification sections. For more information on the microprocessor timing refer to the documentation for the particular microprocessor.

### Clock Timing

The 82C5086 chip has a CLOCK signal for a free running clock that is used for all internal timing. The recommended clock frequency for the 82C5086 chip is 24 to 32 MHz. Figure 2-9 presents the waveform and AC characteristics of the CLOCK signal timing.



Figure 2-9. Clock Timing Characteristics

### Z8 Mode Timing

The 80- and 84-pin versions of the 82C5086 chip can interface with the Z8 microprocessor. When the 82C5086 is interfacing with the Z8 that has a multiplexed address/data bus, the 82C5086 operates in multiplexed mode. Figures 2-10 and 2-11 respectively present signal timings and their AC characteristics for Z8 mode write and read operations. For more details on these signals, refer to in the section "Signals Specific to Z8 Mode" earlier in this chapter.



Figure 2-10. Write Operation Z8 Mode Timing Characteristics



Figure 2-11. Read Operation Z8 Mode Timing Characteristics

# 8085/8051 Mode Timing

The 82C5086 can operate in 8085/8051 mode (multiplexed mode). Figures 2-12 and 2-13 respectively present the signal timings and their AC characteristics for 8085/8051 mode write and read operations.



Figure 2-12. Write Operation 8085/8051 Mode Timing Characteristics



Figure 2-13. Read Operation 8085/8051 Mode Timing Characteristics

### Non-multiplexed Mode Timing

The 82C5086 chip can operate in non-multiplexed mode in order to interface with microprocessors that have non-multiplexed address/data buses. Figures 2-14 and 2-15 respectively present signal timings and their AC characteristics of write and read operations for non-multiplexed mode.



Figure 2-14. Write Operation, Non-multiplexed MPU Timing Characteristics



Figure 2-15. Read Operation, Non-multiplexed MPU Timing Characteristics

### Timing for Data Transfers to System Memory

System design engineers have two alternative ways of wiring the 82C5086 to support data transfers to/from system memory. First, the 82C5086's IORDY pin can be connected to the MPU's wait state generator to support burst transfers (string operation) from the MPU to the 82C5086 chip. Figures 2-16 and 2-17 respectively present the signal timings and their AC characteristics of the IORDY signal and its associated signals for a MPU write and read operation.

The second method of supporting data transfers to/from system memory is to connect the 82C5086's FIFO\_RDY pin to a DMA controller on the system's memory data bus. Figures 2-18 and 2-19 respectively present the signal timings and AC characteristics for the FIFO\_RDY signal and its associated signals.



Figure 2-16. MPU Write IORDY Timing Characteristics



Figure 2-17. MPU Read IORDY Timing Characteristics



2. -16BHAM pin must be enabled in order to be asserted and a 16 bit transfer is requested.

Figure 2-19. FIFO\_RDY without Address Timing Characteristics

### Timing for I/O Interface to Buffer Memory

The 82C5086 communicates with the DMA controller over a bidirectional memory data bus via DMA request/acknowledge handshake control signals. Figures 2-20 and 2-21 respectively present the signal timings and their AC characteristics for a write and a read operation to/from buffer memory.



# Figure 2-20. DMA Interface, Write to 82C5086 Timing Characteristics


## Figure 2-21.

## DMA Interface, Read from 82C5086 Timing Characteristics

#### SCSI Interface Timing

Figures 2-22 through 2-31 present signal timings and their AC characteristics for the 82C5086 signals that support such SCSI interface functions as arbitration of the SCSI bus, selection/reselection of a SCSI device, and asynchronous and synchronous data transfers. Note that signals -HOST\_D(0-7) are depicted in all of these figures. These eight lines comprise the 8-bit SCSI data bus. This bus is used to transfer data to/from the host computer. The -HOST\_D\_P signal is the SCSI data bus parity bit.

#### Timing for the SCSI Bus ARBITRATION Phase

Figure 2-22 presents the signal timings and their AC characteristics for the signals involved in a SCSI device's arbitratation of the SCSI bus.



Figure 2-22. SCSI Arbitration Timing Characteristics

#### Timing for SCSI Bus SELECT/RESELECT Phases

Figure 2-23 presents the signal timings and their AC characteristics for the signals involved in the SCSI bus SELECT/RESELECT phases.



Figure 2-23. SCSI Select/Reselect Timing Characteristics

#### Timing for Asynchronous/Synchronous Transfers

SCSI bus data transfers can be asynchronous or synchronous. Figures 2-24 through 2-27 present signal timings and their AC characteristics for asynchronous data transfers. Figures 2-28 through 2-31 present signal timings and their AC characteristics for synchronous data transfers.



## Figure 2-24. SCSI Target Asynchronous Transfer Output Timing Characteristics

## Chapter 2. 82C5086 Hardware Specifications



### Figure 2-25. SCSI Target Asynchronous Transfer Input Timing Characteristics



## Figure 2-26. SCSI Initiator Asynchronous Transfer Output Timing Characteristics





## Figure 2-27. SCSI Initiator Asynchronous Transfer Input Timing Characteristics





Figure 2-29.

SCSI Target Synchronous Transfer Input Timing Characteristics



Figure 2-30.

## SCSI Initiator Synchronous Transfer Output Timing Characteristics



Figure 2-31.

# SCSI Initiator Synchronous Transfer Input Timing Characteristics

#### D.C. Specifications

Absolute Maximum Ratings

Refer to Table 2-11 for absolute maximum ratings.

## Table 2-11. Absolute Maximum Ratings

| Rating                        | Minimum | Maximum | Unit      |
|-------------------------------|---------|---------|-----------|
| Power supply voltage          | -0.3    | 7.0     | VDC       |
| Ambient operating temperature | 0.0     | +70.0   | C degrees |
| Storage temperature           | -65.0   | +150.0  | C degrees |

### CAUTION

Stresses greater than those indicated may cause permanent damage to the chip. Operation of the chip at conditions above those shown is not implied. Exposure to absolute maximum rating conditions for extended periods may affect the chip's reliability.

#### Standard Test Conditions

The following characteristics apply to standard test conditions unless noted otherwise in test specifications. Voltages are referenced to GND. Positive current flow is into the reference pin. Standard conditions are as follows:

- $V_{cc} = 5.0 \text{ VDC} + -0.25 \text{ VDC}$
- GND = 0 VDC
- 0 degrees C < TA < 70 degrees C

### D.C. Characteristics

Refer to Table 2-12 for a list of D.C. characteristics.

| Table 2-12. D.C. Characteristics |  |
|----------------------------------|--|
|----------------------------------|--|

| Parameter                 | Minimum | Maximum         | Unit |
|---------------------------|---------|-----------------|------|
| Input High Voltage        | 2       | V <sub>cc</sub> | V    |
| Input Low Voltage         | -0.3    | 0.8             | V    |
| Output High Voltage       | 2.4     | Vcc             | V    |
| Output Low Voltage        |         | 0.4             | V    |
| High-level Output Current |         | -4              | mA   |
| Low-level Output Current  |         | 4               | mA   |
| Input Leakage             | -30     | 10              | μA   |
| Output Leakage            |         | 10              | μA   |
| Vcc Supply Current        |         | 50              | mA   |

Drivers/Receivers

Refer to Table 2-13 for a list of D.C. characteristics for drivers and receivers.

## Table 2-13. D.C. Characteristics for Drivers/Receivers

| Drivers   | Sink 48 mA @ 0.5 VDC asserted                                                                               |
|-----------|-------------------------------------------------------------------------------------------------------------|
| Receivers | Asserted at input = 0 to 0.8 VDC<br>Non-asserted at input = 2.0 to 5.25 VDC<br>Minimum hysteresis = 0.2 VDC |

This chapter is intended for firmware engineers. First, it provides a description of the modes the 82C5086 can operate in when used as a host adapter or device controller. Next, it explains how the structure of the 82C5086 architecture supports these various modes.

#### MODES OF OPERATION

As mentioned previously, the 82C5086 provides the functions necessary to implement the SCSI interface on a host computer or a device controller. Used in either of these applications, the 82C5086 can support the following modes of operation:

- Initiator or target mode
- Differential or non-differential mode
- Asynchronous or synchronous transfer mode
- Master or slave mode.

#### **Initiator and Target Modes**

Systems can be configured with single or multiple initiators, and with single or multiple targets. Some SCSI devices can act as an initiator in one SCSI interface transaction, and function as a target in another. The 82C5086 supports both the initiator and target mode.

#### Role of Initiator

Typically, the initiator is the host adapter. The initiator is responsible for originating the operation that the target will perform. In order to initiate a SCSI bus operation, the initiator must complete the following steps:

- 1. Wait for the SCSI bus to go to the BUS FREE phase.
- 2. Arbitrate for control of the SCSI bus.
- 3. Select the device (target) using the target ID placed in the MCS.
- 4. Optionally send an identify message from the MCS to the target.
- 5. Optionally send a two-byte tag message from the MCS to the target.

6. Send the target a multi-byte command from the MCS, defining the activity which is to occur. Refer to the section "Pipelining Structure" later in this chapter for more details on this topic.

The initiator controls the SCSI bus during the ARBITRATION and SELECTION phases. However, once the target is selected, control transfers to the target.

#### Role of the Target

If the 82C5086 is selected as a target it will perform the following sequence under the control of the firmware:

- 1. Save the ID of the initiator in the MCS.
- 2. Optionally receive the identify message and save it in the MCS.
- 3. Optionally receive the two-byte tag message, and save it in the MCS.
- 4. Receive a multi-byte command, and save it in the MCS.
- 5. If the identify message allows the target to disconnect, then send the DISCONNECT message to the initiator. If the identify message disallows disconnect, the sequence is terminated at this point.
- 6. Go to the SCSI bus BUS FREE phase.

Once the target is selected by the initiator, the target controls the SCSI bus. Targets can also arbitrate for the SCSI bus and reselect an initiator. Refer to the target commands in Chapter 5 for more details.

#### Differential and Non-Differential Mode

The SCSI bus signals (e.g., -ATN) between the initiator and the target can be single-ended or multiple-ended. If single-ended drivers/receivers are used, the 82C5086 must operate in non-differential mode. If multiple-ended drivers/receivers are used, the 82C5086 must operate in differential mode. Refer to Table 2-9 for the 82C5086 signals used when the 82C5086 is operating in differential mode. Figure 3-1 illustrates the 82C5086's support of this mode. The 80- and 84-pin packages support this mode. Note that pins 6 and 7 of the differential receiver have been swapped to invert signal polarity.

#### Transfer Modes

When the 82C5086 is transferring data over the SCSI bus, the mode of transfer can be asynchronous or synchronous. An asynchronous transfer rate of up to 4 megabytes/second, and synchronous transfers of up to 5.3 megabytes/second are supported (32 MHz clock).

Chapter 3. 82C5086 Operation



Figure 3-1. Diagram of the 82C5086's Support of Differential SCSI Mode

#### Asynchronous Transfers

Asynchronous transfers use the protocol of the REQ/ACK handshake. With each handshake, one byte of information can be transferred over the SCSI bus. Targets drive the -REQ signal while initiators drive the -ACK signal. In this mode, targets control the directional flow by driving the -I\_O signal. When this signal is asserted, the information is transferred from the target to the initiator over the SCSI bus. When the -I\_O signal is deasserted, the information is transferred from the target.

In this mode, the 82C5086's 64-byte FIFO is used as a buffer between the SCSI bus, and the high-speed memory data bus or MPU bus. Also 5086s can be cascaded to increase the width of SCSI bus and the memory data bus from 8 bits to up to 32 bits. Refer to the section "Master/Slave Mode" later in this chapter for more information on cascading 5086s.

## Synchronous Transfers

Like asynchronous transfers, synchronous transfers use a REQ/ACK handshake. Unlike asynchronous transfers, a transfer rate can be specified with synchronous transfers. Firmware engineers can specify this rate by performing a write operation to Transfer Period Register 15. For targets responsible for driving the -REQ signal, the transfer rate specifies the minimum number of clock cycles between the leading edges of the -REQ signal to the next -REQ pulse. For initiators responsible for driving the -ACK signal, the transfer rate specifies the minimum number of clock cycles between the leading edges of clock cycles between the leading edges of the specifies the minimum number of clock cycles between the leading edges of -ACK pulses.

With synchronous transfers, the -REQ and -ACK signals can be offset by a count of up to 64 bytes; a count up to the size of the 82C5086's internal FIFO. Firmware engineers can specify this offset through a write operation to Maximum Sync Offset Register 14. For more information on these registers refer to Chapter 4.

#### Master/Slave Mode

As Figure 3-2 indicates, 5086s can be cascaded to support wide data transfers over the SCSI and the memory data buses. By cascading four 82C5086 chips these buses can be extended to 32 bits. The 80- and 84-pin packages support this feature.

Firmware engineers have the capability of specifying the following for each 82C5086 in the system:

- Master or slave mode for the 82C5086(s) basic mode of operation (e.g., transferring data to/from the DMA controller's buffer memory), and
- Master or slave mode for the 82C5086(s) SCSI interface functions.



Chapter 3. 82C5086 Operation

The mode the chip is operating in to perform SCSI bus activites can be viewed as a subordinate mode of the chip's main mode of operation. For instance, as Figure 3-2 indicates the chip labelled Slave/Master B is operating in slave mode; it is a slave to the 82C5086 labelled Master/Master A. However, when Slave/Master B is performing SCSI interface activities, it is operating in master mode. Therefore for such operations, it will operate as the master chip for its two slave chips, Slave/Slave A and B.

Firmware engineers can specify the 82C5086's basic mode of operation as master or slave with bit 7 (Slave Mode Bit) of Mode Control Register 7. The 82C5086's subordinate mode, the SCSI bus interface mode, can be specified as master or slave with bit 6 (SCSI Bus Slave Mode) of this register.

When bit 7 is asserted, the 82C5086 is operating in slave mode as its basic mode of operation; when this bit is deasserted the 82C5086 is operating in master mode. When bit 6 is asserted, it forces the chip to operate in slave mode when performing SCSI bus interface functions; when this bit is deasserted, the chip will operate in master mode. Firmware engineers should assert bit 6 only if bit 7 is also asserted. Consequently, bits 7 and 6 must be set as shown in Table 3-1 for the system configuration that is shown in Figure 3-2:

#### Table 3-1. Mode Control Register Setting

| 82C5086 Chip                                                        | Mode Control Register 7 |                         |  |  |
|---------------------------------------------------------------------|-------------------------|-------------------------|--|--|
|                                                                     | Bit 7<br>Slave Mode     | Bit 6<br>SCSI Bus Slave |  |  |
| Master/Master A<br>Slave/Master B<br>Slave/Slave A<br>Slave/Slave B | 0<br>1<br>1<br>1        | 0<br>0<br>1<br>1        |  |  |

If bits 7 and 6 are set as indicated in Table 3-1, the 82C5086 chips are configured as shown in Table 3-2.

| T | ab | le | 3-2. | Master/S | lave | Mode |
|---|----|----|------|----------|------|------|
|---|----|----|------|----------|------|------|

|                 | Basic Mode  | SCSI Bus Mode |
|-----------------|-------------|---------------|
| Master/Master A | Master Mode | Master Mode   |
| Slave/Master B  | Slave Mode  | Master Mode   |
| Slave/Slave A   | Slave Mode  | Slave Mode    |
| Slave/Slave B   | Slave Mode  | Slave Mode    |

#### Master/Master Mode

When bits 7 and 6 of Register 7 are deasserted, the 82C5086 chip is in master mode when performing its basic operations (e.g., transferring data to buffer memory), as well as in master mode when performing SCSI bus functions. Refer to the chip labelled Master/Master A in Figure 3-2. The master chip is responsible for controlling the SCSI bus phase control signals and for transferring bits 0-7 during SCSI bus transfers. It is connected to the host system via a cable referred to as Cable A. For more information on this cable refer to the American National Standard for Information Systems-Small Computer System Interface.

#### Slave/Master Mode

When bit 7 is asserted and bit 6 is deasserted, the chip is forced to operate in slave mode for its basic operation, yet operate in master mode for SCSI bus interface functions. Refer to the chip labelled Slave/Master B in Figure 3-2. This chip is functioning as a slave to Master/Master A. It does not control such SCSI bus phase signals as -ATN, -BSY, -C\_D; Master/Master A is responsible for this. It functions as a slave in such activities as transferring data to the system's buffer memory.

Yet Slave/Master B acts in master mode when performing SCSI bus data transfers. Therefore, this chip must synchronize the transfer of bits 16-32 by Slave/Slave A and Slave/Slave B as well as transfer bits 8-15. Slave/Master B, Slave/Slave A, and Slave/Slave B are connected to the host system via a cable referred to as Cable B. Whereas, the master chip's Cable A carries SCSI bus phase control signals as well as SCSI data (bits 0-7), Cable B carries only the -REQ and -ACK signals and SCSI data (bits 8-32). Cable A and B are independent cables. For more information on these cables refer to the above-mentioned ANSI document.

#### Slave/Slave Mode

When bits 7 and 6 are asserted, the chip is forced to operate in slave mode for its basic operation as well as in slave mode for its SCSI bus interface operations. Refer to the chips labelled Slave/Slave A and B in Figure 3-2.

In slave mode, the 82C5086 is under the control of the master 82C5086 chip. Only the FIFO is active in slave mode; SCSI bus phases or MCS access is not used. Asynchronous and synchronous data transfers proceed as in master mode.

#### Synchronizing Memory Data Bus Transfers

Only the master (Master/Master A) can send request signals (-DMA\_REQ) to the DMA controller. When the slave chips have data ready to transfer over the memory data bus, they all release -DSYNC (DMA Sync); forcing this signal to go high. When the slave(s) -DSYNC signal is high, the master asserts its -DMA\_REQ signal to indicate it has data ready to transfer to the system's buffer memory. When the DMA controller is ready to receive that data, it sends an -ACK signal back. The slaves' -DMA\_ACK pins should be tied to the master's -DMA\_ACK pin; thereby enabling the slaves to detect the DMA's -ACK signal. In slave mode, the slave 82C5086(s) drives the -WPAR as well as the -DSYNC signals.

#### Synchronizing SCSI Bus Data Transfers

A chip operating as a SCSI bus master (Master/Master A or Slave/Master B) conducts a request/acknowledge handshake with the SCSI bus for transferring data. A SCSI bus master chip will not handshake a byte on the SCSI bus until the wire-or'ed -SSYNC signal is deasserted (high). SCSI bus slave chips will assert this signal when they are not ready to process more data.

In slave SCSI mode, the 82C5086 chip is under the control of the master SCSI chip. Only the FIFO is active in slave mode; SCSI bus phases or MCS access is not used. SCSI bus data transfers can be asynchronous or synchronous. In asynchronous or synchronous mode, the -WPAR pin indicates the 82C5086 slave chip(s) has a data parity error or an overrun/underrun error condition.

To ensure correct synchronization, firmware engineers must send pipeline command(s) to the slave 82C5086(s) before sending the identical command(s) to the master 82C5086.

#### Hardware Specifications

The 82C5086 pins that support the buffer memory interface should be wired as follows. The master chip's -DMA\_REQ and -DMA\_ACK pins need to be tied to the DMA controller's REQ/ACK pins. The -DMA\_ACK pin on the slave(s) should be tied to the master's -DMA\_ACK pin. The -DSYNC pin on the slave(s) should be tied to the master's -DSYNC pin.

The 82C5086 pins that support the SCSI bus interface should be wired as follows. The SCSI master chip's -ATN, -BSY, -MSG -C\_D, and -I\_O, -REQ, and -ACK pins should be tied to the SCSI bus. On the master, the -SSYNC and -WPAR should be externally pulled high, or tied to the respective pins on the slave 82C5086(s). The SCSI bus master chip's -REQ and -ACK pins should be tied to their respective pin on the SCSI bus slave(s). Refer to Figure 3-2.

#### METHOD OF OPERATION

Operational modes (e.g., master/slave, synchronous/asynchronous data transfer mode) are supported by functional blocks within the 82C5086. These blocks provide the logic the 82C5086 needs to interface with other system components (e.g., MPU), and to manage the flow of SCSI data, commands, messages, and status through the system. These functional blocks can be grouped into the following categories:

- The I/O interface
- The set of 46 commands, and
- The memory structure that supports the queuing of commands.

It is through its I/O interface that the 82C5086 is able to send/receive signals, addresses, and data to/from the system's other components. Through its command set, the 82C5086 is able to provide the SCSI protocol for command, data, message and status flow through the system. The 82C5086's memory structure consists of a 64-byte FIFO and six, 32-byte Message/Command Space (MSC) scripts. The FIFO enables data transfers to be streamlined, and system performance to be increased. The MCS, in conjunction with the 82C5086's four pipeline registers, enables up to four pipeline commands to be queued.

In the following sections, the first two components, the I/O interface and command set, are briefly discussed. Both of these topics are described in detail in Chapters 2 and 4, respectively. The third component, the 82C5086's memory structure, is described in detail in this section.

#### I/O Interface

This section provides four examples of how this I/O interface enables the 82C5086 to communicate with other system components.

#### Example 1. I/O Interface Providing a Path to the SCSI Bus.

There are nine 82C5086 signals (e.g., -ATN) that comprise the SCSI control bus. Firmware engineers can control these bidirectional signals through the 82C5086's command set. For example, by issuing the CNTL ATN ON pipeline command, firmware engineers can assert the -ATN signal on the SCSI bus.

#### Example 2. I/O Interface to Buffer Memory.

The system's buffer memory (memory data bus) is accessible via a DMA controller. Such DMA controllers as the CHIPS 5055 DMA Controller provide the addresses in the buffer memory to which data is to be transferred. The 82C5086 communicates with the DMA controller over a bidirectional memory data bus via DMA request/acknowledge handshake control signals.

#### Example 3. I/O Interface to the MPU.

The A\_D bus and its associated control signals connect the 82C5086 to the MPU. Each of the 24, internal 82C5086 registers has its own address. Through address bits A4-A0 (non-multiplexed addressing) the MPU can specify an address and select any of the 82C5086's internal registers for a read/write operation. For example, by performing a write operation to MPU FIFO Data Register 12, the MPU can deposit data into the 82C5086's FIFO. From the FIFO, the data can be transferred to the buffer memory via the memory data bus or to the SCSI bus.

#### Example 4. I/O Interface to the Host Computer.

Communication with the host computer is via an 8- or 16-bit bidirectional port. The host computer interface consists of the A\_D Bus (bits 0-7), the memory data bus (bits 8-15), and the MPU control signals. Data is transferred to/from the host computer via the SCSI data bus. This bus is comprised of the eight lines named HOST\_D[0-7].

Certain signals are used only when the 82C5086 is operating in a specific mode. For instance, the MPU\_AEN signal is used only when the 82C5086 is operating in host adapter mode. Refer to Chapter 2 for signal descriptions.

#### Command Set

Through the commands, firmware engineers can control the 82C5086's I/O signals, and thus control the 82C5086's communication with the other system components. These commands provide the functions needed by firmware engineers to implement the SCSI interface on a host computer or a device controller. Through this set of 46 commands firmware engineers can transfer data between the MPU and memory data bus. They can also manage SCSI data, command, message, and status flow through the system. Refer to Chapter 5 for command descriptions.

#### Memory Structure

The 82C5086 provides 256 bytes x 9 of memory. This on-chip memory can be categorized as:

- Data FIFO or,
- Message/Command Space (MCS) script.

The FIFO can be used to smooth out data transfers and increase system throughput. As Figure 3-3 indicates, all data transfers in the system must go through the 82C5086's internal FIFO.

The second component of on-chip memory is the MCS. This portion of memory is used by the firmware to store SCSI sequences comprised of SCSI commands, messages, and/or status. These SCSI sequences are used by the pipeline commands that the firmware engineer places in the 82C5086's pipeline registers. Together, the MCS and the pipeline registers enable the firmware engineer to queue up to four commands, and to use the MCS as an extension of the MPU's memory. Plus, the MCS can be customized for a particular application. Refer to the section "Pipelining Structure" later in this chapter for more details.

Requests to access 82C5086 memory are prioritized in the following descending order: FIFO IN, FIFO OUT, 82C5086 state machine (SM) requests, and MPU requests.



Figure 3-3. Conceptual Diagram of the 82C5086's Memory

#### Data FIFO

All data transfers in the system must use the 82C5086's internal FIFO. This 64-byte section of memory is used as a depository for FIFO data and parity. Firmware engineers use the pipeline commands to manage the flow of this SCSI data. This includes asynchronous, as well as synchronous, SCSI bus data transfers.

In addition to SCSI bus data transfers, the FIFO is also used as a depository for data being transferred between the MPU's data bus and the memory data bus. The high-speed memory data bus provides increased system performance because control and data activities are independent. Joining these two buses provides the firmware with a means of accessing the data stored in the buffer memory. For example, if firmware engineers have read the bad track information from a disk drive, they may need to transfer that information from the buffer memory to the MPU memory. Note that for the MPU to transfer data to/from the 82C5086's FIFO, the MPU must perform a write/read to MPU FIFO Data Register 12. Just as MPU MCS Buffer Register 11 is a holding register for MPU transfers to/from the MCS, the MPU FIFO Data Register is a holding register for MPU transfers of data to/from the FIFO.

Bytes are transferred into and out of the FIFO only when the transfer counter is non-zero. Firmware engineers can load the transfer counter through Registers 16-18. For diagnostic purposes, a firmware engineer may use Register 13 to preset the FIFO count to a value between 0-63. During normal operation, firmware engineers can read Register 13 to determine the number of bytes in the FIFO. Firmware engineers can write to Register 14 to set an offset of up to 64 bytes for synchronous data transfers. Register 14 can also be used to preset the current offset count. Normally, before the 82C5086 executes any data transfer commands it resets the FIFO. For more details on any of these registers refer to Chapter 4.

#### MCS Script

Just as the 82C5086's internal FIFO is used as a depository for data that will be routed through the system, the six, 32-byte MCS scripts can be used to store SCSI commands, messages, and status. Firmware engineers manage the flow of the SCSI sequence(s) stored in the MCS by issuing pipeline commands to the 82C5086's pipeline registers. For more information on this topic refer to the section "Pipelining Structure" later in this chapter.

Firmware engineers can use the MCS as a tool to customize the 82C5086 for their particular applications. For instance, if the 82C5086 is configured as a host adapter operating in initiator mode, the firmware engineer might want to store in the MCS certain messages frequently sent by the initiator.

MCS Address Pointers

The 82C5086 has two registers that serve as pointers to the MCS. One register, MPU MCS Address Register 10, acts as the MPU's pointer to the MCS. The MPU uses this pointer as the starting address for sending/receiving SCSI commands, status and/or messages to/from the MCS. Every time the MPU processes (reads or writes) a byte from the MCS script, the MPU MCS address pointer (Register 10) is incremented.

The second MCS pointer register, SM MCS Address Register 9, contains a pointer to the MCS for the 82C5086 state machine's use. Because there are two 82C5086 registers that can access the MCS, it is possible for the 82C5086 state machine to be accessing one 32-byte MCS script while the MPU is processing another area in the MCS.

#### MCS Auto Advance

The MCS has an auto advance feature. Before starting to execute a pipeline command that accesses the MCS, the 82C5086 SM will automatically advance the SM MCS address pointer (Register 9) to the beginning of the next MCS. This feature enables the 82C5086 to execute a variable length SCSI read sequence followed by a SCSI write sequence.

This auto advance will not occur if the SM MCS address pointer is already pointing to the beginning of an MCS, or if this feature has been disabled. Firmware engineers can disable it by issuing the CNTL DIS ADV command to one of the pipeline registers. If this feature is disabled, all 82C5086 state machine accesses to the MCS will be to contiguous memory locations.

#### **Pipelining Structure**

As mentioned previously, the 82C5086 state machine uses the MCS in conjunction with the four pipeline registers to enable firmware engineers to queue up to four commands. The firmware engineer uses the pipeline registers as a circular queue. When the firmware engineer issues a command to the pipeline register, it establishes an implied relationship between the position in the MCS to which the SM MCS Address Register is pointing, and the pipeline commands.

Before firmware engineers can issue a pipeline command, that will require access to the MCS, they must ensure that the SCSI sequence (e.g., SCSI commands, message, status) has already been stored in the MCS. The firmware is responsible for building this information in the MCS by performing consecutive writes to MPU MCS Buffer Register 11. After the firmware has built the SCSI sequence in the MCS, it must point the SM MCS address pointer (Register 9) to the first byte of this sequence. Once the MCS has been initialized, the firmware engineer can then issue the pipeline command to one of the pipeline registers. The 82C5086 SM scans these four pipeline registers searching for commands to execute. When the 82C5086 SM locates the pipeline command, it executes the command and processes the sequence stored in the MCS. If the 82C5086 detects that all the pipeline registers are empty, it will stop scanning for commands at Register 0. Therefore, it is recommended that firmware engineers place their first pipeline command in Register 0.

After the data transfer is completed, the target needs to set up the MCS to send a status byte to the initiator and then a DISCONNECT message. Refer to the following two examples of how the pipeline registers and the MCS can be used to queue commands. Figure 3-4 illustrates the steps involved in the first example.

#### Example 1. SCSI Transfer Command

Before the MPU can send the SCSI transfer command, it must perform the following three steps as illustrated in Figure 3-4:

## Step 1. Firmware engineer initializes the MPU MCS pointer.

The firmware engineer must set up MPU MCS Address Register 10 to point to the beginning of an MCS script. In this example, assume it uses MCS 0.

#### Step 2. Firmware engineer builds SCSI sequence.

The firmware must perform consecutive write operations to MPU MCS Buffer Register 11 to build the SCSI sequence, in this case a status byte followed by a DISCONNECT message. It starts at location 0 of MCS 0.

#### Step 3. Firmware engineer initializes SM MCS pointer.

The firmware engineer must load SM MCS Address Register 9 with the address in the MCS that contains the first byte of the stored SCSI sequence. In this case, that is location 0.

Once the MCS has been initialized as described above, the firmware engineer can issue the pipeline command and the 82C5086 SM will attempt to execute the queued command(s). Refer to Steps 4-7 of Figure 3-4.



Figure 3-4. 82C5086's Command Queuing



Step 8. 82C5086 SM scans for next command, and stops at location 0.

After executing the TGT WFS SEQ command, the 82C5086 SM proceeds to scan Register 3 which is empty. After scanning this empty register, it circles around and scans Register 0. At this point Register 0 is empty; the 82C5086 SM realizes that the pipeline registers are all empty and stops scanning at Register 0.

Example 2. SCSI Select/Reselect Process.

For operations that require the 82C5086 to select/reselect a SCSI device, the first byte the MCS Address Register points to must be a byte containing the initiator/target SCSI bus ID. For example, if the 82C5086 command to be issued is the Select With ATN Sequence then the firmware must have performed consecutive write operations to MPU MCS Buffer Register 11 to set up the MCS as follows:

#### **MCS** Script

| SM MCS Address><br>(Register 9) | 0 | Target ID byte       |
|---------------------------------|---|----------------------|
|                                 |   | Identify message     |
|                                 |   | Optional tag message |
|                                 |   | Multi-byte command   |

#### Target ID

The initiator can address up to eight peripheral devices that are connected to a device controller. Each SCSI peripheral device attached to the device controller is assigned a SCSI ID at system installation. The eight lines on the SCSI data bus are used to identify which SCSI device(s) is sending a request to the initiator. During the SCSI bus ARBITRATION phase, these device IDs are compared to determine bus usage priority. The device which is tied to the line -HOST\_D[7] has an ID of 7 and the highest priority when arbitrating for the SCSI bus.

#### Identify Message

The identify message is a single-byte message that specifies if a target is allowed to disconnect. It also specifies the initiator's LUN (logical unit number). This optional message is sent by the initiator and stored in the MCS.

#### Tag Message

This two-byte, optional message enables multiple commands to be sent to a target from a single initiator.

Multi-byte Commands

In this example, this portion of the queued SCSI sequence is a SCSI multi-byte command.

Once the MCS has been set up as shown, the firmware engineer could issue the INIT SWA SEQ command to one of the pipeline registers. Again, it is recommended that Register 0 be used. Because the SM MCS address pointer is at the beginning of an MCS script (location 0 of MCS 0), the 82C5086 will not advance this pointer to the beginning of the next MCS (location 32 of MCS 1) before starting to execute the INIT SWA SEQ command. The INIT SWA SEQ will perform the following steps:

- 1. Arbitrate for the SCSI bus.
- 2. Select the target whose ID has been stored at location 0 of the MCS.
- 3. Send a one-byte identify message to the target to indicate if a disconnect will be allowed. This identify message will also indicate the initiator's logical unit number.
- 4. If the modifier bit of the INIT SWQ SEQ command code equals 1, send the target a two-byte tag message.
- 5. Send the target the multi-byte command stored in the MCS.
- 6. Terminate execution at this point if the identify message disallowed a disconnect, or if the Override Disconnect Enable Bit (Register 20's bit 2) is asserted.
- 7. Receive one of the following from the target if a disconnect is allowed:
  - one status byte and one message, or
  - one or two messages.
- 8. Wait for the SCSI bus to go to the BUS FREE phase.

The status byte and/or message received from the target will be placed in MCS 0 after the multi-byte command. The SM MCS address pointer will point to the last byte processed, plus one.

To aid the firmware engineer in sorting out contiguous status and message bytes, the 82C5086 tags all message bytes received over the SCSI bus. Before firmware engineers read the MCS Data Register they can check bit 5 of the SCSI Status Register 19. If the next read of the MCS Data Register will produce a message byte, this bit will be asserted. Firmware engineers should note that Register 19's bit 5 is valid only if Register 19's bit 7 is asserted.

The pipeline status registers contain the counts and the status of the SCSI bus phases that transpired during a command's execution. Refer to Chapter 4's description of the pipeline command registers for more details on the pipeline registers. Chapter 5 provides details on the pipeline commands.



This chapter is directed at firmware engineers. It provides a description of the function and operation of each of the 82C5086's internal registers.

#### FUNCTION OF THE 82C5086'S REGISTERS

The 82C5086 has 24 internal registers that are accessible from an external circuit. They can be categorized as control (write) registers, or status (read) registers. Their function is two-fold. Firmware engineers can use them to control the 82C5086's internal operation, and also to gain processing status and status results of the 82C5086's operation.

Each register has a unique address. The particular register's address is identified by the 82C5086's address bits A0 through A4, as illustrated in Table 4-1.

|   | DRES |   |   |           | REGISTER | OP | REGISTER           |
|---|------|---|---|-----------|----------|----|--------------------|
|   | A3   |   |   | <u>A0</u> | NUMBER   |    | NAME               |
| 0 | 0    | 0 | 0 | 0         | 0        | W  | Command Pipeline 0 |
|   |      |   |   |           | R        |    | Pipeline 0 Status  |
| 0 | 0    | 0 | 0 | 1         | 1        | W  | Command Pipeline 1 |
|   |      |   |   |           | R        |    | Pipeline 1 Status  |
| 0 | 0    | 0 | 1 | 0         | 2        | W  | Command Pipeline 2 |
|   |      |   |   |           | R        |    | Pipeline 2 Status  |
| 0 | 0    | 0 | 1 | 1         | 3        | W  | Command Pipeline 3 |
|   |      |   |   |           | R        |    | Pipeline 3 Status  |
| 0 | 0    | 1 | 0 | 0         | 4        | W  | SCSI Configuration |
|   |      |   |   |           | R        |    | SCSI Status        |
| 0 | 0    | 1 | 0 | 1         | 5        | W  | Interrupt Mask     |
|   |      |   |   |           | R        |    | Interrupt Status   |
| 0 | 0    | 1 | 1 | 0         | 6        | W  | Select Timeout     |
|   |      |   |   |           | R        |    | Extended Status    |
| 0 | 0    | 1 | 1 | 1         | 7        | W  | Mode Control       |
|   |      |   |   |           | R        |    | Buffer Status      |
| 0 | 1    | 0 | 0 | 0         | 8        | W  | SCSI Clock         |
|   |      |   |   |           | R        |    | Input Port 1       |

### Table 4-1. Addressing The 82C5086 Registers

| AD       | DRES | S |    |    | REGISTER | OP | REGISTER                                  |
|----------|------|---|----|----|----------|----|-------------------------------------------|
|          | A3   |   | A1 | A0 | NUMBER   | •  | NAME                                      |
| 0        | 1    | 0 | 0  | 1  | 9        | W  | SM MCS Address                            |
|          |      |   |    |    | R        |    | SM MCS Address                            |
| 0        | 1    | 0 | 1  | 0  | 10       | W  | MPU MCS Address                           |
|          |      |   |    |    | R        |    | MPU MCS Address                           |
| 0        | 1    | 0 | 1  | 1  | 11       | W  | MPU MCS Buffer                            |
|          |      |   |    |    | R        |    | MPU MCS Buffer                            |
| 0        | 1    | 1 | 0  | 0  | 12       | W  | MPU FIFO Data                             |
|          |      |   |    |    | R        |    | MPU FIFO Data                             |
| 0        | 1    | 1 | 0  | 1  | 13       | W  | FIFO Count                                |
|          |      |   |    |    | R        |    | FIFO Count                                |
| 0        | 1    | 1 | 1  | 0  | 14       | W  | Maximum Sync Offset                       |
|          |      |   | _  |    | R        |    | Current Sync Offset                       |
| 0        | 1    | 1 | 1  | 1  | 15       | W  | Transfer Period                           |
|          |      |   |    |    | R        |    | Revision Number                           |
| 1        | 0    | 0 | 0  | 0  | 16       | W  | Transfer Counter/                         |
| <u> </u> |      |   |    |    | R        |    | Low Byte                                  |
| 1        | 0    | 0 | 0  | 1  | 17       | W  | Transfer Counter/                         |
| <u> </u> |      |   |    |    | R        |    | Middle Byte                               |
| 1        | 0    | 0 | I  | 0  | 18       | W  | Transfer Counter/                         |
| <u> </u> |      |   |    |    | R        |    | High Byte                                 |
| 11       | 0    | 0 | 1  | 1  | 19       | W  | Auxiliary Control 1                       |
| <u> </u> |      |   |    |    | R        |    | Auxiliary Status 1                        |
| 1        | 0    | 1 | 0  | 0  | 20       | W  | Auxiliary Control 2<br>Auxiliary Status 2 |
| <u> </u> |      | 1 |    |    | R        |    | Auxinary Status 2                         |
| 1        | 0    | 1 | 0  | 1  | 21       | W  | Sync/Async ID                             |
| <b></b>  | 0    | 1 |    |    | R        |    | Current Target ID                         |
| 1        | 0    | I | I  | 0  | 22<br>P  | W  | CMD Group 6 & 7 Length                    |
| <u> </u> |      | 1 | 1  | 1  | R<br>23  |    | SCSI Data                                 |
| 1        | 0    | I | 1  | 1  | R 23     | W  | Not Defined                               |
| L        |      |   |    |    |          |    | Not Defined                               |

Table 4-1. Addressing The 82C5086 Registers (continued)

## **REGISTER DESCRIPTION**

This section provides an operational description of a write or read operation in each of the 82C5086 internal registers. The registers are organized sequentially (0-23).

#### NOTE

Unless otherwise noted in the register's operational description, a hard reset condition clears all registers.
## REGISTERS 0-3 (0-3h)

| REGISTER<br>NUMBER | OPERATION | REGISTER NAME      |  |
|--------------------|-----------|--------------------|--|
| 0                  | Write     | Command Pipeline 0 |  |
|                    | Read      | Pipeline 0 Status  |  |
| 1                  | Write     | Command Pipeline 1 |  |
|                    | Read      | Pipeline 1 Status  |  |
| 2                  | Write     | Command Pipeline 2 |  |
|                    | Read      | Pipeline 2 Status  |  |
| 3                  | Write     | Command Pipeline 3 |  |
|                    | Read      | Pipeline 3 Status  |  |

# **REGISTER 0-3 (0-3h) - Write Operation**

These four pipeline registers are a circular queue for firmware engineers to send commands to the 82C5086. A command placed in one of these registers could execute a simple task (e.g., send a message to the SCSI bus), or execute a sequence of tasks. For example, the following series of tasks are executed when the firmware engineer issues the TGT WFS SEQ (Target Wait for Select Sequence):

- Wait for select from initiator
- Receive ID message into MCS script
- Optionally receive tag message into MCS script
- Receive multi-byte command into MCS
- Optionally send disconnect message, and proceed to the SCSI bus phase of BUS FREE

The 82C5086 executes pipeline commands in a circular fashion starting with Register 0. For example if the firmware engineer places two commands in Registers 0 and 2, the 82C5086 starts command scanning at Register 0. Once locating the first command, the 82C5086 starts executing it. If this command completes without an error condition, the 82C5086 scans the next register, Register 1, which is empty. The 82C5086 proceeds to Register 2, locates the second command and starts executing it. If this command completes without an error, the 82C5086 scans Register 3 which is empty. Next the 82C5086 scans Register 0 which is empty. At this point the 82C5086 detects all four pipeline registers are empty, and stops scanning.

In this example, note that the 82C5086 is now positioned to start command execution at Register 0. Consequently, firmware engineers are encouraged to begin pipeline command sequences at this location. Refer to Chapter 3's section "Pipelining Structure" for more details. For details on pipeline commands refer to Chapter 5.

| OP | 7   | 6        | 5       | 4   | 3            | 2           | 1          | 0   |  |
|----|-----|----------|---------|-----|--------------|-------------|------------|-----|--|
| W  | Pip | eline Co | mmand C | ode | INIT<br>Mode | TAR<br>Mode | MOD<br>Bit | INT |  |

# Bits 7-4 - Pipeline Command Code

These bits contain the command code for the specific pipeline command. For instance, 0000 specifies the NO OPERATION command. Refer to Chapter 5 for details on each pipeline command.

# Bit 3 - Initiator Mode

If this bit is asserted, the 82C5086 assumes the initiator role on the SCSI bus. This bit and bit 2 should never be enabled within the same pipeline command.

## Bit 2 - Target Mode

The 82C5086 assumes operation in target mode on the SCSI bus when this bit is asserted. This bit and bit 3 control internal logic; they enable differential SCSI drivers/receivers when the DIF\_ENB pin is high. This bit and bit 3 should never be enabled within the same pipeline command.

## Bit 1 - Modifier Bit

Several pipeline commands use this bit as a command modifier bit. For example, commands that transfer data between the SCSI bus and the MPU use this bit to enable 16-bit host adapter mode. The Initiator Select with ATN Sequence (INT SWA SEQ) uses this bit to allow a second message to be sent after the ID Message. The Target Send Busy Sequence (TGT SEND BSY) uses this bit to prevent the command from being cleared upon completion. Consequently, the command can be repeatedly executed until the firmware engineer aborts the sequence.

## Bit 0 - Interrupt when Command Complete

When this bit is asserted and this interrupt is enabled by the Interrupt Mask Register 5, the 82C5086 interrupts the MPU upon command completion.

Notes

When the 82C5086 is executing a SCSI command or command sequence and an unexpected condition occurs, the 82C5086 clears the current command and any other commands in Registers 0-3. Bit 1 (Extended Status) of the Interrupt Status Register 5 is set, and the Auxiliary Status Register 19 indicates the command number that caused the error. Extended Status Register 6 has the bit(s) set indicating which error occurred (e.g., bus phase error).

- The SM MCS Address Register and the MCS's contents are not affected by any error condition. Therefore, firmware engineers can examine these registers and the pipeline registers to determine the number and type of SCSI bus phases that occurred prior to the error.
- Firmware engineers can abort a pipeline command by writing a one to bit 5 (Soft Abort) of the SCSI Configuration Register 4. This soft abort terminates the currently executing command, sets bit 7 (BUSY) of the pipeline status registers to zero, and resets bit 6 of Register 4. Firmware engineers need to examine the status of the SCSI bus, the 82C5086's internal FIFO, and/or SM MCS Address Register, and deal with any conditions created by the command being aborted prematurely.
  - Bits 6 0 are not cleared by a hard reset.

# Registers 0-3 (0-3h) - Read Operation

Firmware engineers can use these registers to obtain status information and to aid in error recovery.

| OP | 7    | 6       | 5      | 4     | 3    | 2   | 1   | 0           |
|----|------|---------|--------|-------|------|-----|-----|-------------|
| R  | BUSY | COMMAND | STATUS | DATA  | MSG_ | OUT | MSC | <u>-</u> IN |
|    |      | PHASE   | PHASE  | PHASE | COL  | JNT | COL | JNT         |

Bit 7 - BUSY

This bit is set when the MPU sends a new command to the pipeline register, and is cleared upon command completion. Firmware engineers can poll this bit to monitor command progress. When a pipeline command terminates with an error, this bit is cleared in all the pipeline status registers.

## Bit 6 - COMMAND Phase

The SCSI bus COMMAND phase permits targets to request command information from initiators. When the 82C5086 detects a SCSI COMMAND phase during the execution of a pipeline command, this bit is asserted.

# Bit 5 - STATUS Phase

The SCSI bus STATUS phase permits targets to request status information be sent from targets to initiators. When the 82C5086 detects a SCSI STATUS phase during the execution of a pipeline command, this bit is asserted.

## Bit 4 - Data Phase

Data phase is a term used to encompass the SCSI bus DATA IN phase and DATA OUT phase. DATA IN phases permit targets to request data be sent from targets to initiators. DATA OUT phases permit targets to request data be sent from initiators to targets.

When this bit is asserted, the 82C5086 detects a SCSI bus DATA IN or DATA OUT phase during pipeline command execution.

# Bits 3-2 - MESSAGE OUT Count

These bits contain an encoded count of the number of SCSI bus MESSAGE OUT phases that transpired during pipeline command execution.

# Bits 1-0 - MESSAGE IN Count

These bits contain an encoded count of the number of SCSI bus MESSAGE IN phases that occurred during pipeline command execution. For example, if these bits contain a decimal 2 and the 82C5086 is configured as a target, the 82C5086 sent two separate messages to the initiator during command execution. The messages could have been single or multi-byte.

Note

The 82C5086 contains no provision for overflow detection from bits 2 and 3, or bits 0 and 1.

# **REGISTER 4 (4h)**

| REGISTER<br>NUMBER | OPERATION | REGISTER NAME      |
|--------------------|-----------|--------------------|
| 4                  | Write     | SCSI Configuration |
|                    | Read      | SCSI Status        |

# Register 4 (4h) - Write Operation

This register aids in the firmware engineer's control of activity on the SCSI bus.

| OP | 7                | 6             | 5             | 4            | 3                      | 2 | 1        | 0  |
|----|------------------|---------------|---------------|--------------|------------------------|---|----------|----|
| w  | Force<br>Connect | Hard<br>Abort | Soft<br>Abort | DIS<br>ARBIT | Extra<br>Data<br>Setup |   | SCSI Bus | ID |

# Bit 7 - Force Connect

This bit should only be used for diagnostic purposes. It forces the 82C5086 to connect to the SCSI bus.

# Bit 6 - Hard Abort

When this bit is asserted, all pipeline command registers are cleared immediately, and all SM activity is halted. This bit is also cleared.

This bit should be used only after the Soft Abort Bit has failed, and a "hung" command needs to be terminated. When the Hard Abort Bit is asserted, the SM Error Bit (bit 7) of the Extended Status Register (Register 6) is asserted, and a pipeline COMMAND COMPLETE condition is generated.

## Bit 5 - Soft Abort

When asserted, this bit causes a soft abort. This bit, unlike a hard abort, attempts to terminate the command execution in an orderly way, as soon as possible, rather than aborting the command immediately. For example, asserting this bit might halt command execution after the selection timeout has expired and the target has not responded, rather than immediately aborting.

Bit 5 clears itself and all command pipeline registers, and generates a pipeline COMMAND COMPLETE condition. When this bit is asserted, the SM Error Bit (bit 7) of the Extended Status Register 6 is set.

Because of the abnormal command abort the MPU might have to perform a clean up. Therefore, the MPU should check the status of the SCSI bus, and contents of the 82C5086's internal FIFO and/or the SM MCS Address Register, and status registers after a soft abort.

## Bit 4 - Disable Arbitration

When this bit is asserted, the 82C5086 omits the ARBITRATION phase and proceeds directly to the SELECTION phase. Because bus arbitration is unnecessary in systems with only one initiator, this bit should be asserted for systems using the single initiator option.

## Bit 3 - Extra Data Setup

When asserted, this bit instructs the 82C5086 to add two clocks of setup time to the data during asynchronous writes to the SCSI bus. Asserting this bit has no effect on synchronous data transfers because such transfers are locked into the system clocking.

# Bits 0-2 - SCSI Bus Identifier

A SCSI bus can support up to eight physical SCSI devices. Each physical device must be assigned a unique identifier. Bits 0-2 specify an encoded SCSI bus device identifier. During the SCSI bus ARBITRATION phase, the 82C5086 puts this decoded ID on the SCSI bus.

Devices can be assigned identifiers (IDs) from 0 through 7. These IDs have priorities for bus arbitration purposes. During arbitration, device IDs on the SCSI bus are compared to determine bus usage priority. A SCSI device with an ID of 7 has the highest priority.

# **Register 4 - Read Operation**

This register aids in the monitoring of activity on the SCSI bus.

| OP | 7      | 6    | 5    | 4    | 3    | 2 | 1          | 0     |
|----|--------|------|------|------|------|---|------------|-------|
| R  | Con-   | SCSI | SCSI | SCSI | SCSI | S | SCSI BUS I | PHASE |
|    | nected | SEL  | BSY  | ACK  | REQ  |   |            |       |

Bit 7 - Connected to the SCSI Bus

When this bit is asserted, the 82C5086 is connected to the SCSI bus. Note that references in this manual to the SCSI bus condition as being connected/disconnected are referring to this bit.

# Bit 6 - SCSI Select

Bit 6 indicates the unlatched status of the SCSI bus -SEL signal.

# Bit 5 - SCSI Busy

This bit indicates the unlatched status of the SCSI bus -BSY signal.

## Bit 4 - SCSI Acknowledge

Bit 4 indicates the unlatched status of the SCSI bus -ACK signal.

# Bit 3 - SCSI REQ

Bit 3 indicates the unlatched status of the SCSI bus -REQ signal.

Bits 0-2 - SCSI Bus Phase

These bits indicate the unlatched condition of the following three SCSI bus control signals: -MSG, -C\_D, and -I\_O.

# Note

• Unlatched signals can be changing asynchronously with respect to the MPU's processing. Therefore, to ensure valid data two readings of unlatched signals should be taken and compared.

REGISTER 5 (5h)

| REGISTER<br>NUMBER | OPERATION     | REGISTER NAME                      |
|--------------------|---------------|------------------------------------|
| 5                  | Write<br>Read | Interrupt Mask<br>Interrupt Status |

Typically, when the 82C5086 encounters any of the following events while it is processing a pipeline command, it can be programmed to generate an interrupt to the MPU:

- Command execution completed
- Unexpected condition occurred
- Detection of a parity error or overrun condition
- A phase change occurred
- Detection of the SCSI SELECTION/RESELECTION, RESET, or ATTENTION signal.

Firmware engineers can use this register to specify under what conditions the 82C5086 should generate interrupts to the MPU. They can enable or disable the associated mask bit by writing to this register. If the Interrupt Mask Bit is asserted and the corresponding event occurs (e.g., the command is completed and the COMMAND COMPLETE Mask Bit (bit 0) is asserted), the 82C5086 will generate an interrupt to the MPU.

| OP | 7                   | 6                   | 5           | 4                       | 3 | 2                          | 1 | 0                           |
|----|---------------------|---------------------|-------------|-------------------------|---|----------------------------|---|-----------------------------|
| w  | SCSI<br>ATN<br>Mask | SCSI<br>RST<br>Mask | SEL<br>Mask | Change<br>Phase<br>Mask |   | Parity/<br>Overrun<br>Mask |   | COMMAND<br>COMPLETE<br>Mask |

# **Register 5 (5h)- Read Operation**

A read to this register provides firmware engineers with the current status of the interrupt events. Interrupting events for bits 0,1, 2, 3, 4, and 6 are latched; bits 5 and 7 are passed unlatched through to the mask bit gate. The trailing edge of the MPU read cycle clears any latched bits.

| OP | 7           | 6           | 5   | 4               | 3                      | 2               | 1                  | 0                   |
|----|-------------|-------------|-----|-----------------|------------------------|-----------------|--------------------|---------------------|
| R  | SCSI<br>ATN | SCSI<br>RST | SEL | Change<br>Phase | FIFO<br>Half-<br>empty | Parity<br>Error | Extended<br>Status | Command<br>Complete |

## Bit 7 - SCSI ATTENTION

This unlatched bit is asserted when the SCSI bus -ATN signal is asserted. The 82C5086 must be connected to the SCSI bus for this bit to be asserted. It is valid in target and initiator mode.

# Bit 6 - SCSI RESET

This latched bit is asserted when the SCSI bus reset signal has been asserted.

# Bit 5 - SELECT

When the 82C5086 is currently being selected or reselected on the SCSI bus, this unlatched bit is asserted. The firmware engineer must have enabled selection and/or reselection for this bit to be asserted. If both selection and reselection are enabled, the firmware engineer must read bit 0 of SCSI Status Register 4 to determine if a selection or reselection occurred. If bit 0 is equal to zero, selection occurred. If bit 0 is equal to 1, reselection occurred.

## Bit 4 - Change Phase

This latched bit indicates a phase change has occurred when the 82C5086 is operating in initiator mode.

# Bit 3 - FIFO Half-empty

This latched bit indicates that the 32nd byte in the FIFO has been accessed. This bit provides a means for the host adapter driver code to gain control of the host processor when the 82C5086 needs more data (non-DMA mode).

## Bit 2 - Parity Error/Overrun

When a parity error is detected or an overflow condition has developed, this latched bit is asserted. Refer to the description of Auxiliary Status Register 20 later in this chapter, for further details on the type of parity error and/or overflow condition.

## Bit 1 - Extended Status

This latched bit is set when a pipeline command is terminated abnormally. This asserted bit indicates that extended status is available in Extended Status Register 6. When this bit is set, all pipeline commands are aborted. Firmware engineers can obtain the number of the pipeline register last executed by reading Auxiliary Status Register 19.

# Bit 0 - Command Complete

This latched bit is asserted when the execution of a pipeline command, that had bit 0 (Interrupt When Command Complete Bit) asserted, is completed. A COMMAND COMPLETE event is also generated when an error condition has developed and the pipeline command was terminated abnormally.

Note

As mentioned previously, all latched bits are cleared by the trailing edge of the Interrupt Status Register read strobe. The 82C5086 contains extra logic to ensure that only bits that are active at the beginning of the read strobe are cleared by the strobe's trailing edge. This implies that firmware engineers do not have to take any precautions to avoid loss of data when reading this register.

In host adapter mode, the 82C5086 driver code could issue the 82C5086 a command (e.g., INIT DATA PTS) to transfer data from the host MPU bus to the SCSI bus. The driver code could then burst transfer (IORDY is connected to the MPU Wait State Generator) 64 bytes into the 82C5086's FIFO, enable an interrupt on bit 3, then transfer control back to the operating system. When the target begins to accept data or an error occurs, and the FIFO is half-empty, bit 3 will generate an interrupt. This interrupt causes the host processor to return control to the 82C5086 driver code. At this point, the 82C5086 driver code would burst transfer 32 bytes to the 82C5086, and wait for bit 5 of FIFO Count Register 13 to be deasserted. It would then repeat the process until all the bytes had been transferred into the FIFO.

# REGISTER 6 (6h)

| REGISTER<br>NUMBER | OPERATION     | REGISTER NAME                              |
|--------------------|---------------|--------------------------------------------|
| 6                  | Write<br>Read | Select/Reselect Timeout<br>Extended Status |

# Register 6 (6h)- Write Operation

This register specifies the selection/reselection timeout. Selection timeout is the maximum time the 82C5086 will wait for a target's response to a SELECT command before terminating the command presently in progress. Reselection timeout is the maximum time an initiator is allowed to respond to a target's RESELECT command.

| OP | 7 | 6 | 5 | 4       | 3          | 2      | 1 | 0 |
|----|---|---|---|---------|------------|--------|---|---|
| W  |   |   |   | Select/ | Reselect t | imeout |   |   |

Bits 0-7 - Select/Reselect Timeout

If the value in Register 8 produces a 400 ns period, this register will produce 1.6 ms resolution for the timeout period (400 ns \* 4096). To produce a timeout period of 250 ms this register should be loaded with 250 ms divided by 1.6 ms which equals 151.

# Register 6 (6h) - Read Operation

If an unexpected condition is detected (Extended Status bit 1 of Register 5 is asserted), this register contains valid data. It indicates why the command was terminated prematurely. Firmware engineers should realize that all pipeline commands have been aborted.

| OP | 7           | 6            | 5            | 4             | 3                     | 2                     | 1            | 0                           |
|----|-------------|--------------|--------------|---------------|-----------------------|-----------------------|--------------|-----------------------------|
| R  | SM<br>Error | Time-<br>out | ARB<br>Error | Soft<br>Reset | Bus<br>Phase<br>Error | Con-<br>nect<br>Error | ATN<br>Error | Illegal<br>Command<br>Error |

Bit 7 - State Machine (SM) Error

A state machine error has occurred when this bit is asserted. Any of the following five conditions cause state machine errors to occur:

The firmware engineer aborted the command via a soft or hard abort.

The 82C5086 received an illegal message. When the 82C5086 does not receive the expected message, this bit is set and the command is aborted immediately. For instance, if the 82C5086 is executing the TGT WFS SEQ command and the first message received is not the identify message, the command is aborted immediately, and this bit is set.

In target mode, the illegal message is deposited in the MCS.

In initiator mode, the 82C5086 does not handshake with the illegal message; it leaves it on the bus with the -REQ signal asserted. The firmware engineer must decide whether or not to receive the message.

- Illegal group code encountered. In order for the 82C5086 to determine the SCSI command length, the group code must be valid. If the 82C5086 encounters a group code of 2, 3, or 4, the command does not have a valid group code.
- While executing the TGT SEND BSY sequence the 82C5086 was reselected. The 82C5086 was expecting to be selected.
- The target disconnected before sending a COMMAND COMPLETE or DISCONNECT message.

# Bit 6 - Timeout

This bit is asserted when the 82C5086 is selecting/reselecting a SCSI device and a timeout occurs; command execution is terminated. Time period is programmable via the value written to Select Timeout Register 6.

# Bit 5 - Arbitration Error

If the 82C5086 is selected while arbitrating for the SCSI bus, this bit is asserted. Command execution is terminated.

## Bit 4 - Soft Reset

A soft reset condition occurs when the SCSI bus reset signal is asserted, and the firmware engineer has asserted the DIS SRI Bit (bit 4 of Auxiliary Control Register 19). Under these conditions, the 82C5086 is not hard reset. Command execution is terminated immediately and this bit is asserted. The soft reset forces the 82C5086 to disconnect from the SCSI bus if connected. All internal registers remain unaltered. Note that when a soft reset occurs, bit 6 of Interrupt Status Register 5 is asserted.

## Bit 3 - Bus Phase Error

Throughout all initiator commands the correct SCSI bus phase must be maintained. If the target switches to an unexpected phase and asserts the -REQ signal, this bit is asserted. Command execution is terminated immediately.

# Bit 2 - Connect Error

Any 82C5086 command accessing the SCSI bus checks the connected bit's status. This status is contained in bit 7 of SCSI Status Register 4. Certain commands, such as TGT SEND MSG, require that the 82C5086 is connected to the SCSI bus throughout the execution phase.

Other commands, such as INIT SWA SEQ, require that the connect state changes with execution. For instance, this command requires the 82C5086 to be disconnected from the SCSI bus when execution begins. However, when the 82C5086 wins SCSI bus arbitration, it requires the 82C5086 to remain connected until the DISCONNECT message is sent. If the target disconnects before command completion, this bit is asserted. Command execution is terminated immediately.

## Bit 1 - Attention Error

The currently executing target command is terminated with this bit set when all the following conditions exist:

- An asserted SCSI -ATN signal
- The 82C5086 is in target mode
- An enabled -ATN pin (bit 2 of Register 19 is set to zero)
- In a phase other than SELECTION or MESSAGE OUT phase
- Not executing TGT XFER BYTE or TGT SEND BSY command.

When these conditions exist, the command termination behavior of the 82C5086 depends on which of the four types of transfer is transpiring.

- <u>Synchronous Data Transfers</u>. If the 82C5086 is transferring synchronous data, the 82C5086 terminates the command after the -REQ pulse is deasserted. As with asynchronous transfers, data remains in the FIFO and the current MPU and/or memory data bus cycle is allowed to complete. The Offset Counter continues to count initiator -ACK pulses until the target changes bus phase.
- <u>Asynchronous Data Transfers</u>. If the 82C5086 is transferring asynchronous data, the 82C5086 completes the last SCSI bus REQ/ACK handshake. The current MPU and/or memory data bus cycle is allowed to complete then command execution is terminated. Data may remain in the 82C5086's interanl FIFO.
- <u>SCSI Bus to MCS Transfers</u>. If the 82C5086 is transferring a command from the SCSI bus into an MCS script, the 82C5086 does not assert -REQ for the next byte. Command execution is terminated.
- <u>MCS to SCSI Bus Transfers</u>. If the 82C5086 is sending messages or status from an MCS script to the SCSI bus, the 82C5086 terminates command execution after the initiator deasserts the -ACK signal.

Bit 0 - Illegal Command Error

When the 82C5086 is issued an undefined command, this bit is asserted.

# REGISTER 7 (7h)

| REGISTER<br>NUMBER | OPERATION     | REGISTER NAME                 |
|--------------------|---------------|-------------------------------|
| 7                  | Write<br>Read | Mode Control<br>Buffer Status |

# Register 7 (7h) - Write Operation

This register specifies the 82C5086's operational modes. Firmware engineers can specify the 82C5086's main mode of operation (e.g., mode when it is transferring data to/from buffer memory) with this register's bit 7. Firmware engineers can use this register's bit 6 to specify whether the 82C5086 is operating in master or slave mode when performing SCSI interface operations (e.g., SCSI bus data transfers).

This register also enables/disables several pin functions.

| OP | 7             | 6                    | 5                        | 4                      | 3                     | 2                   | 1           | 0                       |
|----|---------------|----------------------|--------------------------|------------------------|-----------------------|---------------------|-------------|-------------------------|
| w  | Slave<br>Mode | SCSI<br>Bus<br>Slave | MEM_D<br>Parity<br>Check | SCSI<br>Data<br>Parity | DMA<br>Hand-<br>shake | FIFO_<br>RDY<br>Pin | FIFO<br>RST | Host<br>Adapter<br>Pins |

Bit 7 - Slave Mode

When this bit is asserted, the 82C5086 is operating in slave mode. In this mode, the 82C5086 is under the control of a master 82C5086 chip. Only the FIFO is active in slave mode; SCSI phases or MCS access is not defined. Asynchronous and synchronous data transfers proceed as in master mode. The Transfer Counter can be loaded with the number of bytes to transfer, or an infinite transfer count (Register 20, bit 3) can be programmed. To ensure correct synchronization, the firmware engineer must send pipeline command(s) to the slave 82C5086(s) before sending the identical command(s) to the master 82C5086.

Because the 82C5086 slave does not have a SCSI bus ID, slave mode forces the chip to ID 0. Hence, the firmware engineer specifies synchronous data transfer by setting bit 0 (SCSI bus ID 0) of Register 21, or asynchronous data transfers by clearing bit 0.

When the 82C5086 is operating in slave mode (this bit is asserted), it drives the -WPAR and -DSYNC signals.

# Bit 6 - SCSI Bus Slave

The firmware engineer should assert this bit only if bit 7 is also asserted. It forces the SCSI bus interface to operate in slave mode. Consequently, REQ/ACK control signals are not generated. Rather the -SSYNC pin outputs a ready condition when the slave 82C5086 SCSI interface is ready for additional data.

#### Bit 5 - Memory Data Bus Parity Check

When this bit is asserted, data received over the memory data bus is parity checked. Data sent to the memory data bus from the 82C5086 contains the flow-through parity bit.

When this bit is deasserted and the 82C5086 receives MPU or memory data bus data, the 82C5086 must calculate parity before sending the data to the FIFO or MCS.

# Bit 4 - SCSI Data Parity

Asserting this bit enables parity checking on SCSI bus transfers and all FIFO output transfers. When a parity error is detected, bit 2 (Parity/Overrun) of Interrupt Status Register 5 is asserted.

When a parity error is detected and the Halt on Data Parity Error Bit (bit 0 of Auxiliary Control Register 20) is asserted, the 82C5086 terminates command execution with the Interrupt Status Bits 0,1, and 2, and Extended Status Bit 7 asserted. The precise time of command termination depends on the type of transfer as described below:

- <u>Synchronous/Asynchronous Data Transfers in Target Mode</u>. The 82C5086 receives the byte with the parity error, waits for the completion of the memory data bus and/or MPU cycle then terminates the command. The firmware engineer should read the Up Transfer counter, FIFO Counter, the Offset Counter, and Buffer Status Register to determine the number of transferred bytes.
- Synchronous/Asynchronous Data Transfers in Initiator Mode. The 82C5086 waits for the memory data bus and/or MPU cycle to complete then terminates the command. As mentioned previously, the firmware engineer should check the Up Transfer Counter, FIFO Counter, and the Offset Counter, and Buffer Status Register. Because -ACK is not asserted, the 82C5086 does not receive the byte with the parity error. This provides the firmware engineer with the option of asserting the -ATN signal.
- <u>MCS Transfers in Target Mode</u>. The byte with the parity error is received; however, it is not transferred to the MCS. The 82C5086 then terminates the command.
- <u>MCS Transfers in Initiator Mode</u>. The byte with the parity error is not received. This allows the firmware engineer the option to assert the -ATN signal.

# Bit 3 - DMA Controller Handshake

Normally the 82C5086 does not assert the -DMA\_REQ signal for the next buffer RAM transfer until the DMA controller has deasserted the -DMA\_ACK signal. Asserting this bit, enables the 82C5086 to assert the next -DMA\_REQ signal while the previous -DMA\_ACK signal is still asserted.

## Bit 2 - FIFO Ready Pin

For AT Bus compatibility, the FIFO\_RDY pin is a tri-state output. Asserting this bit, enables the 82C5086 to drive this pin to indicate the MPU FIFO Data Register is ready for additional data. It can be used for 8- or 16-bit MPU data transfers to/from the memory data bus, or the SCSI bus. This pin is typically connected to a DMA controller on the MPU bus.

# Bit 1 - FIFO RESET

Typically, the 82C5086 resets the internal FIFO before starting data transfers. When this bit is asserted, the 82C5086 does not reset the FIFO before starting to execute commands that will transfer data. The firmware engineer is responsible for resetting the FIFO by issuing the CNTL RST FIFO pipeline command.

#### Bit 0 - Host Adapter Pins

When this bit is asserted, the 82C5086 drives the open drain IORDY and -16BHAM output pins. When the MPU FIFO Data Register is accessed yet not ready to receive/send more data from/to the MPU, the IORDY pin is deasserted. Typically this pin is connected to the MPU Wait State Generator. The -16BHAM is asserted when the MPU accesses the MPU FIFO Data Register for a 16-bit data transfer. Typically, this pin enables the upper byte (bits 8-15) to transfer to the MPU memory. Refer to Figure 2-7 for a functional pin out of these host adapter pins.

#### Notes

- The SCSI bus mode can be viewed as a subordinate mode of the chip's main mode of operation as a master or slave. For more details on this topic refer to Chapter 3's section "Master/Slave Mode".
- SCSI bus slave chip(s) must have their -SSYNC, -REQ, and -ACK pins connected to the equivalent pins on the bus master chip.
- When parity checking is enabled on memory data bus transfers, pin 4 of Input Port 1 contains the parity bit.
- In the 82C5086, parity is passed through. For instance, parity received from the SCSI bus is passed through to the memory data bus.

# **Register 7 (7h) - Read Operation**

This register provides status information on the FIFO data buffers. Dual buffers (ping pong) are used on the memory data bus and the SCSI data bus to accelerate the speed of data transfers between these buses and the FIFO.

| OP | 7 | 6        | 5 | 4   | 3     | 2     | 1     | 0     |
|----|---|----------|---|-----|-------|-------|-------|-------|
| R  |   | Not Used |   | MPU | MEM_D | MEM_D | SCSI  | SCSI  |
|    |   |          |   | BUF | BUF_B | BUF_A | BUF_B | BUF_A |

Bit 4 - Microprocessor Buffer

When this bit is asserted, it indicates that the MPU's FIFO data buffer contains data.

Bit 3 - Memory Data Buffer B

When this bit is asserted, it indicates that the memory data buffer B contains data.

Bit 2 - Memory Data Buffer A

When this bit is asserted, it indicates that the memory data buffer A contains data.

Bit 1 - SCSI Buffer B

When this bit is asserted, it indicates that the SCSI buffer B contains data.

# Bit 0 - SCSI Buffer A

When this bit is asserted, it indicates that the SCSI buffer A contains data.

Notes

- The MPU's data bus is not double buffered because the MPU activities usually do not require high speed buffering.
- For error recovery the firmware engineer should also check the FIFO Counter and Transfer Counter's contents.

## REGISTER 8 (8h)

| REGISTER | OPERATION | REGISTER NAME NUMBER |
|----------|-----------|----------------------|
| 8        | Write     | SCSI Clock           |
|          | Read      | Input Port 1         |

# Register 8 (8h) - Write Operation (Lower 4 bits only)

This register sets the SCSI clock. SCSI bus arbitration times are relatively long in comparison to the width of the system clock input to the 82C5086. Consequently, this register sets a divide-by-factor to create an approximately 400 ns square wave. For example, a 406 ns square wave would be produced if the decimal value 12 (the number of clock periods minus one) is placed in this register and the clock input is 32 MHz. To produce a symmetrical square wave, the firmware engineer must load an even count into this register.

| OP | 7        | 6 | 5 | 4 | 3 | 2    | 1     | 0 |
|----|----------|---|---|---|---|------|-------|---|
| W  | Not Used |   |   |   |   | SCSI | Clock |   |

# **Register 8 (8h) - Read Operation**

The contents of this register provide the firmware engineer with status information concerning the SCSI bus RST, the BUF\_IN, and Input Port 1 signals.

| OP | 7          | 6                  | 5                | 4 | 3 | 2                | 1 | 0 |
|----|------------|--------------------|------------------|---|---|------------------|---|---|
| R  | RST<br>PIN | DIF<br>SCSI<br>PIN | BUF<br>IN<br>PIN |   | I | NPUT PIN<br>#4-0 | S |   |

Bit 7 - Reset Pin

This bit provides the firmware engineer with the unlatched status of the SCSI bus reset signal. Bit 6 (SCSI RST) of the Interrupt Status Register 5 latches the SCSI bus reset signal. When the firmware engineer receives an interrupt from the reset pin, this pin can be read to determine if the RST signal is still asserted.

Bit 6 - Differential SCSI Interface Pin

When this bit is asserted, the 82C5086 is connected to a differential SCSI interface on the SCSI bus.

## Bit 5 - Buffer In Pin

This bit provides the firmware engineer with the status of the BUF\_IN pin. In non-differential SCSI mode, the BUF\_IN pin is internally connected to the 48 mA BUF\_OUT pin.

Bit 4-0 - Input Pins # 4-0

These bits provide the firmware engineer with the status of Input Port 1 pins 4-0. The input port is normally used to provide the firmware engineer with the SCSI bus ID.

When the memory data bus parity is enabled, Input Port 1's pin 4 must be used for this parity bit.

## REGISTER 9 (9h)

| REGISTER<br>NUMBER | OPERATION  | REGISTER NAME          |
|--------------------|------------|------------------------|
| 9                  | Write/Read | SM MCS Address Pointer |

# Register 9 (9h) - Write Operation

Register 9 specifies an address pointer in the MCS for the state machine's use. The 82C5086's state machine (SM) uses this address pointer to the MCS to send SCSI commands, status and/or messages.

The 82C5086 contains 192 bytes of MCS space. Therefore, the address placed in this register should be between decimal 0 and decimal 191. Decimal values 192 through 255 access the 82C5086's other section of memory, the FIFO address space.

If a new pipeline command that requires MCS access begins execution and this register is not pointing to location zero of an MCS script, this register is incremented. It is incremented to point to location zero of the next MCS. For example, if this register contains an MCS address pointer of 5 and the new pipeline command requires MCS access, then this register advances to location 32. Location 32 is the starting address of MCS1. Note in this example, that MCS auto advance is not disabled.

| OP | 7                                         | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |
|----|-------------------------------------------|---|---|---|---|---|---|---|--|
| W  | State Machine (SM) Message/Command Script |   |   |   |   |   |   |   |  |
| R  | (MCS) Address Pointer                     |   |   |   |   |   |   |   |  |

Notes

- This register is set up initially by the firmware.
- This register should not be loaded with a value greater than 191.
- The MCS space is considered circular in nature. Consequently, MCS5 follows MCS4 and MCS0 follows MCS5.

## **Register 9 (9h) - Read Operation**

The firmware engineer can read this register to verify execution of a pipeline command, and to aid in error recovery.

If the SM is sending data to the MCS, this register points to the location where the next byte is placed. If the SM is reading data from the MCS, this register points to the location where the next data byte is read.

Note

The SM has third priority in accessing 82C5086 memory. FIFO IN requests have first priority; FIFO OUT requests have second.

| R | E | GI | ST | ER | 10 | (0Ah) |
|---|---|----|----|----|----|-------|
|---|---|----|----|----|----|-------|

| REGISTER<br>NUMBER | OPERATION  | REGISTER NAME   |
|--------------------|------------|-----------------|
| 10                 | Write/Read | MPU MCS Address |

# Register 10 (0Ah) - Write/Read Operation

This register specifies an address in the MCS for the MPU's use. The MPU uses this address pointer to the MCS to send SCSI commands, status and/or messages.

Because there are 192 bytes of 82C5086 Command/Message space the address placed in this register should be between decimal 0 and decimal 191. Decimal values 192 through 255 access the 82C5086's other section of memory, the FIFO address space.

| OP | 7                     | 6                                     | 5 | 4 | 3 | 2 |  | 1 | 0 |
|----|-----------------------|---------------------------------------|---|---|---|---|--|---|---|
| W  |                       | Microprocessor Message/Command Script |   |   |   |   |  |   |   |
| R  | (MCS) Address Pointer |                                       |   |   |   |   |  |   |   |

Notes

- This register is incremented every time the MPU processes a byte from the MCS space.
- The firmware engineer should be careful when writing data in the FIFO address space (addresses 192-255) because erroneous data results if the 82C5086 is concurrently using the FIFO for data transfers.

The firmware engineer can access the MCS at any time. Thus, the firmware engineer could be accessing an MCS script while the 82C5086 is sending SCSI commands, and/or messages to the SCSI bus, or transferring data through the FIFO. For example, the 82C5086 could be executing an INIT DATA STM pipeline command.

- The MPU has the lowest priority in accessing 82C5086 memory. FIFO IN, FIFO OUT, and SM requests have a higher priority.
- Refer to bit 7 of Auxiliary Status Register 19 for a discussion of the MCS Ready Bit.

## **REGISTER 11 (0Bh)**

| REGISTER<br>NUMBER | OPERATION  | REGISTER NAME  |
|--------------------|------------|----------------|
| 11                 | Write/Read | MPU MCS Buffer |

If the MPU's Wait State Generator is not connected to the 82C5086's IORDY pin, the MPU must poll Register 19's MCS Data Ready Bit (bit 7) before transferring data to/from this register. This 82C5086 internal register provides a buffer between the MPU and the MCS.

## Register 11 (0Bh) - Write Operation

Information (e.g., commands, status, messages) written to this register is stored in the MCS at the address specified in the MPU MCS Address Register. Every time information is written to Register 11, the MPU MCS Address Register is incremented by one.

## **Register 11 (0Bh) - Read Operation**

When a MPU read access occurs, the information (e.g., commands, status, messages) at the MCS address specified in the MPU MCS Address Register is latched into Register 11. Every time information is read from Register 11, the MPU MCS Address Register is incremented by one.

Because the 82C5086 must support MPUs that do not have the capability to generate wait states on MPU access, the firmware engineer must perform a dummy read of this register any time the MPU MCS address pointer is changed. This transfers the first byte from the MCS to this register. For write operations, there are no special considerations.

| OP                            | 7                | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |  |  |  |
|-------------------------------|------------------|---|---|---|---|---|---|---|--|--|--|--|
| W                             | W Microprocessor |   |   |   |   |   |   |   |  |  |  |  |
| R Message/Command Script Data |                  |   |   |   |   |   |   |   |  |  |  |  |

# REGISTER 12 (0Ch)

| REGISTER<br>NUMBER | OPERATION  | REGISTER NAME |
|--------------------|------------|---------------|
| 12                 | Write/Read | MPU FIFO Data |

# Write/Read Operation

This register is used when the MPU is transferring data to/from the SCSI bus or the memory data bus. It is used to pass the transferred data to/from the MPU and the 82C5086's FIFO.

There are several ways the MPU can check if data is available or if the FIFO is ready for another byte:

- Connect the FIFO Request (FIFO\_REQ) pin to a DMA controller on the MPU bus. The DMA controller should be programmed to send/receive data from this register. If -MPU\_ACK and MPU\_AEN are asserted, MPU access is forced to Register 12 and an address is not required.
- Poll Auxiliary Status Register's bit 6 before reading or writing Register 12. An asserted bit indicates there is data ready for transfer.
- Connect the 82C5086's Input/Output Ready (IORDY) pin to the MPU Wait State Generator. Then open loop burst data to this register. If the MPU gets ahead of the 82C5086, the IORDY pin is deasserted. This forces the MPU to lengthen its read or write strobe. When the IORDY pin is reasserted, the access is completed.
- Because the MPU bus does not contain a parity bit, parity is generated on MPU writes to this register. On MPU reads, parity is checked as the byte is read from the FIFO; however, the bit is discarded when it is transferred to the MPU.

| OP | 7              | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |  |
|----|----------------|---|---|---|---|---|---|---|--|--|
| W  | Microprocessor |   |   |   |   |   |   |   |  |  |
| R  | FIFO Data      |   |   |   |   |   |   |   |  |  |

# REGISTER 13 (0Dh)

| REGISTER<br>NUMBER | OPERATION  | REGISTER NAME |
|--------------------|------------|---------------|
| 13                 | Write/Read | FIFO Count    |

# Register 13 (0Dh)- Write Operation

The 82C5086 has a 64-byte internal FIFO. For diagnostic purposes this register can be preset to any value (0-63). For example, writing a 10 to this register forces the 82C5086 to assume there are 10 remaining bytes in the FIFO.

| OP | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |  |  |
|----|---|---|---|---|---|---|---|---|--|--|--|
| W  |   |   |   |   |   |   |   |   |  |  |  |

# Register 13 (0Dh)- Read Operation

During normal operation, the firmware engineer can read this register to determine the number of bytes in the FIFO. However, if data transfers are in progress, the firmware engineer should use only bits 5, 6 and 7. Bits 0-4 should be disregarded. They are invalid because the count changes asynchronously with respect to the MPU processing activities.

| $\left[ 0\right]$ | P 7   | 6    | 5 | 4                                     | 3 | 2 | 1 | 0 |  |  |
|-------------------|-------|------|---|---------------------------------------|---|---|---|---|--|--|
| R                 | FIFO  | FIFO |   | Number of bytes in FIFO               |   |   |   |   |  |  |
|                   | Empty | Full |   | · · · · · · · · · · · · · · · · · · · |   |   |   |   |  |  |

Bit 7 - FIFO Empty

When this bit is asserted, the FIFO is empty; there is no data in the FIFO.

## Bit 6 - FIFO Full

When this bit is asserted, the FIFO is full and cannot accept any more data. When it is set, the FIFO contains 64 bytes of data.

# Bit 5-0 - Number of bytes in FIFO

These bits contain a count of the current number of bytes in the FIFO. These bits should be read only when the firmware engineer is certain data transfer has been terminated. Bit 5 can be polled asynchronously and tested for a FIFO half full/empty condition.

# REGISTER 14 (0Eh)

| REGISTER<br>NUMBER | OPERATION     | REGISTER NAME                              |
|--------------------|---------------|--------------------------------------------|
| 14                 | Write<br>Read | Maximum Sync Offset<br>Current Sync Offset |

# Register 14 (0Eh) - Write Operation

The firmware engineer can use this register to set the maximum synchronous offset, or to preset the current offset count.

|   | OP | 7         | 6    | 5                    | 4 | 3 | 2 | 1 | 0 |  |
|---|----|-----------|------|----------------------|---|---|---|---|---|--|
| Г | W  | Unlimited | Not  | Maximum Sync Offset/ |   |   |   |   |   |  |
|   |    | Offset    | Used | Current Sync Offset  |   |   |   |   |   |  |

# Bit 7 - Unlimited Offset

Asserting this bit forces the 82C5086 to an unlimited offset when performing synchronous data transfers.

If the 82C5086 is sending data, it continues to send data until the transfer count equals 0 and the FIFO is empty. In target mode, the initiator's -ACK pulses are disregarded. In initiator mode, -REQ pulses from the target are disregarded.

This bit is disregarded if the 82C5086 is receiving SCSI bus synchronous data.

# Bit 6 - Not Used

## Bits 5-0 - Maximum Synchronous Offset/Current Synchronous Offset

If bit 1 of Auxiliary Control Register 2 is deasserted, a write to this register sets the maximum synchronous offset. If bit 1 of Auxiliary Control Register 2 is asserted, a write to this register presets the current offset count. This is useful for diagnostics and error recovery.

# **Register 14 (0Eh) - Read Operation**

This registers specifies the current offset count. During normal operation, the firmware engineer can read this register to determine the current offset count. However, if data transfers are in progress, the firmware engineer should use only bits 6 and 7. Bits 0-5 should be disregarded because they are invalid; they are not valid because the count changes asynchronously with respect to the MPU processing activities.

| 01 | P 7    | 6      | 5 | 4                    | 3 | 2 | 1 | 0 |  |  |  |
|----|--------|--------|---|----------------------|---|---|---|---|--|--|--|
| R  | Zero   | Max    |   | Current Offset Count |   |   |   |   |  |  |  |
|    | Offset | Offset |   |                      |   |   |   |   |  |  |  |

# Bit 7 - Offset Equals Zero

This bit indicates that the current offset counter is zero.

# Bit 6 - Offset Equals Maximum

When this bit is asserted, the current offset count is equal to the miximum offset count.

# Bits 5-0 - Current Offset Count

Firmware engineers can obtain the current offset count by reading these bits.

| REGISTER<br>NUMBER | OPERATION     | REGISTER NAME                      |
|--------------------|---------------|------------------------------------|
| 15                 | Write<br>Read | Transfer Period<br>Revision Number |

# REGISTER 15 (0Fh)

# Register 15 (0Fh) - Write Operation

The 82C5086 can handle synchronous transfers at 5.3 megabytes/second, or 188 ns/transfer period. If the SCSI device connected to the 82C5086 cannot receive/send data at this rate, delay clocks must be added to decrease the transfer rate. This register specifies the minimum number of clock cycles (minus three) between -REQ and -ACK signals for targets and initiators.

For targets, it specifies the minimum number of clock cycles between the leading edges of the -REQ signal to the next -REQ pulse. For initiators, it specifies the minimum number of clock cycles between the leading edges of -ACK pulses.

For example, for synchronous transfers at 5.3 megabytes/second this register would contain a 3; [188ns / (1 / 32 MHz)] - 3 = 6 - 3 = 3.

| OP | 7 | 6        | 5 | 4 | 3  | 2            | 1  | 0 |
|----|---|----------|---|---|----|--------------|----|---|
| W  | 1 | Not Used |   |   | Tr | ansfer Perio | od |   |

Note

For a write operation, only the lower 5 bits are valid.

# Register 15 (0Fh) - Read Operation

This register specifies the 82C5086's current revision number and the status of the power-on flag. The power on flag is asserted at power up, and cleared by asserting bit 6 of Auxiliary Control Register 19.

| OP | 7       | 6        | 5 | 4 | 3               | 2     | 1          | 0 |  |  |
|----|---------|----------|---|---|-----------------|-------|------------|---|--|--|
| R  | Power   | Not Used |   |   | Current 82C5086 |       |            |   |  |  |
|    | On Flag |          |   |   |                 | Revis | sion Numbe | 7 |  |  |

Bit 7 - Power On Flag

This flag is set when power is first supplied to the 82C5086. It is used for such purposes as power up testing, and waiting for a disk drive to spin up. This flag is cleared by writing a one to Auxiliary Control 1's (Register 19) RST Power Flag Bit (bit 6).

Bits 6-4 - Not Used

Bits 3-0 Current 82C5086 Revision Number

These bits form the encoded 82C5086 revision number. The count began with the prototype part at number 0.

| REGISTER<br>NUMBER | OPERATION  | REGISTER NAME                |
|--------------------|------------|------------------------------|
| 16                 | Write/Read | Transfer Counter/Low Byte    |
| 17                 | Write/Read | Transfer Counter/Middle Byte |
| 18                 | Write/Read | Transfer Counter/High Byte   |

## **REGISTERS 16 - 18 (10 - 12h)**

# Register 16 - 18 (10 - 12h)- Write Operation

The 82C5086 contains two 24-bit transfer counters. These registers contain the 3-byte transfer counter. A write to these registers presets the Down Transfer Counter. Once the Down Transfer Counter is loaded, the SM controls it. The SM decrements it when making a request for more data INTO the FIFO. The Up Transfer Counter counts the number of bytes transferred OUT of the 82C5086 FIFO. It is reset when the 82C5086 resets the FIFO. This register is useful for error recovery.

## Notes

- All bytes processed by the 82C5086 are accounted for by the 24-bit Up Transfer Count, FIFO Count, and Buffer Status Registers.
- The 24-bit Down Counter is not cleared by a reset condition; the 24-bit Up Counter is cleared.

# Registers 16 - 18 (10 - 12h) - Read Operation

The contents of these registers specify the 3-byte transfer counter. When bit 4 of the Auxiliary Control Register 2 is deasserted, these registers contain the decrementing transfer count. When bit 4 is asserted, these registers contain the incrementing transfer count.

# REGISTER 19 (13h)

| REGISTER<br>NUMBER | OPERATION     | REGISTER NAME                             |
|--------------------|---------------|-------------------------------------------|
| 19                 | Write<br>Read | Auxiliary Control 1<br>Auxiliary Status 1 |

# Register 19 (13h) - Write Operation

This register specifies pin functions, and controls reset conditions in the 82C5086.

| OP | 7       | 6     | 5     | 4   | 3   | 2   | 1    | 0    |   |
|----|---------|-------|-------|-----|-----|-----|------|------|---|
|    | RST     | RST   | RST   | DIS | DIS | DIS | Poll | Not  | W |
|    | 82C5086 | Power | OF    | SRI | RO  | ATN | INT  | Used |   |
|    |         | Flag  | Flags | Pin | Pin | Pin | Pin  |      |   |

# Bit 7 - Reset 82C5086

Asserting this unlatched bit resets all internal 82C5086 registers except this one. An external reset via the -RESET\_CAP or the -RESET\_IN pin provides the same function, except this register is also reset.

## Bit 6 - Reset Power-on Flag

At power up, the 82C5086 is reset by approximately a 5 microseconds pulse. This reset signal asserts the power-on flag (bit 7 of Register 15). The firmware engineer can check this flag to determine the type of reset that occurred. The power-on flag is cleared when this unlatched bit is asserted.

#### Bit 5 - Reset Overflow Flags

Asserting this unlatched bit resets the parity and over/underrun flags in Auxiliary Status Register 20.

# Bit 4 - Disable SCSI RESET\_IN Pin

When the firmware engineer asserts this bit, it prevents the SCSI bus -RESET\_IN signal from hard resetting the 82C5086. The 82C5086 still disconnects from the SCSI bus and interrupts the MPU via bit 6 of the Interrupt Status Register. When this bit is asserted and a SCSI reset occurs, the occurrence is referred to as a soft reset.

## Bit 3 - Disable RESET\_OUT Pin

The -RESET\_OUT pin is asserted when the 82C5086 is reset via an internal power on, -RESET\_IN pin, program reset (Register 19's bit 7), or -RESET\_CAP pin.

If the firmware engineer asserts this bit, the -RESET\_OUT pin is disabled.

Bit 2 - Disable ATTENTION Pin

In initiator mode the 82C5086 does not drive the -ATN pin when this bit is asserted. Asserting this bit when the 82C5086 is in target mode, causes the 82C5086 to receive the -ATN signal (bit 7 of Register 5). However, the signal does not cause the 82C5086 to stop execution of the pipeline command.

Bit 1 - Polarity of Interrupt Pin

When this bit is asserted, the polarity of the interrupt pin is high true.

Bit 0 - Not Used

# Register 19 (13h) - Read Operation

This register provides information on the status of 82C5086 operation.

| OP | 7                  | 6                   | 5           | 4              | 3            | 2                 | 1          | 0          |
|----|--------------------|---------------------|-------------|----------------|--------------|-------------------|------------|------------|
| R  | MCS<br>Data<br>Rdy | FIFO<br>Data<br>Rdy | MSG<br>Byte | Target<br>Mode | Init<br>Mode | Pipeline<br>Empty | CMD<br>MSB | CMD<br>LSB |

Bit 7 - Message/Command Script (MCS) Data Ready

When this bit is asserted, the MCS Data Register is ready for more data. During normal operation, the firmware engineer sets the MPU MCS Address Register to point to the starting location of an MCS script. Then the firmware engineer makes consecutive reads or writes to the MPU MCS Buffer Register. The 82C5086 transfers data from the MPU MCS Register to the MCS script, then increments the MCS address pointer.

When this bit is asserted, it indicates data has been sent/received to/from the MCS. If the 82C5086 is not transferring data concurrently through the FIFO, the MPU MCS Buffer Register can be processed in approximately .3 microseconds. In this case, the firmware engineer does not have to poll this bit before sending/receiving the next byte to/from the MPU MCS Buffer Register. When data transfers are occurring through the FIFO in parallel with the MPU accessing the MPU MCS Buffer Register, this bit must be polled before a new byte is transferred to/from the 82C5086.

#### Bit 6 - FIFO Data Ready

This bit is asserted when the MPU is involved in data transfers (e.g., sending MPU data to the SCSI bus) and the FIFO is ready for more MPU data. Data transfers between the MPU and 82C5086 FIFO can be performed in any of the following three ways:

• The MPU polls this bit and transfers data to the MPU FIFO Data Register only when this bit is asserted.

- Enable the FIFO\_RDY pin, then connect it to a DMA controller on the MPU bus. The DMA controller must send/receive data to/from the MPU FIFO Data Register.
- Enable IORDY pin (Mode Control Register 7's bit 0) and connect this pin to the MPU Wait State Generator. The MPU can open loop transfer the data to the MPU FIFO Data Register. If the register is not ready to transfer data, the 82C5086 deasserts the IORDY pin. This causes the MPU to generate wait states until the IORDY pin is asserted.

## Bit 5 - Message Byte

The 82C5086 tags all message bytes received from the SCSI bus. Before the firmware engineer reads the MCS Data Register, this bit can be checked to determine if the next byte is a message. Bit 7 must be asserted for this bit to be valid. During SELECTION/RESELECTION, the 82C5086 also tags the Target ID. If the 82C5086 is reselected (-I\_O signal is asserted), this bit is asserted. As mentioned previously, the firmware engineer must read this bit before reading the MPU FIFO Data Register.

# NOTE

When reading data from the MCS to the MPU MCS Buffer Register, the firmware engineer must perform a dummy read of the MPU MCS Buffer Register. This transfers the first byte from the MCS to the MPU MCS Buffer Register, and also validates this bit. A dummy read is required because the 82C5086 must work with MPUs that do not contain a wait state generator.

## Bit 4 - Target Mode

When this bit is asserted, the 82C5086 is operating as a target. The target or initiator mode is normally set when a target or initiator command is issued to the 82C5086. For most commands the target or initiator role is maintained throughout the command. However, several pipeline commands can change the mode, depending on whether the 82C5086 is selected or reselected. For example, the following four commands change mode within the command itself because they are all dependent upon the selection/reselection process: (1) TGT WFS SEQ, (2) INIT WFR SEQ, (3) INIT WFR CMD, and (4) TGT WFS CMD.

#### Bit 3 - Initiator Mode

When this bit is asserted, the 82C5086 is operating as an initiator.

#### Bit 2 - Pipeline Register Empty

When this bit is asserted, the four pipeline command registers are empty.



## **REGISTER 20 (14h)**

| REGISTER<br>NUMBER | OPERATION     | REGISTER NAME                             |  |  |  |  |  |
|--------------------|---------------|-------------------------------------------|--|--|--|--|--|
| 20                 | Write<br>Read | Auxiliary Control 2<br>Auxiliary Status 2 |  |  |  |  |  |

# Register 20 (14h) - Write Operation

This register provides the firmware engineer with additional control of 82C5086 operation.

| OP | 7             | 6           | 5                   | 4                | 3         | 2                  | 1                      | 0               |
|----|---------------|-------------|---------------------|------------------|-----------|--------------------|------------------------|-----------------|
| w  | Toggle<br>DMA | Not<br>Used | Preset<br>UP<br>CNT | ENB<br>UP<br>CNT | INF<br>TC | OVR<br>DISC<br>ENB | Mode<br>Offset<br>Load | HLT<br>ON<br>PE |

Bit 7 - Toggle DMA Controller

When the 82C5086 is interfaced to a DMA controller that is edge sensitive on the -REQ pulse (not level sensitive), a "hung" condition can develop. The DMA controller's transfer count can expire, yet the 82C5086 can still require more bytes to complete the transfer. The 82C5086 asserts the -DMA\_REQ signal and the DMA controller does not respond with the -DMA\_ACK signal. The firmware engineer should load a transfer count into the DMA controller and reenable it. Then a write to this unlatched bit forces the -DMA\_REQ signal to toggle. This produces an edge and restarts the DMA transfers.

## Bit 6 - Not Used

Bit 5 - Preset Up Counter

For test purposes, the Up Counter can be preset to 7FFFFEH by asserting this unlatched bit. Asserting this bit also presets the Select Timeout Register to 7FFFEH.

## Bit 4 - Enable Up Counter

The 82C5086 contains two 24-bit transfer counters, an Up Counter and a Down Counter. The firmware engineer loads the Down Counter by writing to Registers 16-18. Once a data transfer command is executing, the Down Counter is decremented as each data request is made. The Down Counter is under SM control.

The Up Counter counts bytes that have left the 82C5086 chip. The value of the Up Counter, FIFO Count, and Buffer Status should account for all transferred bytes. By asserting this bit, the firmware engineer can read the Up Count. By deasserting this bit the firmware engineer can read Registers 16-18 for the value of the Down Counter.
#### Bit 6 - FIFO Parity Error

When data is being read from the 82C5086 FIFO and a parity error occurs, this bit is asserted. Either the 82C5086 FIFO is defective, or a byte with bad parity was transferred into the FIFO.

#### Bit 5 - SCSI Parity Error

When a parity error is detected on data received from the SCSI interface, this bit is asserted. For more information on a halt on a parity error, refer to this chapter's explanation of bit 5 of the Mode Control Register (Register 7).

### Bit 4 - Parity Error on Slave 82C5086

When a parity error or overrun condition is detected on a slave 82C5086 chip, the -WPAR pin is asserted which causes this bit to be asserted. The firmware engineer should clear this condition before a new pipeline command is issued to the 82C5086.

#### Bit 3 - Overrun During Synchronous Data Transfer

If synchronous SCSI bus data is being sent to the 82C5086 faster than 5.3 megabytes per second (32 MHz clock), an overrun occurs and this bit is asserted.

### Bit 2 - Offset Counter Overrun

This bit is asserted when the Offset Counter is requested to decrement past zero or to increment greater than the maximum count specified in Register 14. The counter does not perform the illegal request. The 82C5086 latches the up/down count requests to the Offset Counter. For example, if the Offset Counter is requested to increment past the maximum offset, the up request is saved and processed after a down request has decremented the count. This provides for one level of automatic error recovery.

#### Bit 1 - Message/Command Script Overrun

If the IORDY pin is not enabled (Register 7's bit 0) and the MPU writes or reads to the MCS Data Buffer Register faster than the 82C5086 can transfer data to the MCS, this bit is asserted.

When the IORDY pin is enabled, an overrun/underrun cannot occur because the MPU is held off until the 82C5086 is ready to process the transfer.

#### Bit 0 - Microprocessor Overrun

If the IORDY pin is not enabled and the MPU writes or reads to the MPU FIFO Data Register faster than the 82C5086 can transfer data to the FIFO, this bit is asserted.

| REGISTER<br>NUMBER | OPERATION     | REGISTER NAME                                         |
|--------------------|---------------|-------------------------------------------------------|
| 21                 | WRITE<br>READ | Synchronous/Asynchronous ID<br>Current SCSI Device ID |

## REGISTER 21 (15h)

### Register 21 (15h)- Write Operation

This register informs the 82C5086 whether or not a SCSI device is set up for synchronous data transfers. If the bit is deasserted, asynchronous transfer is assumed.

When the 82C5086 selects/reselects a device or is selected/reselected itself, the ID of the SCSI device is saved and compared against this register's contents. If the firmware engineer has enabled synchronous transfers for that device, the 82C5086 is placed in synchronous data transfer mode.

Because a 82C5086 operating in Slave Mode is unaware of bus phases or bus ID's, SID0 is the default ID for placing slave 82C5086 chips into synchronous data transfer mode.

| OP | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|----|-----|-----|-----|-----|-----|-----|-----|-----|
| W  | SID |
|    | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |

- If the firmware engineer asserts the SID bit for its own SCSI bus ID, then all SCSI devices are assumed to be in synchronous data transfer mode.
- If the SID bit for a SCSI device is asserted, the 82C5086 assumes all logical units associated with that SID bit are in synchronous mode.

## Register 21 (15h) - Read Operation

This register contains the last SCSI bus device ID processed by the 82C5086. If the 82C5086 is connected to the SCSI bus as an initiator, then this register contains the ID of the target. If the 82C5086 is connected as a target, then this register contains the ID of the initiator.

| OP | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|----|-----|-----|-----|-----|-----|-----|-----|-----|
| R  | CID |
|    | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |

- When the 82C5086 is executing a select target or reselect initiator sequence, the information in this register must have been previously placed as the first byte in the MCS.
- When the 82C5086 is selected/reselected and a wait for select/reselect sequences is executed, this information is also available as the first byte in the MCS.



Note

The 82C5086 determines the command length from the 4-bit value loaded into this register as follows:

| Value | SCSI Command    |  |
|-------|-----------------|--|
| 0000  | Length in Bytes |  |
| 0000  | Not defined     |  |
| 0001  | 2               |  |
| 0010  | 3               |  |
| 0011  | 4               |  |
| 0100  | 5               |  |
| 0101  | 6               |  |
| 0110  | 7               |  |
| 0111  | 8               |  |
| 1000  | 9               |  |
| 1001  | 10              |  |
| 1010  | 11              |  |
| 1011  | 12              |  |
| 1100  | 13              |  |
| 1101  | 14              |  |
| 1110  | 15              |  |
| 1111  | 16              |  |

## Register 22 (16h) - Read Operation

A read of this register provides the firmware engineer with the unlatched contents of the SCSI data bus. These contents are useful to the firmware engineer for the following reasons:

- If the firmware engineer wants to screen SCSI devices that select/reselect the 82C5086, the firmware engineer can wait until a select/reselect interrupt occurs, then check the device ID by reading this register. If communications with the device is desired, the firmware engineer can issue a pipeline command to process the select/reselect.
- When the 82C5086 is executing an initiator pipeline command that aborted due to an illegal message on the SCSI bus, the firmware engineer can read this register to determine which message is on the SCSI bus. Refer to Chapter 5's discussion of the control commands for further information on messages the 82C5086 chip considers illegal.

| OP | 7                       | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|-------------------------|---|---|---|---|---|---|---|
| R  | R Unlatch SCSI Data Bus |   |   |   |   |   |   |   |



This chapter is directed at firmware engineers intending to use the 82C5086's command functions to implement the SCSI interface on a host computer and/or a device controller. An operational description of each 82C5086 command is provided.

### COMMAND FUNCTIONS

Functions that firmware engineers need in order to implement the SCSI interface are provided by the 82C5086 pipeline commands. Firmware engineers can use the 46 pipeline commands of the 82C5086 to manage SCSI data, command, message, and status flow.

These pipeline commands can be classified into three categories:

- Control commands
- Initiator commands
- Target commands.

Table 1-1 provides a complete list of the 46 commands and a brief description of their function. Through 82C5086 control commands, firmware engineers can set up SCSI bus conditions (e.g., enable a 82C5086 target device to respond to a SCSI bus -SEL signal) required before specific initiator and/or target commands (e.g., wait for select) can be issued.

Firmware engineers can also use 82C5086 control commands to establish a data path between the memory data bus and the MPU's data bus. For instance, the CNTL DATA MTP command (Control Data from Memory Data Bus to MPU) enables data to be transferred from the memory data bus to the MPU data bus.

Certain initiator and target commands perform single tasks (e.g., send a message to the SCSI bus), while others execute a series of tasks. For example, the INIT SWA SEQ (Initiator Select with Attention Sequence) performs eight tasks. Refer to this command sequence's description later in this chapter for a description of the eight tasks performed. Thus, sequences of tasks can be performed simply by issuing a single 82C5086 pipeline command sequence.

In this chapter's command descriptions, directional references (e.g., DATA OUT phase) are in reference to the initiator. For instance, when a target goes to the DATA OUT phase it indicates it is ready to receive data from the initiator.

## COMMAND DESCRIPTION NOTATIONS AND CONVENTIONS

The commands are arranged into the control, initiator, and target groups. Within each of these groupings, commands are ordered sequentially according to command code. For each command the following information is provided: command code, bus condition, memory accessed, execution time, and operational description. Following is a description of the notations and conventions used within the chapter's command descriptions.

### Command Code

As mentioned previously, firmware engineers can queue up to four pipeline commands or command sequences into the 82C5086's pipeline registers (Registers 0-3). When performing a write operation to issue a command to a pipeline register, the following conventions must be used:

| ОР | 7   | 6                     | 5 | 4 | 3 | 2              | 1          | 0   |
|----|-----|-----------------------|---|---|---|----------------|------------|-----|
| w  | Pip | Pipeline Command Code |   |   |   | TARGET<br>Mode | MOD<br>Bit | INT |

### Bits 7-4 - Pipeline Command Code

These bits specify the command code for the particular pipeline command the firmware engineer wants to queue into the pipeline register. For instance, the control NOP command has a command code of 0000. For the command code of any pipeline command refer to the command's description.

### Bits 3 and 2 - Initiator and Target Mode

These bits specify whether the 82C5086 is operating in initiator or target mode, respectively. When bit 3 is asserted, the 82C5086 assumes the initiator role on the SCSI bus. Control commands do not have bit 3 or bit 2 asserted.

### Bit 1 - Modifier Bit

This bit is a command modifier bit. For example, commands that transfer data between the MPU and the 82C5086 use this bit to enable 16-bit transfers over the MPU bus. Bits 0-7 are transferred via the MPU's data bus. Simultaneously, bits 8-15 are transferred via the memory data bus.

#### Bit 0 - Interrupt When COMMAND COMPLETE Bit

When this bit is asserted, and the firmware engineer has enabled the interrupting condition (by enabling its bit in Interrupt Mask Register 5), the 82C5086 interrupts the MPU upon command completion. Refer to the NOP command description for an example of this bit's use.

#### NOTE

When a bit is specified as "X" in a command code, it indicates that the bit can be functional in both asserted and deasserted forms.

#### Bus Condition

The 82C5086 can be disconnected or connected from the SCSI bus. For each of the commands the required SCSI bus condition prior to command execution is noted. "D" denotes a disconnected bus; "C" denotes a connected bus; and "C/D" indicates the command can be issued under either bus condition. Note that the control commands can be issued under either condition.

### **Execution Time**

Stated execution time for the specific command represents a typical execution time (32 MHz operation is assumed). The symbol " $\mu$ s" is used as an abbreviation for microseconds.

#### **Operational Description**

A description of how the particular command operates is provided. On several of the initiator and target commands, there are notes concerning the set up of the MCS script. Before firmware engineers issue the 82C5086 a command, they must have initialized the MCS. For example, if the firmware engineer wants the 82C5086 to send a message to a SCSI device that message must have been built in one of the six MCS scripts before the Send Message Command can be executed. After the firmware performs consecutive write operations to the MPU MCS Buffer Register (Register 11) to build the message in the MCS, it must load the SM MCS Address Register (Register 9) to point to the first byte of that message. After the MPU has completed this MCS set up, the Send Message Command could be issued to one of the four pipeline command registers. Note that if the auto MCS advance feature is enabled, the SM MCS address pointer is checked before command execution begins. If it points to any location within an MCS other than zero, it is advanced automatically to location zero of the next MCS. Therefore, in the previous example the firmware engineer would not have to load the SM MCS Address Register if it were pointing to a location within the previous MCS.

### Possible Errors

When the execution of a command can cause any error conditions, it is noted. The execution of the control commands cannot cause any error conditions. Error conditions noted (e.g., parity error) can be grouped into one of the following categories:

- 1. Error conditions indicated by Extended Status Register 6.
- 2. Error conditions indicated by Auxiliary Status Register 20.

When an unexpected condition is detected, the Extended Status Mask Bit (bit 1) of Interrupt Mask Register 5 is asserted. When this bit is asserted, it indicates Extended Status Register 6 contains information on why the command was terminated prematurely (e.g., SM error, timeout error).

When a parity error or overflow condition is detected, the Parity Error/Overrun Mask Bit (Bit 1) of Interrupt Mask Register 5 is asserted. When this bit is asserted, it indicates Auxiliary Status Register 20 contains additional information (e.g., identifies error as a FIFO parity error or a SCSI parity error) concerning the detected error condition.

## CONTROL COMMAND DESCRIPTIONS

Table 5-1 lists the 82C5086 control commands. Following this table each control command is described in detail.

| Table 5-1. 82C5086 Control Commar | ۱ds |
|-----------------------------------|-----|
|-----------------------------------|-----|

| Command Code      | Command        | Function                                              |
|-------------------|----------------|-------------------------------------------------------|
| 0000 000X         | CNTL NOP       | No operation.                                         |
| 0001 00 <b>0X</b> | CNTL RST FIFO  | Reset 82C5086 data FIFO.                              |
| 0010 000X         | CNTL RST ON    | Assert reset signal to SCSI bus.                      |
| 0011 000X         | CNTL RST OFF   | Deassert reset signal to SCSI bus.                    |
| 0100 000X         | CNTL ATN ON    | Assert -ATN signal to SCSI bus.                       |
| 0101 00 <b>0X</b> | CNTL ATN OFF   | Deassert -ATN signal to SCSI bus.                     |
| 0110 000X         | CNTL ENB SEL   | Enable selection.                                     |
| 0111 00 <b>0X</b> | CNTL DIS SEL   | Disable selection.                                    |
| 1000 000X         | CNTL ENB RESEL | Enable reselection.                                   |
| 1001 000X         | CNTL DIS RESEL | Disable reselection.                                  |
| 1010 <b>000X</b>  | CNTL ENB ADV   | Enable MCS auto advance.                              |
| 1011 000X         | CNTL DIS ADV   | Disable MCS auto advance.                             |
| 1110 000X         | CNTL DATA PTM  | Receive MPU data and send it to the memory data bus.  |
| 1111 000X         | CNTL DATA MTP  | Receive data from memory data bus and send it to MPU. |

## CNTL NOP - No Operation

| Command<br>Code | Bus | Memory<br>Access | Execution<br>Time | Function      |
|-----------------|-----|------------------|-------------------|---------------|
| 0000 000X       | C/D | No               | .5 μs             | No operation. |

### **Operational Description**

3

The firmware engineer can use this command to check that the 82C5086 pipeline/status registers 0-3 are operating correctly. For example, the firmware engineer can send the following four NOP commands to pipeline registers 0-3.

| Command<br>Register | Pipeline | Contents of Command Pipeline<br>Register |  |
|---------------------|----------|------------------------------------------|--|
| 0                   |          | 0000 0000                                |  |
| 1                   |          | 0000 0000                                |  |
| 2                   |          | 0000 0000                                |  |

0000 0001

The first three NOP commands have bit 0 (Interrupt when Command Complete bit) deasserted; however, this bit is set in the fourth NOP command. Consequently, this sequence of pipeline commands should terminate with an interrupt to the MPU under the following conditions:

- The Command Complete Interrupt Bit (bit 0) of Interrupt Mask Register 5 is asserted, and
- All four pipeline commands have executed.

### Notes

•

Once this command has started executing, it cannot be soft aborted.

The execution of this command cannot cause any error conditions.

| ſ | Command   | Bus | Memory | Execution | Function                   |
|---|-----------|-----|--------|-----------|----------------------------|
|   | Code      |     | Access | Time      |                            |
| Ī | 0001 000X | C/D | No     | .5 μs     | Reset 82C5086's data FIFO. |

## **CNTL RST FIFO - Control Reset Data FIFO**

### **Operational Description**

Before executing any data transfer commands, the 82C5086 normally resets the 82C5086 data FIFO. For error handling and diagnostic purposes, firmware engineers may decide to disable the automatic resetting of the FIFO. If it has been disabled by asserting the FIFO Reset Bit (bit 1) of Mode Control Register 7, firmware engineers must issue this command to reset the 82C5086's internal FIFO.

- Once this command has started executing, it cannot be soft aborted.
- The execution of this command cannot cause any error conditions.

## CNTL RST ON - Control RESET On

| Command<br>Code | Bus | Memory<br>Access | Execution<br>Time | Function                             |
|-----------------|-----|------------------|-------------------|--------------------------------------|
| 0010 000X       | C/D | No               | .5 µs             | Assert the reset signal to SCSI bus. |

## **Operational Description**

Firmware engineers can use this command to assert the reset signal on the SCSI control bus. The 82C5086 pin asserted to indicate this reset is dependent on the 82C5086's mode of operation. In non-differential (single-ended drivers/receivers) mode, the -RESET\_IN pin is asserted. The BUF\_OUT pin is asserted in differential mode (multiple-ended drivers/receivers).

The reset signal remains asserted until the firmware engineer issues the CNTL RST OFF command.

## Notes

- SCSI specification requires the reset signal be asserted for a minimum of 25 microseconds.
- Once this command has started executing, it cannot be soft aborted.
- The execution of this command cannot cause any error conditions.

## **CNTL RST OFF - Control RESET Off**

| Command<br>Code | Bus | Memory<br>Access | Execution<br>Time | Function                               |
|-----------------|-----|------------------|-------------------|----------------------------------------|
| 0011 000X       | C/D | No               | .5 μs             | Deassert the reset signal to SCSI bus. |

## **Operational Description**

Reset on the SCSI bus is asserted by executing the CNTL RST ON command. To remove this condition, firmware engineers can issue this command to the pipeline registers.

| CNTL ATN ON - Contr | ol Attention On |
|---------------------|-----------------|
|---------------------|-----------------|

| Command<br>Code | Bus | Memory<br>Access | Execution<br>Time | Function                             |  |  |
|-----------------|-----|------------------|-------------------|--------------------------------------|--|--|
| 0100 000X       | Ċ/D | No               | .5 µs             | Asserts -ATN signal to the SCSI bus. |  |  |

## **Operational Description**

This command asserts the -ATN signal on the SCSI bus. It remains asserted until the firmware engineer issues a CNTL ATN OFF pipeline command, or until the last byte of a MESSAGE OUT phase is transferred.

When the following two initiator pipeline commands select a SCSI device, the -ATN signal is automatically asserted: (1) INIT SWA SEQ (Initiator Select with ATN Sequence) and (2) INIT SWA CMD (Initiator Select with ATN Command).

### Notes

- Automatic deassertion of -ATN is disabled during the transfer of the MESSAGE OUT phase's last byte if the the INIT SEND MSG command's modifier bit is asserted.
- Once this command has started executing, it cannot be soft aborted.
- The execution of this command cannot cause any error conditions.

## CNTL ATN OFF - Control Attention Off

| Comma<br>Code | and Bus | Memory<br>Access | Execution<br>Time | Function                          |
|---------------|---------|------------------|-------------------|-----------------------------------|
| 0101 0        | 00X C/D | No               | .5 μs             | Deassert -ATN signal to SCSI bus. |

### **Operational Description**

Firmware engineers can use this pipeline command to deassert the SCSI bus -ATN signal. It remains deasserted until the CNTL ATN ON pipeline command is issued, or an INIT SWA SEQ (Initiator Select with ATN Sequence) or INIT SWA CMD (Initiator Select with ATN Command) is executed.

- Once this command has started executing, it cannot be soft aborted.
- The execution of this command cannot cause any error conditions.

| Command<br>Code | Bus | Memory<br>Access | Execution<br>Time | Function          |
|-----------------|-----|------------------|-------------------|-------------------|
| 0110 000X       | C/D | No               | .5 µs             | Enable selection. |

# CNTL ENB SEL - Control Enable Select

## **Operational Description**

This command enables the 82C5086 controller to respond to a SCSI bus SELECT phase. When the 82C5086 device is selected, Select Bit (bit 5) of Interrupt Status Register 5 is asserted.

Firmware engineers need to execute this command in order for the TGT WFS CMD (Target Wait for Select Command) and the TGT WFS SEQ (Target Wait for Select then Receive Sequence) to detect a select.

- By executing the CNTL DIS SEL (Control Disable Select) pipeline command, the 82C5086 is disabled from responding to selects.
- After a reset, the 82C5086 does not respond to selects until this command is executed.
- Once this command has started executing, it cannot be soft aborted.
- The execution of this command cannot cause any error conditions.

| Command<br>Code | Bus | Memory<br>Access | Execution<br>Time | Function           |
|-----------------|-----|------------------|-------------------|--------------------|
|                 |     |                  | 1 mile            |                    |
| 0111 000X       | C/D | No               | .5 μs             | Disable selection. |

## **CNTL DIS SEL - Control Disable Select**

### **Operational Description**

Firmware engineers can use this pipeline command to prevent the 82C5086 from responding to a SCSI bus SELECT phase. After this command is executed, a TGT WFS CMD (Target Wait for Select Command ) and a TGT WFS SEQ (Target Wait for Select and Receive Sequence) will not respond to a -SEL signal. Also Interrupt Status Register 5's Select Bit (bit 5) will no longer be asserted when a select occurs.

- By executing the CNTL ENB SEL command, the firmware engineer can • enable the 82C5086 to respond to selects.
- After a reset, the 82C5086 does not respond to selects until the CNTL ENB SEL command is executed.
- Once execution has started, this command cannot be aborted.
- The execution of this command cannot cause any error conditions.

| Command<br>Code | Bus | Memory<br>Access | Execution<br>Time | Function            |
|-----------------|-----|------------------|-------------------|---------------------|
| 1000 000X       | C/D | No               | .5 μs             | Enable reselection. |

## **CNTL ENB RESEL - Control Enable Reselect**

## **Operational Description**

This command enables the 82C5086 to respond to a SCSI bus RESELECT phase. When the 82C5086 initiator device is reselected, the Select Bit (bit 5) of Interrupt Status Register 5 is asserted.

Firmware engineers need to execute this command in order for INIT WFR CMD (Initiator Wait for Reselect Command) and INIT WFR SEQ (Initiator Wait for Reselect then Receive Sequence) to be able to detect a reselect.

- By executing the CNTL DIS RESEL (Control Disable Reselect) pipeline command, the 82C5086 is disabled from responding to the RESELECT phase.
- After a reset, the 82C5086 does not respond to reselects until this command is executed.
- Once this command has started executing, it cannot be soft aborted.
- The execution of this command cannot cause any error conditions.

| Command<br>Code | Bus | Memory<br>Access | Execution<br>Time | Function             |
|-----------------|-----|------------------|-------------------|----------------------|
| 1001 000X       | C/D | No               | .5 µs             | Disable reselection. |

## CNTL DIS RESEL - Control Disable RESELECT

### **Operational Description**

Firmware engineers can issue this command to the pipeline registers to prevent the 82C5086 from responding to a SCSI bus RESELECT phase. After this command is executed, INIT WFR CMD Initiator Wait for Reselect Command) and INIT WFR SEQ (Initiator Wait for Reselect and Receive Sequence) will not respond to a RESELECT phase. When a reselect occurs, the Select Bit (bit 5) of Interrupt Status Register 5 will no longer be asserted.

- By executing the CNTL ENB RESEL (Control Enable Reselect) pipeline command, the firmware engineer can enable the 82C5086 to respond to reselects.
- After a reset, the 82C5086 does not respond to reselects until a CNTL ENB RESEL command is executed.
- Once this command has started executing, it cannot be soft aborted.
- The execution of this command cannot cause any error conditions.

| Command<br>Code | Bus | Memory<br>Access | Execution<br>Time | Function                                   |
|-----------------|-----|------------------|-------------------|--------------------------------------------|
| 1010 000X       | C/D | No               | .5 μs             | Enable auto advance to next<br>MCS script. |

## **CNTL ENB ADV - Control Enable MCS Auto Advance**

## **Operational Description**

•

Normally the 82C5086 advances the SM address pointer to the beginning of the next MCS script at the start of a new pipeline command that involves MCS access. If this auto advance feature is disabled, all 82C5086 state machine (SM) accesses to the MCS will be to contiguous memory locations. Firmware engineers can disable this MCS auto advance by executing a CNTL DIS ADV (Disable MCS Auto Advance) pipeline command.

### Notes

• Once execution has started, this command cannot be soft aborted.

The execution of this command cannot cause any error conditions.

| Command<br>Code | Bus | Memory<br>Access | Execution<br>Time | Function                                    |
|-----------------|-----|------------------|-------------------|---------------------------------------------|
| 1011 000X       | C/D | No               | .5 µs             | Disable auto advance to next<br>MCS script. |

## CNTL DIS ADV - Control Disable MCS Auto Advance

## **Operational Description**

This command prevents the 82C5086 from automatically advancing the SM address pointer to the beginning of the next MCS script at the start of a new pipeline command that involves MCS access. Firmware engineers should realize that when a command that will require MCS access is issued and the SM address pointer is already pointing to location zero of an MCS script, the pointer will not be automatically incremented at the start of command execution.

Firmware engineers may decide to disable auto advance to make more efficient use of MCS space. For instance, the firmware engineer may decide to place all commonly used messages contiguously in one MCS script. After the message has been placed in the MCS, the firmware engineer must complete the following steps to send out that message:

- 1. Execute the CNTL DIS AVD command to disable the MCS auto advance function.
- 2. Load SM MCS Address Register 9 to point to the first byte of the message.
- 3. Execute an INIT SEND MSG or TGT SEND MSG command.

- Once execution has started, this command cannot be aborted.
- The execution of this command cannot cause any error conditions.

| CNTL DATA PTM - Control Data from MPU to Memory Data Bu | CNTL | DATA P | - МТ | Control | Data | from | MPU | to | Memory | Data | Bu |
|---------------------------------------------------------|------|--------|------|---------|------|------|-----|----|--------|------|----|
|---------------------------------------------------------|------|--------|------|---------|------|------|-----|----|--------|------|----|

|    | ommand<br>ode | Bus | Memory<br>Access | Execution<br>Tim <b>e</b> | Function                                                        |
|----|---------------|-----|------------------|---------------------------|-----------------------------------------------------------------|
| 11 | 10 000X       | C/D | FIFO             | 1 μs plus .3 μs/byte      | Receive data from MPU bus<br>and send it to memory data<br>bus. |

## **Operational Description**

The firmware engineer can use this command to provide a data path between the MPU data bus and the memory data bus. It transfers data from the MPU to the memory data bus. When the Down Transfer Counter equals zero and the FIFO is empty, this transfer is completed.

- A soft abort of this command terminates command execution immediately.
- The only possible error with this command is a parity error.
- SCSI bus conditions are not pertinent to this command's execution.
- Refer to Figure 3-3 for an illustration of the MPU's use of MPU FIFO Buffer Register 12 and the 82C5086's internal FIFO to transfer data between these two buses.

| Command<br>Code | Bus | Memory<br>Access | Execution<br>Time    | Function                                                        |
|-----------------|-----|------------------|----------------------|-----------------------------------------------------------------|
| 1111 000X       | C/D | FIFO             | 1 μs plus .3 μs/byte | Receive data from memory<br>data bus and send it to the<br>MPU. |

## **CNTL DATA MTP - Control Data from Memory Data Bus to MPU**

## **Operational Description**

This command provides a data path between the MPU data bus and the memory data bus. Firmware engineers can issue this command to transfer data from the memory data bus to the MPU bus. When the Down Transfer Counter equals zero and the FIFO is empty, the data transfer is completed.

- A soft abort of this command terminates command execution immediately.
- SCSI bus conditions are not pertinent to this command's execution.
- The only possible error with this command is a parity error.

## INITIATOR COMMAND DESCRIPTIONS

Refer to Table 5-2 for a list of the 82C5086 initiator commands. Following this table, each initiator pipeline command is described in detail.

| Command Code | Command Initiator | Function                                                              |
|--------------|-------------------|-----------------------------------------------------------------------|
| 0000 100X    | INIT SWOA SEQ     | Select target without attention sequence.                             |
| 0001 10XX    | INIT SWA SEQ      | Select target with attention sequence.                                |
| 0010 100X    | INIT SWOA CMD     | Select target without attention command.                              |
| 0011 100X    | INIT SWA CMD      | Select target with attention command.                                 |
| 0100 100X    | INIT REC INFO     | Receive information.                                                  |
| 0101 100X    | INIT DATA MTS     | Receive data from memory data<br>bus and send it to SCSI data<br>bus. |
| 0110 10XX    | INIT DATA PTS     | Receive data from MPU and send it to the SCSI data bus.               |
| 0111 100X    | INIT DATA STM     | Receive data from SCSI bus and send it to memory data bus.            |
| 1000 10XX    | INIT DATA STP     | Receive data from SCSI bus and send it to the MPU's data bus.         |
| 1001 10XX    | INIT SEND MSG     | Send message.                                                         |
| 1010 100X    | INIT SEND CMD     | Send multi-byte command.                                              |
| 1011 100X    | INIT XFER PAD     | Transfer filler data.                                                 |
| 1100 10XX    | INIT XFER BYTE    | Transfer a byte.                                                      |
| 1101 100X    | INIT CMDC SEQ     | Perform COMMAND COMPLETE/<br>DISCONNECT sequence.                     |
| 1110 100X    | INIT WFR CMD      | Wait for the RESELECT phase.                                          |
| 1111 100X    | INIT WFR SEQ      | Wait to be reselected, then reconnect.                                |

## Table 5-2. 82C5086 Initiator Commands

| ſ | Command<br>Code | Bus | Memory<br>Access | Execution<br>Time | Function                                            |
|---|-----------------|-----|------------------|-------------------|-----------------------------------------------------|
|   | 0000 100X       | D   | MCS              | 6 µs              | Initiator select target without attention sequence. |

## INIT SWOA SEQ - Initiator Select without Attention Sequence

## **Operational Description**

This initiator command sequence performs the following tasks:

- 1. Arbitrates for the SCSI bus.
- 2. Selects a target.
- 3. Sends a multi-byte command.

The firmware engineer should issue this pipeline command sequence when the initiator does not want to send the target an identify message. The identify message would not be sent to the target when the system is operating in single-initiator mode.

## Possible Errors

The following errors can cause this command sequence to abort prematurely:

- A SELECT/RESELECT signal is detected during the SCSI bus ARBITRATION phase.
- A SELECT/RESELECT timeout occurs.
- An illegal SCSI bus phase is detected.
- SM error (illegal command group code was encountered) occurs.
- The 82C5086 is already connected to the SCSI bus when this command sequence is issued.
- The target disconnects before this command is completed.

#### Notes

٠

٠

- A soft abort of this command sequence halts execution at one of the following points:
- Before the SCSI bus ARBITRATION phase
- Before the SCSI bus SELECTION phase
- During the SCSI bus COMMAND phase.
- Before issuing this command sequence, the firmware engineer should ensure the MCS has been set up as follows:

SM MCS Address -----> (Register 9)

| N | IC | S | S | cr | ij | pt |  |
|---|----|---|---|----|----|----|--|
|   |    |   |   |    |    |    |  |

Target ID byte

Multi-byte command

| Command<br>Code   | Bus | Memory<br>Access | Execution<br>Time | Function                                         |     |
|-------------------|-----|------------------|-------------------|--------------------------------------------------|-----|
| 0001 10 <b>XX</b> | D   | MCS              | 20 µs             | Initiator select target wind attention sequence. | ith |

## INIT SWA SEQ - Initiator Select with Attention Sequence

### **Operational Description**

Firmware engineers can use this initiator command sequence to perform the following series of tasks:

- 1. Arbitrate for the SCSI bus.
- 2. Select a target.
- 3. Send a one-byte identify message to the target.
- 4. Optionally send the target a two-byte tag message (if modifier bit equals 1).
- 5. Send the target a multi-byte command.
- 6. Terminate sequence at this point if:
  - the identify message disallows a disconnect, or
  - the Override Disconnect Enable Bit (bit 2 of Auxiliary Status Register 20) is asserted.
- 7. If a disconnect is allowed, receive one of the following from the target:
  - one status byte and one message
  - one or two messages.
- 8. Wait for the SCSI bus BUS FREE phase.

## **Possible Error**

• This command sequence could be terminated early for any of the conditions listed under the following commands: INIT SWA CMD, INIT SEND MSG, INIT SEND CMD, and INIT CMDC SEQ.

### Notes

- At the beginning of the ARBITRATION phase, or
- At the beginning of the SELECTION phase, or
- After completion of the SELECTION phase.
- Before firmware engineers issue this command sequence, they should ensure the MCS has been set up as follows:

SM MCS Address -----> (Register 9)

| MCS | Scrip | t |
|-----|-------|---|
|-----|-------|---|

Target ID byte

Identify message byte

Optional two-byte tag message (if modifier bit equals 1)

Multi-byte command

Any information received from the SCSI bus (e.g., a DISCONNECT message) will be placed in the MCS after the multi-byte command.

| Command<br>Code | Bus | Memory<br>Access | Execution<br>Time | Function                                           |
|-----------------|-----|------------------|-------------------|----------------------------------------------------|
| 0010 100X       | D   | MĆS              | 6 µs              | Initiator select target without attention command. |

## INIT SWOA CMD - Initiator Select without Attention Command

## **Operational Description**

This initiator command arbitrates for the SCSI bus and selects a target. It is terminated when the target responds with the -BSY signal, or an error occurs.

## Possible Errors

The following errors are possible:

- A SELECT or RESELECT occurs during the ARBITRATION phase.
- A timeout occurs while the initiator is selecting the target.

### Notes

- A soft abort of this command sequence halts execution as follows: before the SCSI bus ARBITRATION phase, or before target SELECTION phase.
- Before issuing this initiator command, firmware engineers should ensure that the MCS has been set up as follows:

MCS Script

SM MCS Address ----> (Register 9)

Target ID byte

| Command<br>Code | Bus | Memory<br>Access | Execution<br>Time | Function                                        |
|-----------------|-----|------------------|-------------------|-------------------------------------------------|
| 0011 100X       | D   | MCS              | 6 µs              | Initiator select target with attention command. |

## **INIT SWA CMD** - Initiator Select with Attention Command

### **Operational**. **Description**

This initiator command arbitrates for the SCSI bus and selects a target with the -ATN signal asserted. This command is terminated when the target responds with the -BSY signal, or an error occurs.

### **Possible Errors**

The following errors are possible:

- A connect error occurs (e.g., 82C5086 is already connected to the SCSI bus when this command begins execution).
- A SELECT/RESELECT occurs during the ARBITRATION phase.
- A SELECT/RESELECT timeout occurs.

#### Notes

- A soft abort of this command halts execution as follows: before the beginning of the SCSI bus ARBITRATION phase, or before the target SELECTION phase.
- Before firmware engineers issue this initiator command, they should ensure the MCS script has been set up as follows:

SM MCS Address ----> (Register 9) MCS Script

Target ID byte

| Command<br>Code | Bus | Memory<br>Access | Execution<br>Time | Function                       |
|-----------------|-----|------------------|-------------------|--------------------------------|
| 0100 100X       | C   | MCS              | 2 μs              | Initiator receive information. |

## **INIT REC INFO - Initiator Receive Information**

## **Operational Description**

This initiator command waits for the target to go to MESSAGE IN phase or STATUS phase and then it receives the target's message or status into the MCS. At this point, the command is completed.

## **Possible Errors**

The following errors can cause this pipeline command to abort prematurely:

- SM error occurs (if target goes to a SCSI bus phase other than the MESSAGE IN or STATUS phase).
- The initiator detects a wrong phase (if this command starts to process a multi-byte message and target unexpectedly changes the SCSI bus phase).

### Notes

- A long message can begin in one MCS and end in another MCS. If a message exceeds 65 bytes, the 82C5086 automatically transfers the first 65 bytes. After this initial transfer, the firmware engineer must handshake each byte by issuing the INIT XFER BYTE or TGT XFER BYTE command. When this condition develops, an error condition is not generated.
- A soft abort of this command terminates execution immediately.
- Once the command is successfully completed, the MCS script will contain the status byte or the message received from the target.

**MCS Script** 

SM MCS Address (Register 9) -----> Status byte or message

|                 |     | 20               |                      |                                                                              |
|-----------------|-----|------------------|----------------------|------------------------------------------------------------------------------|
| Command<br>Code | Bus | Memory<br>Access | Execution<br>Time    | Function                                                                     |
| 0101 100X       | С   | FIFÓ             | 1 μs plus .2 μs/byte | Initiator receive data from the memory data bus and send it to the SCSI bus. |

## INIT DATA MTS - Initiator Receive Data from Memory Data Bus to SCSI Bus

## **Operational Description**

This initiator command waits for the target to go to DATA OUT phase then transfers data from the memory data bus to the SCSI bus. While the 82C5086 initiator is waiting for the target to change to DATA OUT phase, the 82C5086 starts to fill the internal FIFO with the data from the memory data bus.

When the Down Transfer Counter (set with the transfer count in Registers 16-18) equals zero and the FIFO is empty, this command is completed.

## **Possible Errors**

The following errors can cause this command to abort prematurely:

- The target changes to a SCSI bus phase other than the DATA OUT phase, and asserts the -REQ signal; this causes a wrong phase error.
- The 82C5086 is not connected to the SCSI bus during this command's execution.

- Because the 82C5086 is filling the FIFO while waiting for the target to switch to DATA OUT phase, the firmware engineer must be prepared to backup the DMA controller pointers if the target changes to an illegal SCSI bus phase.
- A soft abort of this command terminates execution immediately.

| Command<br>Code | Bus | Memory<br>Access | Execution<br>Time            | Function                                                           |
|-----------------|-----|------------------|------------------------------|--------------------------------------------------------------------|
| 0110 10XX       | С   | FIFO             | 1 μs plus .2 μs/data<br>byte | Initiator receive data<br>from MPU and send it<br>to the SCSI bus. |

## **INIT DATA PTS - Initiator Receive Data from MPU to SCSI Bus**

## **Operational Description**

This pipeline command waits for the target to go to the DATA OUT phase then transfers data from the MPU to the SCSI bus. SCSI bus data can be asynchronous or synchronous. Refer to Chapter 4's description of Sync/Async ID Register 21 for information on how synchronous or asynchronous transfer mode is specified.

While the 82C5086 is waiting for the target to change to the DATA OUT phase, the 82C5086 starts to fill the FIFO with data from the MPU. MPU data transfers can be 8 or 16 bits wide. If the modifier bit (bit 1) of this command code is set, 16-bit transfers are enabled. With 16-bit MPU data transfers, bits 0-7 are transferred via the MPU bus; bits 8-15 are transferred simultaneously via the memory data bus. Data transfers from the MPU to the 82C5086 must be written to MPU FIFO Data Register 12. For more details refer to Register 12's description in Chapter 4.

When the Down Transfer Counter (set with the transfer count in Registers 16-18) equals zero and the FIFO is empty, this command is completed.

## Possible Errors

The following errors can cause this command to abort prematurely:

- The target changes to a SCSI bus phase other than the DATA OUT phase, and asserts the -REQ signal; this causes a wrong phase error.
- The 82C5086 is not connected to the SCSI bus during this command's execution.

- Because the 82C5086 is filling the FIFO while waiting for the target to switch to DATA OUT phase, the firmware engineer must be prepared to backup the DMA controller pointers if the target changes to an illegal SCSI bus phase.
- A soft abort of this command terminates execution immediately.

| Command<br>Code | Bus | Memory<br>Access | Execution<br>Time    | Function                                                                       |
|-----------------|-----|------------------|----------------------|--------------------------------------------------------------------------------|
| 0111 100X       | С   | FIFO             | 1 μs plus .2 μs/byte | Initiator receive data from<br>SCSI bus and send it to the<br>memory data bus. |

## INIT DATA STM - Initiator Receive Data from SCSI to Memory Data Bus

## **Operational Description**

This initiator command waits for the target to switch to the DATA IN phase then transfers data from the SCSI data bus to the memory data bus. SCSI bus data can be asynchronous or synchronous. Refer to Chapter 4's description of Sync/Async ID Register 21 for information on how synchronous or asynchronous transfer mode is specified.

When the Down Transfer Counter equals zero and the FIFO is empty, this command is completed.

## Possible Errors

The following errors can cause this command to abort prematurely:

- The target changes to a SCSI bus phase other than the DATA IN phase, and asserts the -REQ signal; this causes a wrong phase error.
- The 82C5086 is not connected to the SCSI bus during this command's execution.

### Note

If the firmware engineer soft aborts this command, command execution is terminated immediately.

| ſ | Command<br>Code | Bus | Memory<br>Access | Execution<br>Time    | Function                                                                    |
|---|-----------------|-----|------------------|----------------------|-----------------------------------------------------------------------------|
|   | 1000 10XX       | С   | FIFO             | 1 μs plus .2 μs/byte | Initiator receive data from the SCSI bus and send it to the MPU's data bus. |

## INIT DATA STP - Initiator Receive Data from SCSI to MPU Bus

## **Operational Description**

This initiator command waits for the SCSI bus to change to the DATA IN phase then transfers asynchronous or synchronous data from the SCSI data bus to the MPU. The MPU must receive the data by reading the MPU FIFO Buffer Register 12. The MPU can read 8 or 16 bits per cycle. If the modifier bit (bit 1) of this command code is asserted, 16-bit transfers are enabled.

When the Down Transfer Counter equals zero and the FIFO is empty, this command is completed.

### Possible Errors

The following errors can cause this command to abort prematurely:

- The target changes to a SCSI bus phase other than the DATA IN phase, and asserts the -REQ signal; this causes a wrong phase error.
- The 82C5086 is not connected to the SCSI bus during this command's execution.

#### Note

• If the firmware engineer soft aborts this command, execution terminates immediately.

| Command<br>Code | Bus | Memory<br>Access | Execution<br>Time    | Function                          |
|-----------------|-----|------------------|----------------------|-----------------------------------|
| 1001 10XX       | С   | MCS              | 1 μs plus .5 μs/byte | Initiator send message to target. |

## **INIT SEND MSG - Initiator Send Message**

## **Operational Description**

This pipeline command has the initiator wait for the target to go to the MESSAGE OUT phase then transfers a single or multi-byte message from the MCS to the target. If the 82C5086 does not have the -ATN signal asserted, this command does the following:

- 1. Asserts the -ATN signal before transferring the first byte, and
- 2. Deasserts -ATN on the last message byte. However, if the modifier bit (bit 1) of this command code is asserted, -ATN is not deasserted on the last message byte. This enables the firmware engineer the opportunity to send multiple messages to the target.

## **Possible Errors**

The following errors can cause this initiator command to abort prematurely:

- A connect error occurs (if the target disconnects during execution of this pipeline command).
- The initiator detected a wrong SCSI bus phase (e.g., target goes to phase other than the MESSAGE OUT phase).

### Notes

- A long message can begin in one MCS and end in another MCS. If a message exceeds 65 bytes, the 82C5086 automatically transfers the first 65 bytes. After this initial transfer, the firmware engineer must handshake each byte by issuing the INIT XFER BYTE or TGT XFER BYTE command. When this condition develops, an error condition is not generated.
- A soft abort of this command terminates command execution immediately.
- Before firmware engineers issue this command, they should ensure the MCS has been set-up as follows:

SM MCS Address -----> (Register 9) MCS Script

Single or multi-byte message
| Command<br>Code | Bus | Memory<br>Access | Execution<br>Time    | Function                             |
|-----------------|-----|------------------|----------------------|--------------------------------------|
| 1010 100X       | C   | MCS              | 1 µs plus .5 µs/byte | Initiator send a multi-byte command. |

## **INIT SEND CMD - Initiator Send Command**

### **Operational Description**

This initiator command waits for the target to go to the SCSI bus COMMAND phase then transfers a multi-byte command from the MCS to the target. Bits 7-5 of the first pipeline command byte are decoded by the 82C5086 to determine the command length. Refer to Table 5-3 for list of command length codes.

## Table 5-3. Command Length Codes

| Command Byte<br>Bits |   |   | Command Length                                               |  |
|----------------------|---|---|--------------------------------------------------------------|--|
| 7                    | 6 | 5 |                                                              |  |
| 0                    | 0 | 0 | 6 bytes                                                      |  |
| 0                    | 0 | 1 | 10 bytes                                                     |  |
| 0                    | 1 | 0 | SM (state machine) error                                     |  |
| 0                    | 1 | 1 | SM error                                                     |  |
| 1                    | 0 | 0 | SM error                                                     |  |
| 1                    | 0 | 1 | 12 bytes                                                     |  |
| 1                    | 1 | 0 | 12 bytes<br>Register 22's bits 0-3<br>Register 22's bits 4-7 |  |
| 1                    | 1 | 1 | Register 22's bits 4-7                                       |  |

Refer to the operational description of the Target Receive Multi-byte Command (TGT REC CMD) later in this chapter for information on command lengths that cause SM errors. For details on command length specified by Register 22's bits refer to that register's description in Chapter 4.

## Possible Errors

The following errors are possible with the execution of this command:

- A connect error occurs.
- The initiator detects a wrong SCSI bus phase; the target changed to a phase other than the COMMAND phase.

• SM error (illegal group code) occurs. Byte 0, bits 7-5, contains a group code of 2, 3, or 4. If firmware engineers want to transfer a command with one of these group codes to the target, they must back up the SM MCS address pointer one location, and issue the INIT XFER BYTE command for each byte sent to the target.

#### Notes

- A soft abort of this command terminates execution immediately.
- Before firmware engineers issue this command, they should ensure the MCS has been set up as follows:

MCS Script

SM MCS Address -----> (Register 9) Multi-byte command

| <b>INIT XFER PAD - Initiator Transfer I</b> | Pad |
|---------------------------------------------|-----|
|---------------------------------------------|-----|

| Command<br>Code | Bus | Memory<br>Access | Execution<br>Time    | Function                        |
|-----------------|-----|------------------|----------------------|---------------------------------|
| 1011 100X       | C   | No               | 1 μs plus .5 μs/byte | Initiator transfer filler data. |

#### **Operational Description**

This transfer pad command enables the initiator either to receive or send data, depending on the state of the SCSI bus -I\_O signal. Data is transferred until the target changes SCSI bus phase. If this command is receiving data, the data is discarded; parity is not checked. If this command is sending data, it sends a zero value without a parity error.

The Transfer Counter that is set with Registers 16-18 is not effected by this command. This command cannot be used to pad synchronous data bytes. Firmware engineers must do an actual data transfer count when synchronous data padding is required. Except for the -I\_O signal, SCSI bus phase is not pertinent to this command's execution; only a phase change is pertinent. This command does not set any bits in the pipeline status registers.

#### **Possible Error**

The following error can cause this command to abort prematurely:

• A connect error occurs. The 82C5086 is not connected to the SCSI bus during this command's execution.

#### Note

A soft abort of this command terminates execution immediately.

|  | INIT | XFER | BYTE | • | Initiator | Transfer | Byte |
|--|------|------|------|---|-----------|----------|------|
|--|------|------|------|---|-----------|----------|------|

| Command<br>Code | Bus | Memory<br>Access | Execution<br>Time    | Function                   |
|-----------------|-----|------------------|----------------------|----------------------------|
| 1100 10XX       | C   | MCS              | 1 μs plus .5 μs/byte | Initiator transfer a byte. |

#### **Operational Description**

This initiator command transfers a byte from the SCSI bus to the MCS, or transfers the next MCS byte to the SCSI bus. If this command's modifier bit is asserted, this command asserts the -ATN signal while the -REQ signal is true on the SCSI bus. This protocol ensures that the target detects the asserted -ATN signal.

This protocol with the modifier bit asserted is normally used to request the target to perform a MESSAGE OUT phase (possibly to reject a message, etc). Except for the -I\_O signal, SCSI bus phase is not pertinent to this command. This command does not set any bits in the pipeline status registers.

## Possible Error

The following error is possible:

• The 82C5086 is not connected to the SCSI bus during this command's execution.

#### Notes

- A soft abort of this command terminates execution immediately.
- Firmware engineers should ensure the SM address pointer (Register 9) points to the location in the MCS where the bytes should be sent/received. Generally, firmware engineers will want to disable the MCS automatic advance feature before executing this command. This feature can be disabled by issuing the CNTL DIS ADV pipeline command to one of the pipeline registers.

| Command<br>Code | Bus | Memory<br>Access | Execution<br>Time | Function                                              |
|-----------------|-----|------------------|-------------------|-------------------------------------------------------|
| 1101 100X       | С   | MCS              | 4 µs              | Initiator COMMAND<br>COMPLETE/DISCONNECT<br>sequence. |

#### INIT CMDC SEQ - Initiator COMMAND COMPLETE/DISCONNECT Sequence

## **Operational Description**

This initiator command sequence receives one status byte and one message, or two messages; and places the information in the MCS. If one of the messages is the DISCONNECT message or COMMAND COMPLETE message, this command sequence waits for the BUS FREE phase to occur before it is completed.

A state machine (SM) error is generated and the sequence is terminated if the 82C5086 receives a message other than one of the following: (1) DISCONNECT message (2) COMMAND COMPLETE message (3) LINKED COMMAND COMPLETE (4) LINKED COMMAND COMPLETE with flags (5) SAVE DATA POINTERS (6) RESTORE DATA POINTERS or (7) the IDENTIFY message.

## Possible Errors

The following errors can cause this command sequence to abort prematurely:

- A connect error occurs.
- Any of the following four SM errors occur:
  - 1. ILLEGAL PHASE. The target changes the SCSI bus phase to a phase other than the MESSAGE IN or STATUS phase.
  - 2. ILLEGAL MESSAGE. The message byte is not one of the seven legal messages (e.g., DISCONNECT message) listed in this command's "Operational Description" section.
  - 3. ILLEGAL DISCONNECT. The target disconnects without first sending a COMMAND COMPLETE or DISCONNECT message to the initiator.
  - 4. The target asserts the -REQ signal when it should have disconnected.

Notes

- A soft abort of this command sequence terminates execution immediately.
- This initiator command sequence will not receive illegal messages; they are left on the SCSI bus. Firmware engineers can examine the contents of the SCSI bus by reading SCSI Data Register 22.
- When this command is completed successfully, the MCS will contain one status and one message byte, or two message bytes. The SM MCS address pointer (Register 9) will be pointing to the last byte received, plus one byte.

| Command<br>Code | Bus | Memory<br>Access | Execution<br>Time        | Function                     |
|-----------------|-----|------------------|--------------------------|------------------------------|
| 1110 100X       | D   | MCS              | 1.5 μs plus wait<br>time | Initiator wait for reselect. |

#### **INIT WFR CMD - Initiator Wait for Reselect**

## **Operational Description**

Firmware engineers need to execute the CNTL ENB RESEL command for the INIT WRF CMD and INIT WFR SEQ to be able to detect a reselect. The INIT WRF CMD waits for the 82C5086 to be selected or reselected, then it saves the ID of the device that selected or reselected the 82C5086 in the MCS. The command asserts the -BSY signal and waits for the -SEL signal to be deasserted.

This command can also change the initiator or target mode of the 82C5086. If the 82C5086 is reselected, the initiator mode is maintained; however, the 82C5086 is switched to target mode if it is selected. If a reselection occurs, this command deasserts the -BSY signal after the -SEL signal is deasserted.

The 82C5086 tags the ID byte to indicate whether a select or reselect occurred. When the MPU MCS Buffer Register contains the ID byte, firmware engineers should read Register 19's bit 6 before reading the MPU MCS Buffer Register. If bit 6 of Auxiliary Status Register 19 is asserted, a reselection occurred.

#### Possible Error

The following error can cause this command to abort prematurely:

A connect error occurs. The 82C5086 is connected to the SCSI bus during this command's execution.

#### Notes

- A soft abort of this command terminates execution before a select or reselect occurs.
- After this command is successfully executed, the ID of the device that selected or reselected the 82C5086 will have been received from the SCSI bus and placed in the MCS:

MCS Script

| SM   | MCS    | Address |
|------|--------|---------|
| (Reg | gister | 9)      |

ID byte

## **INIT WFR SEQ - Initiator Wait for Reselect Sequence**

| Command<br>Code | Bus | Memory<br>Access | Execution<br>Time | Function                                                                    |
|-----------------|-----|------------------|-------------------|-----------------------------------------------------------------------------|
| 1111 100X       | D   | MCS              | 4 µs              | Initiator wait for RECONNECT<br>condition then begin RECONNECT<br>sequence. |

## **Operational Description**

If the 82C5086 is reselected and the firmware engineer has specified this command, this command sequence is executed. If the 82C5086 is selected, it switches to target mode and executes the Target Wait for Select Sequence (TGT WFS SEQ).

When this sequence is completed, firmware engineers should read Auxiliary Status Register 19 to check if the 82C5086 is in target or initiator mode.

If the reconnected target is set up for synchronous data transfers, this command sequence is terminated after the device ID is saved in the MCS. For details on setting up devices for synchronous data transfers refer to Sync/Async ID Register 21's description in Chapter 4.

If the reconnected target is set up for asynchronous data transfers, this command sequence continues to receive status and the following legal messages: (1) DISCONNECT message (2) COMMAND COMPLETE message (3) LINKED COMMAND COMPLETE (4) LINKED COMMAND COMPLETE with flags (5) SAVE DATA POINTERS (6) RESTORE DATA POINTERS, or (7) the IDENTIFY message. It continues to receive status and/or these legal messages until the target changes to a SCSI bus phase other than the STATUS or MESSAGE IN phase.

The 82C5086 tags the target ID in the MCS to indicate the occurrence of a reselection. When the MPU MCS Buffer Register contains the ID byte, firmware engineers should read Register 19's bit 5 before reading the MPU MCS Buffer Register. If bit 5 of Auxiliary Status Register 19 is asserted, a reselection occurred.

## Possible Errors

The following errors are possible:

- A connect/disconnect error occurs. The 82C5086 is connected when sequence is started, or an unexpected disconnect occurs.
- An SM error occurs. The target sends an illegal message. The message byte is not one of the seven legal messages listed in this command's "Operational Description" section.

#### Notes

- Many times the firmware engineer will not know if the next SCSI bus access will be a selection or reselection. Because the 82C5086 will execute the appropriate command (INIT WFR SEQ or TGT WFS SEQ) regardless of which sequence was specified, the firmware engineer can use these two pipeline commands interchangeably. However, it is recommended that target/initiator mode be maintained whenever possible. For example, if the 82C5086 is operating as an initiator, firmware engineers should issue this command to one of the pipeline registers.
- A soft abort of this sequence terminates execution before the reselect occurs. After the 82C5086 has been reselected, the command will run to completion and ignore the soft abort.
- This initiator sequence will not receive illegal messages; they are left on the SCSI bus for the firmware engineer to handle. Firmware engineers may want to receive the message by issuing an INIT REC INFO command, or may want to begin a message reject process by asserting the -ATN signal.
- After this command is successfully completed, normally the MCS will contain the target ID followed by the status and message bytes.

SM MCS Address (Register 9) MCS Script

Status/message bytes

Target ID

175

## TARGET COMMAND DESCRIPTIONS

Refer to Table 5-4 for a list of the 82C5086 target commands. Following this table each command is described in detail.

## Table 5-4. 82C5086 Target Commands

| Command Code | Command       | TargetFunction                                                 |
|--------------|---------------|----------------------------------------------------------------|
| 0000 010X    | TGT SEND MSG  | Send message.                                                  |
| 0001 010X    | TGT SEND STAT | Send status to initiator.                                      |
| 0010 010X    | TGT DATA MTS  | Receive data from memory data bus and send it to the SCSI bus. |
| 0011 01XX    | TGT DATA PTS  | Receive data from MPU bus and send it to SCSI bus.             |
| 0100 010X    | TGT REC CMD   | Receive a multi-byte command.                                  |
| 0101 010X    | TGT REC MSG   | Receive a single-byte or multi-byte message.                   |
| 0110 010X    | TGT DATA STM  | Receive data from SCSI bus and send it to the memory data bus. |
| 0111 01XX    | TGT DATA STP  | Receive data from SCSI bus and send it to the MPU's data bus.  |
| 1000 010X    | TGT CMDC SEQ  | Perform COMMAND COMPLETE sequence.                             |
| 1001 010X    | TGT XFER BYTE | Transfer byte.                                                 |
| 1010 010X    | TGT DISC CMD  | Disconnect from the SCSI bus.                                  |
| 1011 010X    | TGT DISC SEQ  | Perform DISCONNECT sequence.                                   |
| 1100 01XX    | TGT RCNT SEQ  | Perform RECONNECT sequence.                                    |
| 1101 01XX    | TGT SEND BSY  | Wait for select, then send busy response and disconnect.       |
| 1110 010X    | TGT WFS CMD   | Wait for select.                                               |
| 1111 01XX    | TGT WFS SEQ   | Perform Wait for Select sequence.                              |

| Command<br>Code | Bus | Memory<br>Access | Execution<br>Time                            | Function                                     |
|-----------------|-----|------------------|----------------------------------------------|----------------------------------------------|
| 0000 010X       | С   | MCS              | 2 μs first byte plus<br>1 μs/additional byte | Target send single or<br>multi-byte message. |

#### **Operational Description**

This pipeline command switches the SCSI bus to the MESSAGE IN phase, and sends a single or multi-byte message to the initiator.

### **Possible Error**

The following errors are possible when this command is executing:

- The initiator asserts the -ATN signal unexpectedly.
- Not connected to SCSI when command is issued.

### Notes

- A soft abort of this command terminates execution immediately.
- A long message can begin in one MCS and end in another MCS. If a message exceeds 65 bytes, the 82C5086 automatically transfers the first 65 bytes. After this initial transfer, the firmware engineer must handshake each byte by issuing the TGT XFER BYTE command. When this condition develops, an error condition is not generated.
- Before firmware engineers issue this target command, they should ensure the MCS script has been set up as follows:

MCS Script

SM MCS Address .....> (Register 9)

Single or multi-byte message

| Command   | Bus | Memory | Execution | Function            |
|-----------|-----|--------|-----------|---------------------|
| Code      |     | Access | Time      |                     |
| 0001 010X | С   | MCS    | 2 μs      | Target send status. |

## TGT SEND STAT - Target Send Status

## **Operational Description**

This target command switches the SCSI bus to the STATUS phase, and transfers one status byte from the MCS to the initiator.

## **Possible Errors**

The following errors can cause this target command to abort prematurely:

- A connect error occurs. The 82C5086 is not connected to the SCSI bus when this command is issued.
- The initiator asserts the -ATN signal.

## Notes

- A soft abort of this command terminates execution immediately.
- Before firmware engineers issue this target command, they should ensure the MCS has been set up as follows:

## MCS Script

SM MCS Address -----> (Register 9)

Status byte

| Command<br>Code | Bus | Memory<br>Access | Execution<br>Time    | Function                                                                     |
|-----------------|-----|------------------|----------------------|------------------------------------------------------------------------------|
| 0010 010X       | С   | FIFO             | 1 μs plus .2 μs/byte | Target receive data from<br>memory data bus and send it<br>to SCSI data bus. |

#### TGT DATA MTS - Target Receive Data from Memory Data Bus to SCSI Bus

## **Operational Description**

This pipeline command switches the SCSI bus to the DATA IN phase, and transfers data from the memory data bus to the SCSI bus. Data transfers over the SCSI bus can be synchronous or asynchronous. Refer to the description of the Sync/Async ID Register (Register 21) in Chapter 4 for information on how synchronous or asynchronous mode for data transfers is specified.

When the Down Transfer Counter (set with the transfer count in Registers 16-18) equals zero and the FIFO is empty, this command is completed.

#### Possible Errors

The following errors can cause this command to abort prematurely:

- The 82C5086 is not connected to the SCSI bus during this command's execution.
- The initiator asserts the -ATN signal while this command is executing, and the -ATN pin is not disabled. The -ATN pin is disabled by asserting the Disable ATN Bit (bit 2) of Auxiliary Control Register 19.

#### Note

A soft abort of this command terminates execution immediately.

| Command<br>Code | Bus | Memory<br>Access | Execution<br>Time    | Function                                                  |
|-----------------|-----|------------------|----------------------|-----------------------------------------------------------|
| 0011 01XX       | С   | FIFO             | 1 µs plus .2 µs/byte | Target receive data from MPU bus and send it to SCSI bus. |

## TGT DATA PTS - Target Receive Data from MPU to SCSI Bus

## **Operational Description**

This pipeline command switches the SCSI bus to the DATA IN phase and transfers 8 or 16 bits of data from the MPU bus to the SCSI bus. SCSI bus data transfers can be asynchronous or synchronous. Refer to Chapter 4's description of Sync/Async ID Register 21 for information on how synchronous or asynchronous data transfers are specified.

MPU data transfers can be 8 or 16 bits wide. If the modifier bit (bit 1) of this command is asserted, 16-bit transfers are enabled. With 16-bit MPU data transfers, bits 0-7 are transferred from the MPU bus to MPU FIFO Data Register 12. Bits 8-15 are simultaneously transferred over the memory data bus. For more details on Register 12 refer to Chapter 4.

When the Down Transfer Counter (set with the transfer count in Registers 16-18) equals zero and the FIFO is empty, this command is completed.

#### **Possible Errors**

The following errors can cause this command to abort prematurely:

- The 82C5086 is not connected to the SCSI bus when this command is executing.
- The initiator asserts the -ATN signal while this command is executing, and the -ATN pin is not disabled. The -ATN pin is disabled by asserting the Disable ATN Bit (bit 2) of Auxiliary Control Register 19.

#### Note

• A soft abort of this command terminates execution immediately.

## **TGT REC CMD - Target Receive Command**

| Command<br>Code   | Bus | Memory<br>Access | Execution<br>Time    | Function                             |
|-------------------|-----|------------------|----------------------|--------------------------------------|
| 0100 010 <b>X</b> | С   | MCS              | 1 µs plus .5 µs/byte | Target receive a multi-byte command. |

### **Operational Description**

This pipeline command switches the SCSI bus to the COMMAND phase and transfers a multi-byte command from the SCSI bus to the MCS.

#### **Possible Errors**

The following errors can cause this target command to abort prematurely:

- The 82C5086 is not connected to the SCSI bus when this command is executed.
- The initiator asserts the -ATN signal.
- An SM error (illegal group code) occurs. A command with a group code of 2, 3, or 4 was received. No command bytes have been transferred into the MCS. The firmware engineer must issue the TGT XFER BYTE command to receive each command byte into the MCS.

#### Note

- A soft abort of this command terminates execution immediately.
- After this command is successfully executed, the MCS will contain a multi-byte command:

MCS Script

SM MCS Address (Register 9) ....> Multi-byte command

| Command<br>Code | Bus | Memory<br>Access | Execution<br>Time    | Function                                     |
|-----------------|-----|------------------|----------------------|----------------------------------------------|
| 0101 010X       | С   | MCS              | 1 μs plus .5 μs/byte | Target receive single or multi-byte message. |

## TGT REC MSG - Target Receive Message

### **Operational Description**

This command switches the SCSI bus to the MESSAGE OUT phase and receives a single or multi-byte message into the MCS.

#### **Possible Errors**

The following errors are possible:

• The 82C5086 is not connected to the SCSI bus when this command is executed.

#### Notes

- A long message can begin in one MCS and end in another MCS. If a message exceeds 65 bytes, the 82C5086 automatically transfers the first 65 bytes. After this initial transfer, the firmware engineer must handshake each byte by issuing the TGT XFER BYTE command. When this condition develops, an error condition is not generated.
- A soft abort of this command terminates execution immediately.
- After this command is successfully executed, the MCS will contain the following:

MCS Script

SM MCS Address (Register 9) -----> Single or multi-byte message

| [ | Command<br>Code | Bus | Memory<br>Access | Execution<br>Time    | Function                                                           |
|---|-----------------|-----|------------------|----------------------|--------------------------------------------------------------------|
|   | 0110 010X       | С   | FIFO             | 1 μs plus .2 μs/byte | Target receive data from the SCSI bus and send to memory data bus. |

## TGT DATA STM - Target Receive Data from SCSI Bus to Memory Data Bus

## **Operational Description**

This target command switches the SCSI bus to DATA OUT phase, receives data from the SCSI bus, and sends it to the memory data bus. Data transfers over the SCSI bus can be synchronous or asynchronous. Refer to Chapter 4's description of Sync/Async ID Register 21 for information on how synchronous or asynchronous data transfer mode is specified.

When the Down Transfer Counter (set with the transfer count in Registers 16-18) equals zero and the FIFO is empty, this command is completed.

### **Possible Errors**

The following errors can cause this command to abort prematurely:

- The 82C5086 is not connected to the SCSI bus when this command is executing.
- The initiator asserts the -ATN signal while this command is executing, and the -ATN pin is not disabled. The -ATN pin is disabled by asserting the Disable ATN Bit (bit 2) of Auxiliary Control Register 19.

### Note

• A soft abort will terminate execution of this command immediately.

| Command<br>Code | Bus | Memory<br>Access | Execution<br>Time                | Function                                                                |
|-----------------|-----|------------------|----------------------------------|-------------------------------------------------------------------------|
| 0111 01XX       | С   | FIFO             | 1 μs plus .2 μs/byt <del>e</del> | Target receive data from SCSI<br>bus and send it to memory<br>data bus. |

#### TGT DATA STP - Target Receive Data from SCSI to MPU Bus

## **Operational Description**

This target command switches the SCSI bus to the DATA OUT phase and transfers data from the SCSI data bus to the MPU data bus. Data transferred can be synchronous or asynchronous. Refer to Chapter 4's description of Sync/Async ID Register 21 for details on how synchronous or asynchronous transfer mode can be specified.

If this command's modifier bit (bit 1) is asserted, 16 bits of data will be transferred to the MPU when MPU FIFO Data Register 12 is read. Bits 0-7 are transferred over the MPU data bus while bits 8-15 are being transferred simultaneously over the memory data bus.

#### Possible Errors

The following errors can cause this command to abort prematurely:

- The 82C5086 is not connected to the SCSI bus when this command is executing.
- The initiator asserts the -ATN signal while this command is executing, and the -ATN pin is not disabled. The -ATN pin is disabled by asserting the Disable ATN Bit (bit 2) of Auxiliary Control Register 19.

Note

A soft abort of this command terminates execution immediately.

| TGT CMDC SEQ - Target COMMAND COMPLETE Sequer |
|-----------------------------------------------|
|-----------------------------------------------|

| Command<br>Code | Bus | Memory<br>Access | Execution<br>Time | Function                                     |
|-----------------|-----|------------------|-------------------|----------------------------------------------|
| 1000 010X       | С   | MCS              | 3 µs              | Target perform COMMAND<br>COMPLETE sequence. |

### **Operational Description**

This target command sequence switches the SCSI bus to the STATUS phase and transfers one status byte from the MCS to the initiator. This sequence then switches the SCSI bus to the MESSAGE IN phase and transfers a single or multi-byte message from the MCS to the initiator.

If the transferred message was a COMMAND COMPLETE, the 82C5086 goes to the SCSI bus phase BUS FREE. Otherwise, the 82C5086 remains connected to the SCSI bus.

#### Possible Errors

The following errors can cause this sequence to abort prematurely:

- The 82C5086 is not connected to the SCSI bus when this command sequence is executed.
- The initiator asserted an -ATN signal unexpectedly.

#### Notes

- When this sequence is soft aborted, command execution is terminated immediately.
- Before issuing this target command sequence, firmware engineers should ensure the MCS has been set up as follows:

SM MCS Address -----> (Register 9)

#### MCS Script

Status byte

Single or multi-byte message

| Command   | Bus | Memory | Execution | Function              |
|-----------|-----|--------|-----------|-----------------------|
| Code      |     | Access | Time      |                       |
| 1001 010X | С   | MCS    | 1.5 μs    | Target transfer byte. |

## TGT XFER BYTE - Target Transfer Byte

## **Operational Description**

This command transfers a byte from the MCS to the SCSI bus, or from the SCSI bus to the MCS. It is normally used to perform clean-up when a command sequence has failed. For example, if TGT REC CMD is executing and an illegal group code caused it to abort prematurely, the firmware engineer can receive the SCSI command by executing TGT XFER BYTE. This pipeline command needs to be executed one time for each byte received into the MCS.

Except for the -I\_O signal, SCSI bus phase is not pertinent to this command. It will not change the phase of the SCSI bus, or set any bits in the pipeline status registers.

## Possible Error

The following error can cause this command to abort prematurely:

• A connect error occurs. The 82C5086 is not connected to the SCSI bus when this command started to execute.

## Notes

- A soft abort terminates the execution of this command immediately.
- Parity checking is performed by this command.
- Before issuing this command, firmware engineers should ensure the MCS has been set up as follows:

MCS Script

SM MCS Address (Register 9)

Write Operation Read Operation

One byte transfer to SCSI bus or one byte received from SCSI bus.

| Command<br>Code | Bus | Memory<br>Access | Execution<br>Time | Function                         |
|-----------------|-----|------------------|-------------------|----------------------------------|
| 1010 010X       | C   | N/A.             | 5 µs              | Target disconnect from SCSI bus. |

## TGT DISC CMD - Target Disconnect Command

## **Operational Description**

This command disconnects the 82C5086 from the SCSI bus. The SCSI bus is allowed to go to the BUS FREE phase.

## Note

• Once this command has started executing, it cannot be soft aborted.

## TGT DISC SEQ - Target DISCONNECT Sequence

| Command<br>Code | Bus | Memory<br>Access | Execution<br>Time    | Function                               |
|-----------------|-----|------------------|----------------------|----------------------------------------|
| 1011 010X       | C   | MCS              | 1 µs plus .5 µs/byte | Target perform<br>DISCONNECT sequence. |

## **Operational Description**

This sequence changes the SCSI bus to the MESSAGE IN phase, and transfers message(s) to the initiator until the DISCONNECT message is received. Once the DISCONNECT message is transferred to the initiator, this sequence will set the SCSI bus to the BUS FREE phase and terminate execution. The firmware engineer should exercise care when using this sequence because an infinite loop is possible if the 82C5086 does not find a DISCONNECT message.

### Possible Error

The following error can cause this command to abort prematurely:

• The 82C5086 is not connected to the SCSI bus when this command is executed.

## Notes

- A soft abort terminates the execution of this command immediately.
- Before issuing this command, firmware engineers should ensure the MCS has been set up as follows:

#### MCS Script

SM MCS Address -----> (Register 9)

Multiple, single-byte messages or multi-byte messages

DISCONNECT message

| Command<br>Code | Bus | Memory<br>Access | Execution<br>Time | Function                              |
|-----------------|-----|------------------|-------------------|---------------------------------------|
| 1100 01XX       | D   | MCS              | 6 µs              | Target perform<br>RECONNECT sequence. |

## TGT RCNT SEQ - Target Reconnect Sequence

### **Operational Description**

This sequence arbitrates for the SCSI bus and reselects an initiator. If the modifier bit (bit 1) is set, this sequence changes the SCSI bus to the MESSAGE IN phase, and sends a single or multi-byte message to the initiator.

#### **Possible Errors**

The following errors can cause this command to abort prematurely:

- A select or reselect occurs during the ARBITRATION phase.
- A timeout occurs while reselecting the initiator.
- A connect error occurs. The 82C5086 is connected to the SCSI bus when this command is issued.

#### Notes

• A soft abort of this command halts execution at one of the following points:

-Before the SCSI bus ARBITRATION phase, or

-Before the initiator RESELECTION phase, or

-Any time during the MESSAGE TRANSFER phase.

• Before issuing this command, firmware engineers should ensure the MCS is set up as follows:

MCS Script

SM MCS Address -----> (Register 9) Initiator ID

Optional single or multi-byte message

## TGT SEND BSY - Target Send Busy Command

| Command<br>Code | Bus | Memory<br>Access | Execution<br>Time   | Function                                                             |
|-----------------|-----|------------------|---------------------|----------------------------------------------------------------------|
| 1101 01XX       | D   | N/A              | 5 µs plus wait time | Target wait for select then<br>send busy response and<br>disconnect. |

## **Operational Description**

This sequence should be executed when the firmware engineer wants to disregard any further selects. The sequence will perform the following tasks:

- 1. Wait for a select to occur.
- 2. Assert the -BSY signal on the SCSI bus.
- 3. Receive one message from the initiator if the -ATN signal is asserted; however, the message is not saved.
- 4. Send BUSY status byte to initiator.
- 5. Send COMMAND COMPLETE message to initiator.
- 6. Deassert the -BSY signal and allow the SCSI bus to go to the BUS FREE phase.

If the modifier bit is asserted, this command will not be cleared from the pipeline register when normal execution is completed. If no other commands exist in the other pipeline registers, then this command will be executed repeatedly until the firmware engineer soft aborts the command.

## **Possible Errors**

The following errors can cause this command to abort prematurely:

- The 82C5086 is not connected to the SCSI bus when this command is executed.
- An SM error occurs. A reselection occurs when the sequence is expecting a selection.

## Notes

- A soft abort of this command terminates command execution before the 82C5086 has been selected.
- Firmware engineers will normally terminate this command with a soft abort when they are ready to process selects, or ready to reconnect to an initiator.

| Command<br>Code | Bus | Memory<br>Access | Execution<br>Time     | Function                |
|-----------------|-----|------------------|-----------------------|-------------------------|
| 1110 010X       | D   | MCS              | 1.5 µs plus wait time | Target wait for select. |

### TGT WFS CMD - Target Wait for Select Command

#### **Operational Description**

Firmware engineers need to execute the CNTL ENB SEL command for TGT WFS CMD and TGT WFS SEQ to be able to detect a select. The TGT WFS CMD waits for the 82C5086 to be selected or reselected, then it saves the ID of the device that selected or reselected the 82C5086 in the MCS. This command asserts the -BSY signal, and waits for the -SEL signal to be deasserted.

This command can also change the initiator or target mode of the 82C5086. If the 82C5086 is selected, the target mode is maintained; however, if the 82C5086 is reselected, the 82C5086 is changed to initiator mode. If a reselection occurs, this command deasserts the -BSY signal after the -SEL signal is deasserted.

The 82C5086 tags the ID byte to indicate whether a select or reselect occurred. When the MPU MCS Buffer Register contains the ID byte, firmware engineers should read Register 19's bit 5 before reading the MPU MCS Buffer Register. If bit 5 of Auxiliary Status Register 19 is asserted, a reselection occurred.

## Possible Error

The following error can cause this command to abort prematurely:

• A connect error occurs. The 82C5086 is connected to the SCSI bus when this command is executed.

#### Notes

- A soft abort of this command terminates execution before a select or reselect occurs.
- After this command is successfully executed, the ID of the device that selected or reselected the 82C5086 will have been received from the SCSI bus and placed in the MCS:

#### MCS Script

SM MCS Address (Register 9) -----> ID byte

## TGT WFS SEQ - Target Wait for Select Sequence

| Command<br>Code | Bus | Memory<br>Access | Execution<br>Time | Function                                 |
|-----------------|-----|------------------|-------------------|------------------------------------------|
| 1111 01XX       | D   | MCS              | 10-20 µs          | Target perform wait for select sequence. |

#### **Operational Description**

If the firmware engineer issues this command to one of the pipeline registers and the 82C5086 is reselected, the mode is changed to initiator and INIT WFR SEQ is executed. If the 82C5086 is selected, the following sequence is executed:

- 1. The ID of the initiator is saved in the MCS and the -BSY signal is asserted.
- 2. If the -ATN signal is asserted, the identify message is received and saved in the MCS.
- 3. If the -ATN signal is still asserted and the modifier bit is asserted, then the two-byte tag message is received and saved in the MCS.
- 4. A multi-byte command is received and saved in the MCS.
- 5. If the identify message allows a disconnect and the Override Disconnect Enable Bit is deasserted, the DISCONNECT message is sent to the initiator. If the identify message disallows a disconnect, the sequence is terminated at this point.
- 6. The -BSY signal is deasserted and the SCSI bus is allowed to go to the BUS FREE phase.

## **Possible Errors**

The following errors can cause this command to abort prematurely:

- The 82C5086 is connected to the SCSI bus when this command starts to execute.
- An unexpected -ATN signal is asserted when the 82C5086 is receiving the SCSI command or sending the DISCONNECT message.
- An SM error (illegal message) occurs. If the -ATN signal is asserted, the 82C5086 must receive the ID as the first message, and the optional tag message as the next message. If any other message is received, the sequence is aborted with this error. The illegal message is transferred into the MCS.

#### Notes

- A soft abort of this sequence terminates command execution before the select occurs, or after the sequence is completed.
- This sequence automatically calls the following pipeline commands: TGT WFS CMD, TGT REC MSG, TGT REC CMD, TGT SEND MSG, and TGT DISC CMD. For more information on any of these commands refer to their description in this chapter.
- After this command is successfully executed, the MCS should contain the information received from the initiator:

SM MCS Address .....> (Register 9)

| Initiator ID                                |
|---------------------------------------------|
| Identify message if -ATN signal is asserted |
| Optional two-byte tag message               |
| Multi-byte command                          |
| <br>Multi-byte command                      |

**MCS Script** 



The following chart illustrates the steps involved in completing an asynchronous data transfer to a target device that allows a disconnect. The firmware engineer must initialize certain 82C5086 registers, then queue the commands into the pipeline registers. The 82C5086 target device controller must receive the command from the initiator, decode it, and send status back to the initiator. Commands with vendor unique codes 6 and 7 are not used. For more details on command group codes refer to the description of Register 22 in Chapter 4.

Figure A-1 illustrates the following steps:

- 1. The firmware engineer sets up the necessary 82C5086 internal registers.
- 2. The firmware engineer sets up the 82C5086 pipeline registers for command queuing and places two pipeline commands in these registers.
- 3. The SCSI target device receives the command.
- 4. The data transfer is completed and the target sends the initiator status.
- 5. Control loops back to the command queuing process.



Figure A-1 Device Flow Chart

 $\left( \right)$ 

| A_D                 | address/data                                                                                                                                                                                                                                                                                                                                                                                            |
|---------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ANSI                | American National Standard for Information Systems                                                                                                                                                                                                                                                                                                                                                      |
| ARBITRATION phase   | the SCSI bus phase in which one SCSI device can gain bus control in order to assume the initiator or target role.                                                                                                                                                                                                                                                                                       |
| ATTENTION condition | the SCSI bus condition in which the initiator<br>can signal the target to indicate it has a<br>message ready to transfer out. The target<br>prepares to receive this message by changing<br>the SCSI bus to the MESSAGE OUT phase.<br>The initiator can create the ATTENTION<br>condition at any point other than during the<br>SCSI bus ARBITRATION or BUS FREE<br>phase by asserting the -ATN signal. |
| BUS FREE phase      | the SCSI bus phase that indicates bus<br>availability because there are no SCSI devices<br>actively using it.                                                                                                                                                                                                                                                                                           |
| С                   | centigrade                                                                                                                                                                                                                                                                                                                                                                                              |
| Cascade             | a method of connecting up to four 5086s (80-<br>or 84-pin packages) to support wide SCSI<br>and memory data bus transfers. Cascading<br>four 5086s extend these two buses to 32 bits.                                                                                                                                                                                                                   |
| СНАМ                | chamfer                                                                                                                                                                                                                                                                                                                                                                                                 |
| CMOS                | complementary metal-oxide semiconductor                                                                                                                                                                                                                                                                                                                                                                 |
| COMMAND phase       | the SCSI bus phase in which the target asks the initiator for command information.                                                                                                                                                                                                                                                                                                                      |
| CONNECT sequence    | the occurrence of an initiator selecting a target in order to start an operation.                                                                                                                                                                                                                                                                                                                       |
| СР                  | clock period                                                                                                                                                                                                                                                                                                                                                                                            |

| DATA IN phase         | the SCSI bus phase in which the target requests that data be transferred to the initiator.                                                                                                                                    |
|-----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| DATA OUT phase        | the SCSI bus phase in which the target<br>requests that data from the initiator be<br>transferred to the target.                                                                                                              |
| DC                    | digital circuit or computer                                                                                                                                                                                                   |
| Differential mode     | the mode of operation that supports a system<br>configured with multiple-ended<br>drivers/receivers. This mode supports<br>operation over cables up to 25 meters long.                                                        |
| DISCONNECT sequence   |                                                                                                                                                                                                                               |
|                       | the occurrence of the target giving up control<br>of the SCSI bus, and allowing the SCSI bus<br>to switch to the BUS FREE phase.                                                                                              |
| DMA                   | direct memory access                                                                                                                                                                                                          |
| EEPROM                | electrically erasable programmable read-only memory                                                                                                                                                                           |
| FIFO                  | (first in, first out) the 64 byte portion of 82C5086 memory used for data transfers over the SCSI bus, the memory data bus, and the MPU's data bus.                                                                           |
| Hard reset            | the event that disconnects the target from the SCSI bus, and clears the contents of the 5086's internal registers.                                                                                                            |
| Host adapter          | the use of the 82C5086 as a bridge between the host computer bus and the SCSI bus.                                                                                                                                            |
| Host MPU              | the microprocessor that controls the host computer.                                                                                                                                                                           |
| I/0                   | input/output                                                                                                                                                                                                                  |
| ID                    | identifier                                                                                                                                                                                                                    |
| Identify message      | a single-byte message that specifies if a target<br>is allowed to disconnect. It also specifies the<br>initiator's LUN (logical unit number). This<br>optional message is sent by the initiator, and<br>is stored in the MCS. |
| Information transfers | a term used to encompass transfers of commands, data, status, and messages through the system.                                                                                                                                |

| Initiator             | the SCSI device that initiates an operation<br>with another SCSI device (the target).<br>Usually, the initiator is the host adapter.                                                                                                                                                |
|-----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| LUN                   | logical unit number                                                                                                                                                                                                                                                                 |
| mA                    | milliamp                                                                                                                                                                                                                                                                            |
| Master mode           | one of the operational modes of a cascaded 82C5086. The 82C5086 operating in master mode is responsible for synchronizing the data transfers of the slave chip(s).                                                                                                                  |
| MAX                   | maximum                                                                                                                                                                                                                                                                             |
| MCS script            | (Message/Command Space script). The<br>portion of 82C5086 memory that the<br>82C5086 state machine and the MPU use as a<br>depository for SCSI commands, status<br>and/or messages that will be routed through<br>the system. It consists of six MCS scripts<br>each 32 bytes long. |
| MESSAGE IN phase      | the SCSI bus phase in which the target asks that the message(s) be sent to the initiator.                                                                                                                                                                                           |
| MESSAGE OUT phase     | the SCSI bus phase in which the target asks that it receive the message(s) from the initiator.                                                                                                                                                                                      |
| MESSAGE phase         | the term that encompasses the SCSI bus<br>MESSAGE IN phase or the MESSAGE OUT<br>phase.                                                                                                                                                                                             |
| MHz                   | megahertz                                                                                                                                                                                                                                                                           |
| MIN                   | minimum                                                                                                                                                                                                                                                                             |
| MPU                   | microprocessor                                                                                                                                                                                                                                                                      |
| ms                    | millisecond                                                                                                                                                                                                                                                                         |
| Non-differential mode | mode of operation that supports a system<br>configured with single-ended<br>drivers/receivers. This mode supports<br>operation over cables up to six meters long.                                                                                                                   |
| NRZ                   | non-return to zero                                                                                                                                                                                                                                                                  |
| ns                    | nanosecond                                                                                                                                                                                                                                                                          |

| Peripheral device        | a peripheral (e.g., printer, optical disk)<br>capable of being attached to a SCSI device.                                                    |
|--------------------------|----------------------------------------------------------------------------------------------------------------------------------------------|
| PFP                      | the 80-pin version of the 82C5086 is available in a PFP (plastic flat package).                                                              |
| PLCC                     | the 68 and 84-pin versions of the 82C5086 are available in PLCCs (plastic leaded chip carrier).                                              |
| RAM                      | random access memory                                                                                                                         |
| RECONNECT sequence       | the occurrence of the target selecting an initiator to continue an operation after the target has disconnected.                              |
| <b>RESELECTION</b> phase | the SCSI bus phase in which the target<br>reconnects to continue an incomplete<br>operation after having disconnected from the<br>initiator. |
| <b>RESET</b> condition   | the SCSI bus condition in which all SCSI device connections are cleared from the SCSI bus.                                                   |
| SC                       | SCSI clock                                                                                                                                   |
| SCSI                     | Small Computer System Interface                                                                                                              |
| SCSI device              | the host adapter or device controller that is capable of being attached to a SCSI bus.                                                       |
| SCSI ID                  | a single bit on the SCSI data bus that corresponds to the SCSI device's unique SCSI address.                                                 |
| SELECTION phase          | the SCSI bus phase in which the initiator can select a target in order to initiate an operation.                                             |
| Signal assertion         | the driving of a signal to the true state.                                                                                                   |
| Signal deassertion       | the driving a signal to the false state.                                                                                                     |

| Slave mode      | one of the operational modes of a 82C5086<br>cascaded to support wide data transfers over<br>the SCSI and memory data bus. When in<br>slave mode, the chip's data transfers are<br>synchronized by the 82C5086 chip operating<br>in master mode.                            |
|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SM              | state machine. The 82C5086 controller has<br>an internal state machine. This hardware<br>component manages the flow of SCSI<br>information through the system.<br>Consequently, the firmware is free to manage<br>higher-level system tasks (e.g., resource<br>allocation). |
| Soft reset      | the occurrence that disconnects the target<br>from the SCSI bus; however, contents of the<br>5086's internal registers remain intact.                                                                                                                                       |
| SQ              | square                                                                                                                                                                                                                                                                      |
| Status          | after a command is completed the target sends<br>one byte of status information to the initiator.                                                                                                                                                                           |
| STATUS phase    | the SCSI bus phase in which the target requests the initiator to transfer status to it.                                                                                                                                                                                     |
| ТА              | temperature ambient                                                                                                                                                                                                                                                         |
| Tag message     | a two-byte, optional message that enables<br>multiple commands to be queued in the MCS<br>from a single initiator.                                                                                                                                                          |
| Target          | the SCSI device that responds to the initiator's requests to perform operation(s).                                                                                                                                                                                          |
| ТҮР             | typical                                                                                                                                                                                                                                                                     |
| V               | voltage                                                                                                                                                                                                                                                                     |
| V <sub>dd</sub> | drain DC voltage                                                                                                                                                                                                                                                            |
| μA              | microamp                                                                                                                                                                                                                                                                    |
| μs              | microsecond                                                                                                                                                                                                                                                                 |

.

# INDEX

-16BHAM,40 68-pin PLCC package, 12, 14 80-pin PFP package, 12, 18 84-pin PLCC package, 12, 21 8085/8051 mode timing, 49 8085/8051 mode, 38 80286, 24 A0-A2, 37 A3, 30 A4, 30 -ACK, 31 A.C. specifications, 46 A\_D, 195 A\_D[0-7], 30 absolute maximum ratings, 11,70 Address pointers, 2 ALE\_-AS, 38 **ANSI**, 201 Application flexibility, 6 Applications, 1 **ARB**, 44 ARBITRATION phase, 196 Arbitration timing, 60 Asynchronous mode, 7 Asynchronous transfers, 13,76 Asynchronous transfer timing, 62-65 -ATN, 31 assert, 145 deassert, 145 **ATTENTION condition**, 196

-BSY, 31 BUF\_IN, 31 BUF\_OUT, 31,44 BUS FREE phase, 196 Bus structure, 3

C, 196 -C\_D, 31 Cascading, 3,7,76,196 CHAM, 196 CLOCK, 32 Clock timing, 46 CMOS, 196 COMMAND phase, 196 Command, groups control, 141 initiator, 154 target, 176 Command queuing, 3,10,87 Commands bus condition, 139 categories, 137 command code, 138 execution time, 139 functions, 137 operational description, 147 possible errors, 140 Command set ,3,9,82 CONNECT sequence, 196 Control commands, list, 141 CNTL ATN OFF Control Attention Off, 145 CNTL ATN ON Control Attention On, 145 CNTL DATA MTP Control Data from Memory Data Bus to MPU, 153 CNTL DATA PTM Control Data from MPU to Memory Data Bus, 152 CNTL DIS ADV Control Disable MCS Auto Advance, 151 **CNTL DIS RESEL** Control Disable RESELECT, 149 CNTL DIS SEL Control Disable Select, 147 CNTL ENB ADV Control Enable MCS Auto Advance, 150 CNTL ENB RESEL Control Enable Reselect, 148

CNTL ENB SEL Control Enable Select, 146 CNTL NOP No Operation, 142 CNTL RST FIFO Control Reset Data FIFO, 143 CNTL RST OFF Control RESET Off, 144 CNTL RST ON Control RESET On, 144 CONFIG1, 32 CONFIG2, 32 CP, 201 Current offset count, 120

DATA IN phase, 198 DATA OUT phase, 198 DC, 198 D.C. characteristics, 11,71 Device controller, 1,5,27 Device flow chart, 196 -DIF\_BSY, 44 DIF\_DIR, 44 DIF\_ENB, 44 Differential mode, 7,74,198 Differential SCSI interface, 44 -DIF\_SEL, 44 DISCONNECT sequence, 198 DMA, 198 -DMA\_ACK, 32 DMA controller, 27,58 -DMA\_REQ, 33 Down transfer counter, 124 Driver code, 104 DRV\_GND[0-5], 33 -DSYNC, 42

EEPROM, 198 Electrical specifications, 11,46 External capacitor, 27

Features FIFO, 2,83,198 count, 119 data buffers, 112 resetting, 143 FIFO\_RDY, 40 Firmware features, 3 Functional chip specifications, 24 Functional pin out, 24 Functionality of the 82C5086 device controller, 27 Functionality of the 82C5086 host adapter, 24 Functionality of the 82C5086, 1,13

#### GND[0-2], 33

Handshake control signals, 58 Hard reset, 196 Hardware features, 2 Hardware specifications, 80 Host adapter, 1,4,24,198 Host adapter mode, 40 Host computer's MPU, 26 -HOST\_D[0-7], 33 -HOST\_D\_P, 33 Host MPU, 198

ID, 198 Identify message, 89,198 Information transfers, 198 Initiator, 73, 199 Initiator commands, list, 154 INIT CMDC SEQ Command Complete/Disconnect Sequence, 171 INIT DATA MTS Receive Data from Memory Data to SCSI Bus, 162 INIT DATA PTS Receive Data from MPU to SCSI Bus, 163 INIT DATA STM Receive Data from SCSI to Memory Data Bus, 164 INIT DATA STP Receive Data from SCSI to MPU Bus, 165 INIT REC INFO Receive Information, 161 INIT SEND CMD Send Command, 167 **INIT SEND MSG** Send Message, 166 INIT SWA CMD Select with Attention Command, 160 **INIT SWA SEQ** Select with Attention Sequence, 157 INIT SWOA CMD

Select without Attention, 159 INIT SWOA SEQ Select without Attention Sequence, 155 INIT WFR CMD Wait for Reselect, 173 INIT WFR SEQ Wait for Reselect Sequence, 174 INIT XFER BYTE Transfer Byte, 170 INIT XFER PAD Transfer Pad, 169 Initiator mode, 6 INP1[0-4], 33 INR\_ENB, 45 Internal timing, 46 INTERRUPT, 34 Interrupt generation, 4,102 Introduction, 1 -I\_O, 34 I/O, 196 I/O interface, 8,81 IO\_-MEM\_-DM, 34,38,39 -IORD\_-DS, 38,39 IORDY, 40 I/O signals, 30 -IOWR\_R-W, 38,39

μΑ, 201 µs, 201 mA, 199 Master mode, 7,199 Master/slave mode, 76 MAX, 199 MCS, 2,83 address pointers, 85 auto advance, 85 MCS auto advance disabling, 151 enabling, 150 MCS script, 199 MEM\_D[0-7], 35 Memory data bus, 3,27,58 Memory structure, 2,10 **FIFO, 83** Message/Command Space (see MCS) MESSAGE IN phase, 199 MESSAGE OUT phase, 199 MESSAGE phase, 199 Method of operation, 81 MHz, 199 Microseconds, 139

**MIN**, 199 Modes of operation,73 MPU, 1,199 -MPU\_ACK, 41 MPU\_AEN, 41 MPU data bus, 3 MPU MCS address pointer, 118 MPU MCS buffer, 119 ms, 199 -MSG, 35 Multiplexed mode, 38,47 Non-differential mode, 7,74,199 Non-multiplexed mode timing, 51 NRZ, 199 ns, 199 Operation, 73 Operational modes, 6 Package specifications, 68-pin, 17 Package specifications, 80-pin, 20 Package specifications, 84-pin, 25 Packaging, 12 Pad drive capacity, 45 Performance specifications, 10 Peripheral device, 200 **PFP**, 200 Physical pin out, 68-pin, 14 Physical pin out, 80-pin, 18 Physical pin out, 84-pin, 21 Physical specifications, 13 Pin list, 68-pin, 16 Pin list, 80-pin, 19 Pin list, 84-pin, 22 Pipeline registers, 3,85,95,142 Pipelining structure, 85 **PLCC**, 200 Power-on flag, 123 Programming flexibility, 4 **RAM, 200** 

RECONNECT sequence, 200 Registers addressing 93 function, 93 name, 93 number 93

**Registers 0-3** 

pipeline registers, 95 Register 4 SCSI configuration, 99 SCSI status, 99 Register 5 interrupt mask, 102 interrupt status, 102 Register 6 extended status, 105 select/reselect timeout, 105 Register 7 buffer status, 109 mode control, 109 Register 8 input port 1, 113 SCSI clock, 113 Register 9 SM MCS address pointer, 115 Register 10 MPU MCS address pointer, 116 Register 11 MPU MCS buffer,117 Register 12 MPU FIFO data, 118 Register 13 FIFO count, 119 Register 14 current sync offset, 120 maximum sync offset, 120 Register 15 revision number, 122 transfer period, 122 Registers 16-18 transfer counters, 124 Register 19 auxiliary control 1, 125 auxiliary status 1, 125 Register 20 auxiliary control 2, 129 auxiliary status 2, 129 Register 21 current SCSI device ID, 132 synchronous/asynchronous ID, 132 Register 22 CMD group 6 & 7 length, 134 SCSI data, 134 Register 23, 136 -RĒQ, 35 RESELECT phase disabling, 149 enabling, 148 **RESELECTION** phase, 200 -RESET\_CAP, 36

RESET condition, 125,200 -RESET\_IN, 36 -RESET\_OUT, 36 Reset signal assert, 144 deassert, 144 Revision number, 123 Role of initiator, 73 Role of target, 74 SC, 200 SCSI, 200 SCSI bus, 3 SCSI control bus, 26 SCSI data bus, 26 SCSI bus ID, 132, 200 SCSI clock, 113 SCSI device, 200 SCSI interface, 1 Selection/reselection timeout, 105 SCSI interface timing, 60 SCSI sequence, 85 -SEL, 36 SELECT phase disabling, 147 enabling, 146 SELECTION phase, 200 Select/reselect timing, 61 Signal assertion, 200 Signal deassertion, 200 Signal descriptions, 29 Slave mode, 7,201 SM. 201 SM MCS address pointer, 85,115 Soft reset, 201 SQ, 201 -SSYNC, 42 Standard test conditions, 70 State machine, 3,115 Status, 201 STATUS phase, 201 Supported features, 12 Synchronous mode, 7 Synchronous offset, 120 Synchronous transfers,13 current sync offset, 120 maximum sync offset, 120 Synchronous transfer timing, 66-69 System interface, 8

TA, 201 Tag message, 89,201 TAR\_ENB, 45 Target, 74,201 Target ID, 89 Target mode, 6,73 Target commands, list, 176 TGT CMDC SEQ Command Complete, 185 TGT DATA MTS, Receive Data from Memory Data to SCSI Bus, 179 TGT DATA PTS, Receive Data from MPU to SCSI Bus, 180 TGT DATA STM, Receive Data from SCSI to MPU Bus, 183 **TGT DATA STP** Receive Data from SCSI to MPU Bus, 184 TGT DISC CMD Disconnect Command, 187 TGT DISC SEQ Disconnect Sequence, 188 TGT RCNT SEQ Reconnect Sequence, 189 TGT REC CMD Receive Command, 181 TGT REC MSG Receive Message, 182 TGT SEND BSY Send Busy Command, 190 TGT SEND MSG Send Message, 177 TGT SEND STAT Send Status, 178 TGT WFS CMD Wait for Select Command, 191 TGT WFS SEQ Wait for Select Sequence, 192 TGT XFER BYTE Transfer Byte, 186 Timing for data transfers, 53 Timing for I/O interface, 58 Transfer counters, 124 Transfer modes,74 asynchronous transfers, 76 synchronous transfers, 76 Transfer period, 122 TYP, 201 Typical applications, 4 Upgrading from a 5080, 13

Up transfer counter, 124

Uses of the 82C5086, 1 V, 201 VCC[0-1], 36 Vdd, 201 Wait state generator, 53 Wide data bus transfers, 42 Wide SCSI bus, 8 -WPAR, 43 -XOR[5-7], 37 Z8 mode, 39 Z8 mode timing, 47

