

# MSD95C00

# Small Computer System Interface (SCSI) Controller-SCSIC

# **FEATURES** ☐ Initiator and Target Operation ☐ 5 MByte/Sec Synchronous and 3 MByte/Sec Asynchronous Data Transfers ☐ Automatic Arbitration and (Re) Selection ☐ Supports both Arbitration and Non-Arbitration/Applications ☐ Internal Twelve Byte Buffer ☐ Internal 24-bit Byte Transfer Counter ☐ Built-in 48 mA High-current SCSI Bus Drivers ☐ User Selectable Selection Timeout ☐ Separate Busses for Data and Microprocessor ☐ Separate DMA for Processor and Data Channels ☐ Burst Mode DMA Transfers on Data Bus ☐ Programmed I/O or DMA Transfers on Processor Data Bus ☐ Eight Bit Bi-Directional General Purpose I/O Port ☐ Bus Architecture allows caching ☐ Compatible with MSD95C02 and MSD95C01 Storage Controllers □ Low Power CMOS



## **SCSI OVERVIEW**

Up to 8 SCSI devices, known as Initiators and Targets, may be connected to a single SCSI bus. These SCSI devices communicate across the SCSI bus using a protocol based on ten distinct bus phases. Target devices execute high level commands which they receive from Initiator devices.

☐ TTL compatible inputs and outputs

A SCSI device may have up to 256 Logical Units associated with it. Host adapters, disk drives and printers are examples of Logical Units. Any SCSI device may be connected to a SCSI port. This allows the user to connect any SCSI compatible device to any SCSI bus providing that the operating system is able to associate the type of device connected with its SCSI ID and Logical Unit Number.

The SCSI bus phases are Bus Free, Arbitration, Selection, Reselection, Command, Data In, Data Out, Message In, Message Out and Status. A target is capable of generating an Arbitration, Reselection, Command, Data In, Data Out, Message In, Message Out or Status phase. An initiator is capable of generating an Arbitration or Selection phase. When the SCSI devices are not generating any of the above phases, the system is said to be in the Bus Free phase. Note that the Arbitration phase may be generated by either a target or an initiator. For a complete description of the SCSI protocol, refer to the ANSI X3.131 specification.

#### **GENERAL DESCRIPTION**

The MSD95C00 SCSI Controller is capable of arbitrating for and supporting data transfer on an ANSI SCSI (Small Computer System Interface) compatible computer bus. The internal twelve byte buffer makes this device suitable for both peripheral and host adapter applications in systems that support both Asynchronous and Synchronous data transfer modes.

The MSD95C00 includes circuitry that automatically arbitrates for the SCSI bus and selects or reselects another device. This feature combined with the size of the internal buffer allows a selected Target device to transfer an entire command from an Initiator with a minimum of processor intervention on either side.

The MSD95C00 has three independent busses: one connects to the local microprocessor (the System bus), a second which connects to the data Ring buffer (the Data

bus) and a third which connects to the SCSI bus. Information transfers may be made between the SCSI bus and either of the other two buses. The Data bus supports burst mode DMA transfers and the System Bus supports both programmed I/O and DMA transfers.

Accesses to the Ring buffer are controlled via a DMA request/acknowledge handshake. Local processor transfers, as well as transfers to logical units (e.g. media transfers), are asynchronous with respect to transfers across the SCSI bus.

The MSD95C00 can be combined with the flexible MSD95C02 or MSD95C01 Storage Controllers, a standard microprocessor, and static RAM to support embedded SCSI peripheral applications with minimum component count and synchronous SCSI speeds of up to 5 megabytes per second.

T-52-33-27

# **TABLE OF CONTENTS**

| FEATURES                     | 1  |
|------------------------------|----|
| PIN CONFIGURATION            | 1  |
| SCSI OVERVIEW                | 1  |
| GENERAL DESCRIPTION          | 1  |
| DESCRIPTION OF PIN FUNCTIONS | 3  |
| SYSTEM DESCRIPTION           | 5  |
| FUNCTIONAL DESCRIPTION       | 5  |
| OPERATION DESCRIPTION        | 10 |
| REGISTER DESCRIPTION         | 11 |
| REGISTER BIT MAP             | 12 |
| TIMING DIAGRAMS              | 22 |

# **DESCRIPTION OF PIN FUNCTIONS**

T-52-33-27

| SCSI INT                               | SCSI INTERFACE NOTE: These Signals are Active Low. |                          |     |                                                                                                                                                                                                                                                                                      |  |  |  |  |
|----------------------------------------|----------------------------------------------------|--------------------------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| PIN NO.                                | NAME                                               | SYMBOL                   | 1/0 | DESCRIPTION                                                                                                                                                                                                                                                                          |  |  |  |  |
| 13,14,16,<br>17, 19, 20,<br>22, 23, 25 | SCSI DATA<br>and PARITY                            | SD <u>0-S</u> D7,<br>SDP | 1/0 | These pins are the eight bi-directional SCSI data signals and the SCSI parity signal to/from the SCSI bus. Except during arbitration, their direction depends on the state of the I/O signal and the mode, Initiator or Target, of the chip. Parity is not valid during arbitration. |  |  |  |  |
| 26                                     | ATTENTION                                          | ATN                      | I/O | This pin is the bi-directional ATTENTION signal to/from the SCSI bus. It is an output when the controller is programmed as an initiator and an input when programmed as a target.                                                                                                    |  |  |  |  |
| 28                                     | BUSY                                               | BSY                      | I/O | This pin is the bi-directional BUSY signal to/from the SCSI bus.                                                                                                                                                                                                                     |  |  |  |  |
| 29                                     | ACKNOWLEDGE                                        | ACK                      | 1/0 | This pin is the bi-directional ACKNOWLEDGE signal to/from the SCSI bus. It is an output when the controller is programmed as an initiator and an input when programmed as a target.                                                                                                  |  |  |  |  |
| 31                                     | SCSI BUS<br>RESET                                  | SRST                     | 1/0 | This pin is the bi-directional RESET signal to/from the SCSI bus. A low on this pin indicates a SCSI bus Reset.                                                                                                                                                                      |  |  |  |  |
| 32                                     | MESSAGE                                            | MSG                      | 1/0 | This pin is the bi-directional MESSAGE signal to/from the SCSI bus. It is an output when the controller is programmed as a target and an input when programmed as an initiator.                                                                                                      |  |  |  |  |
| 34                                     | SELECT                                             | SEL                      | 1/0 | This pin is the bi-directional SELECT signal to/from the SCSI bus.                                                                                                                                                                                                                   |  |  |  |  |
| 35                                     | COMMAND/<br>DATA                                   | C/D                      | 1/0 | This pin is the bi-directional COMMAND/DATA signal to/from the SCSI bus. It is an output when the controller is programmed as a target and an input when programmed as an initiator.                                                                                                 |  |  |  |  |
| 37                                     | REQUEST                                            | REQ                      | 1/0 | This pin is the bi-directional REQUEST signal to/from the SCSI bus. It is an output when the controller is programmed as a target and an input when programmed as an initiator.                                                                                                      |  |  |  |  |
| 38                                     | INPUT/OUTPUT                                       | Ī/O                      | 1/0 | This pin is the bi-directional INPUT/OUTPUT signal to/from the SCSI bus. It is an output when the controller is programmed as a target and an input when programmed as an initiator.                                                                                                 |  |  |  |  |

| RING BUFFER INTERFACE |                           |         |     |                                                                                                                          |  |  |  |
|-----------------------|---------------------------|---------|-----|--------------------------------------------------------------------------------------------------------------------------|--|--|--|
| PIN NO                | NAME                      | SYMBOL  | 1/0 | DESCRIPTION                                                                                                              |  |  |  |
| 1-6<br>67,68          | RING BUFFER<br>DATA BUS   | DB0-DB7 | 1/0 | These pins are the eight bi-directional data signals to/from the Ring Buffer.                                            |  |  |  |
| 7                     | DMA CLOCK                 | DMACLK  | 0   | This output is a buffered clock signal derived from the X1 input.                                                        |  |  |  |
| 64                    | DMA REQUEST               | DREQ    | 0   | This active low output to the external DMA controller is used to request a DMA transfer of data to/from the Ring Buffer. |  |  |  |
| 65                    | DMA<br>ACKNOWLEDGE        | DACK    | 1   | This active low input from the external DMA controller is used to strobe data to/from the Ring Buffer.                   |  |  |  |
| 66                    | SYSTEM DATA<br>BUS PARITY | DBP     | 1/0 | This pin is the parity bit for the Ring Buffer Data Bus.                                                                 |  |  |  |

# STANDARD MICROSYSTEMS 33E D 3564686 0005189 9 328C

# DESCRIPTION OF PIN FUNCTIONS (CONTINUED)

T-52-33-27

| MICROPR | MICROPROCESSOR INTERFACE                                      |                     |     |                                                                                                                                                                                                                                          |  |  |  |
|---------|---------------------------------------------------------------|---------------------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| PIN NO  | NAME                                                          | SYMBOL              | 1/0 | DESCRIPTION                                                                                                                                                                                                                              |  |  |  |
| 41-48   | BI-<br>DIRECTIONAL<br>EXTERNAL<br>DATA BUS                    | XD0-XD7             | 1/0 | These pins are open drain general purpose I/O bus signals and have internal 1K pullup resistors.                                                                                                                                         |  |  |  |
| 50      | PROCESSOR<br>DMA REQUEST                                      | PDREQ               | 0   | This output is active high when byte transfers to/from the Processor is required.                                                                                                                                                        |  |  |  |
| 51      | INTERRUPT                                                     | ĪNT                 | 0   | This output is the interrupt signal to the local processor. This output is active low open drain and has an internal pullup resistor.                                                                                                    |  |  |  |
| 52      | WRITE <u>STROB</u> E<br>(READ/WRITE)                          | W <u>R</u><br>(R/W) | I   | When the SCSIC is configured for ALE, this active low strobe is used to latch write data from the AD7-0 bus into the SCSIC. When the SCSIC is configured for AS, the R/W input is used to qualify DS for a read or write cycle.          |  |  |  |
| 53      | READ STROBE<br>(DATA STROBE)                                  | RD (DS)             | L   | When the SCSIC is configured for ALE, this active low strobe is used to enable read data from the SCSIC onto the AD7-0 bus. When the SCSIC is configured for AS, this active low signal is used to strobe data into or out of the SCSIC. |  |  |  |
| 54      | CHIP ENABLE                                                   | CE                  | ı   | This input, when low, enables the SCSIC's registers for reading and writing.                                                                                                                                                             |  |  |  |
| 55      | ADDRESS LATCH<br><u>ENABLE</u><br>( <u>ADDRESS</u><br>STROBE) | ALE (ĀS)            | ı   | When active, this signal indicates a valid address is on the AD7-0 bus. The local processor must read a SCSIC register to configure the chip for ALE or AS operation.                                                                    |  |  |  |
| 56-63   | LOCAL<br>PROCESSOR<br>ADDRESS/<br>DATA BUS                    | AD0-AD7             | I/O | These eight signals are the multiplexed address/data bus to/from the local processor.                                                                                                                                                    |  |  |  |

| MISCELLA | MISCELLANEOUS     |        |     |                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |
|----------|-------------------|--------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| PIN NO   | NAME              | SYMBOL | 1/0 | DESCRIPTION                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |
| 49       | RESET             | RST    | ı   | This active low input causes the MSD95C00 to reset to an initial state. This signal must be held low for at least 1 ms. All SCSI signals are deasserted. DREQ is inactive high. PDREQ is inactive low. INT is inactive high. AD7-0 are inputs. DB7-0 are inputs. Refer to individual register descriptions for the reset state of each register. |  |  |  |  |
| 11       | CRYSTAL<br>INPUT  | X1     | 1   | A 20 MHz. (max) crystal is connected to this input. A TTL clock may be used as an input to this pin.                                                                                                                                                                                                                                             |  |  |  |  |
| 10       | CRYSTAL<br>OUTPUT | X2     | 0   | A 20 MHz. (max) crystal is connected to this output. If a TTL is clock is connected to X1, this input must be left floating.                                                                                                                                                                                                                     |  |  |  |  |

| POWER and GROUND                            |        |        |     |                       |  |  |  |
|---------------------------------------------|--------|--------|-----|-----------------------|--|--|--|
| PIN NO                                      | NAME   | SYMBOL | I/O | DESCRIPTION           |  |  |  |
| 8,12,15,<br>18,21,24,<br>27,30,33,<br>36,39 | GROUND | GND    | Р   | Ground connections.   |  |  |  |
| 9,40                                        | POWER  | Vcc    | Р   | +5V Power connection. |  |  |  |

pair in an effort to complete the command.

#### 33E D

# Initiator to inform the Target being selected that it wishes to send a message to the target.

T-52-33-27

## SYSTEM DESCRIPTION

The block diagram in Figure 1 illustrates a typical implementation of the MSD95C00 used in a hard drive application. The MSD95C00 provides simple interfacing to the SCSI bus, microprocessor and controller logic.

#### **SCSI** Interface

The eighteen SCSI signals may be connected directly to a single ended (open collector) SCSI bus. The MSD95C00 drivers and receivers are fully capable of driving and receiving SCSI bus signals as defined by the ANSI X3.131 specification.

### **Microprocessor Interface**

The microprocessor interface consists of an 8-bit data bus and control bus. With the exception of optional address decoding logic for the CE input, all signals are tied directly to the microprocessor eliminating the need for external circuitry.

#### **Controller Interface**

The controller interface consists of and 8-bit bi-directional data bus, a clock and a pair of request/acknowledge handshake signals. These signals may be connected directly to memory and controller logic such as the SMC MSD95C02 or MSD95C01 storage controllers.

# **FUNCTIONAL DESCRIPTION**

#### **Arbitration Phase**

Arbitration is a system option which allows a SCSI device to gain control of the SCSI bus. Arbitration is required in systems which contain more than one initiator or in systems which support Reselection. While generating an Arbitration phase the MSD95C00 will assert the SCSI Busy signal and it's own ID bit.

Since the Arbitration Phase is a system option, its generation is enabled or disabled via software. Arbitration is enabled in the MSD95C00 by writing a logic 1 to bit 1 of the Mode register during initialization. Arbitration phase timing an Bus Free detection is handled completely by the MSD95C00. If enabled, this phase will be generated prior to a Selection or Reselection phase, with no additional microprocessor intervention, after a Select command (writing a logic 1 to bit 6 of the Command register) has been issued to the MSD95C00. The Arbitrating device with the highest ID typically wins arbitration with Bit 7 having the highest priority and bit 0 having the lowest. Parity is not valid during the Arbitration Phase.

### **Selection Phase**

The Selection phase is generated by an Initiator. The MSD95C00 will assert the SCSI I/O and Select signals during the Selection phase. During the Selection phase the MSD95C00 also asserts it's own SCSI ID bit as well as the SCSI ID bit of the target it wishes to select. Selection phase timing, including Selection Timeout, is handled completely by the MSD95C00. This phase will be generated after a Select command (writing a logic 1 to bit 6 of the Command register) has been issued to the MSD95C00 if bit 0 of the Mode register is set to a logic "1" (Initiator Mode). If bit 0 of the Control register has been set to a logic 1 the SCSI Attention signal will be asserted during the Selection phase. This is part of the SCSI protocol which allows an

#### **Reselection Phase**

Reselection is a system option. The Reselection phase is generated by a Target. The MSD95C00 will assert the SCSI Select signal during the Reselection phase. During the Reselection phase, the MSD95C00 also asserts it's own SCSI ID bit as well as the SCSI ID bit of the initiator it wishes to reselect. Reselection phase timing, including Reselection Timeout, is handled completely by the MSD95C00. This phase will be generated after a Select command (writing a logic 1 to bit 6 of the Command register) has been issued to the MSD95C00 if bit 0 of the Mode register is reset to a logic '0' (Target Mode). This phase should only be used if an Initiator had previously selected a Target and the Target then performed a Disconnect. The Reselection would again establish a connection between the original Initiator Target

#### **Command Phase**

The Command phase is generated by a Target. The local microprocessor must write a logic 1 to bit 2 of the Command 2 register. The phase is initiated and data transfer begins when the local microprocessor writes the Byte Counter Low register. The phase is terminated by initiating a new phase or performing a Disconnect command. The Command phase allows a Target to request a Command Descriptor Block (CDB) from the Initiator. Command discriptor blocks are six, ten or twelve bytes in length. The first byte of the command discriptor block indicates the number of bytes which comprise the command discriptor block. After the first byte is passed from the Initiator to the Target the local microprocessor must read the byte from the Target's FIFO, calculate the number of remaining bytes and set up the Target to transfer the remaining bytes. The remaining bytes of the command discriptor block are then transferred to the Target's FIFO. The target microprocessor is informed, via interrupt or polling, of the completion of this transfer. This block is then transferred, via DMA or programmed I/O, from the FIFO to the target microprocessor's memory. The target microprocessor must then digest and execute the command.

#### **Data-In Phase**

The Data-In phase is generated by a Target. The Target microprocessor writes a logic 1 into bit 1 of the Command 2 register. The phase is initiated and data transfer begins when the Target microprocessor writes to the Byte Counter Low register. The phase is terminated by initiating a new phase or executing a Disconnect command. The Data-In phase allows data to be transferred from a Target to an Initiator. Data-In and Data-Out transfers may be asynchronous or synchronous. All other transfers, such as message, status and command, are defined by the SCSI protocol as being asynchronous. A typical data-in transfer would transfer data from the Target Ring buffer, through the Target SCSIC's FIFO, across the SCSI bus, into the Initiator SCŠI's FIFO and into the Initiators local memory. The Target microprocessor would set up the Target to perform the transfer, initiate the transfer by writing to the Byte Counter Low register and then wait for an interrupt indicating the transfer has been completed. The three bus architecture of the MSD95C00 allows the Initiator and Target microprocessors to perform their housekeeping duties while the data transfer is taking place.



FIGURE 2 - MSD95C00 BLOCK DIAGRAM

#### **Data-Out Phase**

The Data-Out phase is generated by a Target. The Target microprocessor writes a logic 0 into each bit of the Command 2 register. The phase is initiated and transfer begins when the Target microprocessor writes to the Byte Counter Low register. The phase is terminated by initiating a new phase or executing a Disconnect command. The Data-Out phase allows data to be transferred from an Initiator to a Target. Data-In and Data-Out transfers may be asynchronous or synchronous. All other transfers, such as message, status and command, are defined by the SCSI protocol as being asynchronous. A typical data-out transfer would transfer data from Initiator memory to the Initiator SCSIC's FIFO, over the SCSI bus, through the Target SCSIC's FIFO then to the Target Ring buffer. The Target microprocessor would set up the Target to perform the transfer, initiate the transfer by writing to the Byte Counter Low register and then wait for an interrupt indicating the transfer has been completed. The three bus architecture of the MSD95C00 allows the Initiator and Target microprocessors to perform their housekeeping duties while the data transfer is taking place.

# Message-In Phase

The Message-In phase is generated by a Target. The Target microprocessor writes a logic 1 into bit 7 of the Command 2 register. The phase is initiated and transfer begins when the Target microprocessor writes to the Byte Counter Low register. The phase is terminated by initiating a new phase or executing a Disconnect command. Messages are typically one byte in length. The local microprocessor would write the message byte(s) into the Target FIFO and set the Target up for the proper number of bytes to be transferred. Writing to the Byte Counter Low register generates the phase and initiates the transfer.

#### Message-Out Phase

The Message-Out phase is generated by a Target. The Target microprocessor writes a logic 1 into bit 6 of the Command 2 register. The phase is initiated and transfer begins when the Target microprocessor writes to the Byte Counter Low register. The phase is terminated by initiating a new phase or executing a Disconnect command. Messages are typically one byte in length. The Initiator microprocessor would write the message byte(s) into the Initiator FIFO. The target microprocessor would set up the Target for a one byte transfer. Writing to the Byte Counter Low register initiates the transfer. If the target microprocessor detects an extended message is to be transferred it must load the Byte Counter to allow the target to transfer the remainder of the message bytes.

# **Status Phase**

The Status phase is generated by a Target. The Target microprocessor writes a logic 1 into bit 3 of the Command 2 register. The phase is initiated and transfer begins when the Target microprocessor writes to the least significant byte of the Byte counter. The phase is terminated by initiating a new phase or executing a Disconnect command. Status transfers are one byte in length. The Target microprocessor would write the status byte into the Target FIFO and set the Target up for a one byte transfer.

# **Bus Free Phase**

The Bus Free phase occurs when no SCSI devices are driving the SCSI bus and the SCSI SEL and BUSY signals have been false for a specified period of time.

### **Being Selected or Reselected**

T-52-33-27

Typically Targets may be selected and Initiators may be reselected. A device responds to selection or reselection during a selection or reselection phase if it recognizes it's SCSI ID bit on the bus and there are not more than two ID bits on the bus. Parity, if enabled, must not be in error. The MSD95C00 has two bits, bits 1 and 2 of the Control register, which enable or disable it from responding to an attempted selection or attempted reselection regardless of whether the MSD95C00 is programmed to be an initiator or target. If a selection or reselection is attempted, maskable interrupts may be generated and the appropriate status bits are set.

#### Interrupts

There are fifteen interrupt causing conditions generated by the MSD95C00, all of which are maskable. These interrupt causing conditions generate status bits in the Status 2, 3 and 4 registers. Reading the Status 2, 3 or 4 registers will reset the interrupt causing condition in that register. Some of these status bits are ORed together and are readable through the Status 1 register. The remaining status bits are directly readable through the Status 1 register. Reading the Status 1 register allows the software to decide which of Status 2, 3 or 4 registers to read. Reading the Status 1 register does not reset the interrupt causing condition. Please refer to Figure 3.

#### **Transfer Modes**

Data (any information being passed through the system is referred to as data) may be transferred between the SCSI bus and microprocessor memory. Data may also be transferred between the SCSI bus and the Ring buffer memory. All data transfers to and from the SCSI bus pass through the MSD95C00's FIFO. Data cannot be transferred between the microprocessor and the Ring Buffer through the MSD95C00.

# Interrupt Driven I/O

The processor responds to an interrupt by reading the Interrupt Status register. If the SCSIC status bit is active high, the Processor reads the Status 1 register to determine the source of the interrupt.

If the Transfer Requested status bit is active high, the Processor should read the Status 3 register to determine whether it was set by Byte Available or Byte Requested. In response the SCSIC resets the Transfer Requested status

If the Byte Available status bit is set, the processor should read the SCSI Data Out register. The SCSIC clears the Byte Available status bit if, and only if, there is no more data in the FIFO. If the Byte Available status bit is still set, the SCSIC generates a new transfer Request interrupt.

If the Byte Requested status bit is set, the processor should write a byte of data to the SCSIC Data Out register. The SCSIC then clears the Byte Requested status bit if the Byte Counter equals zero or if the FIFO is full. If the Byte Requested status bit remains set after the processor writes the byte of data, the SCSIC generates another Transfer Request interrupt.

#### **DMA Driven I/O**

A DMA controller may be used to transfer a Command Descriptor Block, a message or status byte between the MSD95C00's FIFO and processor memory. Transfers are performed when the PDREQ is a function of the Byte



Requested status bit when writing to the FIFO and is a function of the Byte Available bit when reading the FIFO.

#### Polled I/O

The processor reads the Status 3 register to see if either the Byte Available or Byte Requested status bits are high.

If Byte Available is high, the Processor transfers the byte from the SCSIC Data In register to the Processor or the Processor RAM. If there is no more data in the buffer, the SCSIC clears the Byte Available status bit.

If the Byte Requested is high, the processor transfers the byte from the processor or the processor RAM to the SCSIC Data Out register. If no SCSI REQs are pending or the Buffer is full, the Byte Requested status bit is cleared.

## **SCSI Parity Error Handling**

Initiator (Status, Message In, Data In Phases):

If the Halt On Parity Error bit in the Control Register is set to 1 the SCSIC will halt and set the Halted and PE status bits if data has even parity. If these bits are set, the SCSIC will generate a PE interrupt. If enabled, a Condition Change interrupt will also be generated. In response to the interrupt, the processor reads the Status registers and resets the Parity Error and Condition Change Interrupts.

The processor asserts ATN to request Message Out Phase in order to signal its desire to send either a Message Reject or Message Parity Error. The processor then issues a (Re) Start Command.

Target (Command, Message Out, Data Out Phases):

The SCSIC will set the PE status bit if data has even parity. If the PE bit is set, the SCSIC will generate a PE interrupt. In response to the interrupt, the processor reads the Status registers. Finally, the SCSIC resets the Parity Error Interrupts.

Note: The Halt On Parity Error bit in the Control Register does not affect Target operation.

### **OPERATION DESCRIPTION**

#### **SCSI Read Sequence of Events**

The following is an example of a SCSI Initiator reading from a SCSI Target.

A Host system with SCSIID of 80h wishes to read data from a peripheral containing a hard disk drive with SCSIID of 04h. The initiator and target SCSIID's are encoded using three of the 8 bits available at the general purpose I/O port. Assume the system supports arbitration and parity checking. The Host's MSD95C00 has been initialized as per Table 1.

The host  $\mu P$  assembles the six byte Command Descriptor Block in local memory.

Upon detecting the "Halted" interrupt, the host microprocessor must determine the current bus phase. If the Command phase is detected, the host microprocessor must load the Byte counter with the proper number of bytes. The CDB is transferred to the FIFO one byte for each received SREQ.

The host  $\mu P$  then issues a Select command to its MSD95C00. This is accomplished by writing a "1" to bit 6 of the Command 1 register.

The initiator MSD95C00 will wait for a Bus Free Phase. Upon detection the Bus Free phase the initiator MSD95C00 will arbitrate for the bus. If unsuccessful the initiator MSD95C00 will again wait for the Bus Free phase. When successful, the initiator MSD95C00 will generate the Selection phase. If the target MSD95C00 responds to the selection prior to the initiator's selection timeout period the initiator MSD95C00 will set the Successful Selection Complete bit in Status 2 register and generate an interrupt. If the target MSD95C00 does not respond to the selection within the initiator's selection timeout period the initiator MSD95C00 will set the Unsuccessful Selection Complete bit in the Status 2 register and generate an interrupt. Arbitration and Selection phase timing are handled fully by the MSD95C00. The host microprocessor need only initiate the Select command and wait for an interrupt (or poll the Status 1 register for the (re)selection complete bit). Assuming the target MSD95C00 has responded to the selection the CDB would have to be transferred to the target. The target MSD95C00 has been initialized as per Table 2.

The target MSD95C00 will detect when it has been selected. It will respond by asserting the SCSI Busy signal, internally latching the Source ID (the selecting initiator's ID with the target's ID masked off) and generating a Valid Selection (Status 2 register bit 0) interrupt. The target  $\mu P$  would typically read the Interrupt Status register and decide if the target MSD95C00 is the interrupt causing device. If so it would then read the Status 1 register. Reading the Status 1 register allows the  $\mu P$  to decide which of the remaining status registers holds the interrupt causing status bit. In this

| TABLE 1  |      |                                                                                                             |  |  |  |
|----------|------|-------------------------------------------------------------------------------------------------------------|--|--|--|
| Register | Data | Comments                                                                                                    |  |  |  |
| 00h      | 00h  | Asynchronous transfer mode.                                                                                 |  |  |  |
| 01h      | 7Fh  | Initiator, arbitration enable, parity check enable, DREQ multiple, PDREQ level, selection timeout = 1.6 ms. |  |  |  |
| 06h      | 13h  | Enable the following interrupts: Selection Attempted, (Re) Selection Complete, SCSI parity error.           |  |  |  |
| 07h      | 82h  | Enable the following interrupts: Valid Reselection, SCSI Master Interrupt.                                  |  |  |  |
| 08h      | C4h  | Enable reselection, enable PDREQ, enable DREQ.                                                              |  |  |  |
| 0Eh      | 80h  | Initiator ID.                                                                                               |  |  |  |

| Register | Data | TABLE 2 T-52-33-27 Comments                                                                                         |  |  |  |
|----------|------|---------------------------------------------------------------------------------------------------------------------|--|--|--|
| 00h      | 00h  | Asynchronous Transfer mode.                                                                                         |  |  |  |
| 01h      | 66h  | Target, Enable Arbitration, Enable Parity, DREQ Single Pulse, PDREQ Pulsed, Selection Timeout = 1.6 ms.             |  |  |  |
| 06h      | 1Bh  | Enable the following interrupts: Selection Attempted, (Re)Selection Complete, Transfer Complete, SCSI Parity Error. |  |  |  |
| 07h      | 99h  | Enable the following interrupts: Valid Selection, SCSI Transfer Complete, Transfer Done, SCSI Master Interrupt.     |  |  |  |
| 08h      | C2h  | Enable Selection, Enable REQ, Enable DREQ.                                                                          |  |  |  |
| 0Eh      | 04h  | Target ID.                                                                                                          |  |  |  |

case the Status 2 register should be read. The target  $\mu P$  would determine the interrupt causing condition(s) (in this case the Valid Selection bit, Bit 0, would be set). The target  $\mu P$  should also examine the SCSI Attention signal, bit 7 of the Status 2 register, at this time. This will allow the target to determine if the initiator is requesting a Message-Out phase. A Message-Out phase would be necessary if the initiator wished to perform synchronous data transfers for the first time.

If the SCSI Attention Signal is not asserted the target would typically respond with a Command phase. To accomplish this, the target uP would write a 04h into the Command 2 register and an FEh into the Byte Counter Low register. Upon writing the Byte Counter Low register the target MSD95C00 will generate the Command phase and a SCSI REQ signal. The initiator MSD95C00 will respond by supplying the first byte of the CDB and the SCSI ACK signal. The handshaking is automatically handled by the initiator and target MSD95C00 pair.

The target uP would receive an interrupt (or poll the Transfer Complete bit in the Status 1 register) caused by the SCSI Transfer Complete bit in the Status 3 register. It would respond by reading the Data-In register of the MSD95C00.

The target  $\mu P$  would then examine this first byte. The three MSB's indicate the group code and therefore the number of bytes in the CDB. For the Read command a group code "000" is expected, indicating a six byte CDB including the first byte. The target  $\mu P$  would then write an FFh, FFh, FAh to the Byte Counter register. This would initiate a transfer for the remaining five CDB bytes. The SCSI Transfer Complete bit in the Status 3 register would cause a second interrupt informing the  $\mu P$  that the remainder of the CDB is in the target MSD95C00's FIFO.

The target  $\mu P$  could either transfer five bytes from the MSD95C00's FIFO into it's own memory or use a handshake method, by interrogating the Byte Available bit in the Status 3 register, to transfer the remainder of the CDB.

Once the CDB has been transferred to the target  $\mu$ P's memory the  $\mu$ P must digest and execute the Read command.

The target  $\mu P$  then sets-up the hard disk controller, such as the SMC MSD95C01/02, and the target MSD95C00 for the transfer. The target  $\mu P$  initiates a Data-In Phase by writing an 02h to the Command 2 register, and writing the proper byte count, in 1's complement form, into the Byte Counter registers. Upon writing the Byte Counter Low register the target MSD95C00 will generate a Data-In phase and perform the transfer by handshaking with both the initiator

MSD95C00 and the MSD95C01/02. The target  $\mu P$  is free to perform any other tasks during the read operation and will be interrupted by the Transfer Done bit, bit 4 of the Status 3 register, at the completion of the transfer.

The initiator's  $\mu P$  would need to examine and respond to the SCSI bus phases. When the Data-In phase is detected, the initiator  $\mu P$  would load the Byte counter with the 1's complement of the number of bytes to be transferred and set up it's DMA controller, if one existed. Upon completion of the transfer the initiator  $\mu P$  would receive a Transfer Done interrupt (Bit 4 of the Status 3 register).

Using a similar algorithm, Status and Message Phase transfers would take place. The target would then disconnect from the SCSI bus allowing a new operation to take place.

#### REGISTER DESCRIPTION

**Reset Register** 

8-Bits Read Only (ADDRESS 00H)

An initial dummy read configures the chip for ALE or AS type timing. Reading the Reset register address places the MSD95C00 into the same state as driving the RST input low and simultaneously reads the general purpose I/O port. A write to any other MSD95C00 register will terminate the reset state as well as write to the addressed register. Both the hardware and software resets will perform the same function as the Clear command in addition to resetting certain register bits as detailed below.

**Negotiation Register** 

8-Bit Write Only (ADDRESS 00H)

The 4 MSB's, bits 7 - 4, of this eight bit write only register are used to program the Transfer Period for synchronous data transfers. The transfer period will be (2 + N)T where T is twice the clock period. For a 20 MHz crystal with the Negotiation register programmed for 0xh the transfer frequency is (2 + 0) 100ns = 200ns = 5MHz.

The 4 LSB's are used to program the SCSI REQ/ACK offset and are reset to zero by a hard or soft System Reset. Programming the 4 LSB's to zero configures the SCSIC for Asynchronous operation. Programming the 4 LSB's for 1 thru 12 configures the SCSIC for Synchronous operation with a REQ/ACK offset value equal to the value programmed. The maximum offset value the MSD95C00 will support is 12. This register should be programmed with a REQ/ACK Offset value regardless of whether the chip is operating in Initiator or Target mode.

# MSD95C00 REGISTER BIT MAPS

T-52-33-27

| -                                | ON REGISTER               |                            |                           | (WRITE REGISTER—ADDRESS 00H          |                                       |                                   |                                   |
|----------------------------------|---------------------------|----------------------------|---------------------------|--------------------------------------|---------------------------------------|-----------------------------------|-----------------------------------|
| TR                               | ANSFE                     | R PER                      | IOD                       | REQ/ACK OFFSET                       |                                       |                                   |                                   |
| MODE REGI                        | ·                         |                            |                           |                                      |                                       | GISTER-A                          | DORESS 01H                        |
| RESERVEC                         |                           | N TIMEOUT<br>bit 0         | PDREQ<br>LEVEL/<br>PULSED | DREQ<br>MULTIPLE/<br>SINGLE<br>PULSE | PARITY<br>CHECK<br>ENABLE/<br>DISABLE | ARBITRATE<br>ENABLE/<br>DISABLE   | INITIATOR/<br>TARGET              |
| BYTE COU                         | NTER HIGH                 |                            |                           |                                      | <del></del>                           |                                   | DRESS 02H)                        |
|                                  | MOS                       | T SIGN                     | IIFICAN<br>GISTE          | NT BYT<br>R (1's c                   | E OF E                                | BYTE<br>nent)                     |                                   |
|                                  | TER MIDDLE                | NAME OF TAXABLE PARTY.     |                           |                                      |                                       |                                   | DDRESS 03H)                       |
| M                                | IDDLE                     | BYTE (                     |                           | rE COU<br>plimen                     |                                       | EGISTE                            | ER<br>                            |
| BYTE COUN                        | TER LOW RE                | GISTER                     |                           |                                      | (WRITE RE                             | GISTERAI                          | DDRESS 04H)                       |
|                                  |                           | ST SIGN<br>JNT RE          |                           |                                      |                                       |                                   |                                   |
| VO REGISTE                       | R                         |                            |                           |                                      | (WRITE RE                             | GISTER—AI                         | ODRESS 05H)                       |
|                                  | LATC                      | HED D                      | ATA TO                    | XD7 T                                | O XD0                                 | PINS                              |                                   |
| NTERRUPT                         | ENABLE 1 RE               | EGISTER                    |                           | <del></del>                          | (WRITE RE                             | GISTER—AL                         | DDRESS 06H)                       |
| CONDI-<br>TION<br>CHANGE         | ATN or<br>RESET<br>CHANGE | SYSTEM<br>PARITY<br>ERROR  | SCSI<br>PARITY<br>ERROR   | TRANSFER<br>COMPLETE                 | TRANSFER<br>REQUEST                   | (RE)-<br>SELECT<br>COMPLETE       | SELEC-<br>TION<br>ATTEMPT-<br>ED  |
|                                  | ENABLE 2 RE               | EGISTER                    | r                         |                                      | (WRITE RE                             | GISTER-AL                         | DDRESS 07H)                       |
| SCSI<br>MASTER<br>INTER-<br>RUPT | BUS FREE<br>DETECT        | HALT<br>INTERRUPT          | TRANSFER<br>DONE          | SCSI<br>TRANSFER<br>COMPLETE         | INVALID<br>(RE)-<br>SELECT            | VALID<br>RESELECT                 | VALID<br>SELECT                   |
| CONTROL R                        | EGISTER                   |                            |                           |                                      | (WRITE RE                             | GISTER—AL                         | DDRESS 08H)                       |
| ENABLE<br>DREQ                   | ENABLE<br>PDREQ           | HALT ON<br>PARITY<br>ERROR | ALWAYS 0                  | ALWAYS 0                             | ENABLE<br>RESELECT                    | ENABLE<br>SELECT                  | AUTO<br>ATTEN-<br>TION<br>ASSERT  |
| COMMAND                          | REGISTER                  |                            |                           |                                      | (WRITE RE                             | GISTER—A                          | DDRESS 09H)                       |
| DISCON-<br>NECT                  | SELECT                    | (RE)-<br>START             | CLEAR                     | NEGATE<br>ATTEN-<br>TION             | ASSERT<br>ATTEN-<br>TION              | NEGATE<br>SCSI<br>RESET<br>SIGNAL | ASSERT<br>SCSI<br>RESET<br>SIGNAL |
| COMMAND                          | REGISTER                  |                            |                           |                                      | (WRITE RE                             | GISTER-A                          | DRESS OAH)                        |
| SET<br>MESSAGE<br>IN             | SET<br>MESSAGE<br>OUT     | RESERVED                   | RESERVED                  | SET<br>STATUS<br>PHASE               | SET<br>COMMAND<br>PHASE               | SET<br>DATA IN                    | RESERVED                          |
| RESERVED                         |                           |                            |                           |                                      | (WRITE RE                             | GISTER—AL                         | DRESS (18H)                       |
| (MSB)                            |                           |                            | RESE                      | RVED                                 |                                       |                                   | (LSB)                             |
| RESERVED                         |                           | ·                          |                           |                                      | (WRITE RE                             | GISTER—AD                         | DRESS OCH)                        |
| (MSB)                            |                           |                            | RESE                      | RVED                                 |                                       |                                   | (LSB)                             |
| DESTINATIO                       | N ID REGIST               | ~                          |                           |                                      |                                       | GISTER—AD                         | DRESS (DH)                        |
| (MSB)                            |                           |                            | DESTIN                    | AOITA                                | IID                                   |                                   | (LSB)                             |
| SCSI ID REG                      | ISTER                     |                            |                           |                                      | (WRITE RE                             | GISTER-AD                         | ORESS (EH)                        |
| (MSB)                            |                           | SC                         | SI ID (I                  | NODE                                 | ID)                                   |                                   | (LSB)                             |
| DATA OUT R                       | EGISTER                   |                            |                           |                                      | (WRITE RE                             | GISTER-AC                         | ORESS OFH)                        |

(MSB) DATA TO BE OUTPUT TO THE SCSI BUS (LSB)

| RESET REC                                                                                                 | ISTER                                         |                             |                                     |                                        | (READ RE                              | EGISTER—AI                             | DDRESS 00                        |
|-----------------------------------------------------------------------------------------------------------|-----------------------------------------------|-----------------------------|-------------------------------------|----------------------------------------|---------------------------------------|----------------------------------------|----------------------------------|
|                                                                                                           | XD7-XD0 (IN)                                  |                             |                                     |                                        |                                       |                                        |                                  |
| MODE REG                                                                                                  | ISTER                                         |                             |                                     |                                        | (READ RE                              | GISTER—A                               | DDRESS 0                         |
| RESERVE                                                                                                   |                                               | N TIMEOUT                   | PDREQ<br>LEVEL/<br>PULSED           | DREQ<br>MULTIPLE/<br>SINGLE<br>PULSE   | PARITY<br>CHECK<br>ENABLE/<br>DISABLE | ARBITRA-<br>TION<br>ENABLE/<br>DISABLE | INITIATOI<br>TARGET              |
| BYTE COU                                                                                                  | NTER HIGH                                     | REGISTER                    |                                     |                                        | (READ RE                              | GISTER-AD                              | DRESS 02                         |
| (MSB)                                                                                                     |                                               | MOST                        | SIGNI                               | FICAN                                  | ГВҮТЕ                                 |                                        | (LS                              |
| BYTE COUN                                                                                                 | ITER MIDDLE                                   | REGISTER                    |                                     |                                        | (READ RE                              | GISTER—A                               | DDRESS 0                         |
| (MSB)                                                                                                     | Ŋ                                             | MIDDLE                      | SIGN                                | IFICAN                                 | T BYT                                 | E                                      | (LS                              |
| BYTE COUN                                                                                                 | ITER LOW RE                                   | GISTER                      |                                     |                                        | (READ RE                              | GISTERA                                | ODRESS 0                         |
| (MSB)                                                                                                     |                                               | LEAST                       | SIGNI                               | FICAN                                  | ГВҮТЕ                                 |                                        | (LS                              |
| VO REGISTI                                                                                                | ER                                            |                             |                                     |                                        | (READ RE                              | GISTER—AL                              | DRESS 0                          |
| (MSB)                                                                                                     | LATCHI                                        | ED DAT                      | A FRO                               | M XD7                                  | -XD0 P                                | INS (IN                                | <b>1)</b> (LS                    |
| INTERRUPT                                                                                                 | ENABLE 1 RE                                   | GISTER                      |                                     |                                        | (READ RE                              | GISTER—AI                              | . —                              |
| CONDI-<br>TION<br>CHANGE                                                                                  | ATN or<br>RESET<br>CHANGE                     | SYSTEM<br>PARITY<br>ERROR   | PARITY<br>ERROR                     | TRANSFER<br>DONE                       | TRANSFER<br>REQUEST                   | (RE)-<br>SELECT<br>COMPLETE            | SELEC-<br>TION<br>ATTEMP<br>ED   |
| INTERRUPT                                                                                                 | ENABLE 2 RE                                   | GISTER                      |                                     |                                        | (READ RE                              | GISTER—A                               | DRESS 0                          |
| MASTER<br>INTER-<br>RUPT                                                                                  | BUS FREE<br>DETECT                            | HALT<br>INTERRUPT<br>ENABLE | TRANSFER<br>DONE                    | SCSI<br>TRANSFER<br>COMPLETE           | INVALID<br>(RE)-<br>SELECT            | VALID<br>RESELECT                      | VALID<br>SELEC-<br>TION          |
| CONTROL F                                                                                                 | REGISTER                                      |                             | •                                   |                                        | (READ RE                              | GISTER—AL                              | DRESS 0                          |
| ENABLE<br>DREQ                                                                                            | ENABLE<br>PDREQ                               | HALT ON<br>PARITY<br>ERROR  | ALWAYS 0                            | ALWAYS 0                               | ENABLE<br>RESELECT                    | ENABLE<br>SELECT                       | AUTO<br>ATTEN-<br>TION<br>ASSERT |
| NTERRUPT                                                                                                  | STATUS REG                                    | ISTER                       | •                                   |                                        | (READ RE                              | GISTER—AL                              | ODRESS 0                         |
|                                                                                                           | RE                                            | SERV                        | ED                                  |                                        | SCSI<br>INTER-<br>RUPT                | RESE                                   | RVE                              |
| STATUS 1 R                                                                                                | EGISTER                                       |                             |                                     |                                        | (READ RE                              | GISTERAD                               | DRESS 0                          |
| CONDI-<br>TION<br>CHANGE                                                                                  | ATTN or<br>RESET<br>CHANGE                    | SYSTEM<br>PARITY<br>ERROR   | SCSI<br>PARITY<br>ERROR             | TRANSFER<br>COMPLETE                   | TRANSFER<br>REQUEST                   | (RE)-<br>SELECT<br>COMPLETE            | SELEC-<br>TION AT-<br>TEMPTE     |
| STATUS 2 R                                                                                                | EGISTER<br>T                                  | <del></del>                 | UNSUC-                              | suc-                                   | (READ RE                              | GISTER—AD                              | DRESS OF                         |
| SCSI<br>ATTN<br>SIGNAL                                                                                    | RESERVED                                      | RESERVED                    | CESS<br>(RE)-<br>SELECT<br>COMPLETE | CESSFUL<br>(RE)-<br>SELECT<br>COMPLETE | INVALID<br>(RE)-<br>SELECT            | VALID<br>RESELECT                      | VALID<br>SELEC-<br>TION          |
| STATUS 3 RI                                                                                               | EGISTER                                       |                             |                                     |                                        | (READ RE                              | GISTER-AD                              | DRESS OC                         |
| SCSI<br>ATTN<br>SIGNAL                                                                                    | SCSI<br>RESET                                 | SYSTEM<br>PARITY<br>ERROR   | TRANSFER<br>DONE                    | SCSI<br>TRANSFER<br>COMPLETE           |                                       | BYTE<br>AVAILABLE                      | BYTE RE<br>QUESTE                |
| STATUS 4 R                                                                                                | EGISTER                                       |                             |                                     | ı · <del></del>                        |                                       | GISTER-AD                              |                                  |
| RESERVED BUS FREE DETECTED HALTED ARBITRATION RESERVED RESERVED PHASE PHASE C/D ENCODED ENCODED PHASE L/O |                                               |                             |                                     |                                        |                                       |                                        |                                  |
| SCSI BUS ID                                                                                               | CSI BUS ID REGISTER (READ REGISTER—ADDRESS 0E |                             |                                     |                                        |                                       |                                        |                                  |
| (MSB)                                                                                                     |                                               | SI BUS                      | ID (NC                              | DE SC                                  | URCE                                  | ID)                                    | (LS                              |
| DATA IN REC                                                                                               | SISTER                                        | ··· ··                      |                                     |                                        | (READ RE                              | GISTER-AD                              | DRESS OF                         |
| (MSB)                                                                                                     |                                               | DAT                         | A FRO                               | M BUF                                  | FER                                   | •                                      | (LS                              |
|                                                                                                           |                                               |                             |                                     |                                        |                                       |                                        |                                  |

**Mode Register** 

8-Bits Read/Write (ADDRESS 01H)

T-52-33-27

This 8 bit Read/Write register defines the operating mode a hard or soft System Reset. Refer to Table 3 for the of the SCSIC. The bits in this register are reset to zero by description of the Mode Register bits.

# **TABLE 3 - Mode Register**

|         |                                                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | IADLE                                                                                                                                                                            | - WOUE TO        | -gistoi                         |                                                                                              |  |  |
|---------|-------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|---------------------------------|----------------------------------------------------------------------------------------------|--|--|
| BIT NO. | BIT NAME                                                    | DESCRIPTION                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                  |                  |                                 |                                                                                              |  |  |
| 0       | I <u>nitiato</u> r/<br>Target                               | Writing a "1" to this bit will place the chip into an initiator mode. Writing a "0" to this bit places the chip into a target mode. The state of this bit will not prevent the chip from being selected or reselected by another device. The state of this bit determines whether the select command will start either the select function or the reselect function.                                                                                                                                                                                                     |                                                                                                                                                                                  |                  |                                 |                                                                                              |  |  |
| 1       | Arbitration<br>Enable/<br>Disable                           | Arbitration phase                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | will occur fo                                                                                                                                                                    | ollowing a B     | us Free Phase                   | to this bit disables Arbitration. An if the <u>Select Command</u> has been able/Disable = 1. |  |  |
| 2       | Parity<br>Check<br>Enable                                   | Writing a "1" to the except Bus Free checked.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Writing a "1" to this bit enables the MSD95C00 parity checking for all SCSI bus phases except Bus Free and Arbitration. When this bit is "0", Parity on the SCSI bus will not be |                  |                                 |                                                                                              |  |  |
| 3       | DREQ<br><u>Multiple</u> /<br>Single<br><u>Pulse</u><br>Mode | Writing a "1" to this bit will allow the SCSIC to generate up to 12 DREQ pulses before receiving the first DACK from the external controller logic. When this bit is "0", the SCSIC will not generate the next DREQ unless it has received the previous DACK. In both cases, a transfer is not considered complete until the number of DACK's received equals the number of DREQ's generated.                                                                                                                                                                            |                                                                                                                                                                                  |                  |                                 |                                                                                              |  |  |
| 4       | PDREQ<br><u>Level/</u><br>Pulsed                            | Writing a "1" to this bit will cause the PDREQ signal to operate as a level. When receiving from the SCSI bus PDREQ will be high as long as the buffer is not empty. When sending to the SCSI bus PDREQ will be high as long as the buffer is not full. Writing a "0" to this bit will cause the PDREQ signal to operate as a pulse. The MSD95C00 will drive PDREQ low if receiving and the Data IN register is read. PDREQ will also be driven low when sending and the Data Out register is written. PDREQ will then be driven high if there is more data to transfer. |                                                                                                                                                                                  |                  |                                 |                                                                                              |  |  |
| 6,5     | Selection<br>Timeout                                        | These two bits ar                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | e used to se                                                                                                                                                                     | elect the follo  | owing SCSI S                    | election Timeout:                                                                            |  |  |
|         | Titleout                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Bit 6                                                                                                                                                                            | Bit 5            | Timeout*                        |                                                                                              |  |  |
|         |                                                             | ·                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 0<br>0<br>1<br>1                                                                                                                                                                 | 0<br>1<br>0<br>1 | 839ms<br>210ms<br>52ms<br>1.6ms |                                                                                              |  |  |
|         |                                                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | *based on 20MHz crystal operation                                                                                                                                                |                  |                                 |                                                                                              |  |  |
| 7       | Reserved.                                                   | Must be reset to '                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Must be reset to "0".                                                                                                                                                            |                  |                                 |                                                                                              |  |  |

#### Byte Counter High Register 8-Bit Read/Write (Address 02H)

This 8-bit Read/Write register holds the most significant byte that is to be loaded into the Byte Counter. The data is transferred from the Byte Counter High Register into the Byte Counter when the Byte Counter Low register is loaded. Bit 7 is the MSB and bit 0 is the LSB. The Byte Counter registers are loaded with the 1's complement of the desired byte count.

#### **Byte Counter Middle Register** 8-Bit Read/Write (Address 03H)

This 8- bit Read/Write register holds the middle byte of data that is to be loaded into the Byte Counter. The data is transferred from the Byte Counter Middle Register into the Byte Counter when the Byte Counter Low register is loaded. Bit 7 is the MSB and bit 0 is the LSB. The Byte Counter registers are loaded with the 1's complement of the desired byte count.

#### Byte Counter Low Register 8-Bit Read/Write (Address 04H)

This 8-bit Read/Write register holds the least significant

byte of data that is to be loaded into the Byte Counter. The data is transferred into the Byte Counter when the Byte Counter Low register is loaded. Bit 7 is the MSB and bit 0 is the LSB. The Byte Counter registers are loaded with the 1's complement of the desired byte count.

#### I/O Register

8-Bit Read/Write (Address 05H)

This 8-bit Read/Write register is an eight bit bi-directional I/ O port available to the processor. Data written to this register will be latched and available on the XD7-XD0 pins. Inverted data present on the XD7-XD0 pins will be available to the Processor when this register is read. The XD7-XD0 I/O pins are open drain with internal pullup resistors.

# Interrupt Enable 1 Register

8-Bit Read/Write (Address 06H)

This eight bit Read/Write register enables or disables certain interrupt causing conditions to the microcomputer. Reading this register reflects the states of the bits in it. The bits in this register are cleared to zero by a hard or soft System Reset. Refer to Table 4 for a description of the Interrupt Enable 1 Register bits.

**TABLE 4 - Interrupt Enable 1 Register** 

T-52-33-27

| BIT NO. | BIT NAME                                           | DESCRIPTION                                                                                                                                                                                                                                                       |
|---------|----------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0       | Selection<br>Attempted<br>Interrupt                | When this bit is set to "1", the MSD95C00 drives the SCSI Master Interrupt bit high when the Selection Attempted bit in the Status 1 register is set to one. When this bit is reset to "0", the Master Interrupt will not be driven high for this condition.      |
| 1       | (Re)Selection<br>Complete<br>Interrupt<br>Enable   | When this bit is set to "1", the MSD95C00 drives the SCSI Master Interrupt bit active high when the (Re)Selection Complete bit in the Status 1 register is set to one. If this bit is "0", the Master Interrupt will not be driven high for this condition.       |
| 2       | Transfer<br>Request<br>Interrupt                   | When the bit is set to "1", the MSD95C00 drives the SCSI Master Interrupt bit active high when the Transfer Request bit in the Status 1 register is set to one. If this bit is "0", the Master Interrupt will not be driven high for this condition.              |
| 3       | Transfer<br>Complete<br>Interrupt<br>Enable        | When this bit is set to "1", the MSD95C00 drives the SCSI Master Interrupt bit active high when the Transfer Complete Interrupt bit in the Status 1 register is set to one. The Master Interrupt will not be driven high for this condition.                      |
| 4       | SCSI<br>Parity Error<br>Interrupt<br>Enable        | When this bit is set to "1", the MSD95C00 drives the SCSI Master Interrupt bit active high when the SCSI Parity Error bit in the Status 1 register is set to one. When this bit is "0", the Master Interrupt will not be driven high for this condition.          |
| 5       | System<br>Parity Error<br>Interrupt<br>Enable      | When this bit is set to "1", the MSD95C00 will drive the SCSI Master Interrupt bit active high when the System Parity Error bit in the Status 1 register is set to one. When this bit is "0", the Master Interrupt will not be driven high for this condition.    |
| 6       | SCSI ATN or<br>Reset Change<br>Interrupt<br>Enable | When this bit is set to "1", The MSD95C00 will drive the SCSI Master Interrupt bit active high when the SCSI ATN or Reset Change bit in the Status 1 register is set to 1. When this bit is "0", the Master Interrupt will not be driven high for this condition. |
| 7       | Condition<br>Change<br>Interrupt<br>Enable         | When this bit is set to "1", the MSD95C00 will drive the SCSI Master Interrupt bit active high when the Condition Change bit in the Status 1 register is set to one. When this bit is "0", the Master Interrupt will not be driven high for this condition.       |

# Interrupt Enable 2 Register 8-Bit Read/Write (Address 07H)

This eight bit Read/Write register enables or disables certain microprocessor interrupt causing conditions. Reading this register reflects the states of the bits in it. The line register are cleared to zero by a hard or soft System Reset. Refer to Table 5 for a description of the Interrupt Enable 2 Register bits.

# **TABLE 5 - Interrupt Enable 2 Register**

| BIT NO. | BIT NAME                                            | DESCRIPTION                                                                                                                                                                                                                                                                                   |  |  |  |  |  |
|---------|-----------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| 0       | Valid<br>Selection<br>Interrupt<br>Enable           | When this bit is set to "1", the SCSIC will set the Selection Attempted bit in the Status 1 register to one when the Valid Reselection bit in the Status 2 register is active high. When this bit is "0", the Selection Attempted bit cannot be set by this condition.                        |  |  |  |  |  |
| 1       | Valid<br>Reselection<br>Interrupt<br>Enable         | hen this bit is set to "1", the SCSIC will set the Selection Attempted bit in the Status 1 gister to one when the Valid Reselection bit in the Status 2 register is active high. When is bit is "0", the Selection Attempted bit cannot be set by this condition.                             |  |  |  |  |  |
| 2       | Invalid<br>(Re)Selection<br>Interrupt<br>Enable     | Setting this bit to "1" will cause the SCSIC to set the Selection Attempted bit in the Stature register to one when the Invalid (Re)Selection bit in the Status 2 register is active high this bit is "0", the Selection Attempted bit cannot be set by this condition.                       |  |  |  |  |  |
| 3       | SCSI<br>Transfer<br>Complete<br>Interrupt<br>Enable | Setting this bit to "1" will cause the SCSIC to set the Transfer Complete Interrupt bit in the Status 1 register to one when the SCSI Transfer Complete bit in the Status 3 register is active high. If this bit is "0", the Transfer Complete Interrupt bit cannot be set by this condition. |  |  |  |  |  |
| 4       | Transfer Done<br>Interrupt<br>Enable                | Setting this bit to "1" will cause the MSD95C00 to set the Transfer Complete Interrupt bit in the Status 1 register to one when the Transfer Done bit in the Status 3 register is active high. If this bit is "0", the Transfer Complete Interrupt bit cannot be set by this condition.       |  |  |  |  |  |

# **TABLE 5 - Interrupt Enable 2 Register**

T-52-33-27

| BIT NO. | BIT NAME                                                                                                                                                                                                                                              | DESCRIPTION                                                                                                                                                                                                                                                               |  |  |  |  |
|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| 5       | Setting this bit to "1" will cause the MSD95C00 to set the Condition Change bit in the Status 1 register to one when the Halted bit in the Status 4 register goes high. If this bit is "0", the Condition Change bit cannot be set by this condition. |                                                                                                                                                                                                                                                                           |  |  |  |  |
| 6       | Bus Free<br>Phase Detect<br>Interrupt<br>Enable                                                                                                                                                                                                       | Setting this bit to "1" will cause the MSD95C00 to set the Condition Change bit in the Status 1 register to one when the Bus Free Phase Detect bit in the Status 4 register is active high. If this bit is "0", the Condition Change bit cannot be set by this condition. |  |  |  |  |
| 7       | SCSI Master<br>Interrupt<br>Enable                                                                                                                                                                                                                    | Setting this bit to "1" will cause the MSD95C00 to drive its INT output active low when an enabled condition causes one of the bits in the Status 1 register to go high. If this bit is "0", the INT pin cannot be driven low.                                            |  |  |  |  |

Control Register 8-Bit Read/Write (Address 08H)

This 8 bit Read/Write register is used to control chip operation. The bits are reset to zeros by a hard or soft System Reset. Refer to Table 6 for a description of the Control Register bits.

# **TABLE 6 - Control Register**

| BIT NO. | BIT NAME                   | DESCRIPTION                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |  |  |
|---------|----------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| 0       | Auto<br>ATN<br>Assert      | Vhen this bit is set to "1", the MSD95C00 will automatically assert the SCSI bus ATN ignal before beginning the selection phase of the Select command. When this bit is responder, ATN will not be asserted.                                                                                                                                                                         |  |  |  |  |  |
| 1       | Enable<br>Selection        | When this bit is set to "1", the MSD95C00 will generate a Valid Selection interrupt when selected by another SCSI device. When this bit is reset to "0", the MSD95C00 will generate an Invalid (Re)Selection interrupt when another SCSI device tries to select it. The state of this bit will not prevent the chip from attempting to select or reselect another SCSI device.       |  |  |  |  |  |
| 2       | Enable<br>Reselection      | When this bit is set to "1", the MSD95C00 will generate a Valid Reselection interrupt when reselected by another SCSI device. When this bit is reset to "0", the MSD95C00 will generate an Invalid (Re)Selection interrupt when another SCSI device tries to reselect it. The state of this bit will not prevent the chip from attempting to select or reselect another SCSI device. |  |  |  |  |  |
| 3       |                            | Always 0                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |
| 4       |                            | Always 0                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |
| 5       | Halt On<br>Parity<br>Error | When this bit is set to "1" and the MSD95C00 is operating in the Initiator mode, the MSD95C00 will not assert SACK for bytes with bad parity during Status, Message-In or Data-In phase transfers. This bit does not affect operation in Target mode. When this bit is reset to "0", the MSD95C00 will negate SACK regardless of parity.                                             |  |  |  |  |  |
| 6       | Enable<br>PDREQ            | When this bit is set to "1", the SCSIC will be able to drive the PDREQ output active high. When this bit is reset to "0", the PDREQ output will be driven low.                                                                                                                                                                                                                       |  |  |  |  |  |
| 7       | Enable<br>DREQ             | When this bit is set to "1", the MSD95C00 will be able to drive the DREQ output active low. When this bit is reset to "0", the DREQ output will be driven high.                                                                                                                                                                                                                      |  |  |  |  |  |

Interrupt Status Register 8-Bit Read Only (Address 09H)

This 8 bit Read Only register contains information about

the internal MSD95C00 operation. Refer to Table 7 for a description of the Interrupt Status Register bits.

# **TABLE 7 - Interrupt Status Register**

| BIT NO.       | BIT NAME          | DESCRIPTION                                                                                                                                                                                                  |  |  |  |  |
|---------------|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| 1,0           |                   | Always 0                                                                                                                                                                                                     |  |  |  |  |
| 2             | SCSI<br>Interrupt | This bit is set to "1" when one of the enabled interrupt causing conditions causes a bit in the Status 1 register to go active high. It is reset to "0" when the interrupt causing condition(s) are cleared. |  |  |  |  |
| 7,6,<br>5,4,3 |                   | Always 0                                                                                                                                                                                                     |  |  |  |  |

**Command 1 Register** 

8 - Bit Write Only (Address 09H)

This Write Only register is used to initiate one of the Select or Reselect operations and to assert or negate the SCSI bus signals. Except for the Clear bit, the states of these bits are used to generate a strobe and are not latched in the MSD95C00. A hard or soft System Reset will cause the signals controlled by this register to be negated and the Clear bit to be reset to "0". Refer to Table 8 for a description of the Command 1 Register bits

**TABLE 8 - Command 1 Register** 

| BIT NO. | BIT NAME                    | DESCRIPTION                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |
|---------|-----------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
|         |                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |
| 0 .     | Assert SCSI<br>Reset Signal | Setting this bit to "1" will cause the MSD95C00 to assert the SCSI bus Reset signal (SRST).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |
| 1       | Negate SCSI<br>Reset Signal | Setting this bit to "1" will cause the MSD95C00 to negate the SCSI bus Reset signal (SRST).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |
| 2       | Assert<br>ATN Signal        | Setting this bit to "1" will cause the MSD95C00 to assert the SCSI bus Attention signal (ATN).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |
| 3       | Negate<br>ATN Signal        | Setting this bit to "1" will cause the SCSI chip to negate the SCSI bus Attention signal (ATN).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |
| 4       | Clear                       | Setting this bit to "1" will cause the chip to go into the Clear state and reset all of the internal counters, reset the latched status bits, reset the SCSI Master Interrupt Enable, reset the bits in the Command 2 Register, disconnect from the SCSI bus and negate the SCSI control signals. Resetting this bit to "0" will terminate the Clear state. After setting this bit to "1", the Processor must wait a minimum of one microsecond before clearing it.                                                                                                                                                                                                                                                         |  |  |  |  |
| 5       | (Re)Start                   | When the MSD95C00 is operating in the Initiator mode, writing a "1" to this bit will cause chip operation, that was interrupted by detection of a parity error on the SCSI data bus, to continue (this condition can only occur when the Halt On Parity Error bit in the Control register is set to "1"). Also, writing a "1" to this bit after the MSD95C00 was halted by SREQ going active when the byte counter was equal to "0" will cause the MSD95C00 to respond with SACK. This will allow the Initiator to perform single byte transfers without loading the Byte Counter (data may be written to the buffer before or after writing to the Command register). This bit does not affect Target mode chip operation. |  |  |  |  |
| 6       | Select                      | Setting this bit to "1" will cause the MSD95C00 to initiate a Select operation, a Select with ATN asserted operation, an Arbitrate and Select operation, an Arbitrate and Select with ATN asserted operation or an Arbitrate and Reselect operation. The operation initiated depends on the state of the Target/Initiator and Arbitration Enable/Disable bit the Mode register and the Auto-ATN Assert bit in the Control register.                                                                                                                                                                                                                                                                                         |  |  |  |  |
| 7       | Disconnect                  | Setting this bit to "1" will cause the MSD95C00 to stop driving all of the SCSI Data bus and Control signals.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |

Status 1 Register

8-Bit Read Only (Address 0AH)

This 8-bit Read only register contains information about

the internal MSD95C00 operation. Refer to Table 9 for a description of the Status 1 Register bits.

**TABLE 9 - Status 1 Register** 

| BIT NO. | BIT NAME                  | DESCRIPTION                                                                                                                                                                                                                                                                                                                                      |
|---------|---------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0       | Selection<br>Attempted    | This bit is set to "1" by the active and enabled state of either the Valid Select, Valid Reselect or Invalid (Re)Select status bits in the Status 2 register. It is reset by reading the Status 2 register.                                                                                                                                      |
| 1       | (Re)Selection<br>Complete | This bit is set to "1" by the active state of either the Successful (Re)Selection Complete or Unsuccessful (Re)Selection Complete status bits in the Status 2 register. It is reset by reading the Status 2 register.                                                                                                                            |
| 2       | Transfer<br>Request       | This bit is set to "1" by the active state of either the Byte Available or Byte Requested status bits in the Status 3 register. It is reset by reading the Status 3 register. It will be set again after the Data-In Register is read if Byte Available is still high or when the Data-Out Register is written and Byte Requested is still high. |
| 3       | Transfer<br>Complete      | This bit is set to "1" when either the Transfer Done or SCSI Transfer Complete bits in the Status 3 register go active high and their respective bits in the Interrupt Enable 2 Register are set to one. It reset by reading the Status 3 register.                                                                                              |
| 4       | SCSI<br>Parity Error      | This bit is set to "1" when the SCSI Parity Error bit in the Status 3 register goes active high. It is reset by reading the Status 3 register.                                                                                                                                                                                                   |
| 5       | System<br>Parity Error    | This bit is set to "1" when the System Parity Error bit in the Status 3 register goes active high. It is reset by reading the Status 3 register.                                                                                                                                                                                                 |

# **TABLE 9 - Status 1 Register (continued)**

| BIT NO. | BIT NAME                    | DESCRIPTION                                                                                                                                                              |
|---------|-----------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6       | SCSI ATN or<br>RESET Change | This bit is set to "1" when either the SCSI ATN or RESET signal changes from the high to low or low to high state. It is reset by reading the Status 3 register.         |
| 7       | Condition<br>Change         | This bit is set to "1" when either the (enabled) Bus Free Detected or Halted bits in the Status 4 register go active high. It is reset by reading the Status 4 register. |

**Command 2 Register** 

8-Bit Write Only (Address 0AH)

This Write Only register is used to initiate a new phase when the SCSIC is in Target mode. A hard or soft System Reset or a Disconnect command will clear all the bits in this register to "0". When the Initiator detects that the SCSI Data Bus is changing direction from out (the Initiator driving) to in (the Target driving) it will release the SCSI Data bus within a Data Release Time (400ns) of I/O being asserted. This condition can occur when the Target begins a Message In, Status or Data In phase.

When the Target switches the SCSI Data Bus direction from

This 8 bit Read Only register contains information about

in (the Target driving) to out (the Initiator driving) it will release the SCSI Data bus within a Deskew delay (45ns) of negating I/O. This condition can occur when the Target begins a Message Out, Command or Data Out phase.

Note that the Processor must delay at least 800ns after issuing a Set Phase type command before writing to the byte counter. The phase will be generated upon writing to the LSB of the Byte Count register. Phases must not be changed unless the FIFO is empty. Refer to table 10 for a description of the Command 2 Register bits. The Message Out Phase is generated by setting bits 7 thru 0 to zero causing C/D, I/O and MSG to be negated.

## **TABLE 10 - Command 2 Register**

| BIT NO. | BIT NAME                 | DESCRIPTION                                                                                                  |  |  |  |  |  |
|---------|--------------------------|--------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| 0       | Reserved                 | Must be set to "0" at all times.                                                                             |  |  |  |  |  |
| 1       | Set Data<br>In Phase     | Setting this bit to "1" will cause the MSD95C00 to assert the I/O signal and negate the MSG and C/D signals. |  |  |  |  |  |
| 2       | Set Command<br>Phase     | etting this bit to "1" will cause the MSD95C00 to assert the C/D signal and negate the D and MSG signal.     |  |  |  |  |  |
| 3       | Set Status<br>Phase      | Setting this bit to "1" will cause the MSD95C00 to assert the C/D and I/O signals and negate the MSG signal. |  |  |  |  |  |
| 5,4     | Reserved                 | Must be set to "0" at all times.                                                                             |  |  |  |  |  |
| 6       | Set Message<br>Out Phase | Setting this bit to "1" will cause the MSD95C00 to assert the C/D and MSG signals and negate the I/O signal. |  |  |  |  |  |
| 7       | Set Message<br>In Phase  | Setting this bit to "1" will cause the MSD95C00 to assert the C/D, I/O and MSG signals.                      |  |  |  |  |  |

Status 2 Register

8 - Bit Read Only (Address 0BH)

the internal MSD95C00 operation. Refer to Table 11 for a description of the Status 2 Register bits.

TABLE 11 - Status 2 Register

| BIT NO. | BIT NAME                               | DESCRIPTION                                                                                                                                                                                                                                                                                                             |  |  |  |  |
|---------|----------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| 0       | Valid<br>Selection                     | This bit is set to "1" when the MSD95C00 has been selected by another SCSI device. In order to be selected, the Enable Selection bit in the Control Register must be in the correct state. This bit is reset by reading the Status 2 register.                                                                          |  |  |  |  |
| 1       | Valid<br>Reselection                   | This bit is set to "1" when the MSD95C00 has been reselected by another SCSI device. In order to be reselected, the Enable Reselection bit in the Control Register must be in the correct state. This bit is reset by reading the Status 2 register.                                                                    |  |  |  |  |
| 2       | Invalid<br>(Re)Selection               | This bit is set to "1" when another SCSI device attempts to select or reselect the SCSIC and the corresponding enable bit in the Mode register is not in the correct tate. This bit is reset by reading the Status 2 register.                                                                                          |  |  |  |  |
| 3       | Successfu<br>(RE)Selection<br>Complete | This bit is set to "1" when the MSD95C00 has successfully selected or reselected another SCSI device and that device has responded by asserting BSY. Also, this bit is set to "1" at the trailing edge of SEL when a device has selected or reselected this device. This bit is reset by reading the Status 2 register. |  |  |  |  |
| 4       | Unsuccessful (RE)Selection Complete    | This bit is set to "1" when the MSD95C00 has attempted to select or reselect another SCSI device and that device has not responded by asserting BSY within the programmed Selection Timeout Delay. This bit is reset by reading the Status 2 register.                                                                  |  |  |  |  |
| 6,5     | Reserved                               |                                                                                                                                                                                                                                                                                                                         |  |  |  |  |
| 7       | SCSI ATN                               | This bit reflects the state of the ATN bit on the SCSI bus. It is active high when the ATN signal is asserted and active low when the ATN signal is deasserted.                                                                                                                                                         |  |  |  |  |

Status 3 Register 8-Bit Read Only (Address 0CH)

T-52-33-27

This 8 bit Read Only register contains information about the internal MSD95C00 operation. Refer to Table 12 for a description of the Status 3 Register bits.

TABLE 12 - Status 3 Register

| BIT NO. | BIT NAME                     | DESCRIPTION                                                                                                                                                                                                                                                                                                                 |  |  |  |  |
|---------|------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| 0       | Byte<br>Requested            | This bit is active high when transferring to the SCSI Data bus if there is room for more requested data in the FIFO and the Byte counter is not zero.                                                                                                                                                                       |  |  |  |  |
| 1       | Byte<br>Available            | This bit is active high whenever there is data from the SCSI Data Bus in the FIFO for transfer to the Processor or Ring Buffer Ram.                                                                                                                                                                                         |  |  |  |  |
| 2       | SCSI<br>Parity<br>Error      | This bit is set to "1" if parity checking is enabled and the SCSI chip detects even (bad) parity on received transfers over the SCSI data bus during any Information phase. It is reset by reading the Status 3 register.                                                                                                   |  |  |  |  |
| 3       | SCSI<br>Transfer<br>Complete | This bit is active high when the Byte Counter End Count condition is active high an the last byte has been transferred from the SCSI Bus into the FIFO when the chip operating in the Target mode during Message Out, Command or Data Out phases. all other cases, this status bit will function the same as Transfer Done. |  |  |  |  |
| 4       | Transfer<br>Done             | This bit is active high when the Byte Counter End Count condition is active high and the last byte has been transferred out of the FIFO to the SCSI Data bus, the Processor port or the Ring Buffer DMA port.                                                                                                               |  |  |  |  |
| 5       | System<br>Parity Error       | This bit is set to "1" when the MSD95C00 detects even (bad) parity on the System Data Bus. It is reset by reading the Status 3 register.                                                                                                                                                                                    |  |  |  |  |
| 6       | SCSI<br>Reset                | This bit reflects the state of the RST signal on the SCSI bus. It is high when the RST signal is asserted and low when the RST signal is deasserted.                                                                                                                                                                        |  |  |  |  |
| 7       | SCSI<br>Attention            | This bit reflects the state of the ATN signal on the SCSI bus. It is high when the ATN signal is asserted and low when the ATN signal is deasserted.                                                                                                                                                                        |  |  |  |  |

Status 4 Register 8-Bit Read Only (Address 0DH)

This 8 bit Read Only register contains information about the internal SCSIC operation. Refer to Table 13 for a description of the Status 4 Register bits.

TABLE 13 - Status 4 Register

|         |                             |                                                                                                                                                                                                                                                                      |                                 | · · · · · · · · · · · · · · · · · · · | <del></del>                                                                                                  |  |
|---------|-----------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------|---------------------------------------|--------------------------------------------------------------------------------------------------------------|--|
| BIT NO. | BIT NAME                    | DESCRIPTION                                                                                                                                                                                                                                                          |                                 |                                       |                                                                                                              |  |
| 2-0     | Encoded<br>Phase            | Bit 2<br>MSG                                                                                                                                                                                                                                                         | Bit 1<br>C/D                    | Bit 0<br>I/O                          | INFORMATION PHASE                                                                                            |  |
|         |                             | 0<br>0<br>0<br>1<br>1<br>1                                                                                                                                                                                                                                           | 0<br>0<br>1<br>1<br>0<br>0<br>1 | 0<br>1<br>0<br>1<br>0<br>1<br>0       | Data Out Phase Data In Phase Command Phase Status Phase Reserved Reserved Message Out Phase Message In Phase |  |
|         |                             | These bits reflect the SCSI MSG, C/D and I/O signals. They are used to identify the SCSI Information phases. Refer to the table above.                                                                                                                               |                                 |                                       |                                                                                                              |  |
| 3       |                             | Reserved.                                                                                                                                                                                                                                                            |                                 |                                       |                                                                                                              |  |
| 4       | Arbitration (window)        | This bit goes high four to five internal clock cycles after BSY and SEL are both continuously false. The bit remains high three to four internal clock cycles after the bus is no longer free.                                                                       |                                 |                                       |                                                                                                              |  |
| 5       | Halted                      | This bit can only be set when the chip is operating in the Initiator mode. It is set by SREQ going active when the Byte Counter is "0". It can also be set when a parity error is detected on the SCSI Data bus. This bit is reset by reading the Status 4 register. |                                 |                                       |                                                                                                              |  |
| 6       | Bus Free<br>Phase<br>Detect | This bit is the output of the Bus Free detection circuit. It is latched high when the Bus Free phase, as specified in the SCSI specification, is detected on the SCSI Bus. This bit is reset by reading Status 4 register.                                           |                                 |                                       |                                                                                                              |  |
| 7       |                             | Reserved.                                                                                                                                                                                                                                                            |                                 |                                       |                                                                                                              |  |

**Destination ID Register** 

8-Bit Write Only (Address 0EH)

This 8-bit register Write Only is used to hold the value of the SCSI ID of the device that is to be Selected or Reselected.

**SCSI Bus ID Register** 

8-Bit Read Only (Address 0EH)

This 8-bit Read Only register holds the ID that had been latched from the SCSI bus when an attempt was made to Select or Reselect the SCSIC. The SCSIC's SCSI ID bit is masked off leaving the ID of the device attempting the Selection or Reselection.

**SCSI ID Register** 

8-Bit Write Only (Address 0EH)

This 8-bit Write Only register is used to hold the ID assigned to the MSD95C00.

**Data In Register** 

8-Bit Read Only (Address 0FH)

T-52-33-27

This 8-bit Read Only register is used by the processor during programmed I/O or processor port DMA transfers. It is used to read data received from the SCSI bus which is presently in the internal buffer.

Data Out Register

8-Bit Write Only (Address 0FH)

This 8-bit Write Only register is used by the Processor during programmed I/O or Processor port DMA transfers. The data loaded into this register is output to the SCSI bus via the internal buffer.

#### **COMMANDS**

The SCSIC is an interface between the SCSI bus and the initiator/target unit. When programmed as an initiator (or target supporting reselection), it controls the selection and arbitration process. As a target, it manages the receipt of the command packet from the initiator. All other operations are managed by an outside processor. The typical flow of control progresses as follows:

- The initiator's processor builds the command block.
- The processor then instructs the initiating SCSIC to begin Selection. Arbitration, if enabled, is handled by the chip.
- Once the target unit is selected, the target's processor instructs the target SCSIC to set up a command phase (other phases possible at this point include message, status or data phases).
- 4) The first byte is transmitted to the target.
- 5) The target SCSIC modifies its processor (through polling/interrupt) that it is holding the byte. The processor reads the byte in order to determine the command length.
- 6) The target processor instructs its SCSIC to transfer the remaining bytes.
- The command packet now resides in the target SCSIC's FIFO buffer.
- 8) The target SCSIC notifies its processor (through polling/interrupt) that the command packet is available.
- The processor transfers the command packet into its own memory. The processor is now responsible for digesting and executing the command.
- While the target's processor executes each command, the initiator and target SCSIC's handle handshaking associated with the command.

#### TABLE 14 - MSD95C00 COMMANDS

| COMM<br>CODE<br>(HEX) |                           | SCSI          | ccs       |
|-----------------------|---------------------------|---------------|-----------|
| 00                    | Test Unity Ready          | optional      | mandatory |
| 03                    | Request Sense             | mandatory     | mandatory |
| 04                    | Format Unit               | mandatory     | mandatory |
| 08                    | Read                      | mandatory     | mandatory |
| 0A                    | Write                     | mandatory     | mandatory |
| 01                    | Rezero Unit               | optional      | optional  |
| 05                    | <b>Check Track Format</b> | vendor unique |           |
| 0B                    | Seek                      | optional '    | optional  |
| 12                    | Inquiry                   | extended      | mandatory |
| 1A                    | Mode Sense                | optional      | optional  |
| 25                    | Read Capacity             | extended      | mandatory |
| 06                    | Format Track              | vendor unique |           |
| 0E                    | Assign Alt Track          | vendor unique | •         |
| 15                    | Mode Select               | optional      | optional  |
| 16                    | Reserve Unit              | optional      | mandatory |
| 17                    | Release Unit              | optional      | optional  |
| 1C                    | Receive Diag Result       | optional      | optional  |
| 1D                    | Send Diagnostics          | optional      | mandatory |
| 2E                    | Write and Verify          | optional      | optional  |

# **MAXIMUM GUARANTEED RATINGS**

T-52-33-27

| Operating Temperature Range                         | 0° to +70°C           |
|-----------------------------------------------------|-----------------------|
| Storage Temperature Range                           |                       |
| Lead Temperature (soldering, 10 sec.)               |                       |
| Positive Voltage on any Pin, with respect to Ground | V <sub>cc</sub> +0.3V |
| Negative Voltage on any Pin, with respect to Ground | -0.3V                 |
| Maximum Voltage on V. pin                           | 7.0V                  |

Stresses above those listed may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other condition above those indicated in the operational sections of this specification is not implied.

NOTE: When powering this device from laboratory or system power supplies, it is important that the "Maximum Guaranteed Ratings" not be exceeded, or device failure can result. Some power supplies exhibit voltage spikes or "glitches" on their outputs when AC power is switched off. In addition, voltage transients on the AC power line may appear on the DC output. If this possibility exists it is suggested that a clamp circuit be used.

# DC ELECTRICAL SPECIFICATIONS ( $T_A = 0^{\circ}$ to 70°C, $V_{cc} = 5.0V \pm 5\%$ )

| PARAMETER              | SYMBOL                               | MIN        | TYP | MAX        | UNITS  | COMMENTS                                                                       |
|------------------------|--------------------------------------|------------|-----|------------|--------|--------------------------------------------------------------------------------|
| Supply Current         | l <sub>cc</sub>                      |            |     | 35         | mA     | $V_{cc} = 5.25V$                                                               |
| Output Voltage<br>High | V <sub>OH1</sub>                     | 2.4        |     |            | ٧      | I <sub>OH1</sub> = -400μA. All outputs except SCSI,<br>Interrupt and XD0-XD7.  |
|                        | V <sub>OH2</sub>                     | 2.4        |     |            | V      | I <sub>OH2</sub> = -400μA. XD0- XD7 and Interrupt.<br>Open drain with pull-up. |
| Low                    | V <sub>OL1</sub>                     |            |     | 0.4        | V      | I <sub>OL1</sub> = 4mA. All outputs except SCSI and XD0 - XD7.                 |
|                        | V <sub>OL2</sub><br>V <sub>OL3</sub> |            |     | 0.4<br>0.4 | V<br>V | I <sub>OL2</sub> =2mA. XD0 - XD7.<br>I <sub>OL3</sub> = 48mA. SCSI outputs.    |
| Input Voltage<br>High  | V <sub>IH1</sub><br>V <sub>IH2</sub> | 3.5<br>2.0 |     |            | V<br>V | All inputs except $X_1$ . Use external pull-up. $X_1$ input.                   |
| Low                    | V <sub>IL</sub>                      |            |     | 0.8        | V      | All inputs.                                                                    |
| Input Leakage          |                                      |            |     | ±10        | μΑ     | All pins.                                                                      |
| Pull-up current        |                                      | -200       |     | -800       | μА     | XD0 - XD7.                                                                     |

# TABLE 15

| SYMBOL                                                                                | R/W<br>MC                                                       | DS<br>DE | RD<br>MC                                                         | WR<br>DDE | UNITS                                              | COMMENTS T-52-33-27                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|---------------------------------------------------------------------------------------|-----------------------------------------------------------------|----------|------------------------------------------------------------------|-----------|----------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                                                       | MIN                                                             | MAX      | MIN                                                              | MAX       | "                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| T1<br>T2<br>T3<br>T4<br>T5<br>T6<br>T7<br>T8<br>T9<br>T10<br>T11<br>T12<br>T13<br>T14 | 45<br>30<br>15<br>120<br>10<br>110<br>135<br>25<br>20<br>0<br>0 | 70       | 45<br>30<br>15<br>120<br>10<br>110<br>135<br>25<br>20<br>20<br>0 | 115       | ns<br>ns<br>ns<br>ns<br>ns<br>ns<br>ns<br>ns<br>ns | ALE (AS) active pulse width Address setup to ALE inactive Address hold from ALE inactive Read Strobe low pulse width RD (DS) active to read data valid Read Data hold from RD (DS) high Write Strobe low pulse width Write Data valid to WR (DS) inactive Write Data hold from WR (DS) inactive ALE (AS) inactive to Read Strobe active ALE (AS) inactive to Write Strobe active RD (DS) inactive to ALE active WR (DS) inactive to ALE active CE valid to RD, WR or DS R/W valid to AS inactive |

# TABLE 16

| Parameter             | Min            | Max                                                                               |  |  |
|-----------------------|----------------|-----------------------------------------------------------------------------------|--|--|
| t1 DREQ pulse width   | 1 clock - 15ns | 1 clock + 15ns.                                                                   |  |  |
| t2 DREQ inactive time | 1 clock - 15ns | k - 15ns  1 clock + 15ns for consecutive pulses.  DC for non-consecutive pulses.  |  |  |
| t3 DREQ period        | 2 clocks       | 2 clocks for consecutive pulses (typical 5MHz).<br>DC for non-consecutive pulses. |  |  |
| t4 DACK Pulse width   | 50ns           | DC This is a Function of the external device.                                     |  |  |
| t5 DACK inactive time | 50ns           | DC This is a Function of the external device.                                     |  |  |
| t6 DACK period        | 2 clocks       | 2 clocks for consecutive pulses (typical 5MHz).<br>DC for non-consecutive pulses. |  |  |

Since  $\overline{ACK}$  is a function of an external device which may be asynchronous to the MSD95C00, there is no timing relationship between LE of  $\overline{DREQ}$  and LE of  $\overline{DACK}$ .

For 5 MByte/Sec SCSI transfer rates a 20MHz external crystal or TTL clock is required. The external clock is internally divided by 2. The term 'clock' above refers to the

internal clock period (typical 10MHz).

# **SCSI Bus Timing**

All timing related to the SCSI bus signals meet the SCSI bus timing requirements defined in the ANSI X3.131 - 1986 specification.

I







DACK

DB0-DB7

DATA VALID

| SYMBOL | MIN | MAX | UNITS | COMMENTS        |
|--------|-----|-----|-------|-----------------|
| T1     | 40  |     | ns    | DATA SETUP TIME |
| T2     | 10  |     | ns    | DATA HOLD TIME  |

FIGURE 7: MSD95C00 DMA READ CYCLE



| SYMBOL | MIN | MAX | UNITS | COMMENTS   |
|--------|-----|-----|-------|------------|
| T1     | 50  |     | ns    | DATA SETUP |
| T2     | 10  |     | ns    | DATA HOLD  |

FIGURE 8: MSD95C00 MPU READ PORT TIMING









Refer to Table 15 for DREQ and DACK timing.

FOR FURTHER INFORMATION ON PROGRAMMING OR USE OF THIS DEVICE, PLEASE CONTACT YOUR LOCAL SMC FIELD APPLICATION ENGINEER OR CONTACT FACTORY.



Circuit diagrams utilizing SMC products are included as a means of illustrating typical semiconductor applications; consequently complete information sufficient for construction purposes is not necessarily given. The information has been carefully checked and is believed to be entirely reliable. However, no responsibility is assumed for inaccuracies. Furthermore, such information does not convey to the purchaser of the semiconductor devices described any license under the patent rights of SMC or others. SMC reserves the right to make changes at any time in order to improve design and supply the best product possible.